From 0fab39a5d13523d88c1245a8259cbeb9053e7730 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Thu, 23 Nov 2023 14:10:02 +0100 Subject: [PATCH 01/43] refactored PHbyModeCalculator --- .../matsim/analysis/PHbyModeCalculator.java | 205 +++++++++--------- 1 file changed, 100 insertions(+), 105 deletions(-) diff --git a/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java b/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java index b4663b50388..41cf719a128 100644 --- a/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java +++ b/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java @@ -34,10 +34,7 @@ import org.apache.logging.log4j.LogManager; import org.jfree.chart.axis.CategoryLabelPositions; import org.matsim.api.core.v01.IdMap; -import org.matsim.api.core.v01.population.Activity; -import org.matsim.api.core.v01.population.Leg; -import org.matsim.api.core.v01.population.Person; -import org.matsim.api.core.v01.population.Plan; +import org.matsim.api.core.v01.population.*; import org.matsim.core.config.groups.ControllerConfigGroup; import org.matsim.core.config.groups.GlobalConfigGroup; import org.matsim.core.controler.OutputDirectoryHierarchy; @@ -72,118 +69,116 @@ void addIteration(int iteration, IdMap map) { Map phtbyMode = map.values() .parallelStream() .flatMap(plan -> plan.getPlanElements().stream()) - .map(pe->{ - if (pe instanceof Leg) { - Leg leg = (Leg) pe; - double travelTime = 0.0; - double waitTime = 0.0; - if (leg.getRoute()!=null) { - travelTime = leg.getRoute().getTravelTime().seconds(); - double enterVehicleTime = Double.NaN; - Object attr = leg.getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME); - if (attr != null) { - enterVehicleTime = (Double) attr; - } - waitTime = enterVehicleTime - leg.getDepartureTime().seconds(); - if (!Double.isFinite(waitTime)) {waitTime = 0.0;} - if (waitTime >= 0.0) { - travelTime -= waitTime; - } else { - throw new RuntimeException("negative wait time" + enterVehicleTime + " " + leg.getDepartureTime() - .seconds()); - } - } - - if (Double.isNaN(travelTime)) {travelTime = 0.0; } - - return new AbstractMap.SimpleEntry<>(leg.getMode(),new TravelTimeAndWaitTime(travelTime, waitTime)); - - } else if (pe instanceof Activity) { - Activity act = (Activity) pe; - if (StageActivityTypeIdentifier.isStageActivity(act.getType())) { - double duration = act.getEndTime().orElse(0) - act.getStartTime().orElse(0); - return new AbstractMap.SimpleEntry<>(STAGE_ACTIVITY,new TravelTimeAndWaitTime(0.0, duration)); - } - } - return new AbstractMap.SimpleEntry<>(STAGE_ACTIVITY,new TravelTimeAndWaitTime(0.0, 0.0)); - }) - .collect(Collectors.toMap(e->e.getKey(),e->e.getValue(),(a,b)->TravelTimeAndWaitTime.sum(a, b))); + .map(PHbyModeCalculator::mapPlanElementToEntry) + .collect(Collectors.toMap(AbstractMap.SimpleEntry::getKey, AbstractMap.SimpleEntry::getValue, TravelTimeAndWaitTime::sum)); phtPerIteration.put(iteration,phtbyMode); } + private static AbstractMap.SimpleEntry mapPlanElementToEntry(PlanElement pe) { + if (pe instanceof Leg leg) { + double travelTime = 0.0; + double waitTime = 0.0; + if (leg.getRoute()!=null) { + travelTime = leg.getRoute().getTravelTime().seconds(); + double enterVehicleTime = Double.NaN; + Object attr = leg.getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME); + if (attr != null) { + enterVehicleTime = (Double) attr; + } + waitTime = enterVehicleTime - leg.getDepartureTime().seconds(); + if (!Double.isFinite(waitTime)) {waitTime = 0.0;} + if (waitTime >= 0.0) { + travelTime -= waitTime; + } else { + throw new RuntimeException("negative wait time" + enterVehicleTime + " " + leg.getDepartureTime() + .seconds()); + } + } + if (Double.isNaN(travelTime)) {travelTime = 0.0; } + return new AbstractMap.SimpleEntry<>(leg.getMode(), new TravelTimeAndWaitTime(travelTime, waitTime)); + } else if (pe instanceof Activity act) { + if (StageActivityTypeIdentifier.isStageActivity(act.getType())) { + double duration = act.getEndTime().orElse(0) - act.getStartTime().orElse(0); + return new AbstractMap.SimpleEntry<>(STAGE_ACTIVITY, new TravelTimeAndWaitTime(0.0, duration)); + } + } + return new AbstractMap.SimpleEntry<>(STAGE_ACTIVITY, new TravelTimeAndWaitTime(0.0, 0.0)); + } void writeOutput() { - writePHTText(); - + writeCsv(); + if(writePng){ + writePng(); + } } - private void writePHTText() { - TreeSet allModes = new TreeSet<>(); - allModes.addAll(this.phtPerIteration.values() - .stream() - .flatMap(i->i.keySet().stream()) - .collect(Collectors.toSet())); - - try (CSVPrinter csvPrinter = new CSVPrinter(Files.newBufferedWriter(Paths.get(controllerIO.getOutputFilename( FILENAME+ ".csv"))), CSVFormat.DEFAULT.withDelimiter(this.delimiter.charAt(0)))) { - csvPrinter.print("Iteration"); - for (String mode: allModes) { - csvPrinter.print(mode + TRAVEL_TIME_SUFFIX); - csvPrinter.print(mode + WAIT_TIME_SUFFIX); - } - csvPrinter.println(); - - for (Map.Entry> e : phtPerIteration.entrySet()){ - csvPrinter.print(e.getKey()); - for (String mode : allModes){ - TravelTimeAndWaitTime travelTimeAndWaitTime = e.getValue().getOrDefault(mode, new TravelTimeAndWaitTime(0.0, 0.0)); - csvPrinter.print((int) Math.round(travelTimeAndWaitTime.travelTime / 3600.0)); - csvPrinter.print((int) Math.round(travelTimeAndWaitTime.waitTime / 3600.0)); - } - csvPrinter.println(); - } - - - } catch (IOException e) { + private void writeCsv() { + TreeSet allModes = getAllModes(); + try { + CSVPrinter csvPrinter = new CSVPrinter(Files.newBufferedWriter(Paths.get(controllerIO.getOutputFilename( FILENAME+ ".csv"))), CSVFormat.DEFAULT.withDelimiter(this.delimiter.charAt(0))); + writeHeader(csvPrinter, allModes); + writeValues(csvPrinter, allModes); + } catch (IOException e) { LogManager.getLogger(getClass()).error("Could not write PH Modestats."); } - if (writePng){ - String[] categories = new String[phtPerIteration.size()]; - int i = 0; - for (Integer it : phtPerIteration.keySet()){ - categories[i++] = it.toString(); - } - - StackedBarChart chart = new StackedBarChart("Passenger hours traveled per Mode","Iteration","person hours",categories); - //rotate x-axis by 90degrees - chart.getChart().getCategoryPlot().getDomainAxis().setCategoryLabelPositions(CategoryLabelPositions.UP_90); - - for (String mode : allModes){ - double[] valueTravelTime = phtPerIteration.values().stream() - .mapToDouble(k->k.getOrDefault(mode,new TravelTimeAndWaitTime(0.0, 0.0)).travelTime/3600.0) - .toArray(); - chart.addSeries(mode + TRAVEL_TIME_SUFFIX, valueTravelTime); - double[] valueWaitTime = phtPerIteration.values().stream() - .mapToDouble(k->k.getOrDefault(mode,new TravelTimeAndWaitTime(0.0, 0.0)).waitTime/3600.0) - .toArray(); - chart.addSeries(mode + WAIT_TIME_SUFFIX, valueWaitTime); - } - chart.addMatsimLogo(); - chart.saveAsPng(controllerIO.getOutputFilename(FILENAME+ ".png"), 1024, 768); - - } - - } - - private static class TravelTimeAndWaitTime { - private double travelTime; - private double waitTime; + } + + private void writeValues(CSVPrinter csvPrinter, TreeSet allModes) throws IOException { + for (Map.Entry> e : phtPerIteration.entrySet()){ + csvPrinter.print(e.getKey()); + for (String mode : allModes){ + TravelTimeAndWaitTime travelTimeAndWaitTime = e.getValue().getOrDefault(mode, new TravelTimeAndWaitTime(0.0, 0.0)); + csvPrinter.print((int) Math.round(travelTimeAndWaitTime.travelTime / 3600.0)); + csvPrinter.print((int) Math.round(travelTimeAndWaitTime.waitTime / 3600.0)); + } + csvPrinter.println(); + } + } - private TravelTimeAndWaitTime(double travelTime, double waitTime) { - this.travelTime = travelTime; - this.waitTime = waitTime; - } + private static void writeHeader(CSVPrinter csvPrinter, TreeSet allModes) throws IOException { + csvPrinter.print("Iteration"); + for (String mode: allModes) { + csvPrinter.print(mode + TRAVEL_TIME_SUFFIX); + csvPrinter.print(mode + WAIT_TIME_SUFFIX); + } + csvPrinter.println(); + } + + private void writePng(){ + TreeSet allModes = getAllModes(); + String[] categories = new String[phtPerIteration.size()]; + int i = 0; + for (Integer it : phtPerIteration.keySet()){ + categories[i++] = it.toString(); + } - private static TravelTimeAndWaitTime sum(TravelTimeAndWaitTime object1, TravelTimeAndWaitTime object2) { + StackedBarChart chart = new StackedBarChart("Passenger hours traveled per Mode","Iteration","person hours",categories); + //rotate x-axis by 90degrees + chart.getChart().getCategoryPlot().getDomainAxis().setCategoryLabelPositions(CategoryLabelPositions.UP_90); + + for (String mode : allModes){ + double[] valueTravelTime = phtPerIteration.values().stream() + .mapToDouble(k->k.getOrDefault(mode,new TravelTimeAndWaitTime(0.0, 0.0)).travelTime/3600.0) + .toArray(); + chart.addSeries(mode + TRAVEL_TIME_SUFFIX, valueTravelTime); + double[] valueWaitTime = phtPerIteration.values().stream() + .mapToDouble(k->k.getOrDefault(mode,new TravelTimeAndWaitTime(0.0, 0.0)).waitTime/3600.0) + .toArray(); + chart.addSeries(mode + WAIT_TIME_SUFFIX, valueWaitTime); + } + chart.addMatsimLogo(); + chart.saveAsPng(controllerIO.getOutputFilename(FILENAME+ ".png"), 1024, 768); + } + + private TreeSet getAllModes() { + return this.phtPerIteration.values() + .stream() + .flatMap(i -> i.keySet().stream()) + .collect(Collectors.toCollection(TreeSet::new)); + } + + private record TravelTimeAndWaitTime(double travelTime, double waitTime){ + private static TravelTimeAndWaitTime sum(TravelTimeAndWaitTime object1, TravelTimeAndWaitTime object2) { return new TravelTimeAndWaitTime(object1.travelTime + object2.travelTime, object1.waitTime + object2.waitTime); } } From c2ebc79acb80d3e4327c80ca6c40f91f72468a8f Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Fri, 24 Nov 2023 11:24:25 +0100 Subject: [PATCH 02/43] fix test --- ...IterationTravelStatsControlerListener.java | 1 + .../matsim/analysis/PHbyModeCalculator.java | 63 ++++++++++--------- 2 files changed, 34 insertions(+), 30 deletions(-) diff --git a/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java b/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java index 17ea8796459..92ff3b139d4 100644 --- a/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java +++ b/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java @@ -56,6 +56,7 @@ class IterationTravelStatsControlerListener implements IterationEndsListener, Sh @Inject Scenario scenario; + @Inject private ExperiencedPlansService experiencedPlansService; diff --git a/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java b/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java index 41cf719a128..7ea20608222 100644 --- a/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java +++ b/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java @@ -20,6 +20,7 @@ package org.matsim.analysis; +import java.io.BufferedWriter; import java.io.IOException; import java.nio.file.Files; import java.nio.file.Paths; @@ -48,31 +49,31 @@ */ public class PHbyModeCalculator { - private final Map> phtPerIteration = new TreeMap<>(); - private final boolean writePng; - private final OutputDirectoryHierarchy controllerIO; + private final Map> phtPerIteration = new TreeMap<>(); + private final boolean writePng; + private final OutputDirectoryHierarchy controllerIO; private final String delimiter; - private final static String FILENAME = "ph_modestats"; - - private static final String TRAVEL_TIME_SUFFIX = "_travel"; - private static final String WAIT_TIME_SUFFIX = "_wait"; - private static final String STAGE_ACTIVITY = "stageActivity"; - - @Inject - PHbyModeCalculator(ControllerConfigGroup controllerConfigGroup, OutputDirectoryHierarchy controllerIO, GlobalConfigGroup globalConfig) { - this.writePng = controllerConfigGroup.isCreateGraphs(); - this.controllerIO = controllerIO; - this.delimiter = globalConfig.getDefaultDelimiter(); - } - - void addIteration(int iteration, IdMap map) { - Map phtbyMode = map.values() - .parallelStream() - .flatMap(plan -> plan.getPlanElements().stream()) - .map(PHbyModeCalculator::mapPlanElementToEntry) - .collect(Collectors.toMap(AbstractMap.SimpleEntry::getKey, AbstractMap.SimpleEntry::getValue, TravelTimeAndWaitTime::sum)); - phtPerIteration.put(iteration,phtbyMode); - } + private final static String FILENAME = "ph_modestats"; + + private static final String TRAVEL_TIME_SUFFIX = "_travel"; + private static final String WAIT_TIME_SUFFIX = "_wait"; + private static final String STAGE_ACTIVITY = "stageActivity"; + + @Inject + PHbyModeCalculator(ControllerConfigGroup controllerConfigGroup, OutputDirectoryHierarchy controllerIO, GlobalConfigGroup globalConfig) { + this.writePng = controllerConfigGroup.isCreateGraphs(); + this.controllerIO = controllerIO; + this.delimiter = globalConfig.getDefaultDelimiter(); + } + + void addIteration(int iteration, IdMap map) { + Map phtbyMode = map.values() + .parallelStream() + .flatMap(plan -> plan.getPlanElements().stream()) + .map(PHbyModeCalculator::mapPlanElementToEntry) + .collect(Collectors.toMap(AbstractMap.SimpleEntry::getKey, AbstractMap.SimpleEntry::getValue, TravelTimeAndWaitTime::sum)); + phtPerIteration.put(iteration,phtbyMode); + } private static AbstractMap.SimpleEntry mapPlanElementToEntry(PlanElement pe) { if (pe instanceof Leg leg) { @@ -105,19 +106,21 @@ private static AbstractMap.SimpleEntry mapPlanEle return new AbstractMap.SimpleEntry<>(STAGE_ACTIVITY, new TravelTimeAndWaitTime(0.0, 0.0)); } - void writeOutput() { + void writeOutput() { writeCsv(); if(writePng){ writePng(); } - } + } private void writeCsv() { TreeSet allModes = getAllModes(); try { - CSVPrinter csvPrinter = new CSVPrinter(Files.newBufferedWriter(Paths.get(controllerIO.getOutputFilename( FILENAME+ ".csv"))), CSVFormat.DEFAULT.withDelimiter(this.delimiter.charAt(0))); + BufferedWriter writer = Files.newBufferedWriter(Paths.get(controllerIO.getOutputFilename(FILENAME + ".csv"))); + CSVPrinter csvPrinter = new CSVPrinter(writer, CSVFormat.Builder.create().setDelimiter((this.delimiter.charAt(0))).build()); writeHeader(csvPrinter, allModes); writeValues(csvPrinter, allModes); + csvPrinter.close(); } catch (IOException e) { LogManager.getLogger(getClass()).error("Could not write PH Modestats."); } @@ -179,8 +182,8 @@ private TreeSet getAllModes() { private record TravelTimeAndWaitTime(double travelTime, double waitTime){ private static TravelTimeAndWaitTime sum(TravelTimeAndWaitTime object1, TravelTimeAndWaitTime object2) { - return new TravelTimeAndWaitTime(object1.travelTime + object2.travelTime, object1.waitTime + object2.waitTime); - } - } + return new TravelTimeAndWaitTime(object1.travelTime + object2.travelTime, object1.waitTime + object2.waitTime); + } + } } From ff5746fa8f2294890ccbfed1eb85b818bfd6fc32 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Fri, 1 Dec 2023 14:39:44 +0100 Subject: [PATCH 03/43] refactored analysis of ph, pkm and trips/legs --- .../org/matsim/analysis/ActivityWriter.java | 120 ++++++++++++ ...IterationTravelStatsControlerListener.java | 183 ++++-------------- .../analysis/IterationTravelStatsModule.java | 10 +- .../matsim/analysis/PHbyModeCalculator.java | 15 +- .../matsim/analysis/PKMbyModeCalculator.java | 111 ++++++----- .../org/matsim/analysis/PersonWriter.java | 105 ++++++++++ ...CSVWriter.java => TripsAndLegsWriter.java} | 157 ++++++++------- .../config/groups/ControllerConfigGroup.java | 12 ++ .../analysis/PHbyModeCalculatorTest.java | 10 +- .../analysis/PKMbyModeCalculatorTest.java | 8 +- ...rTest.java => TripsAndLegsWriterTest.java} | 24 +-- 11 files changed, 456 insertions(+), 299 deletions(-) create mode 100644 matsim/src/main/java/org/matsim/analysis/ActivityWriter.java create mode 100644 matsim/src/main/java/org/matsim/analysis/PersonWriter.java rename matsim/src/main/java/org/matsim/analysis/{TripsAndLegsCSVWriter.java => TripsAndLegsWriter.java} (78%) rename matsim/src/test/java/org/matsim/analysis/{TripsAndLegsCSVWriterTest.java => TripsAndLegsWriterTest.java} (96%) diff --git a/matsim/src/main/java/org/matsim/analysis/ActivityWriter.java b/matsim/src/main/java/org/matsim/analysis/ActivityWriter.java new file mode 100644 index 00000000000..9305dd02a51 --- /dev/null +++ b/matsim/src/main/java/org/matsim/analysis/ActivityWriter.java @@ -0,0 +1,120 @@ +package org.matsim.analysis; + +import jakarta.inject.Inject; +import org.apache.commons.csv.CSVFormat; +import org.apache.commons.csv.CSVPrinter; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; +import org.matsim.api.core.v01.Id; +import org.matsim.api.core.v01.population.Activity; +import org.matsim.api.core.v01.population.Person; +import org.matsim.api.core.v01.population.Plan; +import org.matsim.core.config.Config; +import org.matsim.core.controler.Controler; +import org.matsim.core.controler.OutputDirectoryHierarchy; +import org.matsim.core.router.TripStructureUtils; +import org.matsim.core.scoring.ExperiencedPlansService; +import org.matsim.core.utils.io.IOUtils; + +import java.io.BufferedWriter; +import java.io.IOException; +import java.util.ArrayList; +import java.util.List; +import java.util.Map; + +public class ActivityWriter { + + @Inject + private Config config; + + @Inject + private ExperiencedPlansService experiencedPlansService; + + @Inject + private OutputDirectoryHierarchy outputDirectoryHierarchy; + + private static final Logger log = LogManager.getLogger(ActivityWriter.class); + + void writeCsv(int iteration) { + log.info("Writing all Activities to " + Controler.DefaultFiles.activitiescsv); + + List attributes = prepareAttributes(); + String[] header = prepareHeader(attributes); + + try{ + BufferedWriter bufferedWriter = IOUtils.getBufferedWriter(outputDirectoryHierarchy.getIterationFilename(iteration, Controler.DefaultFiles.activitiescsv)); + CSVPrinter csvPrinter = new CSVPrinter(bufferedWriter, CSVFormat.Builder.create() + .setDelimiter(config.global().getDefaultDelimiter().charAt(0)) + .setHeader(header).build()); + + for (Map.Entry, Plan> e : experiencedPlansService.getExperiencedPlans().entrySet()) { + writeActivitiesPerPerson(e.getKey(), e.getValue(), attributes, csvPrinter); + } + + csvPrinter.close(); + } catch (IOException e) { + e.printStackTrace(); + } + + log.info("...done"); + } + + private static void writeActivitiesPerPerson(Id personId, Plan plan, List attributes, CSVPrinter csvPrinter) throws IOException { + int i = 0; + for (Activity act : TripStructureUtils.getActivities(plan, TripStructureUtils.StageActivityHandling.ExcludeStageActivities)) { + + List line = new ArrayList<>(); + int id = ++i; + line.add(personId); + line.add(id); + line.add(personId.toString() + "_" + id); + line.add(act.getType()); + + line.add(act.getStartTime().isDefined() ? act.getStartTime().seconds() : ""); + line.add(act.getEndTime().isDefined() ? act.getEndTime().seconds() : ""); + line.add(act.getMaximumDuration().isDefined() ? act.getMaximumDuration().seconds() : ""); + line.add(act.getLinkId() != null ? act.getLinkId() : ""); + line.add(act.getFacilityId() != null ? act.getFacilityId(): ""); + + if (act.getCoord() != null) { + line.add(act.getCoord().getX()); + line.add(act.getCoord().getY()); + } else { + line.add(""); + line.add(""); + } + + for (String attribute : attributes) { + Object value = plan.getAttributes().getAttribute(attribute); + String result = value != null ? String.valueOf(value) : ""; + line.add(result); + } + + csvPrinter.printRecord(line); + } + } + + private List prepareAttributes() { + return experiencedPlansService.getExperiencedPlans().values().stream() + .flatMap(p -> TripStructureUtils.getActivities(p, TripStructureUtils.StageActivityHandling.ExcludeStageActivities).stream()) + .flatMap(act -> act.getAttributes().getAsMap().keySet().stream()) + .sorted().distinct().toList(); + } + + private static String[] prepareHeader(List attributes) { + List header = new ArrayList<>(); + header.add("person"); + header.add("activity_number"); + header.add("activity_id"); + header.add("activity_type"); + header.add("start_time"); + header.add("end_time"); + header.add("maximum_duration"); + header.add("link_id"); + header.add("facility_id"); + header.add("coord_x"); + header.add("coord_y"); + header.addAll(attributes); + return header.toArray(String[]::new); + } +} diff --git a/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java b/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java index 92ff3b139d4..4f1e3aeda1a 100644 --- a/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java +++ b/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java @@ -21,15 +21,7 @@ package org.matsim.analysis; -import org.apache.commons.csv.CSVFormat; -import org.apache.commons.csv.CSVPrinter; -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; -import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; -import org.matsim.api.core.v01.population.Activity; -import org.matsim.api.core.v01.population.Person; -import org.matsim.api.core.v01.population.Plan; import org.matsim.core.config.Config; import org.matsim.core.controler.Controler; import org.matsim.core.controler.OutputDirectoryHierarchy; @@ -37,26 +29,15 @@ import org.matsim.core.controler.events.ShutdownEvent; import org.matsim.core.controler.listener.IterationEndsListener; import org.matsim.core.controler.listener.ShutdownListener; -import org.matsim.core.router.AnalysisMainModeIdentifier; -import org.matsim.core.router.TripStructureUtils; import org.matsim.core.scoring.ExperiencedPlansService; -import org.matsim.core.utils.io.IOUtils; import jakarta.inject.Inject; -import java.io.IOException; -import java.util.ArrayList; -import java.util.List; -import java.util.Map; -import java.util.stream.Collectors; class IterationTravelStatsControlerListener implements IterationEndsListener, ShutdownListener { @Inject Config config; - @Inject - Scenario scenario; - @Inject private ExperiencedPlansService experiencedPlansService; @@ -68,163 +49,65 @@ class IterationTravelStatsControlerListener implements IterationEndsListener, Sh @Inject private PKMbyModeCalculator pkMbyModeCalculator; - @Inject - OutputDirectoryHierarchy outputDirectoryHierarchy; @Inject - TripsAndLegsCSVWriter.CustomTripsWriterExtension customTripsWriterExtension; - @Inject - TripsAndLegsCSVWriter.CustomLegsWriterExtension customLegsWriterExtension; - @Inject - TripsAndLegsCSVWriter.CustomTimeWriter customTimeWriter; + OutputDirectoryHierarchy outputDirectoryHierarchy; + @Inject + PersonWriter personWriter; - @Inject - AnalysisMainModeIdentifier mainModeIdentifier; + @Inject + ActivityWriter activityWriter; - Logger log = LogManager.getLogger(IterationTravelStatsControlerListener.class); + @Inject + TripsAndLegsWriter tripsAndLegsWriter; @Override public void notifyIterationEnds(IterationEndsEvent event) { + + if (config.controller().getCreateGraphsInterval()>0 && event.getIteration() % config.controller().getCreateGraphsInterval() == 0) { + //do something + } + travelDistanceStats.addIteration(event.getIteration(), experiencedPlansService.getExperiencedPlans()); pHbyModeCalculator.addIteration(event.getIteration(), experiencedPlansService.getExperiencedPlans()); pkMbyModeCalculator.addIteration(event.getIteration(), experiencedPlansService.getExperiencedPlans()); - pHbyModeCalculator.writeOutput(); - pkMbyModeCalculator.writeOutput(); - final boolean writingTripsAtAll = config.controller().getWriteTripsInterval() > 0; - final boolean regularWriteEvents = writingTripsAtAll && ((event.getIteration() > 0 && event.getIteration() % config.controller().getWriteTripsInterval() == 0) || event.isLastIteration()); - if (regularWriteEvents || (writingTripsAtAll && event.getIteration() == 0)) { - new TripsAndLegsCSVWriter(scenario, customTripsWriterExtension, customLegsWriterExtension, mainModeIdentifier, customTimeWriter).write(experiencedPlansService.getExperiencedPlans() + + boolean writeGraph = isWriteGraph(event); + pHbyModeCalculator.writeOutput(writeGraph); + pkMbyModeCalculator.writeOutput(writeGraph); + + if (isWriteTripsAndLegs(event)) { + tripsAndLegsWriter.write(experiencedPlansService.getExperiencedPlans() , outputDirectoryHierarchy.getIterationFilename(event.getIteration(), Controler.DefaultFiles.tripscsv) , outputDirectoryHierarchy.getIterationFilename(event.getIteration(), Controler.DefaultFiles.legscsv)); - writeActivityCSV(event.getIteration()); + activityWriter.writeCsv(event.getIteration()); } } - @Override public void notifyShutdown(ShutdownEvent event) { travelDistanceStats.close(); if (config.controller().getWriteTripsInterval() > 0) { - writePersonsCSV(); + personWriter.writeCsv(); } } - private void writePersonsCSV() { - LogManager.getLogger(getClass()).info("Writing all Person and Attributes to " + Controler.DefaultFiles.personscsv); - List attributes = new ArrayList<>(scenario.getPopulation().getPersons().values().parallelStream().flatMap(p -> p.getAttributes().getAsMap().keySet().stream()).collect(Collectors.toSet())); - attributes.remove("vehicles"); - List header = new ArrayList<>(); - header.add("person"); - header.add("executed_score"); - header.add("first_act_x"); - header.add("first_act_y"); - header.add("first_act_type"); - header.addAll(attributes); - try (CSVPrinter csvPrinter = new CSVPrinter(IOUtils.getBufferedWriter(outputDirectoryHierarchy.getOutputFilename(Controler.DefaultFiles.personscsv)), - CSVFormat.DEFAULT.withDelimiter(config.global().getDefaultDelimiter().charAt(0)).withHeader(header.stream().toArray(String[]::new)))) { - for (Person p : scenario.getPopulation().getPersons().values()) { - if (p.getSelectedPlan() == null) { - log.error("Found person without a selected plan: " + p.getId().toString() + " will not be added to output_persons.csv"); - continue; - } - List line = new ArrayList<>(); - line.add(p.getId().toString()); - line.add(p.getSelectedPlan().getScore() == null ? "null" : p.getSelectedPlan().getScore().toString()); - String x = ""; - String y = ""; - String actType = ""; - if (p.getSelectedPlan().getPlanElements().size() > 0) { - Activity firstAct = (Activity) p.getSelectedPlan().getPlanElements().get(0); - if (firstAct.getCoord() != null) { - x = Double.toString(firstAct.getCoord().getX()); - y = Double.toString(firstAct.getCoord().getY()); - } - actType = firstAct.getType(); - } - line.add(x); - line.add(y); - line.add(actType); - for (String attribute : attributes) { - Object value = p.getAttributes().getAttribute(attribute); - String result = value != null ? String.valueOf(value) : ""; - line.add(result); - } - csvPrinter.printRecord(line); - } - } catch (IOException e) { - e.printStackTrace(); - } - LogManager.getLogger(getClass()).info("...done"); - } + private boolean isWriteGraph(IterationEndsEvent event){ + return config.controller().getCreateGraphsInterval() > 0 && event.getIteration() % config.controller().getCreateGraphsInterval() == 0; + } - private void writeActivityCSV(int iteration) { - - List attributes = experiencedPlansService.getExperiencedPlans().values().stream() - .flatMap(p -> TripStructureUtils.getActivities(p, TripStructureUtils.StageActivityHandling.ExcludeStageActivities).stream()) - .flatMap(act -> act.getAttributes().getAsMap().keySet().stream()) - .sorted().distinct().toList(); - - List header = new ArrayList<>(); - header.add("person"); - header.add("activity_number"); - header.add("activity_id"); - header.add("activity_type"); - header.add("start_time"); - header.add("end_time"); - header.add("maximum_duration"); - header.add("link_id"); - header.add("facility_id"); - - header.add("coord_x"); - header.add("coord_y"); - - header.addAll(attributes); - - try (CSVPrinter csvPrinter = new CSVPrinter(IOUtils.getBufferedWriter(outputDirectoryHierarchy.getIterationFilename(iteration, Controler.DefaultFiles.activitiescsv)), - CSVFormat.DEFAULT.withDelimiter(config.global().getDefaultDelimiter().charAt(0)).withHeader(header.stream().toArray(String[]::new)))) { - - for (Map.Entry, Plan> e : experiencedPlansService.getExperiencedPlans().entrySet()) { - - int i = 0; - for (Activity act : TripStructureUtils.getActivities(e.getValue(), TripStructureUtils.StageActivityHandling.ExcludeStageActivities)) { - - List line = new ArrayList<>(); - - int id = ++i; - line.add(e.getKey()); - line.add(id); - line.add(e.getKey().toString() + "_" + id); - line.add(act.getType()); - - line.add(act.getStartTime().isDefined() ? act.getStartTime().seconds() : ""); - line.add(act.getEndTime().isDefined() ? act.getEndTime().seconds() : ""); - line.add(act.getMaximumDuration().isDefined() ? act.getMaximumDuration().seconds() : ""); - line.add(act.getLinkId() != null ? act.getLinkId() : ""); - line.add(act.getFacilityId() != null ? act.getFacilityId(): ""); - - if (act.getCoord() != null) { - line.add(act.getCoord().getX()); - line.add(act.getCoord().getY()); - } else { - line.add(""); - line.add(""); - } - - for (String attribute : attributes) { - Object value = e.getValue().getAttributes().getAttribute(attribute); - String result = value != null ? String.valueOf(value) : ""; - line.add(result); - } - - csvPrinter.printRecord(line); - } - } - } catch (IOException e) { - e.printStackTrace(); + private boolean isWriteTripsAndLegs(IterationEndsEvent event){ + if (config.controller().getWriteTripsInterval() <= 0) { + return false; } - } + if (event.getIteration() == 0 || event.isLastIteration()){ + return true; + } + + return event.getIteration() % config.controller().getWriteTripsInterval() == 0; + } } diff --git a/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsModule.java b/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsModule.java index 4b431499d01..32f54c9ca8c 100644 --- a/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsModule.java +++ b/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsModule.java @@ -31,10 +31,12 @@ public void install() { bind(TravelDistanceStats.class).asEagerSingleton(); bind(PKMbyModeCalculator.class).asEagerSingleton(); bind(PHbyModeCalculator.class).asEagerSingleton(); - bind(TripsAndLegsCSVWriter.CustomTripsWriterExtension.class).to(TripsAndLegsCSVWriter.NoTripWriterExtension.class).asEagerSingleton(); - bind(TripsAndLegsCSVWriter.CustomLegsWriterExtension.class).to(TripsAndLegsCSVWriter.NoLegsWriterExtension.class).asEagerSingleton(); - bind(TripsAndLegsCSVWriter.CustomTimeWriter.class).to(TripsAndLegsCSVWriter.DefaultTimeWriter.class).asEagerSingleton(); + bind(TripsAndLegsWriter.CustomTripsWriterExtension.class).to(TripsAndLegsWriter.NoTripWriterExtension.class).asEagerSingleton(); + bind(TripsAndLegsWriter.CustomLegsWriterExtension.class).to(TripsAndLegsWriter.NoLegsWriterExtension.class).asEagerSingleton(); + bind(TripsAndLegsWriter.CustomTimeWriter.class).to(TripsAndLegsWriter.DefaultTimeWriter.class).asEagerSingleton(); + bind(ActivityWriter.class); + bind(PersonWriter.class); + bind(TripsAndLegsWriter.class); addControlerListenerBinding().to(IterationTravelStatsControlerListener.class); } - } diff --git a/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java b/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java index 7ea20608222..e572fbcc8a8 100644 --- a/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java +++ b/matsim/src/main/java/org/matsim/analysis/PHbyModeCalculator.java @@ -50,9 +50,8 @@ public class PHbyModeCalculator { private final Map> phtPerIteration = new TreeMap<>(); - private final boolean writePng; private final OutputDirectoryHierarchy controllerIO; - private final String delimiter; + private final String delimiter; private final static String FILENAME = "ph_modestats"; private static final String TRAVEL_TIME_SUFFIX = "_travel"; @@ -60,8 +59,7 @@ public class PHbyModeCalculator { private static final String STAGE_ACTIVITY = "stageActivity"; @Inject - PHbyModeCalculator(ControllerConfigGroup controllerConfigGroup, OutputDirectoryHierarchy controllerIO, GlobalConfigGroup globalConfig) { - this.writePng = controllerConfigGroup.isCreateGraphs(); + PHbyModeCalculator(OutputDirectoryHierarchy controllerIO, GlobalConfigGroup globalConfig) { this.controllerIO = controllerIO; this.delimiter = globalConfig.getDefaultDelimiter(); } @@ -97,19 +95,22 @@ private static AbstractMap.SimpleEntry mapPlanEle } if (Double.isNaN(travelTime)) {travelTime = 0.0; } return new AbstractMap.SimpleEntry<>(leg.getMode(), new TravelTimeAndWaitTime(travelTime, waitTime)); - } else if (pe instanceof Activity act) { + } + + if (pe instanceof Activity act) { if (StageActivityTypeIdentifier.isStageActivity(act.getType())) { double duration = act.getEndTime().orElse(0) - act.getStartTime().orElse(0); return new AbstractMap.SimpleEntry<>(STAGE_ACTIVITY, new TravelTimeAndWaitTime(0.0, duration)); } } + return new AbstractMap.SimpleEntry<>(STAGE_ACTIVITY, new TravelTimeAndWaitTime(0.0, 0.0)); } - void writeOutput() { + void writeOutput(boolean writePng) { writeCsv(); if(writePng){ - writePng(); + new Thread(this::writePng).start(); } } diff --git a/matsim/src/main/java/org/matsim/analysis/PKMbyModeCalculator.java b/matsim/src/main/java/org/matsim/analysis/PKMbyModeCalculator.java index 1b05fccdb2f..c9979b9ae4f 100644 --- a/matsim/src/main/java/org/matsim/analysis/PKMbyModeCalculator.java +++ b/matsim/src/main/java/org/matsim/analysis/PKMbyModeCalculator.java @@ -20,6 +20,7 @@ package org.matsim.analysis; +import java.io.BufferedWriter; import java.io.IOException; import java.nio.file.Files; import java.nio.file.Paths; @@ -49,14 +50,12 @@ public class PKMbyModeCalculator { private final Map> pmtPerIteration = new TreeMap<>(); - private final boolean writePng; private final OutputDirectoryHierarchy controllerIO; private final String delimiter; private final static String FILENAME = "pkm_modestats"; @Inject - PKMbyModeCalculator(ControllerConfigGroup controllerConfigGroup, OutputDirectoryHierarchy controllerIO, GlobalConfigGroup globalConfig) { - writePng = controllerConfigGroup.isCreateGraphs(); + PKMbyModeCalculator(OutputDirectoryHierarchy controllerIO, GlobalConfigGroup globalConfig) { this.controllerIO = controllerIO; this.delimiter = globalConfig.getDefaultDelimiter(); } @@ -72,61 +71,75 @@ void addIteration(int iteration, IdMap map) { if (Double.isNaN(dist)) {dist = 0.0; } return new AbstractMap.SimpleEntry<>(leg.getMode(),dist); }) - .collect(Collectors.toMap(e->e.getKey(),e->e.getValue(),(a,b)->a+b)); + .collect(Collectors.toMap(AbstractMap.SimpleEntry::getKey, AbstractMap.SimpleEntry::getValue, Double::sum)); pmtPerIteration.put(iteration,pmtbyMode); } - - void writeOutput() { - writeVKTText(); - + void writeOutput(boolean writePng) { + writeCsv(); + if (writePng){ + new Thread(this::writePng).start(); + } } - private void writeVKTText() { - TreeSet allModes = new TreeSet<>(); - allModes.addAll(this.pmtPerIteration.values() - .stream() - .flatMap(i->i.keySet().stream()) - .collect(Collectors.toSet())); - - try (CSVPrinter csvPrinter = new CSVPrinter(Files.newBufferedWriter(Paths.get(controllerIO.getOutputFilename( FILENAME+ ".csv"))), CSVFormat.DEFAULT.withDelimiter(this.delimiter.charAt(0)))) { - csvPrinter.print("Iteration"); - csvPrinter.printRecord(allModes); - - for (Map.Entry> e : pmtPerIteration.entrySet()){ - csvPrinter.print(e.getKey()); - for (String mode : allModes){ - csvPrinter.print((int) Math.round(e.getValue().getOrDefault(mode, 0.0) / 1000.0)); - } - csvPrinter.println(); - } - + private void writeCsv() { + TreeSet allModes = getAllModes(); + try { + BufferedWriter writer = Files.newBufferedWriter(Paths.get(controllerIO.getOutputFilename(FILENAME + ".csv"))); + CSVPrinter csvPrinter = new CSVPrinter(writer, CSVFormat.Builder.create().setDelimiter((this.delimiter.charAt(0))).build()); + writeHeader(csvPrinter, allModes); + writeValues(csvPrinter, allModes); + csvPrinter.close(); } catch (IOException e) { LogManager.getLogger(getClass()).error("Could not write PKM Modestats."); } - if (writePng){ - String[] categories = new String[pmtPerIteration.size()]; - int i = 0; - for (Integer it : pmtPerIteration.keySet()){ - categories[i++] = it.toString(); - } - - StackedBarChart chart = new StackedBarChart("Passenger kilometers traveled per Mode","Iteration","pkm",categories); - //rotate x-axis by 90degrees - chart.getChart().getCategoryPlot().getDomainAxis().setCategoryLabelPositions(CategoryLabelPositions.UP_90); - - for (String mode : allModes){ - double[] value = pmtPerIteration.values().stream() - .mapToDouble(k->k.getOrDefault(mode,0.0)/1000.0) - .toArray(); - chart.addSeries(mode, value); - } - chart.addMatsimLogo(); - chart.saveAsPng(controllerIO.getOutputFilename(FILENAME+ ".png"), 1024, 768); - - } - } + + private void writeHeader(CSVPrinter csvPrinter, TreeSet allModes) throws IOException { + csvPrinter.print("Iteration"); + csvPrinter.printRecord(allModes); + } + + private void writeValues(CSVPrinter csvPrinter, TreeSet allModes) throws IOException { + for (Map.Entry> e : pmtPerIteration.entrySet()){ + csvPrinter.print(e.getKey()); + for (String mode : allModes){ + csvPrinter.print((int) Math.round(e.getValue().getOrDefault(mode, 0.0) / 1000.0)); + } + csvPrinter.println(); + } + } + + private void writePng() { + String[] categories = new String[pmtPerIteration.size()]; + int i = 0; + for (Integer it : pmtPerIteration.keySet()){ + categories[i++] = it.toString(); + } + + StackedBarChart chart = new StackedBarChart("Passenger kilometers traveled per Mode","Iteration","pkm",categories); + //rotate x-axis by 90degrees + chart.getChart().getCategoryPlot().getDomainAxis().setCategoryLabelPositions(CategoryLabelPositions.UP_90); + + for (String mode : getAllModes()){ + double[] value = pmtPerIteration.values().stream() + .mapToDouble(k->k.getOrDefault(mode,0.0)/1000.0) + .toArray(); + chart.addSeries(mode, value); + } + chart.addMatsimLogo(); + + synchronized (controllerIO) { + chart.saveAsPng(controllerIO.getOutputFilename(FILENAME+ ".png"), 1024, 768); + } + } + + private TreeSet getAllModes() { + return this.pmtPerIteration.values() + .stream() + .flatMap(i -> i.keySet().stream()) + .collect(Collectors.toCollection(TreeSet::new)); + } } diff --git a/matsim/src/main/java/org/matsim/analysis/PersonWriter.java b/matsim/src/main/java/org/matsim/analysis/PersonWriter.java new file mode 100644 index 00000000000..5c3257a2aa5 --- /dev/null +++ b/matsim/src/main/java/org/matsim/analysis/PersonWriter.java @@ -0,0 +1,105 @@ +package org.matsim.analysis; + +import jakarta.inject.Inject; +import org.apache.commons.csv.CSVFormat; +import org.apache.commons.csv.CSVPrinter; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; +import org.matsim.api.core.v01.Scenario; +import org.matsim.api.core.v01.population.Activity; +import org.matsim.api.core.v01.population.Person; +import org.matsim.core.config.Config; +import org.matsim.core.controler.Controler; +import org.matsim.core.controler.OutputDirectoryHierarchy; +import org.matsim.core.utils.io.IOUtils; + +import java.io.BufferedWriter; +import java.io.IOException; +import java.util.ArrayList; +import java.util.List; +import java.util.stream.Collectors; + +public class PersonWriter { + + @Inject + Config config; + + @Inject + Scenario scenario; + + @Inject + OutputDirectoryHierarchy outputDirectoryHierarchy; + + private static final Logger log = LogManager.getLogger(PersonWriter.class); + + void writeCsv() { + log.info("Writing all Persons to " + Controler.DefaultFiles.personscsv); + + List attributes = prepareAttributes(); + String[] header = prepareHeader(attributes); + + try { + BufferedWriter bufferedWriter = IOUtils.getBufferedWriter(outputDirectoryHierarchy.getOutputFilename(Controler.DefaultFiles.personscsv)); + CSVPrinter csvPrinter = new CSVPrinter(bufferedWriter, CSVFormat.Builder.create() + .setDelimiter(config.global().getDefaultDelimiter().charAt(0)) + .setHeader(header).build()); + for (Person p : scenario.getPopulation().getPersons().values()) { + writePerson(p, attributes, csvPrinter); + } + + csvPrinter.close(); + } catch (IOException e) { + e.printStackTrace(); + } + log.info("...done"); + } + + private void writePerson(Person p, List attributes, CSVPrinter csvPrinter) throws IOException { + if (p.getSelectedPlan() == null) { + log.error("Found person without a selected plan: " + p.getId().toString() + " will not be added to output_persons.csv"); + return; + } + List line = new ArrayList<>(); + line.add(p.getId().toString()); + line.add(p.getSelectedPlan().getScore() == null ? "null" : p.getSelectedPlan().getScore().toString()); + String x = ""; + String y = ""; + String actType = ""; + if (!p.getSelectedPlan().getPlanElements().isEmpty()) { + Activity firstAct = (Activity) p.getSelectedPlan().getPlanElements().get(0); + if (firstAct.getCoord() != null) { + x = Double.toString(firstAct.getCoord().getX()); + y = Double.toString(firstAct.getCoord().getY()); + } + actType = firstAct.getType(); + } + line.add(x); + line.add(y); + line.add(actType); + for (String attribute : attributes) { + Object value = p.getAttributes().getAttribute(attribute); + String result = value != null ? String.valueOf(value) : ""; + line.add(result); + } + csvPrinter.printRecord(line); + } + + private String[] prepareHeader(List attributes) { + List header = new ArrayList<>(); + header.add("person"); + header.add("executed_score"); + header.add("first_act_x"); + header.add("first_act_y"); + header.add("first_act_type"); + header.addAll(attributes); + return header.toArray(String[]::new); + } + + private List prepareAttributes() { + List attributes = scenario.getPopulation().getPersons().values().parallelStream() + .flatMap(p -> p.getAttributes().getAsMap().keySet().stream()).distinct() + .collect(Collectors.toList()); + attributes.remove("vehicles"); + return attributes; + } +} diff --git a/matsim/src/main/java/org/matsim/analysis/TripsAndLegsCSVWriter.java b/matsim/src/main/java/org/matsim/analysis/TripsAndLegsWriter.java similarity index 78% rename from matsim/src/main/java/org/matsim/analysis/TripsAndLegsCSVWriter.java rename to matsim/src/main/java/org/matsim/analysis/TripsAndLegsWriter.java index daf244648d1..ea222d892e4 100644 --- a/matsim/src/main/java/org/matsim/analysis/TripsAndLegsCSVWriter.java +++ b/matsim/src/main/java/org/matsim/analysis/TripsAndLegsWriter.java @@ -21,6 +21,7 @@ package org.matsim.analysis; +import jakarta.inject.Inject; import org.apache.commons.csv.CSVFormat; import org.apache.commons.csv.CSVPrinter; import org.apache.commons.lang3.ArrayUtils; @@ -34,7 +35,6 @@ import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.*; import org.matsim.core.router.AnalysisMainModeIdentifier; -import org.matsim.core.router.RoutingModeMainModeIdentifier; import org.matsim.core.router.TripStructureUtils; import org.matsim.core.scoring.EventsToLegs; import org.matsim.core.utils.collections.Tuple; @@ -56,7 +56,7 @@ /** * @author jbischoff / SBB */ -public class TripsAndLegsCSVWriter { +public class TripsAndLegsWriter { public static final String[] TRIPSHEADER_BASE = {"person", "trip_number", "trip_id", "dep_time", "trav_time", "wait_time", "traveled_distance", "euclidean_distance", "main_mode", "longest_distance_mode", "modes", "start_activity_type", @@ -70,43 +70,43 @@ public class TripsAndLegsCSVWriter { private final String[] TRIPSHEADER; private final String[] LEGSHEADER; - private final String separator; private final CustomTripsWriterExtension tripsWriterExtension; private final Scenario scenario; private final CustomLegsWriterExtension legsWriterExtension; private final AnalysisMainModeIdentifier mainModeIdentifier; private final CustomTimeWriter customTimeWriter; - private static final Logger log = LogManager.getLogger(TripsAndLegsCSVWriter.class); - - public TripsAndLegsCSVWriter(Scenario scenario, CustomTripsWriterExtension tripsWriterExtension, - CustomLegsWriterExtension legWriterExtension, - AnalysisMainModeIdentifier mainModeIdentifier, CustomTimeWriter customTimeWriter) { - this.scenario = scenario; - this.separator = scenario.getConfig().global().getDefaultDelimiter(); - TRIPSHEADER = ArrayUtils.addAll(TRIPSHEADER_BASE, tripsWriterExtension.getAdditionalTripHeader()); - LEGSHEADER = ArrayUtils.addAll(LEGSHEADER_BASE, legWriterExtension.getAdditionalLegHeader()); - this.tripsWriterExtension = tripsWriterExtension; - this.legsWriterExtension = legWriterExtension; - this.mainModeIdentifier = mainModeIdentifier; - this.customTimeWriter = customTimeWriter; - } + private static final Logger log = LogManager.getLogger(TripsAndLegsWriter.class); + + @Inject + TripsAndLegsWriter(Scenario scenario, CustomTripsWriterExtension tripsWriterExtension, CustomLegsWriterExtension legWriterExtension, + AnalysisMainModeIdentifier mainModeIdentifier, CustomTimeWriter customTimeWriter) { + this.scenario = scenario; + this.tripsWriterExtension = tripsWriterExtension; + this.legsWriterExtension = legWriterExtension; + this.mainModeIdentifier = mainModeIdentifier; + this.customTimeWriter = customTimeWriter; + + TRIPSHEADER = ArrayUtils.addAll(TRIPSHEADER_BASE, tripsWriterExtension.getAdditionalTripHeader()); + LEGSHEADER = ArrayUtils.addAll(LEGSHEADER_BASE, legWriterExtension.getAdditionalLegHeader()); + } - public void write(IdMap experiencedPlans, String tripsFilename, String legsFilename) { + private char getDefaultDelimiter(){ + return scenario.getConfig().global().getDefaultDelimiter().charAt(0); + } + + public void write(IdMap experiencedPlans, String tripsFilename, String legsFilename) { try (CSVPrinter tripsCSVprinter = new CSVPrinter(IOUtils.getBufferedWriter(tripsFilename), - CSVFormat.DEFAULT.withDelimiter(separator.charAt(0)).withHeader(TRIPSHEADER)); + CSVFormat.Builder.create().setDelimiter(getDefaultDelimiter()).setHeader(TRIPSHEADER).build()); CSVPrinter legsCSVprinter = new CSVPrinter(IOUtils.getBufferedWriter(legsFilename), - CSVFormat.DEFAULT.withDelimiter(separator.charAt(0)).withHeader(LEGSHEADER)) - + CSVFormat.Builder.create().setDelimiter(getDefaultDelimiter()).setHeader(LEGSHEADER).build()) ) { - for (Map.Entry, Plan> entry : experiencedPlans.entrySet()) { Tuple, Iterable> tripsAndLegRecords = getPlanCSVRecords(entry.getValue(), entry.getKey()); tripsCSVprinter.printRecords(tripsAndLegRecords.getFirst()); legsCSVprinter.printRecords(tripsAndLegRecords.getSecond()); } } catch (IOException e) { - e.printStackTrace(); } } @@ -202,29 +202,14 @@ private Tuple, Iterable> getPlanCSVRecords(Plan experiencedPlan, tripRecord.add(firstPtBoardingStop != null ? firstPtBoardingStop : ""); tripRecord.add(lastPtEgressStop != null ? lastPtEgressStop : ""); tripRecord.addAll(tripsWriterExtension.getAdditionalTripColumns(personId, trip)); + if (TRIPSHEADER.length != tripRecord.size()) { // put the whole error message also into the RuntimeException, so maven shows it on the command line output (log messages are shown incompletely) - StringBuilder str = new StringBuilder(); - str.append("Custom CSV Trip Writer Extension does not provide an identical number of additional values and additional columns. Number of columns is " + TRIPSHEADER.length + ", and number of values is " + tripRecord.size() + ".\n"); - str.append("TripsWriterExtension class was: " + tripsWriterExtension.getClass() + ". Column name to value pairs supplied were:\n"); - for(int j = 0; j < Math.max(TRIPSHEADER.length, tripRecord.size()); j++) { - String columnNameJ; - try { - columnNameJ = TRIPSHEADER[j]; - } catch (ArrayIndexOutOfBoundsException e) { - columnNameJ = "!COLUMN MISSING!"; - } - String tripRecordJ; - try { - tripRecordJ = tripRecord.get(j); - } catch (IndexOutOfBoundsException e) { - tripRecordJ = "!VALUE MISSING!"; - } - str.append(j + ": " + columnNameJ + ": " + tripRecordJ + "\n"); - } - log.error(str.toString()); - throw new RuntimeException(str.toString()); + String errorMessage = getTripErrorMessage(tripRecord).toString(); + log.error(errorMessage); + throw new RuntimeException(errorMessage); } + Activity prevAct = null; Leg prevLeg = null; List allElements = new ArrayList<>(); @@ -232,9 +217,8 @@ private Tuple, Iterable> getPlanCSVRecords(Plan experiencedPlan, allElements.addAll(trip.getTripElements()); allElements.add(trip.getDestinationActivity()); for (PlanElement pe : allElements) { - if (pe instanceof Activity) { - Activity currentAct = (Activity) pe; - if (prevLeg != null) { + if (pe instanceof Activity currentAct) { + if (prevLeg != null) { List legRecord = getLegRecord(prevLeg, personId.toString(), tripId, prevAct, currentAct, trip); legRecords.add(legRecord); } @@ -249,7 +233,32 @@ private Tuple, Iterable> getPlanCSVRecords(Plan experiencedPlan, return record; } - private List getLegRecord(Leg leg, String personId, String tripId, Activity previousAct, Activity nextAct, TripStructureUtils.Trip trip) { + private StringBuilder getTripErrorMessage(List tripRecord) { + StringBuilder str = new StringBuilder(); + str.append("Custom CSV Trip Writer Extension does not provide an identical number of additional values and additional columns. Number of columns is ") + .append(TRIPSHEADER.length).append(", and number of values is ").append(tripRecord.size()) + .append(".\n") + .append("TripsWriterExtension class was: ").append(tripsWriterExtension.getClass()) + .append(". Column name to value pairs supplied were:\n"); + for(int j = 0; j < Math.max(TRIPSHEADER.length, tripRecord.size()); j++) { + String columnNameJ; + try { + columnNameJ = TRIPSHEADER[j]; + } catch (ArrayIndexOutOfBoundsException e) { + columnNameJ = "!COLUMN MISSING!"; + } + String tripRecordJ; + try { + tripRecordJ = tripRecord.get(j); + } catch (IndexOutOfBoundsException e) { + tripRecordJ = "!VALUE MISSING!"; + } + str.append(j + ": " + columnNameJ + ": " + tripRecordJ + "\n"); + } + return str; + } + + private List getLegRecord(Leg leg, String personId, String tripId, Activity previousAct, Activity nextAct, TripStructureUtils.Trip trip) { List record = new ArrayList<>(); record.add(personId); record.add(tripId); @@ -290,34 +299,46 @@ private List getLegRecord(Leg leg, String personId, String tripId, Activ record.add(vehicleId != null ? vehicleId.toString() : ""); record.addAll(legsWriterExtension.getAdditionalLegColumns(trip, leg)); + if (LEGSHEADER.length != record.size()) { // put the whole error message also into the RuntimeException, so maven shows it on the command line output (log messages are shown incompletely) - StringBuilder str = new StringBuilder(); - str.append("Custom CSV Leg Writer Extension does not provide an identical number of additional values and additional columns. Number of columns is " + LEGSHEADER.length + ", and number of values is " + record.size() + ".\n"); - str.append("LegsWriterExtension class was: " + legsWriterExtension.getClass() + ". Column name to value pairs supplied were:\n"); - for(int j = 0; j < Math.max(LEGSHEADER.length, record.size()); j++) { - String columnNameJ; - try { - columnNameJ = LEGSHEADER[j]; - } catch (ArrayIndexOutOfBoundsException e) { - columnNameJ = "!COLUMN MISSING!"; - } - String recordJ; - try { - recordJ = record.get(j); - } catch (IndexOutOfBoundsException e) { - recordJ = "!VALUE MISSING!"; - } - str.append(j + ": " + columnNameJ + ": " + recordJ + "\n"); - } - log.error(str.toString()); - throw new RuntimeException(str.toString()); + String errorMessage = getLegErrorMessage(record); + log.error(errorMessage); + throw new RuntimeException(errorMessage); } return record; } - private Coord getCoordFromActivity(Activity activity) { + private String getLegErrorMessage(List record) { + StringBuilder str = new StringBuilder(); + str.append("Custom CSV Leg Writer Extension does not provide an identical number of additional values and additional columns. Number of columns is ") + .append(LEGSHEADER.length) + .append(", and number of values is ") + .append(record.size()) + .append(".\n") + .append("LegsWriterExtension class was: ") + .append(legsWriterExtension.getClass()) + .append(". Column name to value pairs supplied were:\n"); + for(int j = 0; j < Math.max(LEGSHEADER.length, record.size()); j++) { + String columnNameJ; + try { + columnNameJ = LEGSHEADER[j]; + } catch (ArrayIndexOutOfBoundsException e) { + columnNameJ = "!COLUMN MISSING!"; + } + String recordJ; + try { + recordJ = record.get(j); + } catch (IndexOutOfBoundsException e) { + recordJ = "!VALUE MISSING!"; + } + str.append(j).append(": ").append(columnNameJ).append(": ").append(recordJ).append("\n"); + } + return str.toString(); + } + + private Coord getCoordFromActivity(Activity activity) { if (activity.getCoord() != null) { return activity.getCoord(); } else if (activity.getFacilityId() != null && scenario.getActivityFacilities().getFacilities().containsKey(activity.getFacilityId())) { diff --git a/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java b/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java index f1d8bae8b6a..d68aa5bf6e6 100644 --- a/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java +++ b/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java @@ -73,6 +73,7 @@ public enum CleanIterations { private static final String WRITE_TRIPS_INTERVAL = "writeTripsInterval"; private static final String OVERWRITE_FILE = "overwriteFiles"; private static final String CREATE_GRAPHS = "createGraphs"; + private static final String CREATE_GRAPHS_INTERVAL = "createGraphsInterval"; private static final String DUMP_DATA_AT_END = "dumpDataAtEnd"; private static final String CLEAN_ITERS_AT_END = "cleanItersAtEnd"; private static final String COMPRESSION_TYPE = "compressionType"; @@ -102,6 +103,7 @@ public enum MobsimType {qsim, JDEQSim, hermes} private String mobsim = MobsimType.qsim.toString(); private int writeSnapshotsInterval = 1; private boolean createGraphs = true; + private int createGraphsInterval = 1; private boolean dumpDataAtEnd = true; private CompressionType compressionType = CompressionType.gzip; @@ -373,6 +375,16 @@ public void setCreateGraphs(boolean createGraphs) { this.createGraphs = createGraphs; } + @StringGetter( CREATE_GRAPHS_INTERVAL ) + public int getCreateGraphsInterval() { + return createGraphsInterval; + } + + @StringSetter( CREATE_GRAPHS_INTERVAL ) + public void setCreateGraphsInterval(int createGraphsInterval) { + this.createGraphsInterval = createGraphsInterval; + } + @StringGetter( OVERWRITE_FILE ) public OverwriteFileSetting getOverwriteFileSetting() { return overwriteFileSetting; diff --git a/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java b/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java index e123bfceea9..ae647a6fd59 100644 --- a/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java @@ -93,28 +93,28 @@ private void performTest(IdMap map, String outputDirectory) { controllerConfigGroup.setCreateGraphs(true); controllerConfigGroup.setFirstIteration(0); controllerConfigGroup.setLastIteration(10); - PHbyModeCalculator phbyModeCalculator = new PHbyModeCalculator(controllerConfigGroup, controlerIO, new GlobalConfigGroup()); + PHbyModeCalculator phbyModeCalculator = new PHbyModeCalculator(controlerIO, new GlobalConfigGroup()); phbyModeCalculator.addIteration(1, map); - phbyModeCalculator.writeOutput(); + phbyModeCalculator.writeOutput(false); readAndValidateValues(1, map); // removing person 2 map.remove(person2); phbyModeCalculator.addIteration(2, map); - phbyModeCalculator.writeOutput(); + phbyModeCalculator.writeOutput(false); readAndValidateValues(2, map); // removing person 3 map.remove(person3); phbyModeCalculator.addIteration(3, map); - phbyModeCalculator.writeOutput(); + phbyModeCalculator.writeOutput(false); readAndValidateValues(3, map); // removing person 4 map.remove(person4); phbyModeCalculator.addIteration(4, map); - phbyModeCalculator.writeOutput(); + phbyModeCalculator.writeOutput(false); readAndValidateValues(4, map); } diff --git a/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java b/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java index ba62f04f994..810b9954e1d 100644 --- a/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java @@ -160,10 +160,10 @@ private void performTest(IdMap map, HashMap modeCa controllerConfigGroup.setCreateGraphs(true); controllerConfigGroup.setFirstIteration(0); controllerConfigGroup.setLastIteration(10); - PKMbyModeCalculator pkmbyModeCalculator = new PKMbyModeCalculator(controllerConfigGroup, controlerIO, new GlobalConfigGroup()); + PKMbyModeCalculator pkmbyModeCalculator = new PKMbyModeCalculator(controlerIO, new GlobalConfigGroup()); // iteration 0 pkmbyModeCalculator.addIteration(0, map); - pkmbyModeCalculator.writeOutput(); + pkmbyModeCalculator.writeOutput(false); Double totalCarDist = modeCalcDist.get("person1CarDist") + modeCalcDist.get("person2CarDist") + modeCalcDist.get("person3CarDist"); Double totalPtDist = modeCalcDist.get("person1PtDist") + modeCalcDist.get("person4PtDist"); @@ -176,7 +176,7 @@ private void performTest(IdMap map, HashMap modeCa map.remove(person2.getId()); // iteration 1 pkmbyModeCalculator.addIteration(1, map); - pkmbyModeCalculator.writeOutput(); + pkmbyModeCalculator.writeOutput(false); totalCarDist = modeCalcDist.get("person1CarDist") + modeCalcDist.get("person3CarDist"); totalPtDist = modeCalcDist.get("person1PtDist") + modeCalcDist.get("person4PtDist"); totalWalkDist = modeCalcDist.get("person1WalkDist") + modeCalcDist.get("person3WalkDist") + modeCalcDist.get("person4WalkDist"); @@ -187,7 +187,7 @@ private void performTest(IdMap map, HashMap modeCa map.remove(person3.getId()); // iteration 2 pkmbyModeCalculator.addIteration(2, map); - pkmbyModeCalculator.writeOutput(); + pkmbyModeCalculator.writeOutput(false); totalCarDist = modeCalcDist.get("person1CarDist"); totalPtDist = modeCalcDist.get("person1PtDist") + modeCalcDist.get("person4PtDist"); totalWalkDist = modeCalcDist.get("person1WalkDist") + modeCalcDist.get("person4WalkDist"); diff --git a/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java b/matsim/src/test/java/org/matsim/analysis/TripsAndLegsWriterTest.java similarity index 96% rename from matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java rename to matsim/src/test/java/org/matsim/analysis/TripsAndLegsWriterTest.java index 788452ea7bb..a2517b9f76d 100644 --- a/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TripsAndLegsWriterTest.java @@ -23,8 +23,8 @@ import org.junit.Assert; import org.junit.Rule; import org.junit.Test; -import org.matsim.analysis.TripsAndLegsCSVWriter.NoLegsWriterExtension; -import org.matsim.analysis.TripsAndLegsCSVWriter.NoTripWriterExtension; +import org.matsim.analysis.TripsAndLegsWriter.NoLegsWriterExtension; +import org.matsim.analysis.TripsAndLegsWriter.NoTripWriterExtension; import org.matsim.api.core.v01.*; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -60,7 +60,7 @@ * @author Aravind * */ -public class TripsAndLegsCSVWriterTest { +public class TripsAndLegsWriterTest { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); @@ -164,19 +164,19 @@ public void testTripsAndLegsCSVWriter() { } private void performTest(String tripsFilename, String legsFilename, IdMap map, AnalysisMainModeIdentifier mainModeIdentifier) { - TripsAndLegsCSVWriter.NoTripWriterExtension tripsWriterExtension = new NoTripWriterExtension(); - TripsAndLegsCSVWriter.NoLegsWriterExtension legWriterExtension = new NoLegsWriterExtension(); - TripsAndLegsCSVWriter.CustomTimeWriter timeWriter = new TripsAndLegsCSVWriter.DefaultTimeWriter(); - TripsAndLegsCSVWriter.CustomTripsWriterExtension customTripsWriterExtension = new CustomTripsWriterExtesion(); - TripsAndLegsCSVWriter.CustomLegsWriterExtension customLegsWriterExtension = new CustomLegsWriterExtesion(); - TripsAndLegsCSVWriter tripsAndLegsWriter = new TripsAndLegsCSVWriter(scenario, tripsWriterExtension, + TripsAndLegsWriter.NoTripWriterExtension tripsWriterExtension = new NoTripWriterExtension(); + TripsAndLegsWriter.NoLegsWriterExtension legWriterExtension = new NoLegsWriterExtension(); + TripsAndLegsWriter.CustomTimeWriter timeWriter = new TripsAndLegsWriter.DefaultTimeWriter(); + TripsAndLegsWriter.CustomTripsWriterExtension customTripsWriterExtension = new CustomTripsWriterExtesion(); + TripsAndLegsWriter.CustomLegsWriterExtension customLegsWriterExtension = new CustomLegsWriterExtesion(); + TripsAndLegsWriter tripsAndLegsWriter = new TripsAndLegsWriter(scenario, tripsWriterExtension, legWriterExtension, mainModeIdentifier, timeWriter); tripsAndLegsWriter.write(map, tripsFilename, legsFilename); readTripsFromPlansFile(map, mainModeIdentifier); readAndValidateTrips(persontrips, tripsFilename); readLegsFromPlansFile(map); readAndValidateLegs(legsfromplan, legsFilename); - TripsAndLegsCSVWriter tripsAndLegsWriterTest = new TripsAndLegsCSVWriter(scenario, customTripsWriterExtension, + TripsAndLegsWriter tripsAndLegsWriterTest = new TripsAndLegsWriter(scenario, customTripsWriterExtension, customLegsWriterExtension, mainModeIdentifier, timeWriter); tripsAndLegsWriterTest.write(map, tripsFilename, legsFilename); } @@ -671,7 +671,7 @@ private void createNetwork() { NetworkUtils.writeNetwork(network, utils.getOutputDirectory() + "/network.xml"); new MatsimNetworkReader(scenario.getNetwork()).readFile(utils.getOutputDirectory() + "/network.xml"); } - private static class CustomTripsWriterExtesion implements TripsAndLegsCSVWriter.CustomTripsWriterExtension{ + private static class CustomTripsWriterExtesion implements TripsAndLegsWriter.CustomTripsWriterExtension{ @Override public String[] getAdditionalTripHeader() { @@ -701,7 +701,7 @@ public List getAdditionalTripColumns(Trip trip) { } - static class CustomLegsWriterExtesion implements TripsAndLegsCSVWriter.CustomLegsWriterExtension { + static class CustomLegsWriterExtesion implements TripsAndLegsWriter.CustomLegsWriterExtension { @Override public String[] getAdditionalLegHeader() { String[] legHeader = new String[]{"isIntermodalWalkPt"}; From 025af2ab83be0e2144509843b16ba70976aaf877 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Fri, 1 Dec 2023 15:55:24 +0100 Subject: [PATCH 04/43] refactored TravelDistanceStats --- ...IterationTravelStatsControlerListener.java | 6 +- .../matsim/analysis/TravelDistanceStats.java | 243 ++++++++++-------- .../analysis/TravelDistanceStatsTest.java | 25 +- 3 files changed, 159 insertions(+), 115 deletions(-) diff --git a/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java b/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java index 4f1e3aeda1a..8055a2c04db 100644 --- a/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java +++ b/matsim/src/main/java/org/matsim/analysis/IterationTravelStatsControlerListener.java @@ -64,11 +64,6 @@ class IterationTravelStatsControlerListener implements IterationEndsListener, Sh @Override public void notifyIterationEnds(IterationEndsEvent event) { - - if (config.controller().getCreateGraphsInterval()>0 && event.getIteration() % config.controller().getCreateGraphsInterval() == 0) { - //do something - } - travelDistanceStats.addIteration(event.getIteration(), experiencedPlansService.getExperiencedPlans()); pHbyModeCalculator.addIteration(event.getIteration(), experiencedPlansService.getExperiencedPlans()); pkMbyModeCalculator.addIteration(event.getIteration(), experiencedPlansService.getExperiencedPlans()); @@ -76,6 +71,7 @@ public void notifyIterationEnds(IterationEndsEvent event) { boolean writeGraph = isWriteGraph(event); pHbyModeCalculator.writeOutput(writeGraph); pkMbyModeCalculator.writeOutput(writeGraph); + travelDistanceStats.writeOutput(event.getIteration(), writeGraph); if (isWriteTripsAndLegs(event)) { tripsAndLegsWriter.write(experiencedPlansService.getExperiencedPlans() diff --git a/matsim/src/main/java/org/matsim/analysis/TravelDistanceStats.java b/matsim/src/main/java/org/matsim/analysis/TravelDistanceStats.java index cc46e9434fd..9d0176c8adf 100644 --- a/matsim/src/main/java/org/matsim/analysis/TravelDistanceStats.java +++ b/matsim/src/main/java/org/matsim/analysis/TravelDistanceStats.java @@ -26,7 +26,6 @@ import org.matsim.api.core.v01.population.Leg; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; -import org.matsim.core.config.Config; import org.matsim.core.config.groups.ControllerConfigGroup; import org.matsim.core.config.groups.GlobalConfigGroup; import org.matsim.core.controler.OutputDirectoryHierarchy; @@ -39,8 +38,7 @@ import java.io.BufferedWriter; import java.io.IOException; import java.io.UncheckedIOException; -import java.util.DoubleSummaryStatistics; -import java.util.Locale; +import java.util.*; import java.util.stream.Collectors; /** @@ -59,14 +57,16 @@ public class TravelDistanceStats { + private static final int HISTORY_SIZE = 5000; + private final ControllerConfigGroup controllerConfigGroup; - private final BufferedWriter out; + private BufferedWriter out; private final String legStatsPngName; private final String tripStatsPngName; private final String delimiter; - private double[] legStatsHistory = null; - private double[] tripStatsHistory = null; + private DoubleSummaryStatistics[] legStats; + private DoubleSummaryStatistics[] tripStats; private final static Logger log = LogManager.getLogger(TravelDistanceStats.class); @@ -75,136 +75,175 @@ public class TravelDistanceStats { this(controllerConfigGroup, controlerIO.getOutputFilename("traveldistancestats"), controlerIO.getOutputFilename("traveldistancestats") + "legs", controlerIO.getOutputFilename("traveldistancestats") + "trips", - controllerConfigGroup.isCreateGraphs(), globalConfig.getDefaultDelimiter()); } - /** - * @param filename including the path, excluding the file type extension - * @param createPNG true if in every iteration, the distance statistics should be visualized in a graph and written to disk. - * @throws UncheckedIOException - */ - public TravelDistanceStats(final Config config, final String filename, final boolean createPNG, final String delimiter) throws UncheckedIOException { - this(config.controller(), filename, filename + "legs", filename + "trips", createPNG, delimiter); - } - - private TravelDistanceStats(ControllerConfigGroup controllerConfigGroup, String travelDistanceStatsFileName, - String legStatsPngName, String tripStatsPngName, boolean createPNG, String delimiter) { + private TravelDistanceStats(ControllerConfigGroup controllerConfigGroup, String travelDistanceStatsFileName, String legStatsPngName, + String tripStatsPngName, String delimiter) { this.controllerConfigGroup = controllerConfigGroup; this.legStatsPngName = legStatsPngName; this.tripStatsPngName = tripStatsPngName; this.delimiter = delimiter; - if (createPNG) { - int iterations = controllerConfigGroup.getLastIteration() - controllerConfigGroup.getFirstIteration(); - if (iterations > 5000) { - iterations = 5000; // limit the history size - } - this.legStatsHistory = new double[iterations+1]; - this.tripStatsHistory = new double[iterations+1]; - } + initStats(controllerConfigGroup); + initWriter(travelDistanceStatsFileName); + } + + private void initWriter(String travelDistanceStatsFileName) { if (travelDistanceStatsFileName.toLowerCase(Locale.ROOT).endsWith(".csv")) { this.out = IOUtils.getBufferedWriter(travelDistanceStatsFileName); } else { this.out = IOUtils.getBufferedWriter(travelDistanceStatsFileName + ".csv"); } + try { - this.out.write("ITERATION" + this.delimiter + "avg. Average Leg distance" + this.delimiter + "avg. Average Trip distance\n"); + writeCsvHeader(); } catch (IOException e) { throw new UncheckedIOException(e); } } + private void initStats(ControllerConfigGroup controllerConfigGroup) { + int iterations = controllerConfigGroup.getLastIteration() - controllerConfigGroup.getFirstIteration(); + if (iterations > HISTORY_SIZE) { + iterations = HISTORY_SIZE; // limit the history size + } + this.legStats = new DoubleSummaryStatistics[iterations+1]; + this.tripStats = new DoubleSummaryStatistics[iterations+1]; + } + public void addIteration(int iteration, IdMap map) { - DoubleSummaryStatistics legStats = map.values() - //TODO: This probably doesn't control how many threads parallelStream is using despite the number of threads setting in config - .parallelStream() - .flatMap(plan -> plan.getPlanElements().stream()) - .filter(Leg.class::isInstance) - .mapToDouble(l -> { - Leg leg = (Leg) l; - return leg.getRoute() != null ? leg.getRoute().getDistance() : Double.NaN; - }) - // the following means legs with infinite distance are ignored - .filter(Double::isFinite) - .summaryStatistics(); - - DoubleSummaryStatistics tripStats = map.values() - .parallelStream() - .flatMap(plan -> TripStructureUtils.getTrips(plan).stream()) - .mapToDouble(t -> { - Trip trip = (Trip) t; - return trip.getTripElements() - .stream() - .filter(Leg.class::isInstance) - .collect(Collectors.summingDouble(l -> { - Leg leg = (Leg) l; - // TODO NaN handling of Collectors.summingDouble will lead to many NaNs... rethink - return leg.getRoute() != null ? leg.getRoute().getDistance() : Double.NaN; - })); - }) - // the following means trips with infinite distance are silently ignored. - .filter(Double::isFinite) - .summaryStatistics(); - - log.info("-- average leg distance per plan (executed plans only): " + legStats.getAverage() + " meters"); + DoubleSummaryStatistics legStats = getLegStats(map); + DoubleSummaryStatistics tripStats = getTripStats(map); + + log.info("-- average leg distance per plan (executed plans only): " + legStats.getAverage() + " meters"); log.info("average leg distance per Person (executed plans only): " + legStats.getSum() / map.size() + " meters (statistic on all " + legStats.getCount() + " legs which have a finite distance)"); log.info("-- average trip distance per plan (executed plans only): " + tripStats.getAverage() + " meters"); log.info("average trip distance per Person (executed plans only): " + tripStats.getSum() / map.size() + " meters (statistic on all " + tripStats.getCount() + " trips which have a finite distance)"); log.info("(TravelDistanceStats takes an average over all legs where the simulation reports travelled (network) distances"); log.info("(and teleported legs whose route contains a distance.)");// TODO: still valid? + int index = getIndex(iteration); + if (index >= this.legStats.length){ + return; + } + this.legStats[index] = legStats; + this.tripStats[index] = tripStats; + } + + void writeOutput(int iteration, boolean writePngs){ + writeCsvEntry(iteration); + + if (iteration >= HISTORY_SIZE){ + return; + } + + if(writePngs){ + writePngs(iteration); + } + } + + private void writeCsvHeader() throws IOException { + this.out.write("ITERATION" + this.delimiter + "avg. Average Leg distance" + this.delimiter + "avg. Average Trip distance\n"); + this.out.flush(); + } + + private void writeCsvEntry(int iteration) { + DoubleSummaryStatistics legStats = this.legStats[getIndex(iteration)]; + DoubleSummaryStatistics tripStats = this.tripStats[getIndex(iteration)]; + try { this.out.write(iteration + this.delimiter + legStats.getAverage() + this.delimiter + tripStats.getAverage() + "\n"); this.out.flush(); } catch (IOException e) { e.printStackTrace(); } + } + + void writePngs(int iteration){ + writeLegStatsPng(iteration); + writeTripStatsPng(iteration); + } - if (this.legStatsHistory != null) { - int index = iteration - controllerConfigGroup.getFirstIteration(); - this.legStatsHistory[index] = legStats.getAverage(); - - if (iteration != controllerConfigGroup.getFirstIteration()) { - // create chart when data of more than one iteration is available. - XYLineChart chart = new XYLineChart("Leg Travel Distance Statistics", "iteration", "average of the average leg distance per plan "); - double[] iterations = new double[index + 1]; - for (int i = 0; i <= index; i++) { - iterations[i] = i + controllerConfigGroup.getFirstIteration(); - } - double[] values = new double[index + 1]; - System.arraycopy(this.legStatsHistory, 0, values, 0, index + 1); - chart.addSeries("executed plan", iterations, values); - chart.addMatsimLogo(); - chart.saveAsPng(this.legStatsPngName + ".png", 800, 600); - } - if (index == (this.legStatsHistory.length - 1)) { - // we cannot store more information, so disable the graph feature. - this.legStatsHistory = null; - } + private void writeTripStatsPng(int iteration) { + if (iteration == controllerConfigGroup.getFirstIteration()){ + return; } - if (this.tripStatsHistory != null) { - int index = iteration - controllerConfigGroup.getFirstIteration(); - this.tripStatsHistory[index] = tripStats.getAverage(); - - if (iteration != controllerConfigGroup.getFirstIteration()) { - // create chart when data of more than one iteration is available. - XYLineChart chart = new XYLineChart("Trip Travel Distance Statistics", "iteration", "average of the average trip distance per plan "); - double[] iterations = new double[index + 1]; - for (int i = 0; i <= index; i++) { - iterations[i] = i + controllerConfigGroup.getFirstIteration(); - } - double[] values = new double[index + 1]; - System.arraycopy(this.tripStatsHistory, 0, values, 0, index + 1); - chart.addSeries("executed plan", iterations, values); - chart.addMatsimLogo(); - chart.saveAsPng(this.tripStatsPngName + ".png", 800, 600); - } - if (index == (this.tripStatsHistory.length - 1)) { - // we cannot store more information, so disable the graph feature. - this.tripStatsHistory = null; - } + int index = getIndex(iteration); + // create chart when data of more than one iteration is available. + XYLineChart chart = new XYLineChart("Trip Travel Distance Statistics", "iteration", "average of the average trip distance per plan "); + double[] iterations = new double[index + 1]; + double[] values = new double[index + 1]; + + for (int i = 0; i <= index; i++) { + iterations[i] = i + controllerConfigGroup.getFirstIteration(); + values[i] = Optional.ofNullable(this.tripStats[i]).map(DoubleSummaryStatistics::getAverage).orElse(0.); } + + chart.addSeries("executed plan", iterations, values); + chart.addMatsimLogo(); + chart.saveAsPng(this.tripStatsPngName + ".png", 800, 600); + } + + private void writeLegStatsPng(int iteration) { + if (iteration == controllerConfigGroup.getFirstIteration()){ + return; + } + + int index = getIndex(iteration); + // create chart when data of more than one iteration is available. + XYLineChart chart = new XYLineChart("Leg Travel Distance Statistics", "iteration", "average of the average leg distance per plan "); + double[] iterations = new double[index + 1]; + double[] values = new double[index + 1]; + + for (int i = 0; i <= index; i++) { + iterations[i] = i + controllerConfigGroup.getFirstIteration(); + values[i] = Optional.ofNullable(this.legStats[i]).map(DoubleSummaryStatistics::getAverage).orElse(0.); + + } + + chart.addSeries("executed plan", iterations, values); + chart.addMatsimLogo(); + chart.saveAsPng(this.legStatsPngName + ".png", 800, 600); + } + + private static DoubleSummaryStatistics getTripStats(IdMap map) { + return map.values() + .parallelStream() + .flatMap(plan -> TripStructureUtils.getTrips(plan).stream()) + .mapToDouble(t -> { + Trip trip = (Trip) t; + return trip.getTripElements() + .stream() + .filter(Leg.class::isInstance) + .collect(Collectors.summingDouble(l -> { + Leg leg = (Leg) l; + // TODO NaN handling of Collectors.summingDouble will lead to many NaNs... rethink + return leg.getRoute() != null ? leg.getRoute().getDistance() : Double.NaN; + })); + }) + // the following means trips with infinite distance are silently ignored. + .filter(Double::isFinite) + .summaryStatistics(); + } + + private static DoubleSummaryStatistics getLegStats(IdMap map) { + return map.values() + //TODO: This probably doesn't control how many threads parallelStream is using despite the number of threads setting in config + .parallelStream() + .flatMap(plan -> plan.getPlanElements().stream()) + .filter(Leg.class::isInstance) + .mapToDouble(l -> { + Leg leg = (Leg) l; + return leg.getRoute() != null ? leg.getRoute().getDistance() : Double.NaN; + }) + // the following means legs with infinite distance are ignored + .filter(Double::isFinite) + .summaryStatistics(); + } + + private int getIndex(int iteration) { + return iteration - controllerConfigGroup.getFirstIteration(); } public void close() { @@ -215,6 +254,4 @@ public void close() { } } - - } diff --git a/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java b/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java index e1e0a8fb0d2..4d471767085 100644 --- a/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java @@ -337,25 +337,35 @@ public void testTravelDistanceStats() { private void performTest(IdMap map, String outputDirectory) { - ControllerConfigGroup controllerConfigGroup = new ControllerConfigGroup(); - OutputDirectoryHierarchy controlerIO = new OutputDirectoryHierarchy(outputDirectory, - OverwriteFileSetting.overwriteExistingFiles, CompressionType.gzip); - controllerConfigGroup.setCreateGraphs(true); - controllerConfigGroup.setFirstIteration(0); - controllerConfigGroup.setLastIteration(10); - TravelDistanceStats travelDistanceStats = new TravelDistanceStats(controllerConfigGroup, controlerIO, new GlobalConfigGroup()); + TravelDistanceStats travelDistanceStats = getTravelDistanceStats(outputDirectory); + travelDistanceStats.addIteration(0, map); + travelDistanceStats.writeOutput(0, false); readAndValidateValues(0, person1legsum + person2legsum + person3legsum, 12, person1TotalNumberOfLegs + person2TotalNumberOfLegs + person3TotalNumberOfLegs); + map.remove(person2.getId()); travelDistanceStats.addIteration(1, map); + travelDistanceStats.writeOutput(1, false); readAndValidateValues(1, person1legsum + person3legsum, 8, person1TotalNumberOfLegs + person3TotalNumberOfLegs); + map.remove(person3.getId()); travelDistanceStats.addIteration(2, map); + travelDistanceStats.writeOutput(2, false); readAndValidateValues(2, person1legsum, 6, person1TotalNumberOfLegs); travelDistanceStats.close(); } + private static TravelDistanceStats getTravelDistanceStats(String outputDirectory) { + ControllerConfigGroup controllerConfigGroup = new ControllerConfigGroup(); + OutputDirectoryHierarchy controlerIO = new OutputDirectoryHierarchy(outputDirectory, + OverwriteFileSetting.overwriteExistingFiles, CompressionType.gzip); + controllerConfigGroup.setCreateGraphs(true); + controllerConfigGroup.setFirstIteration(0); + controllerConfigGroup.setLastIteration(10); + return new TravelDistanceStats(controllerConfigGroup, controlerIO, new GlobalConfigGroup()); + } + private void readAndValidateValues(int itr, Double legSum, int totalTrip, long totalLeg) { String file = utils.getOutputDirectory() + "/TravelDistanceStat" + "/traveldistancestats.csv"; @@ -385,6 +395,7 @@ private void readAndValidateValues(int itr, Double legSum, int totalTrip, long t } iteration++; } + Assert.assertEquals("There are too less entries.", itr, iteration); } catch (IOException e) { e.printStackTrace(); } From 6fe7a3cf81023adf4b7ee4ba6a2a53a6ca80b781 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Fri, 1 Dec 2023 17:34:10 +0100 Subject: [PATCH 05/43] removed every core dependency of isCreateGraph --- .../common/timeprofile/ProfileWriter.java | 5 +- .../matsim/analysis/LegHistogramListener.java | 3 +- .../analysis/ModeStatsControlerListener.java | 111 ++++++++---------- .../analysis/ScoreStatsControlerListener.java | 36 +++--- .../core/controler/AbstractController.java | 2 +- .../DependencyGraphControlerListener.java | 52 ++++---- .../ModeStatsControlerListenerTest.java | 1 + .../ScoreStatsControlerListenerTest.java | 3 + 8 files changed, 104 insertions(+), 109 deletions(-) diff --git a/contribs/common/src/main/java/org/matsim/contrib/common/timeprofile/ProfileWriter.java b/contribs/common/src/main/java/org/matsim/contrib/common/timeprofile/ProfileWriter.java index 768ec3ea404..e98f9cbb2b4 100644 --- a/contribs/common/src/main/java/org/matsim/contrib/common/timeprofile/ProfileWriter.java +++ b/contribs/common/src/main/java/org/matsim/contrib/common/timeprofile/ProfileWriter.java @@ -87,7 +87,8 @@ public void notifyIterationEnds(IterationEndsEvent event) { } } - if (this.matsimServices.getConfig().controller().isCreateGraphs()) { + int createGraphsInterval = this.matsimServices.getConfig().controller().getCreateGraphsInterval(); + if (createGraphsInterval > 0 && event.getIteration() % createGraphsInterval == 0) { DefaultTableXYDataset xyDataset = createXYDataset(times, profiles); generateImage(xyDataset, TimeProfileCharts.ChartType.Line); generateImage(xyDataset, TimeProfileCharts.ChartType.StackedArea); @@ -103,7 +104,7 @@ private DefaultTableXYDataset createXYDataset(double[] times, Map { XYSeries series = new XYSeries(name, true, false); for (int i = 0; i < times.length; i++) { - series.add((double)times[i] / 3600, profile[i]); + series.add((double) times[i] / 3600, profile[i]); } seriesList.add(series); }); diff --git a/matsim/src/main/java/org/matsim/analysis/LegHistogramListener.java b/matsim/src/main/java/org/matsim/analysis/LegHistogramListener.java index e5c1a9b8e2d..9393b17c2e7 100644 --- a/matsim/src/main/java/org/matsim/analysis/LegHistogramListener.java +++ b/matsim/src/main/java/org/matsim/analysis/LegHistogramListener.java @@ -55,7 +55,8 @@ public void notifyIterationStarts(final IterationStartsEvent event) { public void notifyIterationEnds(final IterationEndsEvent event) { this.histogram.write(controlerIO.getIterationFilename(event.getIteration(), "legHistogram.txt")); this.printStats(); - if (controllerConfigGroup.isCreateGraphs()) { + int createGraphsInterval = event.getServices().getConfig().controller().getCreateGraphsInterval(); + if (createGraphsInterval > 0 && event.getIteration() % createGraphsInterval == 0) { LegHistogramChart.writeGraphic(this.histogram, controlerIO.getIterationFilename(event.getIteration(), "legHistogram_all.png")); for (String legMode : this.histogram.getLegModes()) { LegHistogramChart.writeGraphic(this.histogram, controlerIO.getIterationFilename(event.getIteration(), "legHistogram_" + legMode + ".png"), legMode); diff --git a/matsim/src/main/java/org/matsim/analysis/ModeStatsControlerListener.java b/matsim/src/main/java/org/matsim/analysis/ModeStatsControlerListener.java index c9f4ff89ce0..dc351742a11 100644 --- a/matsim/src/main/java/org/matsim/analysis/ModeStatsControlerListener.java +++ b/matsim/src/main/java/org/matsim/analysis/ModeStatsControlerListener.java @@ -73,7 +73,6 @@ public final class ModeStatsControlerListener implements StartupListener, Iterat private final String modeFileName; private final String delimiter; - private final boolean createPNG; private final ControllerConfigGroup controllerConfigGroup; Map> modeHistories = new HashMap<>(); @@ -94,7 +93,6 @@ public final class ModeStatsControlerListener implements StartupListener, Iterat this.population = population1; this.modeFileName = controlerIO.getOutputFilename(FILENAME_MODESTATS); this.delimiter = globalConfigGroup.getDefaultDelimiter(); - this.createPNG = controllerConfigGroup.isCreateGraphs(); this.mainModeIdentifier = mainModeIdentifier; } @@ -105,7 +103,8 @@ public void notifyStartup(final StartupEvent event) { @Override public void notifyIterationEnds(final IterationEndsEvent event) { - collectModeShareInfo(event) ; + collectModeShareInfo(event); + writeOutput(event); } private void collectModeShareInfo(final IterationEndsEvent event) { @@ -156,7 +155,53 @@ private void collectModeShareInfo(final IterationEndsEvent event) { } modeHistory.put( event.getIteration(), share ) ; } + modeCnt.clear(); + } + + void writeOutput(IterationEndsEvent event) { + writeCsv(event); + + if (isWriteGraphs(event)) { + writePngs(); + } + } + + private boolean isWriteGraphs(IterationEndsEvent event) { + return this.controllerConfigGroup.getCreateGraphsInterval() > 0 && + event.getIteration() % this.controllerConfigGroup.getCreateGraphsInterval() == 0 && + event.getIteration() > this.minIteration; + } + private void writePngs() { + // create chart when data of more than one iteration is available. + XYLineChart chart = new XYLineChart("Mode Statistics", "iteration", "mode"); + for ( Entry> entry : this.modeHistories.entrySet() ) { + String mode = entry.getKey() ; + Map history = entry.getValue() ; + chart.addSeries(mode, history ) ; + } + chart.addMatsimLogo(); + chart.saveAsPng(this.modeFileName + ".png", 800, 600); + + /////// EDIT: STACKED_BAR /////////////////////////////////////////////////////// + // create chart when data of more than one iteration is available. + StackedBarChart chart2 = new StackedBarChart("Mode Statistics", "iteration", "share"); + for (Entry> entry : this.modeHistories.entrySet()) { + String mode = entry.getKey(); + Map history = entry.getValue(); + double[] historyArray = new double[history.size()]; + int i = 0; + for ( Entry entryHistory : history.entrySet() ) { + historyArray[i] = entryHistory.getValue(); + i++; + } + chart2.addSeries(mode, historyArray); + } + chart2.addMatsimLogo(); + chart2.saveAsPng(this.modeFileName + "_stackedbar.png", 800, 600); + } + + private void writeCsv(IterationEndsEvent event) { try (BufferedWriter modeOut = IOUtils.getBufferedWriter(this.modeFileName + ".csv")) { modeOut.write("iteration"); for ( String mode : modes ) { @@ -176,65 +221,5 @@ private void collectModeShareInfo(final IterationEndsEvent event) { e.printStackTrace(); throw new UncheckedIOException(e); } - - - // yyyy the following does not work!! - // Why? The charts seem to be useful (JB, April 2017) - if (this.createPNG && event.getIteration() > this.minIteration) { - // create chart when data of more than one iteration is available. - XYLineChart chart = new XYLineChart("Mode Statistics", "iteration", "mode"); - for ( Entry> entry : this.modeHistories.entrySet() ) { - String mode = entry.getKey() ; - Map history = entry.getValue() ; -// log.warn( "about to add the following series:" ) ; -// for ( Entry item : history.entrySet() ) { -// log.warn( item.getKey() + " -- " + item.getValue() ); -// } - chart.addSeries(mode, history ) ; - } - chart.addMatsimLogo(); - chart.saveAsPng(this.modeFileName + ".png", 800, 600); - - /////// EDIT: STACKED_BAR /////////////////////////////////////////////////////// - if (event.getIteration() > this.minIteration) { - // create chart when data of more than one iteration is available. - StackedBarChart chart2 = new StackedBarChart("Mode Statistics", "iteration", "share"); - for (Entry> entry : this.modeHistories.entrySet()) { - String mode = entry.getKey(); - Map history = entry.getValue(); - double[] historyArray = new double[history.size()]; - int i = 0; - for ( Entry entryHistory : history.entrySet() ) { - historyArray[i] = entryHistory.getValue(); - i++; - } - chart2.addSeries(mode, historyArray); - } - chart2.addMatsimLogo(); - chart2.saveAsPng(this.modeFileName + "_stackedbar.png", 800, 600); - } - } - modeCnt.clear(); - } - - public final Map> getModeHistories() { - return Collections.unmodifiableMap( this.modeHistories ) ; - } - - ////////////copied methods - to not depend on dvrp /////////////////////////////////////////////////////// - private void makeStayTaskSeriesGrey(XYPlot plot) { - XYDataset dataset = plot.getDataset(0); - for (int i = 0; i < dataset.getSeriesCount(); i++) { - plot.getRenderer().setSeriesPaint(i, Color.LIGHT_GRAY); - return; - } - } - private static void saveAsPNG(JFreeChart chart, String filename, int width, int height) { - try { - ChartUtils.writeChartAsPNG(new FileOutputStream(filename + ".png"), chart, width, height); - } catch (IOException e) { - throw new RuntimeException(e); - } } - ////////////////////////////////////////////////////////////////////////////////////////////////////////// } diff --git a/matsim/src/main/java/org/matsim/analysis/ScoreStatsControlerListener.java b/matsim/src/main/java/org/matsim/analysis/ScoreStatsControlerListener.java index 1593cec5243..8e82756527c 100644 --- a/matsim/src/main/java/org/matsim/analysis/ScoreStatsControlerListener.java +++ b/matsim/src/main/java/org/matsim/analysis/ScoreStatsControlerListener.java @@ -69,7 +69,6 @@ public enum ScoreItem { worst, best, average, executed }; private final String delimiter; private final BufferedWriter out; - private final boolean createPNG; private final ControllerConfigGroup controllerConfigGroup; private final Map> scoreHistory = new HashMap<>(); @@ -87,7 +86,6 @@ public enum ScoreItem { worst, best, average, executed }; this.population = population; this.controllerIO = controllerIO; this.delimiter = globalConfig.getDefaultDelimiter(); - this.createPNG = controllerConfigGroup.isCreateGraphs(); this.out = IOUtils.getBufferedWriter(controllerIO.getOutputFilename("scorestats.csv")); Set subpopulations = population.getPersons().values().stream() @@ -127,10 +125,19 @@ public void notifyStartup(final StartupEvent event) { @Override public void notifyIterationEnds(final IterationEndsEvent event) { collectScoreInfo(event); + if (isWriteGraph(event)) { + writePng(); + } } - private void collectScoreInfo(final IterationEndsEvent event) { + private boolean isWriteGraph(IterationEndsEvent event) { + // create chart when data of more than one iteration is available. + return this.controllerConfigGroup.getCreateGraphsInterval() > 0 && + event.getIteration() % this.controllerConfigGroup.getCreateGraphsInterval() == 0 && + event.getIteration() > this.minIteration; + } + private void collectScoreInfo(final IterationEndsEvent event) { ScoreInfo info = new ScoreInfo(); Map perSubpop = new HashMap<>(); @@ -165,21 +172,16 @@ private void collectScoreInfo(final IterationEndsEvent event) { this.scoreHistory.get( ScoreItem.best ).put( event.getIteration(), info.sumScoreBest / info.nofScoreBest ) ; this.scoreHistory.get( ScoreItem.average ).put( event.getIteration(), info.sumAvgScores / info.nofAvgScores ) ; this.scoreHistory.get( ScoreItem.executed ).put( event.getIteration(), info.sumExecutedScores / info.nofExecutedScores ) ; + } - if (this.createPNG && event.getIteration() > this.minIteration) { - // create chart when data of more than one iteration is available. - XYLineChart chart = new XYLineChart("Score Statistics", "iteration", "score"); -// double[] iterations = new double[index + 1]; -// for (int i = 0; i <= index; i++) { -// iterations[i] = i + this.minIteration; -// } - chart.addSeries("avg. worst score", this.scoreHistory.get( ScoreItem.worst ) ) ; - chart.addSeries("avg. best score", this.scoreHistory.get( ScoreItem.best) ); - chart.addSeries("avg. of plans' average score", this.scoreHistory.get( ScoreItem.average) ); - chart.addSeries("avg. executed score", this.scoreHistory.get( ScoreItem.executed ) ); - chart.addMatsimLogo(); - chart.saveAsPng(this.controllerIO.getOutputFilename("scorestats.png"), 800, 600); - } + private void writePng() { + XYLineChart chart = new XYLineChart("Score Statistics", "iteration", "score"); + chart.addSeries("avg. worst score", this.scoreHistory.get( ScoreItem.worst ) ) ; + chart.addSeries("avg. best score", this.scoreHistory.get( ScoreItem.best) ); + chart.addSeries("avg. of plans' average score", this.scoreHistory.get( ScoreItem.average) ); + chart.addSeries("avg. executed score", this.scoreHistory.get( ScoreItem.executed ) ); + chart.addMatsimLogo(); + chart.saveAsPng(this.controllerIO.getOutputFilename("scorestats.png"), 800, 600); } @Override diff --git a/matsim/src/main/java/org/matsim/core/controler/AbstractController.java b/matsim/src/main/java/org/matsim/core/controler/AbstractController.java index 5edf2d01b20..93c1680a231 100644 --- a/matsim/src/main/java/org/matsim/core/controler/AbstractController.java +++ b/matsim/src/main/java/org/matsim/core/controler/AbstractController.java @@ -178,7 +178,7 @@ public void run() { } catch (UncheckedIOException e) { log.error("Could not write stopwatch file.", e); } - if (config.controller().isCreateGraphs()) { + if (config.controller().getCreateGraphsInterval() > 0 && iteration % config.controller().getCreateGraphsInterval() == 0) { this.getStopwatch().writeGraphFile(this.getControlerIO().getOutputFilename("stopwatch.png", ControllerConfigGroup.CompressionType.none)); } log.info(MARKER + "ITERATION " + iteration + " ENDS"); diff --git a/matsim/src/main/java/org/matsim/guice/DependencyGraphControlerListener.java b/matsim/src/main/java/org/matsim/guice/DependencyGraphControlerListener.java index 37492d3f785..9c108996bca 100644 --- a/matsim/src/main/java/org/matsim/guice/DependencyGraphControlerListener.java +++ b/matsim/src/main/java/org/matsim/guice/DependencyGraphControlerListener.java @@ -68,33 +68,35 @@ class DependencyGraphControlerListener implements StartupListener { } public void notifyStartup(StartupEvent event) { - if (event.getServices().getConfig().controller().isCreateGraphs()) { - try (PrintWriter out = new PrintWriter(new File(controlerIO.getOutputFilename("modules.dot")))) { - MatsimGrapher grapher = new MatsimGrapher(new AbstractInjectorGrapher.GrapherParameters() - .setAliasCreator(bindings -> { - List allAliases = Lists.newArrayList(); - for (Binding binding : bindings) { - if (binding instanceof ProviderBinding) { - allAliases.add(new Alias(NodeId.newTypeId(binding.getKey()), - NodeId.newTypeId(((ProviderBinding) binding).getProvidedKey()))); - } + if (event.getServices().getConfig().controller().getCreateGraphsInterval() <= 0) { + return; + } + + try (PrintWriter out = new PrintWriter(new File(controlerIO.getOutputFilename("modules.dot")))) { + MatsimGrapher grapher = new MatsimGrapher(new AbstractInjectorGrapher.GrapherParameters() + .setAliasCreator(bindings -> { + List allAliases = Lists.newArrayList(); + for (Binding binding : bindings) { + if (binding instanceof ProviderBinding) { + allAliases.add(new Alias(NodeId.newTypeId(binding.getKey()), + NodeId.newTypeId(((ProviderBinding) binding).getProvidedKey()))); } - allAliases.addAll(getMapBinderAliases(String.class, TravelTime.class, bindings)); - allAliases.addAll(getMapBinderAliases(String.class, TravelDisutilityFactory.class, bindings)); - allAliases.addAll(getMapBinderAliases(String.class, RoutingModule.class, bindings)); - allAliases.addAll(getMapBinderAliases(ReplanningConfigGroup.StrategySettings.class, PlanStrategy.class, bindings)); - allAliases.addAll(getMultibinderAliases(ControlerListener.class, bindings)); - allAliases.addAll(getMultibinderAliases(SnapshotWriter.class, bindings)); - allAliases.addAll(getMultibinderAliases(MobsimListener.class, bindings)); - allAliases.addAll(getMultibinderAliases(EventHandler.class, bindings)); - allAliases.addAll(getMultibinderAliases(AbstractQSimModule.class, bindings)); - return allAliases; } - ), out); - grapher.graph(injector); - } catch (IOException e) { - throw new RuntimeException(e); - } + allAliases.addAll(getMapBinderAliases(String.class, TravelTime.class, bindings)); + allAliases.addAll(getMapBinderAliases(String.class, TravelDisutilityFactory.class, bindings)); + allAliases.addAll(getMapBinderAliases(String.class, RoutingModule.class, bindings)); + allAliases.addAll(getMapBinderAliases(ReplanningConfigGroup.StrategySettings.class, PlanStrategy.class, bindings)); + allAliases.addAll(getMultibinderAliases(ControlerListener.class, bindings)); + allAliases.addAll(getMultibinderAliases(SnapshotWriter.class, bindings)); + allAliases.addAll(getMultibinderAliases(MobsimListener.class, bindings)); + allAliases.addAll(getMultibinderAliases(EventHandler.class, bindings)); + allAliases.addAll(getMultibinderAliases(AbstractQSimModule.class, bindings)); + return allAliases; + } + ), out); + grapher.graph(injector); + } catch (IOException e) { + throw new RuntimeException(e); } } diff --git a/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java index daf5a8cd90d..6ccaba6938c 100644 --- a/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java @@ -460,6 +460,7 @@ private void readAndcompareValues(HashMap modes, int itr) { } iteration++; } + Assert.assertEquals(itr, iteration); } catch (IOException e) { e.printStackTrace(); } diff --git a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java index 33345fdfb2b..dc94a183ea7 100644 --- a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java @@ -551,10 +551,13 @@ private void readAndValidateValues(String outDir, int itr, Population populatio 0); Assert.assertEquals("avg average score does not match", (getScore(population, "avgaverage")/getNoOfPlans(population)), avgAverage, 0); + break; } iteration++; } + Assert.assertEquals(itr, iteration); + Assertions.assertThat(new File(outDir, "scorestats_group1.csv")) .isFile(); From 57cc8ece08d6d8f6d159a3b83d7bf1b3dee6cdcd Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Fri, 1 Dec 2023 17:47:18 +0100 Subject: [PATCH 06/43] removed all dependencies of isCreateGraph --- .../contrib/common/timeprofile/TimeProfileCollector.java | 9 +++++++-- .../shifts/analysis/ShiftAnalysisControlerListener.java | 5 +++-- .../shifts/analysis/ShiftHistogramListener.java | 4 +++- .../ShiftEfficiencyAnalysisControlerListener.java | 5 +++-- .../drt/analysis/DrtAnalysisControlerListener.java | 3 ++- .../ChargerOccupancyTimeProfileCollectorProvider.java | 2 +- .../usage/analysis/CourtesyHistogramListener.java | 9 +++++---- .../matsim/core/config/groups/ControllerConfigGroup.java | 5 ----- 8 files changed, 24 insertions(+), 18 deletions(-) diff --git a/contribs/common/src/main/java/org/matsim/contrib/common/timeprofile/TimeProfileCollector.java b/contribs/common/src/main/java/org/matsim/contrib/common/timeprofile/TimeProfileCollector.java index e44bebb84d7..ce926be9116 100644 --- a/contribs/common/src/main/java/org/matsim/contrib/common/timeprofile/TimeProfileCollector.java +++ b/contribs/common/src/main/java/org/matsim/contrib/common/timeprofile/TimeProfileCollector.java @@ -99,8 +99,13 @@ public void notifyMobsimBeforeCleanup(@SuppressWarnings("rawtypes") MobsimBefore } } - for (ChartType t : chartTypes) { - generateImage(header, t); + int createGraphsInterval = matsimServices.getConfig().controller().getCreateGraphsInterval(); + boolean createGraphs = createGraphsInterval >0 && matsimServices.getIterationNumber() % createGraphsInterval == 0; + + if(createGraphs){ + for (ChartType t : chartTypes) { + generateImage(header, t); + } } } diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/ShiftAnalysisControlerListener.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/ShiftAnalysisControlerListener.java index de7026de9e2..60c9c9e1cb0 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/ShiftAnalysisControlerListener.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/ShiftAnalysisControlerListener.java @@ -52,9 +52,10 @@ public ShiftAnalysisControlerListener(Config config, DrtConfigGroup drtConfigGro @Override public void notifyIterationEnds(IterationEndsEvent event) { - boolean createGraphs = event.getServices().getConfig().controller().isCreateGraphs(); + int createGraphsInterval = event.getServices().getConfig().controller().getCreateGraphsInterval(); + boolean createGraphs = createGraphsInterval >0 && event.getIteration() % createGraphsInterval == 0; - writeAndPlotShiftDurationComparison(shiftDurationXY.getShift2plannedVsActualDuration(), + writeAndPlotShiftDurationComparison(shiftDurationXY.getShift2plannedVsActualDuration(), filename(event, "shiftDurationComparison", ".png"), filename(event, "shiftDurationComparison", ".csv"), createGraphs); diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/ShiftHistogramListener.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/ShiftHistogramListener.java index 15aef81a055..aceaa023f7d 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/ShiftHistogramListener.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/ShiftHistogramListener.java @@ -35,7 +35,9 @@ public void notifyIterationStarts(final IterationStartsEvent event) { public void notifyIterationEnds(final IterationEndsEvent event) { this.shiftHistogram.write(matsimServices.getControlerIO().getIterationFilename(event.getIteration(), drtConfigGroup.getMode() + "_" + "shiftHistogram.txt")); this.printStats(); - boolean createGraphs = event.getServices().getConfig().controller().isCreateGraphs(); + int createGraphsInterval = event.getServices().getConfig().controller().getCreateGraphsInterval(); + boolean createGraphs = createGraphsInterval >0 && event.getIteration() % createGraphsInterval == 0; + if (createGraphs) { ShiftHistogramChart.writeGraphic(this.shiftHistogram, matsimServices.getControlerIO().getIterationFilename(event.getIteration(),drtConfigGroup.getMode() + "_" + "shiftHistogram.png")); } diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyAnalysisControlerListener.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyAnalysisControlerListener.java index f75637f76d7..57e451f31b0 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyAnalysisControlerListener.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyAnalysisControlerListener.java @@ -56,9 +56,10 @@ public ShiftEfficiencyAnalysisControlerListener(DrtConfigGroup drtConfigGroup, @Override public void notifyIterationEnds(IterationEndsEvent event) { - boolean createGraphs = event.getServices().getConfig().controller().isCreateGraphs(); + int createGraphsInterval = event.getServices().getConfig().controller().getCreateGraphsInterval(); + boolean createGraphs = createGraphsInterval >0 && event.getIteration() % createGraphsInterval == 0; - writeAndPlotShiftEfficiency( + writeAndPlotShiftEfficiency( shiftEfficiencyTracker.getCurrentRecord().getRevenueByShift(), shiftEfficiencyTracker.getCurrentRecord().getRequestsByShift(), shiftEfficiencyTracker.getCurrentRecord().getFinishedShifts(), diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtAnalysisControlerListener.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtAnalysisControlerListener.java index 1f33b8cf008..399804f9aee 100644 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtAnalysisControlerListener.java +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtAnalysisControlerListener.java @@ -160,7 +160,8 @@ private static List newDrtLegs(EventSequence sequence, Function @Override public void notifyIterationEnds(IterationEndsEvent event) { - boolean createGraphs = event.getServices().getConfig().controller().isCreateGraphs(); + int createGraphsInterval = event.getServices().getConfig().controller().getCreateGraphsInterval(); + boolean createGraphs = createGraphsInterval >0 && event.getIteration() % createGraphsInterval == 0; writeAndPlotWaitTimeEstimateComparison(drtEventSequenceCollector.getPerformedRequestSequences().values(), filename(event, "waitTimeComparison", ".png"), filename(event, "waitTimeComparison", ".csv"), createGraphs); diff --git a/contribs/ev/src/main/java/org/matsim/contrib/ev/stats/ChargerOccupancyTimeProfileCollectorProvider.java b/contribs/ev/src/main/java/org/matsim/contrib/ev/stats/ChargerOccupancyTimeProfileCollectorProvider.java index a11883f50f2..4827a4c351d 100644 --- a/contribs/ev/src/main/java/org/matsim/contrib/ev/stats/ChargerOccupancyTimeProfileCollectorProvider.java +++ b/contribs/ev/src/main/java/org/matsim/contrib/ev/stats/ChargerOccupancyTimeProfileCollectorProvider.java @@ -67,7 +67,7 @@ public MobsimListener get() { }; var collector = new TimeProfileCollector(header, calc, 300, "charger_occupancy_time_profiles", matsimServices); - if (matsimServices.getConfig().controller().isCreateGraphs()) { + if (matsimServices.getConfig().controller().getCreateGraphsInterval()>0) { collector.setChartTypes(ChartType.Line, ChartType.StackedArea); } else { collector.setChartTypes(); diff --git a/contribs/socnetsim/src/main/java/org/matsim/contrib/socnetsim/usage/analysis/CourtesyHistogramListener.java b/contribs/socnetsim/src/main/java/org/matsim/contrib/socnetsim/usage/analysis/CourtesyHistogramListener.java index c659828ea59..4edd091b5d5 100644 --- a/contribs/socnetsim/src/main/java/org/matsim/contrib/socnetsim/usage/analysis/CourtesyHistogramListener.java +++ b/contribs/socnetsim/src/main/java/org/matsim/contrib/socnetsim/usage/analysis/CourtesyHistogramListener.java @@ -50,16 +50,14 @@ public class CourtesyHistogramListener implements IterationEndsListener, IterationStartsListener { private final CourtesyHistogram histogram; - private final boolean outputGraph; private static final Logger log = LogManager.getLogger(CourtesyHistogramListener.class); private final OutputDirectoryHierarchy controlerIO; @Inject - CourtesyHistogramListener(Config config, CourtesyHistogram histogram, OutputDirectoryHierarchy controlerIO) { + CourtesyHistogramListener(CourtesyHistogram histogram, OutputDirectoryHierarchy controlerIO) { this.controlerIO = controlerIO; this.histogram = histogram; - this.outputGraph = config.controller().isCreateGraphs(); } @Override @@ -70,7 +68,10 @@ public void notifyIterationStarts(final IterationStartsEvent event) { @Override public void notifyIterationEnds(final IterationEndsEvent event) { this.histogram.write(controlerIO.getIterationFilename(event.getIteration(), "courtesyHistogram.txt")); - if (this.outputGraph) { + + int createGraphsInterval = event.getServices().getConfig().controller().getCreateGraphsInterval(); + boolean createGraphs = createGraphsInterval >0 && event.getIteration() % createGraphsInterval == 0; + if (createGraphs) { for ( String type : histogram.getDataFrames().keySet() ) { writeGraphic( this.histogram, diff --git a/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java b/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java index d68aa5bf6e6..aff78717f7f 100644 --- a/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java +++ b/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java @@ -355,11 +355,6 @@ public void setWriteSnapshotsInterval(int writeSnapshotsInterval) { this.writeSnapshotsInterval = writeSnapshotsInterval; } - @StringGetter( CREATE_GRAPHS ) - public boolean isCreateGraphs() { - return createGraphs; - } - /** * Sets whether graphs showing some analyses should automatically be * generated during the simulation. The generation of graphs usually takes a From 196f70e88743bed593d01d5837b92a5a8c439a88 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Fri, 1 Dec 2023 18:30:54 +0100 Subject: [PATCH 07/43] adapted controller config group --- .../config/groups/ControllerConfigGroup.java | 21 +++++++++++++++++-- .../groups/ControllerConfigGroupTest.java | 18 ++++++++++++++++ 2 files changed, 37 insertions(+), 2 deletions(-) diff --git a/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java b/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java index aff78717f7f..8736a467ab6 100644 --- a/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java +++ b/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java @@ -102,7 +102,6 @@ public enum MobsimType {qsim, JDEQSim, hermes} private int writeTripsInterval = 50; private String mobsim = MobsimType.qsim.toString(); private int writeSnapshotsInterval = 1; - private boolean createGraphs = true; private int createGraphsInterval = 1; private boolean dumpDataAtEnd = true; @@ -136,6 +135,11 @@ public final Map getComments() { map.put(CREATE_GRAPHS, "Sets whether graphs showing some analyses should automatically be generated during the simulation." + " The generation of graphs usually takes a small amount of time that does not have any weight in big simulations," + " but add a significant overhead in smaller runs or in test cases where the graphical output is not even requested." ); + + map.put(CREATE_GRAPHS_INTERVAL, "Sets the interval in which graphs are generated. Default is 1. If set to 0, no graphs are generated." + + " The generation of graphs usually takes a small amount of time that does not have any weight in big simulations," + + " but add a significant overhead in smaller runs or in test cases where the graphical output is not even requested." ); + map.put(COMPRESSION_TYPE, "Compression algorithm to use when writing out data to files. Possible values: " + Arrays.toString(CompressionType.values())); map.put(EVENT_TYPE_TO_CREATE_SCORING_FUNCTIONS, "Defines when the scoring functions for the population are created. Default=IterationStarts. Possible values: " + Arrays.toString(EventTypeToCreateScoringFunctions.values())); @@ -355,6 +359,13 @@ public void setWriteSnapshotsInterval(int writeSnapshotsInterval) { this.writeSnapshotsInterval = writeSnapshotsInterval; } + @StringGetter( CREATE_GRAPHS ) + @Deprecated + public boolean getCreateGraphs() { + log.warn("Configuration 'createGraphs' is deprecated. Using 'createGraphsInterval' instead."); + return this.createGraphsInterval > 0; + } + /** * Sets whether graphs showing some analyses should automatically be * generated during the simulation. The generation of graphs usually takes a @@ -366,8 +377,14 @@ public void setWriteSnapshotsInterval(int writeSnapshotsInterval) { * true if graphs showing analyses' output should be generated. */ @StringSetter( CREATE_GRAPHS ) + @Deprecated public void setCreateGraphs(boolean createGraphs) { - this.createGraphs = createGraphs; + log.warn("Configuration 'createGraphs' is deprecated. Using 'createGraphsInterval' instead."); + if (createGraphs) { + this.setCreateGraphsInterval(1); + } else { + this.setCreateGraphsInterval(0); + } } @StringGetter( CREATE_GRAPHS_INTERVAL ) diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java index a1c50b1d46f..545d28d9415 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java @@ -161,5 +161,23 @@ public void testWriteSnapshotInterval(){ Assert.assertEquals(42, cg.getWriteSnapshotsInterval()); } + @Test + public void testCreateGraphsInterval() { + ControllerConfigGroup cg = new ControllerConfigGroup(); + //initial value + Assert.assertEquals(1, cg.getCreateGraphsInterval()); + //modify by string + cg.addParam("createGraphsInterval", "10"); + Assert.assertEquals(10, cg.getCreateGraphsInterval()); + //modify by setter + cg.setCreateGraphsInterval(42); + Assert.assertEquals("42", cg.getValue("createGraphsInterval")); + Assert.assertEquals(42, cg.getCreateGraphsInterval()); + //modify by deprecated setter + cg.setCreateGraphs(true); + Assert.assertEquals(1, cg.getCreateGraphsInterval()); + Assert.assertEquals(true, cg.getCreateGraphs()); + } + } From 40b89479469876f3a0379de1f13481f308014e8b Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Tue, 5 Dec 2023 14:33:24 +0100 Subject: [PATCH 08/43] allow orphan setters on config groups in order to provide backwards compatibility. --- .../core/config/ReflectiveConfigGroup.java | 4 +- .../config/groups/ControllerConfigGroup.java | 49 ++++++++----------- .../config/ReflectiveConfigGroupTest.java | 9 ++-- .../groups/ControllerConfigGroupTest.java | 1 - 4 files changed, 28 insertions(+), 35 deletions(-) diff --git a/matsim/src/main/java/org/matsim/core/config/ReflectiveConfigGroup.java b/matsim/src/main/java/org/matsim/core/config/ReflectiveConfigGroup.java index 1301c6daeb1..0cf673c78e4 100644 --- a/matsim/src/main/java/org/matsim/core/config/ReflectiveConfigGroup.java +++ b/matsim/src/main/java/org/matsim/core/config/ReflectiveConfigGroup.java @@ -143,7 +143,9 @@ public ReflectiveConfigGroup(final String name, final boolean storeUnknownParame paramFields = getParamFields(); registeredParams = Sets.union(stringGetters.keySet(), paramFields.keySet()); - checkModuleConsistency(setters.keySet().equals(stringGetters.keySet()), "setters and getters inconsistent"); + // Each parameter which has a setter must have a getter. But there can be parameters which have a getter but no setter in order + // to provide backwards compatibility. + checkModuleConsistency(setters.keySet().containsAll(stringGetters.keySet()), "setters and getters inconsistent"); checkModuleConsistency(paramFields.keySet().stream().noneMatch(setters::containsKey), "Use either StringGetter/Setter or Parameter annotations"); } diff --git a/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java b/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java index 8736a467ab6..9cbde96f1e3 100644 --- a/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java +++ b/matsim/src/main/java/org/matsim/core/config/groups/ControllerConfigGroup.java @@ -84,7 +84,6 @@ public enum MobsimType {qsim, JDEQSim, hermes} private static final String WRITE_SNAPSHOTS_INTERVAL = "writeSnapshotsInterval"; - private String outputDirectory = "./output"; private int firstIteration = 0; private int lastIteration = 1000; @@ -359,44 +358,36 @@ public void setWriteSnapshotsInterval(int writeSnapshotsInterval) { this.writeSnapshotsInterval = writeSnapshotsInterval; } - @StringGetter( CREATE_GRAPHS ) - @Deprecated - public boolean getCreateGraphs() { - log.warn("Configuration 'createGraphs' is deprecated. Using 'createGraphsInterval' instead."); - return this.createGraphsInterval > 0; - } - - /** - * Sets whether graphs showing some analyses should automatically be - * generated during the simulation. The generation of graphs usually takes a - * small amount of time that does not have any weight in big simulations, - * but add a significant overhead in smaller runs or in test cases where the - * graphical output is not even requested. - * - * @param createGraphs - * true if graphs showing analyses' output should be generated. - */ - @StringSetter( CREATE_GRAPHS ) - @Deprecated - public void setCreateGraphs(boolean createGraphs) { - log.warn("Configuration 'createGraphs' is deprecated. Using 'createGraphsInterval' instead."); - if (createGraphs) { - this.setCreateGraphsInterval(1); - } else { - this.setCreateGraphsInterval(0); - } - } - @StringGetter( CREATE_GRAPHS_INTERVAL ) public int getCreateGraphsInterval() { return createGraphsInterval; } + /** + * Sets whether graphs showing some analyses should automatically be + * generated during the simulation. The generation of graphs usually takes a + * small amount of time that does not have any weight in big simulations, + * but add a significant overhead in smaller runs or in test cases where the + * graphical output is not even requested. + * + * @param createGraphsInterval iteration interval in which graphs are generated + */ @StringSetter( CREATE_GRAPHS_INTERVAL ) public void setCreateGraphsInterval(int createGraphsInterval) { this.createGraphsInterval = createGraphsInterval; } + @StringSetter( CREATE_GRAPHS ) + @Deprecated + public void setCreateGraphs(boolean createGraphs) { + log.warn("Parameter 'createGraphs' is deprecated. Using 'createGraphsInterval' instead. The output_config.xml will contain the new parameter."); + if (createGraphs) { + this.setCreateGraphsInterval(1); + } else { + this.setCreateGraphsInterval(0); + } + } + @StringGetter( OVERWRITE_FILE ) public OverwriteFileSetting getOverwriteFileSetting() { return overwriteFileSetting; diff --git a/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java index a662f53d5ad..884777ff20b 100644 --- a/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java @@ -172,18 +172,19 @@ public void testComments() { } @Test - public void testFailOnConstructingOrphanSetter() { - assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { + public void testAllowOnConstructingOrphanSetter() { + // no exception + new ReflectiveConfigGroup("name") { @StringSetter("setterWithoutGetter") public void setStuff(String s) { } - }).isInstanceOf(InconsistentModuleException.class); + }; } @Test public void testFailOnConstructingOrphanGetter() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { - @StringGetter("setterWithoutGetter") + @StringGetter("getterWithoutSetter") public Coord getStuff() { return null; } diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java index 545d28d9415..e6f47897853 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java @@ -176,7 +176,6 @@ public void testCreateGraphsInterval() { //modify by deprecated setter cg.setCreateGraphs(true); Assert.assertEquals(1, cg.getCreateGraphsInterval()); - Assert.assertEquals(true, cg.getCreateGraphs()); } From 6cfdc995be333686317689b5f4152fbdcf3690bf Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Tue, 5 Dec 2023 15:39:50 +0100 Subject: [PATCH 09/43] corrected TravelDistanceStats --- .../matsim/analysis/TravelDistanceStats.java | 57 +++++++------------ 1 file changed, 21 insertions(+), 36 deletions(-) diff --git a/matsim/src/main/java/org/matsim/analysis/TravelDistanceStats.java b/matsim/src/main/java/org/matsim/analysis/TravelDistanceStats.java index 9d0176c8adf..9099b8f67f6 100644 --- a/matsim/src/main/java/org/matsim/analysis/TravelDistanceStats.java +++ b/matsim/src/main/java/org/matsim/analysis/TravelDistanceStats.java @@ -57,7 +57,7 @@ public class TravelDistanceStats { - private static final int HISTORY_SIZE = 5000; + private static final int MAX_ITERATIONS_IN_GRAPH = 5000; private final ControllerConfigGroup controllerConfigGroup; private BufferedWriter out; @@ -65,8 +65,8 @@ public class TravelDistanceStats { private final String tripStatsPngName; private final String delimiter; - private DoubleSummaryStatistics[] legStats; - private DoubleSummaryStatistics[] tripStats; + private Map legStats; + private Map tripStats; private final static Logger log = LogManager.getLogger(TravelDistanceStats.class); @@ -103,12 +103,9 @@ private void initWriter(String travelDistanceStatsFileName) { } private void initStats(ControllerConfigGroup controllerConfigGroup) { - int iterations = controllerConfigGroup.getLastIteration() - controllerConfigGroup.getFirstIteration(); - if (iterations > HISTORY_SIZE) { - iterations = HISTORY_SIZE; // limit the history size - } - this.legStats = new DoubleSummaryStatistics[iterations+1]; - this.tripStats = new DoubleSummaryStatistics[iterations+1]; + int expectedIterations = controllerConfigGroup.getLastIteration() - controllerConfigGroup.getFirstIteration(); + this.legStats = new HashMap<>(expectedIterations+1); + this.tripStats = new HashMap<>(expectedIterations+1); } public void addIteration(int iteration, IdMap map) { @@ -122,22 +119,16 @@ public void addIteration(int iteration, IdMap map) { log.info("(TravelDistanceStats takes an average over all legs where the simulation reports travelled (network) distances"); log.info("(and teleported legs whose route contains a distance.)");// TODO: still valid? - int index = getIndex(iteration); - if (index >= this.legStats.length){ - return; - } - this.legStats[index] = legStats; - this.tripStats[index] = tripStats; + this.legStats.put(iteration, legStats); + this.tripStats.put(iteration, tripStats); + + assert this.legStats.size() == this.tripStats.size(); } void writeOutput(int iteration, boolean writePngs){ writeCsvEntry(iteration); - if (iteration >= HISTORY_SIZE){ - return; - } - - if(writePngs){ + if(writePngs && this.legStats.size() < MAX_ITERATIONS_IN_GRAPH){ writePngs(iteration); } } @@ -148,8 +139,8 @@ private void writeCsvHeader() throws IOException { } private void writeCsvEntry(int iteration) { - DoubleSummaryStatistics legStats = this.legStats[getIndex(iteration)]; - DoubleSummaryStatistics tripStats = this.tripStats[getIndex(iteration)]; + DoubleSummaryStatistics legStats = this.legStats.get(iteration); + DoubleSummaryStatistics tripStats = this.tripStats.get(iteration); try { this.out.write(iteration + this.delimiter + legStats.getAverage() + this.delimiter + tripStats.getAverage() + "\n"); @@ -169,15 +160,14 @@ private void writeTripStatsPng(int iteration) { return; } - int index = getIndex(iteration); // create chart when data of more than one iteration is available. XYLineChart chart = new XYLineChart("Trip Travel Distance Statistics", "iteration", "average of the average trip distance per plan "); - double[] iterations = new double[index + 1]; - double[] values = new double[index + 1]; + double[] iterations = new double[iteration + 1]; + double[] values = new double[iteration + 1]; - for (int i = 0; i <= index; i++) { + for (int i = 0; i <= iteration; i++) { iterations[i] = i + controllerConfigGroup.getFirstIteration(); - values[i] = Optional.ofNullable(this.tripStats[i]).map(DoubleSummaryStatistics::getAverage).orElse(0.); + values[i] = Optional.ofNullable(this.tripStats.get(i)).map(DoubleSummaryStatistics::getAverage).orElse(0.); } chart.addSeries("executed plan", iterations, values); @@ -190,15 +180,14 @@ private void writeLegStatsPng(int iteration) { return; } - int index = getIndex(iteration); // create chart when data of more than one iteration is available. XYLineChart chart = new XYLineChart("Leg Travel Distance Statistics", "iteration", "average of the average leg distance per plan "); - double[] iterations = new double[index + 1]; - double[] values = new double[index + 1]; + double[] iterations = new double[iteration + 1]; + double[] values = new double[iteration + 1]; - for (int i = 0; i <= index; i++) { + for (int i = 0; i <= iteration; i++) { iterations[i] = i + controllerConfigGroup.getFirstIteration(); - values[i] = Optional.ofNullable(this.legStats[i]).map(DoubleSummaryStatistics::getAverage).orElse(0.); + values[i] = Optional.ofNullable(this.legStats.get(i)).map(DoubleSummaryStatistics::getAverage).orElse(0.); } @@ -242,10 +231,6 @@ private static DoubleSummaryStatistics getLegStats(IdMap map) { .summaryStatistics(); } - private int getIndex(int iteration) { - return iteration - controllerConfigGroup.getFirstIteration(); - } - public void close() { try { this.out.close(); From 365aa9621e63c87b6ffe4cc0bf88bc6ca445554e Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Tue, 5 Dec 2023 16:41:05 +0100 Subject: [PATCH 10/43] add junit 5 dependency --- benchmark/pom.xml | 12 ++++++++++-- contribs/pom.xml | 12 ++++++++++-- matsim/pom.xml | 12 ++++++++++-- pom.xml | 25 +++++++++++++++++++------ 4 files changed, 49 insertions(+), 12 deletions(-) diff --git a/benchmark/pom.xml b/benchmark/pom.xml index 43ee7d820b2..dd8bbafda2c 100644 --- a/benchmark/pom.xml +++ b/benchmark/pom.xml @@ -41,8 +41,16 @@ 16.0-SNAPSHOT - junit - junit + org.junit.vintage + junit-vintage-engine + + + org.junit.jupiter + junit-jupiter-engine + + + org.junit.jupiter + junit-jupiter diff --git a/contribs/pom.xml b/contribs/pom.xml index 9ffc2dec10e..49124a6bd25 100644 --- a/contribs/pom.xml +++ b/contribs/pom.xml @@ -104,8 +104,16 @@ - junit - junit + org.junit.vintage + junit-vintage-engine + + + org.junit.jupiter + junit-jupiter-engine + + + org.junit.jupiter + junit-jupiter org.matsim diff --git a/matsim/pom.xml b/matsim/pom.xml index 6bf9a851f4d..5f88ffc874b 100644 --- a/matsim/pom.xml +++ b/matsim/pom.xml @@ -160,8 +160,16 @@ 1.5.4 - junit - junit + org.junit.vintage + junit-vintage-engine + + + org.junit.jupiter + junit-jupiter-engine + + + org.junit.jupiter + junit-jupiter org.matsim diff --git a/pom.xml b/pom.xml index be8af9131d3..23a9f29ff66 100644 --- a/pom.xml +++ b/pom.xml @@ -37,6 +37,7 @@ 7.0.0 2.16.0 2.5.0 + 5.10.1 @@ -215,12 +216,24 @@ 4.2.2 - - junit - junit - 4.13.2 - test - + + org.junit.vintage + junit-vintage-engine + ${junit.version} + test + + + org.junit.jupiter + junit-jupiter-engine + ${junit.version} + test + + + org.junit.jupiter + junit-jupiter + ${junit.version} + test + org.slf4j From c092055fe2a8e760163a2822ff72494ad0ae742d Mon Sep 17 00:00:00 2001 From: nkuehnel Date: Wed, 6 Dec 2023 10:43:15 +0100 Subject: [PATCH 11/43] sharing factor and pooling rate for DRT --- .../drt/analysis/DrtModeAnalysisModule.java | 3 + .../SharingFactorControlerListener.java | 144 ++++++++++++ .../sharingfactor/SharingFactorModule.java | 38 ++++ .../sharingfactor/SharingFactorTracker.java | 112 ++++++++++ .../drt/sharingfactor/SharingFactorTest.java | 205 ++++++++++++++++++ 5 files changed, 502 insertions(+) create mode 100644 contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorControlerListener.java create mode 100644 contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorModule.java create mode 100644 contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTracker.java create mode 100644 contribs/drt/src/test/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTest.java diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtModeAnalysisModule.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtModeAnalysisModule.java index e362e4d4935..e5cd54688c2 100644 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtModeAnalysisModule.java +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtModeAnalysisModule.java @@ -34,6 +34,7 @@ import org.matsim.contrib.drt.schedule.DrtDriveTask; import org.matsim.contrib.drt.schedule.DrtStayTask; import org.matsim.contrib.drt.scheduler.EmptyVehicleRelocator; +import org.matsim.contrib.drt.sharingfactor.SharingFactorModule; import org.matsim.contrib.dvrp.analysis.ExecutedScheduleCollector; import org.matsim.contrib.dvrp.fleet.FleetSpecification; import org.matsim.contrib.dvrp.run.AbstractDvrpModeModule; @@ -136,5 +137,7 @@ public void install() { getter.getModal(DrtVehicleDistanceStats.class), getter.get(MatsimServices.class), getter.get(Network.class), getter.getModal(DrtEventSequenceCollector.class), getter.getModal(VehicleOccupancyProfileCalculator.class)))) .asEagerSingleton(); + + install(new SharingFactorModule(drtCfg)); } } diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorControlerListener.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorControlerListener.java new file mode 100644 index 00000000000..2173b1c6840 --- /dev/null +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorControlerListener.java @@ -0,0 +1,144 @@ +package org.matsim.contrib.drt.sharingfactor; + +import com.google.inject.Inject; +import org.jfree.chart.ChartFactory; +import org.jfree.chart.ChartUtils; +import org.jfree.chart.JFreeChart; +import org.jfree.chart.renderer.category.BoxAndWhiskerRenderer; +import org.jfree.data.statistics.DefaultBoxAndWhiskerCategoryDataset; +import org.matsim.api.core.v01.Id; +import org.matsim.contrib.drt.run.DrtConfigGroup; +import org.matsim.contrib.dvrp.optimizer.Request; +import org.matsim.core.config.Config; +import org.matsim.core.controler.MatsimServices; +import org.matsim.core.controler.events.IterationEndsEvent; +import org.matsim.core.controler.listener.IterationEndsListener; +import org.matsim.core.utils.io.IOUtils; + +import java.io.BufferedWriter; +import java.io.FileOutputStream; +import java.io.IOException; +import java.util.Arrays; +import java.util.Map; +import java.util.Optional; +import java.util.stream.Collectors; + +/** + * @author nkuehnel / MOIA + */ +public class SharingFactorControlerListener implements IterationEndsListener { + private final MatsimServices matsimServices; + + private final DrtConfigGroup drtConfigGroup; + private final SharingFactorTracker sharingFactorTracker; + + private boolean headerWritten = false; + + private final String runId; + + private final String delimiter; + + private static final String notAvailableString = "NA"; + + + @Inject + public SharingFactorControlerListener(Config config, + DrtConfigGroup drtConfigGroup, + SharingFactorTracker sharingFactorTracker, + MatsimServices matsimServices) { + this.drtConfigGroup = drtConfigGroup; + this.sharingFactorTracker = sharingFactorTracker; + this.matsimServices = matsimServices; + runId = Optional.ofNullable(config.controller().getRunId()).orElse(notAvailableString); + this.delimiter = config.global().getDefaultDelimiter(); + + } + + @Override + public void notifyIterationEnds(IterationEndsEvent event) { + boolean createGraphs = event.getServices().getConfig().controller().isCreateGraphs(); + + Map, Double> sharingFactors = sharingFactorTracker.getSharingFactors(); + Map, Boolean> poolingRates = sharingFactorTracker.getPoolingRates(); + + writeAndPlotShiftEfficiency( + sharingFactors, + poolingRates, + filename(event, "sharingFactors", ".png"), + filename(event, "poolingRates", ".png"), + filename(event, "poolingMetrics", ".csv"), + createGraphs); + + double nPooled = poolingRates.values().stream().filter(b -> b).count(); + double nTotal = poolingRates.values().size(); + double meanPoolingRate = nPooled / nTotal; + double meanSharingFactor = sharingFactors.values().stream().mapToDouble(d -> d).average().orElse(Double.NaN); + + writeIterationPoolingStats(meanPoolingRate + delimiter + meanSharingFactor + delimiter + nPooled +delimiter + nTotal, event.getIteration()); + } + + private void writeAndPlotShiftEfficiency(Map, Double> sharingFactorByRequest, + Map, Boolean> rates, + String sharingFactors, + String poolingRates, + String csvFile, + boolean createGraphs) { + try (var bw = IOUtils.getBufferedWriter(csvFile)) { + bw.append(line("Request", "SharingFactor", "Pooled")); + + for (Map.Entry, Double> sharingFactorEntry : sharingFactorByRequest.entrySet()) { + bw.append(line(sharingFactorEntry.getKey(), sharingFactorEntry.getValue(),rates.get(sharingFactorEntry.getKey()))); + } + bw.flush(); + + if (createGraphs) { + final DefaultBoxAndWhiskerCategoryDataset sharingFactorDataset + = new DefaultBoxAndWhiskerCategoryDataset(); + + final DefaultBoxAndWhiskerCategoryDataset poolingRateDataset + = new DefaultBoxAndWhiskerCategoryDataset(); + + sharingFactorDataset.add(sharingFactorByRequest.values().stream().toList(), "", ""); + poolingRateDataset.add(rates.values().stream().toList(), "", ""); + + JFreeChart chartRides = ChartFactory.createBoxAndWhiskerChart("Sharing factor", "", "Factor", sharingFactorDataset, false); + JFreeChart chartPooling = ChartFactory.createBoxAndWhiskerChart("Pooling rate", "", "Rate", poolingRateDataset, false); + + ((BoxAndWhiskerRenderer) chartRides.getCategoryPlot().getRenderer()).setMeanVisible(true); + ((BoxAndWhiskerRenderer) chartPooling.getCategoryPlot().getRenderer()).setMeanVisible(true); + ChartUtils.writeChartAsPNG(new FileOutputStream(sharingFactors), chartRides, 1500, 1500); + ChartUtils.writeChartAsPNG(new FileOutputStream(poolingRates), chartPooling, 1500, 1500); + } + } catch ( + IOException e) { + throw new RuntimeException(e); + } + } + + private String filename(IterationEndsEvent event, String prefix, String extension) { + return matsimServices.getControlerIO() + .getIterationFilename(event.getIteration(), prefix + "_" + drtConfigGroup.getMode() + extension); + } + + private String line(Object... cells) { + return Arrays.stream(cells).map(Object::toString).collect(Collectors.joining(delimiter, "", "\n")); + } + + + private void writeIterationPoolingStats(String summarizePooling, int it) { + try (var bw = getAppendingBufferedWriter("drt_pooling_stats", ".csv")) { + if (!headerWritten) { + headerWritten = true; + bw.write(line("runId", "iteration", "poolingRate", "sharingFactor", "nPooled", "nTotal")); + } + bw.write(runId + delimiter + it + delimiter + summarizePooling); + bw.newLine(); + } catch (IOException e) { + throw new RuntimeException(e); + } + } + + private BufferedWriter getAppendingBufferedWriter(String prefix, String extension) { + return IOUtils.getAppendingBufferedWriter(matsimServices.getControlerIO().getOutputFilename(prefix + "_" + drtConfigGroup.getMode() + extension)); + } +} diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorModule.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorModule.java new file mode 100644 index 00000000000..3ce63eddc2e --- /dev/null +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorModule.java @@ -0,0 +1,38 @@ +package org.matsim.contrib.drt.sharingfactor; + +import org.matsim.api.core.v01.Id; +import org.matsim.api.core.v01.population.Person; +import org.matsim.contrib.drt.run.DrtConfigGroup; +import org.matsim.contrib.dvrp.run.AbstractDvrpModeModule; +import org.matsim.core.controler.MatsimServices; + +/** + * @author nkuehnel / MOIA + */ +public class SharingFactorModule extends AbstractDvrpModeModule { + + private final DrtConfigGroup drtConfigGroup; + + public SharingFactorModule(DrtConfigGroup drtConfigGroup) { + super(drtConfigGroup.getMode()); + this.drtConfigGroup = drtConfigGroup; + } + + @Override + public void install() { + bindModal(SharingFactorTracker.class).toProvider(modalProvider(getter -> + new SharingFactorTracker(new SharingFactorTracker.GroupPredicate() { + @Override + public boolean isGroupRepresentative(Id personId) { + return SharingFactorTracker.GroupPredicate.super.isGroupRepresentative(personId); + } + }))).asEagerSingleton(); + addEventHandlerBinding().to(modalKey(SharingFactorTracker.class)); + bindModal(SharingFactorControlerListener.class).toProvider(modalProvider(getter -> + new SharingFactorControlerListener(getConfig(), drtConfigGroup, + getter.getModal(SharingFactorTracker.class), + getter.get(MatsimServices.class)) + )); + addControlerListenerBinding().to(modalKey(SharingFactorControlerListener.class)); + } +} diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTracker.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTracker.java new file mode 100644 index 00000000000..cc28f6131a9 --- /dev/null +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTracker.java @@ -0,0 +1,112 @@ +package org.matsim.contrib.drt.sharingfactor; + +import org.matsim.api.core.v01.Id; +import org.matsim.api.core.v01.population.Person; +import org.matsim.contrib.dvrp.fleet.DvrpVehicle; +import org.matsim.contrib.dvrp.optimizer.Request; +import org.matsim.contrib.dvrp.passenger.PassengerDroppedOffEvent; +import org.matsim.contrib.dvrp.passenger.PassengerDroppedOffEventHandler; +import org.matsim.contrib.dvrp.passenger.PassengerPickedUpEvent; +import org.matsim.contrib.dvrp.passenger.PassengerPickedUpEventHandler; +import org.matsim.core.mobsim.framework.events.MobsimBeforeCleanupEvent; +import org.matsim.core.mobsim.framework.listeners.MobsimBeforeCleanupListener; + +import java.util.*; + +/** + * @author nkuehnel / MOIA + */ +public class SharingFactorTracker implements PassengerPickedUpEventHandler, PassengerDroppedOffEventHandler, MobsimBeforeCleanupListener { + + private final GroupPredicate groupPredicate; + + record Segment(double start, int occupancy) { + } + + private final Map, List>> map = new HashMap<>(); + + private final Map, List> segments = new HashMap<>(); + + private final Map, Double> sharingFactors = new HashMap<>(); + private final Map, Boolean> poolingRate = new HashMap<>(); + + public interface GroupPredicate { + default boolean isGroupRepresentative(Id personId) { + return true; + } + } + + public SharingFactorTracker(GroupPredicate groupPredicate) { + this.groupPredicate = groupPredicate; + } + + + @Override + public void handleEvent(PassengerDroppedOffEvent event) { + if (groupPredicate.isGroupRepresentative(event.getPersonId())) { + + List> occupancy = map.get(event.getVehicleId()); + occupancy.remove(event.getRequestId()); + occupancy.forEach(p -> segments.get(p).add(new Segment(event.getTime(), occupancy.size()))); + + + List finishedSegments = segments.remove(event.getRequestId()); + + double total = 0; + double portion = 0; + + boolean pooled = false; + + Segment last = finishedSegments.get(0); + if (last.occupancy > 1) { + pooled = true; + } + for (int i = 1; i < finishedSegments.size(); i++) { + Segment next = finishedSegments.get(i); + double duration = next.start - last.start; + total += duration; + portion += duration / last.occupancy; + last = next; + if (last.occupancy > 1) { + pooled = true; + } + } + + double duration = event.getTime() - last.start; + total += duration; + portion += duration / last.occupancy; + + double sharingFactor = total / portion; + sharingFactors.put(event.getRequestId(), sharingFactor); + poolingRate.put(event.getRequestId(), pooled); + } + } + + @Override + public void handleEvent(PassengerPickedUpEvent event) { + if (groupPredicate.isGroupRepresentative(event.getPersonId())) { + map.computeIfAbsent(event.getVehicleId(), vehicleId -> new ArrayList<>()); + List> occupancy = map.get(event.getVehicleId()); + occupancy.add(event.getRequestId()); + occupancy.forEach( + p -> segments.computeIfAbsent(p, requestId -> new ArrayList<>()).add(new Segment(event.getTime(), occupancy.size())) + ); + } + } + + @Override + public void notifyMobsimBeforeCleanup(MobsimBeforeCleanupEvent e) { + map.clear(); + segments.clear(); + poolingRate.clear(); + sharingFactors.clear(); + } + + public Map, Double> getSharingFactors() { + return Collections.unmodifiableMap(sharingFactors); + } + + public Map, Boolean> getPoolingRates() { + return Collections.unmodifiableMap(poolingRate); + } +} diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTest.java new file mode 100644 index 00000000000..fc2c8b96add --- /dev/null +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTest.java @@ -0,0 +1,205 @@ +package org.matsim.contrib.drt.sharingfactor; + +import org.junit.Assert; +import org.junit.Test; +import org.matsim.api.core.v01.Id; +import org.matsim.api.core.v01.population.Person; +import org.matsim.contrib.dvrp.fleet.DvrpVehicle; +import org.matsim.contrib.dvrp.optimizer.Request; +import org.matsim.contrib.dvrp.passenger.PassengerDroppedOffEvent; +import org.matsim.contrib.dvrp.passenger.PassengerPickedUpEvent; +import org.matsim.core.events.ParallelEventsManager; +import org.matsim.testcases.MatsimTestUtils; + +import java.util.HashSet; +import java.util.Set; + +/** + * @author nkuehnel / MOIA + */ +public class SharingFactorTest { + + /** + * Test method for {@link SharingFactorTracker}. + */ + @Test + public void testDrtSharingFactorHandler() { + String mode = "mode_0"; + + var vehicleId = Id.create("v1", DvrpVehicle.class); + var personId1 = Id.createPersonId("p1"); + var personId2 = Id.createPersonId("p2"); + + + Set> groupRepresentatives = new HashSet<>(); + + // two separate bookings + groupRepresentatives.add(personId1); + groupRepresentatives.add(personId2); + + + ParallelEventsManager events = new ParallelEventsManager(false); + SharingFactorTracker sharingFactorTracker = new SharingFactorTracker(new SharingFactorTracker.GroupPredicate() { + @Override + public boolean isGroupRepresentative(Id personId) { + return groupRepresentatives.contains(personId); + } + }); + events.addHandler(sharingFactorTracker); + + events.initProcessing(); + + + { + //single trip, no pooling + var requestId = Id.create(0, Request.class); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId)); + + events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId, personId1, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(300.0, mode, requestId, personId1, vehicleId)); + events.flush(); + + Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId)); + Assert.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId)); + Assert.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId), MatsimTestUtils.EPSILON); + } + + //clean up + sharingFactorTracker.notifyMobsimBeforeCleanup(null); + + { + //two trips exactly after each other, no pooling + var requestId1 = Id.create(0, Request.class); + var requestId2 = Id.create(1, Request.class); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + + events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId1, personId1, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(300.0, mode, requestId1, personId1, vehicleId)); + events.processEvent(new PassengerPickedUpEvent(300.0, mode, requestId2, personId2, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(500.0, mode, requestId2, personId2, vehicleId)); + events.flush(); + + Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); + Assert.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); + + Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); + Assert.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assert.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); + } + + //clean up + sharingFactorTracker.notifyMobsimBeforeCleanup(null); + + { + //two trips overlap half of the time + var requestId1 = Id.create(0, Request.class); + var requestId2 = Id.create(1, Request.class); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + + events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId1, personId1, vehicleId)); + events.processEvent(new PassengerPickedUpEvent(200.0, mode, requestId2, personId2, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(300.0, mode, requestId1, personId1, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(400.0, mode, requestId2, personId2, vehicleId)); + events.flush(); + + Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); + Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertEquals((100. + 100.) / (100 + 50), sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); + + Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); + Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assert.assertEquals((100. + 100.) / (50 + 100), sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); + } + + + //clean up + sharingFactorTracker.notifyMobsimBeforeCleanup(null); + + { + // second trip (sharing factor = 2) happens completely within first trip (sharing factor = 1.2) + var requestId1 = Id.create(0, Request.class); + var requestId2 = Id.create(1, Request.class); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + + events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId1, personId1, vehicleId)); + events.processEvent(new PassengerPickedUpEvent(200.0, mode, requestId2, personId2, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(300.0, mode, requestId2, personId2, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(400.0, mode, requestId1, personId1, vehicleId)); + events.flush(); + + Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); + Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertEquals((100. + 100. + 100.) / (100 + 50 + 100), sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); + + Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); + Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assert.assertEquals((100. ) / (50.), sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); + } + + //clean up + sharingFactorTracker.notifyMobsimBeforeCleanup(null); + + { + // two persons share exact same trip but not part of a group + + var requestId1 = Id.create(0, Request.class); + var requestId2 = Id.create(1, Request.class); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + + events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId1, personId1, vehicleId)); + events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId2, personId2, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(200.0, mode, requestId1, personId1, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(200.0, mode, requestId2, personId2, vehicleId)); + events.flush(); + + Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); + Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertEquals(2., sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); + + Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); + Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assert.assertEquals(2., sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); + } + + + //clean up + sharingFactorTracker.notifyMobsimBeforeCleanup(null); + + { + // two persons part of a group, only person 1 is representative -> not pooled + groupRepresentatives.remove(personId2); + + var requestId1 = Id.create(0, Request.class); + var requestId2 = Id.create(1, Request.class); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + + events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId1, personId1, vehicleId)); + events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId2, personId2, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(200.0, mode, requestId1, personId1, vehicleId)); + events.processEvent(new PassengerDroppedOffEvent(200.0, mode, requestId2, personId2, vehicleId)); + events.flush(); + + Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); + Assert.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assert.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); + + Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assert.assertNull(sharingFactorTracker.getSharingFactors().get(requestId2)); + } + } +} From 4390990d69b4f505a49aeb7b124f979b3f396223 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 6 Dec 2023 14:14:44 +0000 Subject: [PATCH 12/43] build(deps): bump io.grpc:grpc-all from 1.59.1 to 1.60.0 Bumps [io.grpc:grpc-all](https://github.com/grpc/grpc-java) from 1.59.1 to 1.60.0. - [Release notes](https://github.com/grpc/grpc-java/releases) - [Commits](https://github.com/grpc/grpc-java/compare/v1.59.1...v1.60.0) --- updated-dependencies: - dependency-name: io.grpc:grpc-all dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] --- contribs/hybridsim/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/contribs/hybridsim/pom.xml b/contribs/hybridsim/pom.xml index cc8bcea53c5..8954573f022 100644 --- a/contribs/hybridsim/pom.xml +++ b/contribs/hybridsim/pom.xml @@ -11,7 +11,7 @@ 3.25.1 - 1.59.1 + 1.60.0 From 0109267af2521fb36b2df53b70fa6cdcb4e80cce Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 6 Dec 2023 15:25:57 +0000 Subject: [PATCH 13/43] build(deps): bump org.apache.httpcomponents.client5:httpclient5 Bumps [org.apache.httpcomponents.client5:httpclient5](https://github.com/apache/httpcomponents-client) from 5.2.3 to 5.3. - [Changelog](https://github.com/apache/httpcomponents-client/blob/master/RELEASE_NOTES.txt) - [Commits](https://github.com/apache/httpcomponents-client/compare/rel/v5.2.3...rel/v5.3) --- updated-dependencies: - dependency-name: org.apache.httpcomponents.client5:httpclient5 dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] --- contribs/analysis/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/contribs/analysis/pom.xml b/contribs/analysis/pom.xml index 83989a7fcbf..38facf17423 100644 --- a/contribs/analysis/pom.xml +++ b/contribs/analysis/pom.xml @@ -32,7 +32,7 @@ org.apache.httpcomponents.client5 httpclient5 - 5.2.3 + 5.3 From 4f97de8ae148b172f9a441d866a4dd50b6dbf49b Mon Sep 17 00:00:00 2001 From: nkuehnel Date: Thu, 7 Dec 2023 13:24:43 +0100 Subject: [PATCH 14/43] update sharing metrics code --- .../drt/analysis/DrtModeAnalysisModule.java | 4 +- .../sharingfactor/SharingFactorModule.java | 38 ------------------- .../SharingMetricsControlerListener.java} | 18 ++++----- .../sharingmetrics/SharingMetricsModule.java | 33 ++++++++++++++++ .../SharingMetricsTracker.java} | 10 ++--- .../SharingFactorTest.java | 6 +-- 6 files changed, 51 insertions(+), 58 deletions(-) delete mode 100644 contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorModule.java rename contribs/drt/src/main/java/org/matsim/contrib/drt/{sharingfactor/SharingFactorControlerListener.java => sharingmetrics/SharingMetricsControlerListener.java} (90%) create mode 100644 contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsModule.java rename contribs/drt/src/main/java/org/matsim/contrib/drt/{sharingfactor/SharingFactorTracker.java => sharingmetrics/SharingMetricsTracker.java} (90%) rename contribs/drt/src/test/java/org/matsim/contrib/drt/{sharingfactor => sharingmetrics}/SharingFactorTest.java (97%) diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtModeAnalysisModule.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtModeAnalysisModule.java index e5cd54688c2..67d38dad708 100644 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtModeAnalysisModule.java +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/analysis/DrtModeAnalysisModule.java @@ -34,7 +34,7 @@ import org.matsim.contrib.drt.schedule.DrtDriveTask; import org.matsim.contrib.drt.schedule.DrtStayTask; import org.matsim.contrib.drt.scheduler.EmptyVehicleRelocator; -import org.matsim.contrib.drt.sharingfactor.SharingFactorModule; +import org.matsim.contrib.drt.sharingmetrics.SharingMetricsModule; import org.matsim.contrib.dvrp.analysis.ExecutedScheduleCollector; import org.matsim.contrib.dvrp.fleet.FleetSpecification; import org.matsim.contrib.dvrp.run.AbstractDvrpModeModule; @@ -138,6 +138,6 @@ public void install() { getter.getModal(DrtEventSequenceCollector.class), getter.getModal(VehicleOccupancyProfileCalculator.class)))) .asEagerSingleton(); - install(new SharingFactorModule(drtCfg)); + install(new SharingMetricsModule(drtCfg)); } } diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorModule.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorModule.java deleted file mode 100644 index 3ce63eddc2e..00000000000 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorModule.java +++ /dev/null @@ -1,38 +0,0 @@ -package org.matsim.contrib.drt.sharingfactor; - -import org.matsim.api.core.v01.Id; -import org.matsim.api.core.v01.population.Person; -import org.matsim.contrib.drt.run.DrtConfigGroup; -import org.matsim.contrib.dvrp.run.AbstractDvrpModeModule; -import org.matsim.core.controler.MatsimServices; - -/** - * @author nkuehnel / MOIA - */ -public class SharingFactorModule extends AbstractDvrpModeModule { - - private final DrtConfigGroup drtConfigGroup; - - public SharingFactorModule(DrtConfigGroup drtConfigGroup) { - super(drtConfigGroup.getMode()); - this.drtConfigGroup = drtConfigGroup; - } - - @Override - public void install() { - bindModal(SharingFactorTracker.class).toProvider(modalProvider(getter -> - new SharingFactorTracker(new SharingFactorTracker.GroupPredicate() { - @Override - public boolean isGroupRepresentative(Id personId) { - return SharingFactorTracker.GroupPredicate.super.isGroupRepresentative(personId); - } - }))).asEagerSingleton(); - addEventHandlerBinding().to(modalKey(SharingFactorTracker.class)); - bindModal(SharingFactorControlerListener.class).toProvider(modalProvider(getter -> - new SharingFactorControlerListener(getConfig(), drtConfigGroup, - getter.getModal(SharingFactorTracker.class), - getter.get(MatsimServices.class)) - )); - addControlerListenerBinding().to(modalKey(SharingFactorControlerListener.class)); - } -} diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorControlerListener.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java similarity index 90% rename from contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorControlerListener.java rename to contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java index 2173b1c6840..521be363f49 100644 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorControlerListener.java +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java @@ -1,4 +1,4 @@ -package org.matsim.contrib.drt.sharingfactor; +package org.matsim.contrib.drt.sharingmetrics; import com.google.inject.Inject; import org.jfree.chart.ChartFactory; @@ -26,11 +26,11 @@ /** * @author nkuehnel / MOIA */ -public class SharingFactorControlerListener implements IterationEndsListener { +public class SharingMetricsControlerListener implements IterationEndsListener { private final MatsimServices matsimServices; private final DrtConfigGroup drtConfigGroup; - private final SharingFactorTracker sharingFactorTracker; + private final SharingMetricsTracker sharingFactorTracker; private boolean headerWritten = false; @@ -42,10 +42,10 @@ public class SharingFactorControlerListener implements IterationEndsListener { @Inject - public SharingFactorControlerListener(Config config, - DrtConfigGroup drtConfigGroup, - SharingFactorTracker sharingFactorTracker, - MatsimServices matsimServices) { + public SharingMetricsControlerListener(Config config, + DrtConfigGroup drtConfigGroup, + SharingMetricsTracker sharingFactorTracker, + MatsimServices matsimServices) { this.drtConfigGroup = drtConfigGroup; this.sharingFactorTracker = sharingFactorTracker; this.matsimServices = matsimServices; @@ -61,7 +61,7 @@ public void notifyIterationEnds(IterationEndsEvent event) { Map, Double> sharingFactors = sharingFactorTracker.getSharingFactors(); Map, Boolean> poolingRates = sharingFactorTracker.getPoolingRates(); - writeAndPlotShiftEfficiency( + writeAndPlotSharingMetrics( sharingFactors, poolingRates, filename(event, "sharingFactors", ".png"), @@ -77,7 +77,7 @@ public void notifyIterationEnds(IterationEndsEvent event) { writeIterationPoolingStats(meanPoolingRate + delimiter + meanSharingFactor + delimiter + nPooled +delimiter + nTotal, event.getIteration()); } - private void writeAndPlotShiftEfficiency(Map, Double> sharingFactorByRequest, + private void writeAndPlotSharingMetrics(Map, Double> sharingFactorByRequest, Map, Boolean> rates, String sharingFactors, String poolingRates, diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsModule.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsModule.java new file mode 100644 index 00000000000..2ebe3777ac1 --- /dev/null +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsModule.java @@ -0,0 +1,33 @@ +package org.matsim.contrib.drt.sharingmetrics; + +import org.matsim.api.core.v01.Id; +import org.matsim.api.core.v01.population.Person; +import org.matsim.contrib.drt.run.DrtConfigGroup; +import org.matsim.contrib.dvrp.run.AbstractDvrpModeModule; +import org.matsim.core.controler.MatsimServices; + +/** + * @author nkuehnel / MOIA + */ +public class SharingMetricsModule extends AbstractDvrpModeModule { + + private final DrtConfigGroup drtConfigGroup; + + public SharingMetricsModule(DrtConfigGroup drtConfigGroup) { + super(drtConfigGroup.getMode()); + this.drtConfigGroup = drtConfigGroup; + } + + @Override + public void install() { + bindModal(SharingMetricsTracker.class).toProvider(modalProvider(getter -> + new SharingMetricsTracker(personId -> true))).asEagerSingleton(); + addEventHandlerBinding().to(modalKey(SharingMetricsTracker.class)); + bindModal(SharingMetricsControlerListener.class).toProvider(modalProvider(getter -> + new SharingMetricsControlerListener(getConfig(), drtConfigGroup, + getter.getModal(SharingMetricsTracker.class), + getter.get(MatsimServices.class)) + )); + addControlerListenerBinding().to(modalKey(SharingMetricsControlerListener.class)); + } +} diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTracker.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsTracker.java similarity index 90% rename from contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTracker.java rename to contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsTracker.java index cc28f6131a9..f5393b29144 100644 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTracker.java +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsTracker.java @@ -1,4 +1,4 @@ -package org.matsim.contrib.drt.sharingfactor; +package org.matsim.contrib.drt.sharingmetrics; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -16,7 +16,7 @@ /** * @author nkuehnel / MOIA */ -public class SharingFactorTracker implements PassengerPickedUpEventHandler, PassengerDroppedOffEventHandler, MobsimBeforeCleanupListener { +public class SharingMetricsTracker implements PassengerPickedUpEventHandler, PassengerDroppedOffEventHandler, MobsimBeforeCleanupListener { private final GroupPredicate groupPredicate; @@ -31,12 +31,10 @@ record Segment(double start, int occupancy) { private final Map, Boolean> poolingRate = new HashMap<>(); public interface GroupPredicate { - default boolean isGroupRepresentative(Id personId) { - return true; - } + boolean isGroupRepresentative(Id personId); } - public SharingFactorTracker(GroupPredicate groupPredicate) { + public SharingMetricsTracker(GroupPredicate groupPredicate) { this.groupPredicate = groupPredicate; } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingmetrics/SharingFactorTest.java similarity index 97% rename from contribs/drt/src/test/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTest.java rename to contribs/drt/src/test/java/org/matsim/contrib/drt/sharingmetrics/SharingFactorTest.java index fc2c8b96add..e98a066d0ce 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingfactor/SharingFactorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingmetrics/SharingFactorTest.java @@ -1,4 +1,4 @@ -package org.matsim.contrib.drt.sharingfactor; +package org.matsim.contrib.drt.sharingmetrics; import org.junit.Assert; import org.junit.Test; @@ -20,7 +20,7 @@ public class SharingFactorTest { /** - * Test method for {@link SharingFactorTracker}. + * Test method for {@link SharingMetricsTracker}. */ @Test public void testDrtSharingFactorHandler() { @@ -39,7 +39,7 @@ public void testDrtSharingFactorHandler() { ParallelEventsManager events = new ParallelEventsManager(false); - SharingFactorTracker sharingFactorTracker = new SharingFactorTracker(new SharingFactorTracker.GroupPredicate() { + SharingMetricsTracker sharingFactorTracker = new SharingMetricsTracker(new SharingMetricsTracker.GroupPredicate() { @Override public boolean isGroupRepresentative(Id personId) { return groupRepresentatives.contains(personId); From 3f463412766be1ceef9034fda3f045e483a11c95 Mon Sep 17 00:00:00 2001 From: nkuehnel Date: Thu, 7 Dec 2023 13:33:54 +0100 Subject: [PATCH 15/43] update to #2955 --- .../drt/sharingmetrics/SharingMetricsControlerListener.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java index 521be363f49..9257af67aee 100644 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java @@ -56,7 +56,8 @@ public SharingMetricsControlerListener(Config config, @Override public void notifyIterationEnds(IterationEndsEvent event) { - boolean createGraphs = event.getServices().getConfig().controller().isCreateGraphs(); + int createGraphsInterval = event.getServices().getConfig().controller().getCreateGraphsInterval(); + boolean createGraphs = createGraphsInterval >0 && event.getIteration() % createGraphsInterval == 0; Map, Double> sharingFactors = sharingFactorTracker.getSharingFactors(); Map, Boolean> poolingRates = sharingFactorTracker.getPoolingRates(); From 787e0bb82687893c1537ea393b27760c3ed998ca Mon Sep 17 00:00:00 2001 From: nkuehnel Date: Thu, 7 Dec 2023 13:50:00 +0100 Subject: [PATCH 16/43] change file names from pooling stats to sharing metrics --- .../drt/sharingmetrics/SharingMetricsControlerListener.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java index 9257af67aee..9884fce28cc 100644 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/sharingmetrics/SharingMetricsControlerListener.java @@ -67,7 +67,7 @@ public void notifyIterationEnds(IterationEndsEvent event) { poolingRates, filename(event, "sharingFactors", ".png"), filename(event, "poolingRates", ".png"), - filename(event, "poolingMetrics", ".csv"), + filename(event, "sharingMetrics", ".csv"), createGraphs); double nPooled = poolingRates.values().stream().filter(b -> b).count(); @@ -127,7 +127,7 @@ private String line(Object... cells) { private void writeIterationPoolingStats(String summarizePooling, int it) { - try (var bw = getAppendingBufferedWriter("drt_pooling_stats", ".csv")) { + try (var bw = getAppendingBufferedWriter("drt_sharing_metrics", ".csv")) { if (!headerWritten) { headerWritten = true; bw.write(line("runId", "iteration", "poolingRate", "sharingFactor", "nPooled", "nTotal")); From 739c036247a4270b046d0f0399042d848d6b9a9b Mon Sep 17 00:00:00 2001 From: rakow Date: Thu, 7 Dec 2023 15:02:28 +0100 Subject: [PATCH 17/43] Allow URLs to shape files on command line (#2987) * allow using urls in ShpOptions * more efficient geometry joining, update tests --- .../application/options/ShpOptions.java | 142 +++++++++++------- .../prepare/ShapeFileTextLookup.java | 7 +- .../network/CreateNetworkFromSumo.java | 2 +- .../FreightDemandGeneration.java | 2 +- .../application/options/ShpOptionsTest.java | 16 +- .../andorra-latest-free.shp.zip | Bin 3236913 -> 976713 bytes .../org/matsim/core/utils/io/IOUtils.java | 2 +- 7 files changed, 93 insertions(+), 78 deletions(-) diff --git a/contribs/application/src/main/java/org/matsim/application/options/ShpOptions.java b/contribs/application/src/main/java/org/matsim/application/options/ShpOptions.java index d4c7b45342f..4537c88bfb9 100644 --- a/contribs/application/src/main/java/org/matsim/application/options/ShpOptions.java +++ b/contribs/application/src/main/java/org/matsim/application/options/ShpOptions.java @@ -7,9 +7,7 @@ import org.geotools.data.shapefile.ShapefileDataStore; import org.geotools.data.shapefile.ShapefileDataStoreFactory; import org.geotools.referencing.CRS; -import org.locationtech.jts.geom.Coordinate; -import org.locationtech.jts.geom.Envelope; -import org.locationtech.jts.geom.Geometry; +import org.locationtech.jts.geom.*; import org.locationtech.jts.index.strtree.AbstractNode; import org.locationtech.jts.index.strtree.Boundable; import org.locationtech.jts.index.strtree.ItemBoundable; @@ -20,20 +18,27 @@ import org.matsim.core.utils.geometry.geotools.MGC; import org.matsim.core.utils.geometry.transformations.TransformationFactory; import org.matsim.core.utils.gis.ShapeFileReader; +import org.matsim.core.utils.io.IOUtils; import org.opengis.feature.simple.SimpleFeature; import org.opengis.feature.simple.SimpleFeatureType; import org.opengis.referencing.FactoryException; import org.opengis.referencing.crs.CoordinateReferenceSystem; -import javax.annotation.Nullable; import picocli.CommandLine; + +import javax.annotation.Nullable; import java.io.IOException; import java.io.UncheckedIOException; +import java.net.URI; +import java.net.URISyntaxException; +import java.net.URL; import java.nio.charset.Charset; -import java.nio.file.FileSystem; -import java.nio.file.FileSystems; -import java.nio.file.Files; import java.nio.file.Path; -import java.util.*; +import java.util.ArrayList; +import java.util.Collection; +import java.util.List; +import java.util.Set; +import java.util.zip.ZipEntry; +import java.util.zip.ZipInputStream; /** * Reusable class for shape file options. @@ -45,7 +50,7 @@ public final class ShpOptions { private static final Logger log = LogManager.getLogger(ShpOptions.class); @CommandLine.Option(names = "--shp", description = "Optional path to shape file used for filtering", required = false) - private Path shp; + private String shp; @CommandLine.Option(names = "--shp-crs", description = "Overwrite coordinate system of the shape file") private String shpCrs; @@ -60,22 +65,72 @@ public ShpOptions() { * Constructor to use shape options manually. */ public ShpOptions(Path shp, @Nullable String shpCrs, @Nullable Charset shpCharset) { + this.shp = shp == null ? null : shp.toString(); + this.shpCrs = shpCrs; + this.shpCharset = shpCharset; + } + + /** + * Constructor to use shape options manually. + */ + public ShpOptions(String shp, @Nullable String shpCrs, @Nullable Charset shpCharset) { this.shp = shp; this.shpCrs = shpCrs; this.shpCharset = shpCharset; } + /** + * Opens datastore to a shape-file. + */ + public static ShapefileDataStore openDataStore(String shp) throws IOException { + + FileDataStoreFactorySpi factory = new ShapefileDataStoreFactory(); + + URL url = IOUtils.resolveFileOrResource(shp); + + ShapefileDataStore ds; + if (shp.endsWith(".shp")) + ds = (ShapefileDataStore) factory.createDataStore(url); + else if (shp.endsWith(".zip")) { + + // Zip files will only work with local files + URI uri; + try (ZipInputStream zip = new ZipInputStream(IOUtils.getInputStream(url))) { + + ZipEntry entry; + while ((entry = zip.getNextEntry()) != null) { + if (entry.getName().endsWith(".shp")) + break; + } + + if (entry == null) + throw new IllegalArgumentException("No .shp file found in the zip."); + + log.info("Using {} from {}", entry.getName(), shp); + uri = new URI("jar:" + url + "!/" + entry.getName()); + } catch (URISyntaxException e) { + throw new IllegalArgumentException("Could not create URI for zip file: " + url, e); + } + + ds = (ShapefileDataStore) factory.createDataStore(uri.toURL()); + } else { + throw new IllegalArgumentException("Shape file must either be .zip or .shp, but was: " + shp); + } + + return ds; + } + /** * Return whether a shape was set. */ public boolean isDefined() { - return shp != null && !shp.toString().isBlank() && !shp.toString().equals("none"); + return shp != null && !shp.isBlank() && !shp.equals("none"); } /** * Get the provided input crs. */ - public Path getShapeFile() { + public String getShapeFile() { return shp; } @@ -94,8 +149,6 @@ public String getShapeCrs() { public List readFeatures() { if (shp == null) throw new IllegalStateException("Shape file path not specified"); - if (!Files.exists(shp)) - throw new IllegalStateException(String.format("Shape file %s does not exists", shp)); try { ShapefileDataStore ds = openDataStore(shp); @@ -108,57 +161,33 @@ public List readFeatures() { } } - /** - * Opens datastore to a shape-file. - */ - public static ShapefileDataStore openDataStore(Path shp) throws IOException { - - FileDataStoreFactorySpi factory = new ShapefileDataStoreFactory(); - - ShapefileDataStore ds; - if (shp.toString().endsWith(".shp")) - ds = (ShapefileDataStore) factory.createDataStore(shp.toUri().toURL()); - else if (shp.toString().endsWith(".zip")) { - - FileSystem fs = FileSystems.newFileSystem(shp, ClassLoader.getSystemClassLoader()); - Optional match = Files.walk(fs.getPath("/")) - .filter(p -> p.toString().endsWith(".shp")) - .findFirst(); - - if (match.isEmpty()) - throw new IllegalArgumentException("No .shp file found in the zip."); - - log.info("Using {} from {}", match.get(), shp); - ds = (ShapefileDataStore) factory.createDataStore(match.get().toUri().toURL()); - } else { - throw new IllegalArgumentException("Shape file must either be .zip or .shp, but was: " + shp); - } - - return ds; - } - /** * Return the union of all geometries in the shape file. */ public Geometry getGeometry() { Collection features = readFeatures(); - if (features.size() < 1) { + if (features.isEmpty()) { throw new IllegalStateException("There is no feature in the shape file. Aborting..."); } - Geometry geometry = (Geometry) features.iterator().next().getDefaultGeometry(); - if (features.size() > 1) { - for (SimpleFeature simpleFeature : features) { - if (simpleFeature.getDefaultGeometry() == null) { - log.warn("Features {} has no geometry", simpleFeature); - continue; - } - Geometry subArea = (Geometry) simpleFeature.getDefaultGeometry(); - geometry = geometry.union(subArea); - } + if (features.size() == 1) { + return (Geometry) features.iterator().next().getDefaultGeometry(); + } + + GeometryFactory factory = ((Geometry) features.iterator().next().getDefaultGeometry()).getFactory(); + + GeometryCollection geometryCollection = (GeometryCollection) factory.buildGeometry( + features.stream() + .filter(f -> f.getDefaultGeometry() != null) + .map(f -> (Geometry) f.getDefaultGeometry()).toList() + ); + + if (geometryCollection.isEmpty()) { + throw new IllegalStateException("There are noe geometries in the shape file."); } - return geometry; + + return geometryCollection.union(); } /** @@ -172,8 +201,6 @@ public Index createIndex(String queryCRS, String attr, Set filter) { if (!isDefined()) throw new IllegalStateException("Shape file path not specified"); - if (!Files.exists(shp)) - throw new IllegalStateException(String.format("Shape file %s does not exists", shp)); if (queryCRS == null) throw new IllegalArgumentException("Query crs must not be null!"); @@ -242,8 +269,7 @@ public final class Index { * @param ct coordinate transform from query to target crs * @param attr attribute for the result of {@link #query(Coord)} */ - Index(CoordinateTransformation ct, String attr, @Nullable Set filter) - throws IOException { + Index(CoordinateTransformation ct, String attr, @Nullable Set filter) throws IOException { ShapefileDataStore ds = openDataStore(shp); if (shpCharset != null) diff --git a/contribs/application/src/main/java/org/matsim/application/prepare/ShapeFileTextLookup.java b/contribs/application/src/main/java/org/matsim/application/prepare/ShapeFileTextLookup.java index 6242e889061..1be1a71eed1 100644 --- a/contribs/application/src/main/java/org/matsim/application/prepare/ShapeFileTextLookup.java +++ b/contribs/application/src/main/java/org/matsim/application/prepare/ShapeFileTextLookup.java @@ -59,15 +59,10 @@ public Integer call() throws Exception { return 1; } - if (shp.getShapeFile() == null) { + if (!shp.isDefined()) { throw new IllegalArgumentException("Shape file must be given!"); } - if (!Files.exists(shp.getShapeFile())) { - log.error("Shape file {} does not exists", shp.getShapeFile()); - return 1; - } - List features = shp.readFeatures(); Map map = new HashMap<>(); diff --git a/contribs/application/src/main/java/org/matsim/application/prepare/network/CreateNetworkFromSumo.java b/contribs/application/src/main/java/org/matsim/application/prepare/network/CreateNetworkFromSumo.java index 23672056f9d..b4a3521e48d 100644 --- a/contribs/application/src/main/java/org/matsim/application/prepare/network/CreateNetworkFromSumo.java +++ b/contribs/application/src/main/java/org/matsim/application/prepare/network/CreateNetworkFromSumo.java @@ -74,7 +74,7 @@ public static void main(String[] args) { @Override public Integer call() throws Exception { - SumoNetworkConverter converter = SumoNetworkConverter.newInstance(input, output, shp.getShapeFile(), crs.getInputCRS(), crs.getTargetCRS(), freeSpeedFactor); + SumoNetworkConverter converter = SumoNetworkConverter.newInstance(input, output, Path.of(shp.getShapeFile()), crs.getInputCRS(), crs.getTargetCRS(), freeSpeedFactor); Network network = NetworkUtils.createNetwork(); Lanes lanes = LanesUtils.createLanesContainer(); diff --git a/contribs/application/src/main/java/org/matsim/freightDemandGeneration/FreightDemandGeneration.java b/contribs/application/src/main/java/org/matsim/freightDemandGeneration/FreightDemandGeneration.java index 2f52ac86d17..caec3bbf367 100644 --- a/contribs/application/src/main/java/org/matsim/freightDemandGeneration/FreightDemandGeneration.java +++ b/contribs/application/src/main/java/org/matsim/freightDemandGeneration/FreightDemandGeneration.java @@ -196,7 +196,7 @@ public Integer call() throws IOException, InvalidAttributeValueException, Execut Collection polygonsInShape = null; shp = new ShpOptions(shapeFilePath, shapeCRS, null); - if (shp.getShapeFile() != null && Files.exists(shp.getShapeFile())) { + if (shp.isDefined()) { log.warn("Use of shpFile. Locations for the carriers and the demand only in shp: " + shp.getShapeFile()); polygonsInShape = shp.readFeatures(); crsTransformationFromNetworkToShape = shp.createTransformation(networkCRS); diff --git a/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java b/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java index 8874cfaf671..441c54fcdf3 100644 --- a/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java @@ -1,6 +1,6 @@ package org.matsim.application.options; -import org.junit.Assert; +import org.assertj.core.data.Offset; import org.junit.Assume; import org.junit.Rule; import org.junit.Test; @@ -60,7 +60,7 @@ public void all() { List ft = index.getAll(); assertThat(ft) - .hasSize(578) + .hasSize(4906) .hasSize(Set.copyOf(ft).size()); } @@ -77,15 +77,9 @@ public void testGetGeometry() { ShpOptions shp = new ShpOptions(input, null, null); Geometry geometry = shp.getGeometry() ; - Geometry expectedGeometry = new GeometryFactory().createEmpty(2); - List features = shp.readFeatures(); + assertThat(geometry.getArea()) + .isCloseTo(1.9847543618489646E-4, Offset.offset(1e-8)); - for(SimpleFeature feature : features) { - Geometry geometryToJoin = (Geometry) feature.getDefaultGeometry(); - expectedGeometry = expectedGeometry.union(geometryToJoin); - } - - Assert.assertTrue(geometry.equals(expectedGeometry)); } -} \ No newline at end of file +} diff --git a/contribs/application/test/input/org/matsim/application/prepare/CreateLandUseShpTest/andorra-latest-free.shp.zip b/contribs/application/test/input/org/matsim/application/prepare/CreateLandUseShpTest/andorra-latest-free.shp.zip index 3e1b339376e4ba8a7b91164805a524e02f84b8ed..8c2e290f5820125085c0abf079248292af2c51da 100644 GIT binary patch delta 582 zcmdmZ;waFH= zLj^WxGd)TXJcgm}p^sMA^eksXzRBOxjbVzL4KmsdG8loF35c12m<5Pgw;N=z<>;TK?!Yu;3}YBy-nIzUdoXfFS{Lk32Nm85jb*S=ktXfC~uk MF*7iPKIQ}R04FJ?ga7~l delta 2271627 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ⅅ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%0DV?*JnjfSKOKRWyuPan(2KV*@ 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

@WhtLuda@ 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

%Db0DT;%{rY0J(;ZhDYU2B|@lR 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�&VBxf{`_YKuquGM_Gu$4V z5f;o{ihjiiSFdkK-0iB2-Ez+R*O<_rEkyFV-&?}0O&PLwWw~szpd%YG($Y^wkQ;P< zr667V8XEhse=w1vie)`J{y-?H?AmXTNEGRGFERZvs#-1ZxQ2m1{3sxF`L7DBV)IrL zOV6#)ws~gS^iB<<9*BI0Z{st#WCsU3S}4Kqkbd~WkX+{TMw69mw$&SVE|1g?a&Bj{ zL>>TDJVvIGgX_V-tcARmJceVpq}|XRIR+jBW(1DVPg&Snl=q+U6W0kS45&6j9EHG{ zJIZxT6Uu)Ey1f@x^7lhY`x4mAPM<(Vgj)W$RY`RrTWsldU&&Ip(Ugf)n_PyVJUL${ zKFzFrV>dcVAsGU|+io-PDGTjC>EUlxauZcO?@$!-r-VP@Kg2&s6D{BEvVa*~9lxW< zsX^)rZ@fJZy+Ykvmq+1V_Hvo&+jqR`#yVf3TFvZjV3e5}@;1Q!j}`KmBlexb<@~14 z#{B&`){r+3)&q(E;1Bi<%)*zd)A9bl;d~!zb>~>#C)WV!QXFuti)ELcy=DID<*4<1 z6^}K~n)Uw?LVd-^p#_dDx9Y;d5yx=39C8)UMr)MG>T#-+qE#dO$8OmS zOO?a--cO$dc-FB}9Eq9+pgUeC} z;zX^bTbuxKkoHQmJB4N_>u-+JW!InUZ`|_V&TZCm@M=D6u^e1(QUuKoWvkI`#94)v z)hE*}+vuX96(5SZeT=;YQiqiknl5|2j91Q`Z1-Jcac9dB=)q;SYuzG>Ikg-bw%Fvl zMfovEJAot9TLNAmC}Idb99payz5qi*zRd8;{t&fU=k7;nQl+53Gn)ZnWh9_N(;V$6l)vI)8u5f8t4gJPnxac0&`+U!>m; zk=tOk#LAI^bvQ>(^FzC|331x{Wi>BRN!8=7ULLxz-a9cuE=5{+^)}{>j%oW~nFA%- zoRa7-o!t|+5!66zro>J3O=uE|4(qegq7c4c`~svv#abf~Fq!aM#xxHgQ8WQcgWrdv zl&3E>CBo;+W8(k>aS`k%glKWQV_@Oo96dXCS$$50+Tx*#@O%^{e~R!$|3ZjCR&{-^ zRZb^h-GhX7Q0=?es(XJ6svGe<2gkx~)2!T{| z3=5G(q+>sn`54m1cWL_G1tPmWEPAk*M5_@6*ny{1nUU{~i`~0;qVJrW7F|iFp?LA+ z&8|tXZRI4w_p?4&xc$9}-D3j+fHdqq@lhEG9P$X(akvj^dl!^Z^H@27L2c)ndDX#6 z6-EB?(N}%5oij2I3bQf4xOlL+G++2sa!Z+DmD6ek1X73v${!8^EKSQ}o_IZvkRbxK zxCe9t6Dfm;FYe3UKj5|WNs+hCRCx_1HKi3^(i7EuNPamYuv4te+rE{tPdy-~6|ncZ z?%Vr7HY?p@=O{i%EH@6EJnT{&$-X@IJ^~_Ny`KNMIB>ZmeUc`ndM-0@G6}-a9=d#w z0ZIP;BsZsT$sW+))cxCGlycT&82BXa&5kAE!?05IWuo2=SluJe!uxUN&LIa#kg6;b zGBNZ#V5SXUJ1RHxZuS1RwMQVW%EBp`8-lQ^dahIWPE2Bc!eBKliNnVu8D|nWMloTT&Vo&Pd>VZt15fC@`i$* zDZ^Q>4aE`PO92Q(B`w!Zg)c5%lc)0y7EW?8!h4i6nf{oa!nqjPtEIqE4GD^x^a}8 zZ&A6j%Gniw3Q$J3<_y1;MWna~48^&s?~54E^NXkWyAasrW+b4TE~#YK^G0_EQYLcv zrO;X1hasV{xuF=JJ7ex^n-QrWdA~9KPoXXF@DMDokO1UL?${ zIn53vV`KC3hTJjb?~5IRkFG48vcz_)Wq+h@kbm}j=~^dOfA&t%24LqPYAcsxzT-wb z__^v$NPPc-+x62(?bmX*|Jc<5!zM2<-+N0&7r%QXVKl%_je)TCf$w@hfF<|xGi%k2 zUft7TCNa^}rDqMh@N79YiGAg^4`;&jiAxTp-Q%?hi+P~~rSTW$(uB$Z%{7_V5~A+3 z*oa1;)m(Erk+T)QDoyw&m#utu9NcSC@4S3LUv_m7HNnWa0!C7gXv%{Vjw=4N)pv|9 z?;iJqg>%(wuFFEhh8?;9KBvB^AtgInGiZNF-Z8UY6BGVUpL>W*eL{oxYFL+zS|4A* znlCb|Oqr6TUyZx5G2f%RD4+7rW}ue|Y(J0s}UWg1;3 z@Jcb;YpK&^LSI%jcigx$p~Y)2FQJ-a#2@eRkE>#v;$UC6q4g0E5}rT_ii?n6({}Q| z5u8QtlmPK+&p+GHUJ#PM)|YsaW~P1l)yuE-=s{MM%i6hH5aC^C7X7S;m+qE@I;{Rj z?AA+jRQqh1i=Sb~(?<8XXL4>G&vQgCegiu?6tHpbE#I8#)6*$?&1%vt)9Qqtt5LtP zBpriUJ^E&DP>=TtwIaTH?z(TgEx8{TOY=6Ozd;4XR93a|dyUCJG4A@zEu3+v)MCfXVxKV6 z$~EMCudYu!p3-LjtTvqqT($4tDqsd@$XS1GK5!v!e2GR@q@A1?O8> zhL^dz8&~`}9bC&b$Z=W1Rpu9xZ0YX(LCA92@m?!>IHR0~ufovp=Y^LOa1=>X9nwNz z5`i`khBI?paWpQLl|bjWl&!uzj)zvDe`u|J+7KFhpzYCKc_m~HvKqONyW)p2pR~99 zN!=GRa4EYLXU3bBuw_c$Cy^4Wy~c@9j4oVSgJl7DpI@OGcO;e=s5Qu(8uNU^E^UWg zTUBmyyBf%?Kj!y!T;(QOG`=2iSFZZcZ-3YuepH)cFm4E()L(}4{8oS=`|s=Y4pXW&piy!{%zI76Ub&Eq7x;g zPa%M3W5cZ+*!^>%I5U!%{G3o2E>a|=t?(#))-JS=YrgMNdpPgtyuJpzKu0LwZoO8j zmogfY?XeJ7Q}rvqnHM>3l(z(sr zI&yboPdv_#?|KzH9k0W;&JL9>2Gi}3Lqy_EDrX`+_YG#(CKyN89)Eu2Wi8ER;(YZL zmP}8aWfk+E{kk^(yd-38NLryfeTe)0>lv%3*yd5i(S%oY289^tu3~%e-e?tX8r##Q zBJYO=oG(B&iUGv?f>ZAlGfg_(fl%1v3&)6;#}%$kq%39?&4f*ah6``gMkU$e>IL#C zkmY9X1KiTMJJGo3_AULL`Hnw%U~zM03F`l*|E>-&6kL+=$_yRzCPEsRQ)G4@6rrOR z(p`dLcWW##=OH6afLjf3zutmh1F>44j^dU=j{-49X({Oi=eb02)p&rLS#~&L%>KQ4 zhZv+XfoVEp-@X%wq6yaCo%eUjZEDZqJEue`+pj$*RvDc24nJ9_vh16RRZHT_*BcU5 z3uO1rnk@G8^tCho%032CBz%(FAmg_1D#G2Tdk;DL#qx8$Gs7+)ISX^zSBm{AAu%Aa z=$H8??`P9K74p5ar2)2Xw_2Si{Jh3nzFRj5p;3 zj$shAWw7o>5OiWbp8*EPC+2u!^U?VSJ(63BEmnR;(3X_l7%mQHHf%(Gz}na)z5Hb- zcx_i+-12R;T38`t>bd6J4Q9+#V)lj;gn|@I7=i0q*Pp}N2pF7>c5*;`!m1i(8~Ui!AP)y7&=X$=>{I<9;w<2K7y3 zLbpc7;B6k6`!#+=8bA0#+ay$(@2v~{;14fw$k{|x#kM^sMnWq;cv-^IWG(50&o2L>MXwZp(L43BrPOtT zvDQ^;kVX*)N1=_ifmYUw=7akQ<6i4My$@)4x7oCEhJW$sZ0rWV9$_S4b~lEfSYD=V z1!{9R5?342&PuEtMXS3?(|V1rEfq6Qyi-C7 zBgyGtWsI3S_~gk&za$Oj5_)lmkh84Nc;^7bOD|&&Yqtt~v;S*}TrtfE z9Z?9HWY<+Fmx-?I$?fKjzGX2VldY(Ny$Nv4kvB`u+iAPnV;wgpnCjZ~Tfm)|_aJYR zldo*q*ois3xc58X%Os+Ya<0k=W|3!N(C5oil2^F0ePEGZxX~_dNC@flFC{1>FI7L} z*qUY$xuK<)691w3ZTpv^^JK}tFux-hNEMRn9-VLkTz+Sn8LX?!?r&w`B}%V72F{H^ zi9+*Z8k=qYl;?V5bB!D$(@MiG%5#HRG+7*45_i5Fe*G|?;tQR-!cH33uUvk!d=afu z7pB!H5-HTRw|!5R*n)bC(>h2e>H3}lk+~+;zR^J(xt$p^;s;5k>JZj0Yg{a?W02-} zW#;g;cI}fudNL%;w#q}@!o zDT0giNaXwx!)EO1N_MJSeN_*v+$X$K#A~}ZYwz03^~K6-Susq4x7Hc~2wXJ&A`JXC zPHykxA+$*oy>2PuKkAio)vq0b&P~iwfTTDY3Bn798itt*uB6_<|JDq#wlV&rr1VX$ zeSxl&XKJWz7^>JfO}mRQwLS>-RY0-so4N0I=EfvuY@gZgAleRoo^#Zn9qHbgh%nbd z^L+)BL~1`jYj51yj0OUHF3+^!%!{h+Y^UNz$$aoTKhDZn@SNiLBL69(T10aq4`KOF z8yTB5A1RETU3`_tS&yo|J>T*3ez=?bLm^S==~ZZrMJajM_r<5NvPRpi^`4*ho`h1i zX$^u$;D;MT*KvFd%fW9QJCJ%e`W9GMs`ZZ@YYOI9@fy07n+JGv4f$Q%M6*xN>{7*N z&9)B6puMvmnk}i3E~+|>{LDs0&fYfuORfG<{?W%jKgdVH`}bP_{?H|wUZdGtLL_!P zHbw0r%)(x})|WfJ#)_z38Gq{jPH8CvR?np?x!c}wD0tRUv^T&|+HqoHPrwM3wyN133{L2=;RnNN=+0AXHSG@KY?6~C`ZzFxzAUY*DVlnGP`D?7b zG-C>ji(?*6eFWB*+Gz(X&eC_5EWisX1ya3J`5f1i`z|uwr339hJA}rHjPk8?cp0%B z3D$6!GITJgC@KbHWsGH8`&KA|@xJJyjw@CA>2Iei{)5p}PJMfy9lWHF?sd1uHwE19 zcO(96)kju+2%G&{GMiq8;q-h#D=dW(W!IYQsT3Jc z(hl*@-q2;b+Ijhqv$AAI<~;!Efk|G?A4<)dEM-_yZ5bwIPTz;4 z^nm!#PYL~IM=p~OKO>P>sT^#On6xO@j!Y%wL@8^`-r-KNvd;x+q%`xfJbS{GY33kC zw{?!`pbtuC`Zq@Xh9<}6@AT~6ZpU>;LzKhCFwY#&4Z`WmfM#N|G6T_SyC8QsM<`AJ zI0roWSNwB_o5OKe(<939{^Wrc7FnVy8G9*dP7n&lL`m>1c8HW#peeV>GJ^-N0_)|t zO8T#+g&~Du*EEsfEgqqs&T@WE(MOl~TFV<6Y&J?6VtXn7`PVPyj9GNs*@d3m>Y&5D zuAk5ijXQzb69v6Iswqw{437J7wyD5Zp&nD+Kw4zol;J}@)9ItPZL!15{l1!C*J9zA zH2`6E;nV8WPak@MW{NVI`TOQsS=R8jn{dL*k7%|*yT~6vjdRRAM@!BOk1$I4AGyiF zP*{uAC%bL*lxLvo1(IPvPfNxg3o3ga;Apn0Ge2EQ-KzXQK=8HT&h@Qe;aY%mB(Fnt zFj1iEZFFW*L-0FkZ@w%H?54T|8a!N~266p8TIdrP`h6U;uJSv5p%{whLo`@(;@fg( zV)1b}`^P11Y?{h)^k&T!BpkDBCa?FZrLy@|L`8aLG|BGe?9j2OychD9@|~Tfp>Tx4 zbWQ(gZ)WnvXv2>1CoOw=X8>K$Xx@~C?;uSGRd)H7LL_ZC z3U(KXYS?L-DSWgXV17Q;61NHXX+wf5?z~O?#8OO5FwD8ol3gXX0qJ$|IyiX?@J3(z zM_eR>b^$R16QJcGd&~zC_4#)()Zy(-|9q%`_^~M{obd`C;pR+lq#qz$E*%tk*?hNg zWAviH64taQ#a*R$PdlyG-QY!jNTk)zKE0~(ChOB|J}ZGHUR~fu%3G}f*JyOE(_e-k zhnqY#{}vuB1f5Q{1ITUve86$EVB9-Al-e=W^MRv#&#Sq6iz?pqm5q12FXfTVU{%LM zkgG`1%QF}UDHrW}0bb;Fn9Js(XeB*vC<^$wrgidpXSprNjZ1Mljf<5aYy8ii+DFV*ZEd8kHrP()DzT`4c2)a`$!o8%kxM96;fB_BX1HKU5HOJ z+_NO|K|Imk@<7|k^f@`yB2JEeD`ZhPm63SD{MuY@+**1@bECjT@ zM(j$&{4_#gojG^t;^G@@3xB7DpkXQ^w|b|!WMF&>WoT>;R|5tGmqIx`=`(C=LLg;X z5D-h3L)IcfKmtT*_Bxn9^|!MHS^eYpRp;kDt6|TGeR~A8F0GcU_Is(mK9+}&u3vA2Q(>KBP2g@rB-C|S=w8`gtM4LHEz zlP&T2&}LWIQsX47lHux-hl}4vlic~){uUmJ*cun>fqA0tJg|0KJ0y$mo{!)V{FXt- zBVmny|FYe5xD0|s^aSg$f0Lw@ZC@)EHyg1IrBw6#)OAi^W&yvgPFrnWGVJTNV{|5} zbcZI0NN9FdElt->!)>J|sfX2s^Z{-}KwIzp@|Hnmt{`HpzjAP@E2yqWNB<)=Y}(wM z>QuHRwWKpV@S;|G`S%+AGgE~5;7d!H5BdJZZ{$1i9QONS5k_RvlLHcF+5hsOz20@S z7*&&2dqK;lZPkG8>Rr}kWoqx!Kyv3OD%%&nV2N>*A+x@tfo@B)@VtpT2G~b~dT8B7 zZV!5t^2P$x-b<>{JN9JyBwqEliT0Jg@YMCa=zzT=MX>queCn#n{0h<{t|;hTc3r-* zt)#ej6JNvP<*K_EeN2C5OY0zY4rHGj)ysH=-E}E$AIWSoBV==I_*%w&&R;wo(@{6-N(NAU%xb9i0;u9k&t;&CToc;(OBi zbragImGK6*@AGC&h#u}RxY!<;OcD5FOyv8WH6M%ZL^DSYD)zyYK0@}FRbV?zG0mL0 z{i#%-Y5Gb3D)r`8@R^>%2HR=o`~ww!$dcR5ksn(&Arm3OM@KUNILN1VS);`e<*=qLGk( z(5gIrW`eD>ZMCLrm!`g4qm`qW$%xMto|+;i9XNi;GyDFHYwN>{`;HqgzaTikz>8CF z^Q!v7UFk1~U;e-&yD-rUH7A!B0_JUDmL7Iek)Fz9%<8zZt!;bfcRzi5((%mxwQ-BEH8_fv&Se;28Mprk+Zw*cYfDl7gFD2EF{!&6E|24|kL7VsxyDL~ItBA|7u zXa|A+Ss}|jeUx2sR_msOthrtYIbUwfICEEB?gnp7c>|;VuLOcl{vzb*U;?n6po;*P zbGp9}jwx$@Vah&QRXdo%OhTOQ>4yP;$hWRU9+rB4H$|w($GRvkF z)~$&G)Y1A#_rK7PSzqfT$%NR)+OYrVqLYpMRxf0 zF#%ocU0URlv(O-fwTpu_hs20f)j)XAW~IErwQ(;Bp`9R+L-sY(rqE#1zQ;|Tv+=`m zudB$#Iep$2U;2LM=Gc%8*6#WC^V%&na;>388@2dzK9}^LNJfs|N^GH?r(5aTBA|c} zx@H0K@5?74zVJ8I7qN?(jW6+%S#rS#HF@c+guYYBER_GUDGC2YaRr5s{~UKfYlN?+ zO2g$)EU*er-g~f!m>8IG44ve?SfZ3gDV#2WVS_%TgYwVHv4PNu|9Z5D1x?yY-Uf`d zll(?|Lc!*yLc3YojJ2~uF~vBt7XWI)x|^Hx%i;91P$T*c(CrbgAN98vUYtIJW-cLa z>}S2p12?&uuP%p>Pvt`0IdkD3RCO!QpLyzJ7~~y+^>(Zt?(#tjP)hg6&V=OF8b#U#h zno~uISkO(E6cJ6dJ>L$X5}THnWAT%(#ucy!A151@{b}OuEw1bMyxMlWq*-ZKyz`HFs#-KHivsZinZV+KH2*dnJ zqxkSzC$iW1r&CEQ^o^-kp)u$BwM%bqor^wqI()^=wKd1_pcVI@5P8vNAVmAvbc1_B?G!BLE#vDslGT;6RCj(CiDZVe7qJ=XyMD;ww+f+ON zizlVgKan>cRsJ(Tedzc87|4!|LVK5R?`A4YSKkOq>riipH;$ct+#?R29G*&ENj|(X z>#1>wn@PC+wXoOw@@Vk`yku>tpW0W&eaI+uWD$||*U_Qy(gM_C-VE-v&U)-#U1GUB z(F%-?0E2D+&KOX?vW9J@k!R#wy{D25>l&zKf7G$^Ug0Oc&33U~z?w?d$$cczlhZA#o)H^!=ox5aA2B{IZ(3AJq;7sMWhvQ*&s z(&cD(g7RQ#fBJj}mW$aF7nU&Us@01l&PAZL5XyMNby_Q3rROvM^6fuV7GM6!QS?!k zb`H3!WwluQc);JY9j(@??Yx}HaOg^E;>+zpX7B#uMYSQU1^071UWW1)B3l$soVv5O zh2ma26&$~AU+{UrF8g^CoVRtyArL@>J{ha3SR&uq=xb%U^k=fNuYK(Nh0FH4MD3Q$ z7_cb|B-Z-QBnMFAO0yKA_6MiDoRL$bgYVik|NSA-6c}XjuIkL zf~1tRG)UJjuu@Xe&9Zdw!m=!|_3%H>%Xu+zX6Bsl%zfXV>x#H5NH-Dnkt2Z~dG4a~ z%Hj{zCFFx0b9dAjRl4%>>)QGc+(rcZanwLUs8qxXPbPOi>?w)uh}W5KY9_!c#QOL- zL`Z)9-qQ_5_c6Ap$LoFNz@;0Ai=rvbkuCKethhWBs)m(yQl`n_R+oO+7&XmwkeOlc z-WhZ873bwUncR{Hi7l3>`Lq>2p~$=KNo(&zSt8Y>$X%DpX6D#quv{|e>l&%fAR z&dVvRys8{qu!-4u3yb`PI0k48nm+A)lne=CNrd|7mvtQ#TV=-go|?PBPgAFPR;NFZP~=CI>1kXC!EqZ>?Ss(paw>gaTWH zU=Fsk-p1A``%_!;roy82TsQO19NI8@F0Qnh97I3AR@z}IP8`JY6^_PoAG*B<9%Uz* zceezyrhL=Emja;|Pl|iO;!Z+C4t$VrTS37*JR2DY{;yISHPBl#Gpj-S1GUt}WRSma zy+2n@+ESIKM;T0&SqJn$VTh&r8uy86kWog@;48hsbbd;^qxRfKQ;Q`R*=5z=`+4#| z$r4H-K$F^5%GG1N!J}%ZBzmX}I%wQ>eP*=qw7%NsGoZ4+Bnwe$fTh-wrrG;*?H>L-7eFxK8Ct9dvV(M}qt&Hw$S zJg20$t{OqSyII(xsxUd+H5|g_G$X>UxZjGpP9V zBkcb8%U!%pmUVK;T%##_F3gtG&7v-DwO&G}T`6q^FTd4lf;KDrX*<%+kF9$``%o>) zBaNse->@eXli22v_nd6a$J$sBzABn3WTGDgSmxlrhj5+(oPq03AS{J>`Cb;%kd9ba zN+2zz+skv|`V>QA6;jd)L#d=Hyve=q78G{QH~CDrSo28o?x&sE^8pigiCgqYBezVh zWS&vB>ciYmCwqW`QR)RR%X|)5iAH0iilKy{^tyR9mTla6%*~!Ng`Rta$|*3XSRYVH zCRY;FTcI8$sIc{zU*Pr`3;5Ctt7G4KnF^(gxFFv4TJ-``Drm!i*w!VP`xQiq+s=gc1aPmd!GpX<4e%{Icz z5={;yb^cC{lri6KDswjLA7Z!H9kqsD$fw||`k1JMAd4HeQEN>8kc(&dwgoSh#Q%6& zdLxo>{fqjKx48(Ov@)lq_#e@0hVPld(Vs7KlFg&c7BWuCl4fQ3)DFH*4-p5=wz$$M z*8rzKE6q+rE1{&zgpG_KV6ZHrB!C!JJEc>a4<||l&c(L>fyt$MnT~Kvn|ya*(p>XA z5ah+5cI)+(rjIvUNbD1jap;|(COD*vC4pyl2_fA)LdW?}B4kg{MEWRId{{`y1SWrS zZ6CYkZ7vbFhKoNEiE3;66XLwQ_U&$UC&jF`wk$?aX(?@Q_0}Yy_w`L!lYr&5c(?0r zALy3KH#cUY+HJcG)Lhn`uIzqrI3shEFN+p#HMTz8gWTKI7(s#2Nj);vo+~Zht0G;m z^kpe66ODo^HG9mr?D0$Q?c!pU*<5GANj(OzYr*a%HQZ082)lpRU=#Ga#36mO+6BDkxjvxso?p;YP%EbX71MlF6xhLL26zBhV2#75&z zR-;f;mB73>{r~HYgkHLxdPMNVN}0*tg(Rb=!KkuEXe0XBw%i#I+MAt>_0H()a7(Hw+&M7M^ZwD7y7van zn0@l$>*e5{Yx!WHNtyq2_>t+aG$^H;&c~*bw;~OZp7p&3fXmf_0G}DSo$nU(>(g zR;{uoPmx-{Ls%)C{VDnA$7t|aAl?IePCMAx{kCPJ^yH<@(7m-Z3sWo82w-iit8SuwZIc$WD0aOVV@r=yE@ekw zrM{EeTeC)8Sk+uYJ>vhTaQ$+PRbkH7gV}*3yyx9TtEOI031P)LUo#fr`~$^>kH=fWlWSfmf4KIs9xc)xH^;Cb!2eHL;einvQ}}VZ0`$A z9WP81<|{BmOtCu3mQ;*?(gS`Rve(|UI`a0<;i`~9c9c+aa{bHaxrGX@R2pZrvd`s8 zz5$#~y1}l02$i_7lNa8osTsco;pX-tQpsd;9@<|C_=QMh%kFzuVKo1;BC=#geKXU;+IkR)%Z%e_`2>u^jb=iX_XBD~ z2U0gx`58e~y~H5H&&Qr61f;jBFpt%yL6R-~mX*{O@YT%4`1%EESb1e``Zd2*zb<-< z5khJ={?9la)4@5^q5XUy z)FgP1)Bx;0+b|v70wTn#0vJU&DYrP3l~gFKBUrRmVHzF?dfZiRc&b+2$7;@FmF;#R`72G%#CnZY>{E9w|3- z!k1Eo-+LpUX=u1f8gzZRy_Joo!=81CMRrVd~i~wj?vdlBfgNSmzN|-3QM`R9n!keN0>@m+s@>UTiPF8 zB6+vk-$}^JN>X@rXFjBPaoQPhI_KG@c5o#CJI^Rb*7^C@qpbRmwy?R4>IFJyUhBx& zDRM>tAfFf9+QD7F83nz=tOV&5$eE}5{-)kilRB2FqmGezpzLa-lR5?VyKVbGktgwGY<5A)slvf z+m&vx!sl&MACH%pg-e|gp$%Q%gRjwrh6TZ>U&5ly#aLa&P;39PMl#@e9wpr+OIm-*ZFj8v#VkLFeuL1On^wLU@ z$a4NFQN<$fG>e%KDL+B?7WCq6)!EIcc){R_R|jr;I3bwLBPQ73iAq=w5>aJk(&HF? zCuTQ+7=7ot95nnavW#19+N4hFE;I+{7a%r;qJrhn!Xb)LzkpXb-F4@hR6UYBSt6=R=2#={UXp71#5_G0}M7G_Zj?t#as4aVT zkXC&9=(uq(eCkU+=I6KHuU<^FWgHil!D4sjJpZ$c)bI_>c|HG4>VF&XpY%}CI zIrQN&T;dZIk?$Y)UE=9J15F5P@ImTkfeKTdGT$y%JTChg&?JX>b%InPEEm`+#F1gA zM?IJEf@>mGsC!L_`neEJx?_7!9kve#Qjv#*yz{3oa@TkvUuEhmoo-(eJ&;X@_o7W?N<=yS9OF zD8T;7qprINW&Y8r{!?u#-m8@yfJhV^t@8}!5r^kir-I*jd97T4934iyavu7FIyObN*mM;WlhExYjWJT`a&EZ zR25CxTu+;=aigItKYu_M6`-R+V#Ak^7uoe-4El0;YiQHKcD*;=8U$n#6Z#h-!ERf= z;4W+Be``Nc+W{cN$y7<8O`Ete{|~B6uab&m+L^)ViCBv%7W}n+ndna`~k}>x&&$FZ989l4w&#hagrL&WmQS5`;z$&Zn4i6`qlklPzD5o zM&*gSoGd?Y^I!f8Ddp~MYA^rF!MxO0SQ$ZK?BSMwo*vg!S=^v`D*lG5m+KK|f!nE! zy6wVC;c3;;v_~_jDoQ^gS2<=m|j*9C>O9p>pi%;iZ5qiFt=}6iodh+~rog%|clR#CttL)u^7^>DM#O zefD&QCW8=hs~be9210E7BI}qz6DaPQp(oPjynyx5Hj{R^m*CpP@%P=>1S>vT`{1 zp6(5oMZ^VTsktTKk29weuzJ~c07LOcyK~2k4q`n=u#;3Uq3qHzlRo^;*!t_KxSL@T z_t-`LfvuGK0{jP~4c+u{e0DKi%<@2xZez0Y+S=oBcot^s2Lmd{?BjW%oy=LmSEhd69rG1F@_h;Mq%l;aZA zkYX`h*IWd7OK&I9XAnM}CJn4qDNu3e`kYI8gA5FFvjYLMRg<8b!AvvT4+ zG$)4FEEVpROeb7?aC2`DFh1@~sjA#PA)ofT#f__6p?wvJ%Yd0)z( zDVT+$`#2g)9Z-NZSfTQA+(h=j=vQR!Tb;a z$%X9dXel?#wa9rX4+Sfh#Y`upup2LyQV3DCMot7bMHla7^TT^&9|_-Dxp{~Mze8L4 z;KS8VLgrod2OY1}gYbMxKe5irzDDklOERw#d`EUUM>jmf>CV@BmBZ`upHww$;l(a{ z#$83xT}JUWFNr|QLA^>7)#lZTmI z8%T)OGF+wO1HFjNj&d0OH&RiFLUwu_tIrvnj#;8vY+4jlyi#Ru)8wse;q7Kj4r;c| z^evz*st)}_x)&%YQb=ok8SWZkh^IgKI(JPgRfD@W0?1^BzA3@}s#bdh)(_igU8iY$ zLp+A7R(ZXkpWtqgx8cb8SNMp02U6u{+Q*%9_yI;{kPQ1+(pdDpKLpwM~hQ0zgd24!uJMTba8GpkKx^}0~Y1~4*zWiwq z+cKM?05+CUSS07&VxNs0LlY9i-6^~Du1(0?=zM9p!=T zxuG{!jw8N1FmuG%kiXo;4}`4nLq+75Yo32xFX-^jLPZ3mAu;i$I(PwKVJ5EmiUBLD zSo1bM9%^DDWg3u8uRZuDJDhSlSnI6o(LpK}(6CK}U*Dm!F{7KKu`2WToVq`&FyIBZ zN>6P#DnSG=70d`nI5EOrD_l(&|FG)Wg&na343k&U;M}B#-q(%VgA&wy0)vZ2V^ydx z{k*pdA-E*bNz4lgQ)j((mT}u>(iPTmnmshtb48ipMi6kLgg6)G_bE~A6cS+ zhl9Vg7z3Q%v7>UH2R@*T_#D91aa=$_cM37!z7C_Sa%Jej1j;*I=zeYUt2#to_fKz| z+oJDTO02zcA{*szDH)(Pes0;2E!IU|J@nr4Qe}Rs=;3W6*fZ5KhIP~9b3eE9=kJ+1 z=SpsTKvU&VKJ&(ci#EX_z7}1&US{+a;9YYvg$T1!KT}qR1Xzmyx`z`v&w~U;Vr`9T zlBC<64@tUTr3~x{`yBM`O?fi=DpS_c8Efo`&?)0byl?t*xF9{~K9V&DPxlodk+(>% zD=UcZZ-Q>{CbM_&tMU9kGz=Oc*Vev4oi!%Aa3%l->V6Ly$PwOWE=rtDHDwn_A_b9R zYK>h{y~cbh;g6QBmD(vrGL!r>R%h2WqC_sPIL&3V>YYYsIyGLM$&@}C_Bj4NsUd?z zqiR70bt?-8IF0tO0J#wEfzQAwlx4x`>&abKn4~<5m7JF~oUM5~X;~x~v^rnC{PCUK zv-*EumJ`lO`A3N?BPYSD&qs!m-aOGb-)OIZ@{ITzmGH1O5(*N?IL;GE0AI&pJtA5vEOw%}V>?K|b0QY;k*D?Id zT4q0$%cXbg?{BGH9}cAhwVCt;S=)(-{ERvE-JNDK82qK8+$tq?l|*>z^f8Nh>^z^Y zc!OF%_w~PDh_&egV#5k>bNLzB8fdgxv<(d1&=on(N#0Jx*8KUE=Cw`k;M?^oI0e<$ z+DQ^&LzUnD@z0V z9&kPsfB!ME_oi4e&W=y|ZR}_vX)wRkdO&J6$aU}^Pnjsbc3lJzelXbalbVif$o~{2 zV)Z4u^;VK|R-Uk`MPKR6`L_2+3ii z_{-MjE0<#8xv0AHG`ug~3ZX4J?>yoBkz_wm8N@PB;L%p19A(}e6W31;O}I-uq!ShO z967^AeCl;!at9O(hC6n@R3(xUmOjVSGmYUCmc8@~@i0ge!3Ks$H1^L8Lb>`H-$oX@ zp^Ebm{GOt~)#A~a_sFGSUd&a0sy-HjF|nFOR{vX2$$+_E!9gbrQmd(4kxeq7ce$w? z3OH;?OmBluSKya3A?ZEUq!Q_ZHf1L6zI+k-|%xC-oR9`g^ti&TVk|poAIV6vf_gl8}$*ml?Swi^d z8@+(60-pT{?pvu@?a@2lnA7gOq2F`6SrDD~gsAet#?s{_YgRJe6Jrp|F&RRamK)Y# z25GqH;{8oC$ZMN$h-z^|`k!27NbL}AcjL&CzD}!X5qx0e&b0^@44ri_v1s`{Mz^Cy zB`VN*-Dw!-svYj;(ED)tCsFZ103sqP^J2TW6R1w3{qQD2&|=ooq@v@jg=u_^NTSFE zO}6CSTw`|3!Sf$)WOd{mur{$ODY_-!#O(6-id5A9^s=WPct+ceewlg}|32`|Fx>V& zYtx?!9{>9kbpI3|%kn^k4Ks3R`(ObWjH)H;otzYd|M>Z`gIum#3wI>rt{qkj@u<+` zLV)W+V8lE7`%wEYr7npYR=no@i4CKv+ z68=!$+No(!V_eTQ1d1^+Ce{UQk~OWMuQ60IXIfWv&e zMJ^Q*f>AuK?)ve8wq~9Ssd?O05a3>pEGyf-Eqk%lBId;qz&G7;$(n`pajP ztOi79NTVBtj1~LWED~}LIYHk7vYY~d^OAlMOXbaK2~yFJZV4XE-)l1Po&*~t!%!5C zQPbB%KGE;c{N0;Ss)N>#1i1r7vL8)F6{Q^E2^t6=)2q2wx-^<~8HQ3zv^u1|+HYda zbat=K=N~i%IV`=C;g!v(OKn^_Z|&Vny`OnU=bNe9Qd;%>(DMrv)Q;X-8!Pp+ZQLWr zfi7W=7XXqg1G#Z0OF|$3A359hjSN-jr()lXulJkW$3VPn)tQY8$wu7fP zGos$CG@zZ>yL)GLZw)vzUH|T{iQF24rWi(b!H&X};|(%js3*D)ohfnZ`Y3?He|W~UN^ zj%bgvGT$@?KPvJP+4i~%I<6*GLe5yb=xI)Y0+eCc45yt6fNTjq)L*gsJsSGRPD~Cx z5YPPBO}bhPDT!{-Q}s;hi?@`%IY=t+ici0(qcLX7i z*$pBf?8KO0`yZp)!E6R?>1Co8g{yYb3;G=u3T*J+TG# zTNrtNem?JHIj%_sbdk6j%+NvZG;r!b1YhTtRVYoj$Un$?!qI4|&>yXIvG8T(?unL* z8TI)y0iWpaeMk=5>eH)@%}kvr~oHkGlPnbvqn$E3Ppkt@4Xb@gBVYS&@%`u!)~ z)!eyCf1K|Qg}_wTy1Cj^t@EvUBqsC|mwA7TMU9~4Xk*iTl+tt>xbfGh{<;l}(dF&b zBx&ypJw~X-JzI0Ju$45&JZTx)2#RBAw_5}fHQp|lp%P%Rw}7^Wn2Y%smtI+hAA3ABT=L4mp^lN3qT2Qq&jgjV3AB1Tk?>QFpw7?F2&xtWzY~^n8Pz_JIy3RCM>(H_M4<63eZPTzyz`An5+$%mZn+Byh0lrad$T;?+XFtDl`y^x|h{G!&uy@8z zEX@TwYz(iRm!#WrCk(dxw<1aHoThk#Z;%8s3iqyGwh4r&O)}`?wuqS=#C>+c4e3)jR@Y+O$n{SASL(BGGDL?I z`E_3!>l+(s-6JWcJ)be}5-EqIE$>5IwolVownMAzUML zR)+TrWM4N%gG1sqi409eO)$_Ttn$NJL*IkhQ?{$!d_%4O!$3Jc2TZ(ZHgxZOw_c(3{;;t?KC`&f|1$RZd%onK zS&Sit13UzFQ-k|N{L!Gc9K-GFiWTcIkM!u7z=2WPpLURu%Frb*+bt#>qb}U{T=n#{ z8w8X${&@olJen}7W6Sf{~EO{A<7~qJxZPUhY9ZJ>|i( z4zm1A%bQ@W?JG(_1M@{Vn>kvyKLyAGK6s8}H~a^Pa4W2XKbJL;GEGVOC-aSjrPoE@ zXw%rd>z&&|J^nfTmRzzyUkq2PgFfoTCjcPG6;gKUf##ueBFj%q+hgwYFYZdf_-P+H zHeSoZ*Ru)snjr|h+srBFHlAbb=M4!H)7VMmiKOSQrGd=2^yd@ZlGMU)POlJnq>T(n zj*kuoS=}gdgZ&eReEopmK_VAXzZJa_dHPYI)t-ZnFE-}`UPCyBq@e>6(7am_FHcbQce%~F`!kCl<628|}Jag^j#RyzlYsn*%{CBizYhw@Asl(PS%iKM15Kw6D+|jy}k?-G6{zFIl zZjVz29g0LK2Dr!Z4aSRZAwFZ6e!sR*V@98HKfXquYdX6btax0D+V`Aw5JA9=&W7*x3_8{f&B+IOpq(9LrF70dyy{=5t~no!+u!lt z-`aLNs7Z0*%Dvvcy4P0=TIp)i5YD2?m0((&y@JZnuX#s9@WA1uENlMeGZh;n4GE8g zWh_xeT#7Fe5#3?-GgfjOKu20sOP1VdNYAmX<8R908MnW)>cNi&9nu& zNtP;?-zx5JW>n5@2#bjCREP?DVm~QUEf>{Kno&Uls$O`5NIBh%ud`B5M+B3&Lj&n z3a5n6JT#Z+L?pNbXd7kI*kI^fC6%fLnILqa0(5;1?>=7LTWV~6e6xDfT*ibGugFh? z-q-GHdxRq@xpPDJDOy%e<=m(WVTw*+HLOZ*23qc-@z$8r5jVESVwmBDM?Na;&6m`$ z>EAQ_A0B|x9%%~#vauf7N5EqcJ%YsnM*X8Zyj8dsVQ5ci0oKW3bUqNaLv z6JsOHHDSR13}J9b@pS#QMNR-NHsmp~RQE3BTVVa>SIWNo9eKt=ITPmttQB{RJ}+@S zVKE>Ijk|MPP~f8^29OL$h8eeJmTi<5x29nP>fqIzT*{JH$^ooYit!)=VfwbHyqD0kXlhnHJFo;v4>X znh5BRR^LY-`Ou^ELl9LUhqEVVYqfml!8uvKmcH<14POIn6AHG5+fv_sYV!t;_6rN_ zXH<{Dl2nO2X;R2~*zwmE)qSwI=d3y3^uS3^G)|4YRVxw`U+tse`H#k=cUdj-SP>iF z`ckA_*`zl65U4b@?MPTjy|xy_YYQrFN~44Yn~rH>T}~7k;^TPcXX>A-m3gJ+f})Gh zY25)-(_7y%P)>rFg~BhDXu!EO+K+(W)YHc+^E#Or-phRT`j`0aPrwVoSKKN?j*Gu% zxC-{#D$R8MkZ<5~v0(xov)%VK;`0IHJQLN84)O{5{%PNA?04@v4peZz2m_Y(**UZB zy75Qrnf8k{_P>r*FPGd6J~xPErG9y4jVpRq$J($(47F|njY;^CBmtD7$=UuByAh_d z-mAmWlgr+^nsipAG!I-xj9;Qkq(s5#&!3wK_V(LPLsqoK1QK&i>;K~uP&`(Azjm?P0;K4XF-OlZ$Y)0y*Q=~Q zuYKuivhh0N1t%k>g|}2KSsqahZcVh)2pRP*^*5SkK)*H@^s-XH+iKto@?T{LY_N z9j2$d&<~)hYngi;fQ!D6_5fm$`({L->+{=<)cWWg<7T7ZuYTvXlDSd;D-&IQa^i8s zt+cPt+Ht#NWk)hppB|f;gDWauOgjW7e8#tL0cF5|BVV$aKvdWFDU}5-kzQi(9_Cc4 z=INv`%MuGK?5+2z*lS|&ALiV%*kL8_&>CKD(ewIJ*?sCvWKZd*AdK71*&*>CE4oAq zj&t1OgfVi4<$*6tj-Ya}pA~nnfeMS;IC81rLmvVharAJQoWC`NGsI1QPaJI`p z0JtTP+aoyi@Cw#?d6?Y6w05vgk7J~<#T9;=ej3}S_Q+Z(_$q4gLn6cX9>+$?YzUUo z=;!r=<)^0huDQ%>TJS(seA%8yrrEnm>0b~Jx7@oo1+>qs$guxp_#k82=%9889>Q{Ysk z6RR&y1G&=KaZ+Q(MG2Ibb}mZ+FO}Tg&PEbU2h!;7ARoGQek=l0;e<~e2z)x&?qOXl zMy}}iaAPjJ3JfE>ekUWBFL-4;o;izq+c21=*o7vhxWEzzBR!^;NqD0e!VbCpTORWm z+^PR8g?5kLG%bKSM_wb>^m98Muw3BJyzJ*}y{SLzoIosj$qE#d_G)<#+9d89oP=29 zn`+Yz#k3J;TE6POk!QWCr$4{JK^w)2A5yx8l7nt#(d;MxTW9|dhG5RTueU>!QG)NX zE(zj8kFp9VCJO;T+qjR|SMyIYrTWnK7h1{ZVsZa{5UuJm%_!VICf5u7uP%8&ULb`g ziar`JM+t3x1zO`0-_!fm4L$`bRsQ~QPIVYr=k7g4VhQjIvK6WvScsYm569Up%vv~2 zIM1Ts1PX3%!(L;5-ZR`(&S@yxh%^U&@I9Ed?LwYYQYVBUnHRNl(CXm-A4$}=eY4;l zz0`<(Tp7Lla4y)En)B_Gmvb!4+|g{<2dTya92~iP8D4tWs}^w#{jfh3!qZ2WHF#P%5n0vQW7wqk-FV`f!&!2{*N|X9ULNT9+k1}o%(F~$xdbU>AA0^) z9um(S#Jk|xBK?!n?1R(SczByUKjNzmkx>2KHf+$0{_Rn!W&cTGg++xIDexOqMV}=n zw{*!l9g7*4K_oEozy}ecegNH@g?W)>fSs1Bjr_%a>GfO%5!=MUmNl@VgQG8Nn*T1t zPNO$;-Pq^~BoCs*&Ubpl{yYw) zD;SC=`?7GW(UxC{8f%P6$|vZ~-1&wnvk>S=E@mg}) z+w1GEgMmK0q8**zZMb%(smM*p|=#}gg-q3-auzheLJ`F%Ur#~e8w8M5zb4>k=w*%IH7dKAzzjt5!Y)1q73 zz#phRsqBM|%BjzPg$p+_XKSN`0vuB2`8rY8JlAtoNSsK-Y5L|mc(u#VN zIvDw;yJ8v`21vAe`M+&y?_UIfZAIR5L8&!y0Woyvpc>^eDuH$!5yO z_V*_jFw)y57_G`tDkdZLSitu82fw+Dq1*Fcntn~_%(QNZ1mMD>WJwp1MgLdz4hKeb z-;Xbw@bc}-2CAAvpWx`#&)uFJnpwv3zUh^`tpt(nivwM{s?RurJxILZ2tDNzv)<&F z{`3g{DTdT4i$@tQ_B|)U>`pFWtqp#6Jp33#)6S<(Eo(5?4tfU`~d%zWTe_>m7SGymdmFF7Z8V zEKPM+fBmk)g>s3k#}-$>OyPp%*?T&FH}@;>*9o{W-*VI*C`c9cUiv0&{ik=a(~&{W zytzUC39KF4xnP0QjRF8c@|al2idW)Xgfm*2C*P-(9TG}TKYsQe~* z+g2E=@Fk`5N`8W#S=VtR>ar!P5wH%v0fafF)pDyunhNF0kFqVp3mKKnbyOM@|ES!G z4+$;7g(<(6LNzV8Ft!}AVG2Y(uy>W4$Dc3U zj;(fITPl5+Ayl--h^fg_0l?;r z(_-+Ok8HRe$=`#Ev)G^O6J=EJO#ygXbEeKO*gc0Huc-)_?3aIWKS?iJ(Anlu$ce68 z{$?U-YvUg&_-&sUSQ~lN$trkI78u3fs|~}TJSu010m{3GCcwOhn#5#{nbT&2MZnG3 z^(Mk@vC=pErCAK3%}s6Cwy@|29OcYMNzt~SO4BCHDc(g-)GZNC*(C2 z==^ps{TI8OlY60LoY#xx>Wa7BXO%{aK9{z3sm!tEt0i9@Ikxm6*}Sd5NLRc6p^H+1 z$GSdcOnQ5;?pigie)0JI(Yc|5gwOmF@9~>Va4pprC(eWdj@0%t+Re($t74eg1kT8# zHA0OZo2)H-$ty=VYRxP-^!rX|T)_?eH4EAMa{CGu(4+@>HEdj;Qdiy3*9tlrXkxqx zud4E?CpU*RJ#Rz?VXt!oQqX6WSK_T}Y_SgPKBw}5 z3xWN@&H%?{A{19qqji!J*v?Tcb!sy|*b!(3$VBvL{2Ig{JH6H_vojLOcfuzl&nPvX8kGh6lth4fu$Q;PD>b1 z(_Y8JvihDelZ$$@1Y+qRxbp zQNE>@a?vZ4Wm<>zTNNLsU6+gU@)N7Sg92|&xI{r5?s`XuLNhljvfJ6$tg^9bJIZk` zrse;>N( zx6^+ipCiq6``sO-+T}{T?~4Rnl~qX^$oHwsYOgNH;mSl}Wo>q{@=jaOY>1IadrIP2 z_rz(9KhgPjspGfhUJ>`t5YLmM;5t|D4I3&M1{up>nsX7m`{J|F!~K$V$Ne-e$bAp@ z&)wSJ5P+DA1W=zn4ECJ$|JZw^8Ge)RheBP3Zne8ADA>!pPV{(?ZZc#i^!F8Xr8=Is zR#75HWL`04nL@kpKfktF?X!%55(-;X9YRyhaxV6b+A{0qUWcJY`@_nt31wEEyw!t& zXpuhJjWIVP@GVbMv~Mj=MaItcNGo!;K`nR~7*(Q|S;KnIC#}`&5jz4zIxd?*Zo<0P z-0K!6jMndECPJl$9$lxyaMhKt83|h{XC4-mTjH*P&VE9L?F}soN!?#}-J+rHj<2#m zTw98&DA#L39m7LgS{|npjsu!@B>|bbwpm_fy2cQ(K!qz+w_XkW#664|hWNg{I;$ND zkcvvyai=XXy-w+`cl&l!M%|s8jTrhJH$%m|i*T>2HkwK-6e2!s_asqG>I%QtS@1p) z&onJBIG3S@rayVozJFsEk!^YyV53y@wjkkm#s?J|j$qV_L2*Q%+^o5%WAK%VlJVv3 zFCo}}*hu~uQUF=w8cts9@VL!zt?D5supybCSZOecz4czqk~64)FMV*kA?oolHtu`h z>C)B~sLIIY7W-^k(;+vwhe_EXJ@rohflD+lZgZS)r}o>vy_^*`4taGJuQn8GBe$|t zRUKn%3QOh$$sOa?Ul;^xOhn%d4UB&St&|q-#fyI&tdIy1X`owPuQ+>4zZqu@AeD7H zg38c&sl}fypRhQdw0ER>!!?y9WYbwtw>^K%Ik#C?do8J?vl!EPvdA5Y@`$3$2p8Y1 zfGk^4so3ANqu!t+h5tw+Hz6E!2`OGu4B;`B2${alct$yT2U+b)_B{2W*dR!4&EFGl z;Hi7iLYO+-8Lk~AIQ9x)93&Tm|f($MkDIcI1TGiy2#RI)YZlcn4V*zQ;~qu#oC ze~01sD-gHGx1I8gVHp$3re_=I6ltR>|*-viEbm z)+=E6TY3qTgA;?8TyJ2W=z?s1N9@yK{MJtcL^yd~LGMR znrTEelb250MovelfD_z!HFan{j-N0b+_i&NDe241`US|IXU^)RleLa}MbO!Xx)O;s z-=hK#`2rIr(Ow2NOU6-AWB3%Dlp364EH|rFwK!}!&DqE*1AJ#$A^~JaOVDf%=z4Sl zn%mg^*=0LNKR(@+#1~zX)}=9A(yA9mb83cY`iTP#PR9a^F(kL&+qWcm1C!Iy+-&KP z>l5L)P~TQ80})C17W4^&9Hf6yz1yt_;|!AINc8}YrSB4VT0)@9IakVuWPjM+3RpbU z)c-6bM(JTmH=6dYQ7O42Gg2yG=AqaH_*Z&yG(7OBI>QBSp@K0ljY+Q)&ao>H*GD5BN;WL9-#=Oz=hKu*H!Pw}^^Lhcrw@MOwPML}GNqqasXNMY;qerE}zf(KWhZbVzJ4V2rWt%kTH^ z{pWq$$MHPZb)M(z{Ci8*V+LGumkRwSiQnBxSAIIz8A?@Hb@mk9pZA0$i`JGLYAm)8 zl0T4PpW);Y$hw+EHa3LFrcwYPvykZ~+6|%QU51T~HD^X+Y9%9vyMdHSPCu~9cbP+T zycE*6l^d28YgjhwU!dqkwDnq~HY=*w&24s-Q2$-&&l53psf%^peE<37(XXv#UtI)F z#Sd<2jQD+?EI+g@$=W(&S^amVioM#seDj*3Je<(b6n6ee@j>|fHu?_`=Z?pA9QAE5 zox@wt>aBxAx3JpQ!3CS!Zs@ju3CHtQOG8O~jaNxIf9kHO=0S{o_AS9&y*akNDdu~! zwm%q~CvL|p-o4ivd191uRZPAy>qEL25ZJqN!pT}OAGW}(SHyEY;1$P+vQ;_KX`ysg zSA9mM(5~!D400`b$_bzzCd$Er;5*{IXu@U9_ZajSyGOaFOSSnCVm2$6rIH|@e>Un2 zzZz5jOneSR)7P>^XQT6nCjx>hh!P0yt-DHpy>Bb{82uZ!y=q&`k=c7%bzA6vDm&^( z+0L6cqyqWB^Hg-NFEgyNI5Igrmx1wakAnK(r}KaBaka9age7_W%+J|_x+bj&!xWS&22vU#c5ZbvjA64f21XW zq`PM3OBocBWa;VKJnbKks0-l|eayK>7q}$SwhK$|Jj8o|Ll z!!xgWcxk2Q`K2%(zrZNd5g@*$1qCJGv#I_viFY=nijU_@8Hu{LG*9(1GM_f>nNxz& z_)Fby!zLC$v)5$}Yn6u|_*^WP8S(clcQHrlvLP$cN~tel#$t$-o7*56mte|}jqdu+ zWB{GK&yixrUzHXf|M71>l%vM7(|<(i>v!is$w?R2$JRA=LO37%?r+@-GkoGBLv*G0 zynOQGnzWn&K&>BP#5pebmCyB&dD-=2iJqMwo*#d^y!ogsC->StGJY1z0@f z2g<9KOOgj2!j`?F^ZDnQq>6wW3_i2u1KFG*> z3GMA3y?(ZLD3=!d>2rwdHXI&Z;-j!~6?TeRsAF-_#hLRc$OxgwUtH6VgcL8x3(+h- zN@oL;`^%WygM5#O@oF4|Y^zoOD2=rQseGVm>@C8M*3}UXs${NUXkZ82ZV9~JC5R!M zBt8e{`|PdAbxZrYT;sp<>%K23xYbAa-pEM%<5Qj;qFr)6Jo)8wuuksMPDkFW*hQat z)y)^Z)x7k?d*9{LhVj|Elt(GUaoD{8Y(wmip#Pyz25FkyW{+1@Q9~7)%~S7i)C#OH zBDbK@{=8nz7XwtbGlCpwXpB-YN&TOdpNFYRLtfOC$ehN3@7b(Rdm2M|xNv8WLlk5H z;B4I^_qClnb-cp;-_|BKNCCh-bzd;2tl@*~t*McAqp z`p;&s18H?B6y~`iASE%mju8`&FjEUBJvl6WOwEmdl&9D0*f1PF{0K9{@KyR?Q8eKy zbU#ZqXHds-OSpY1EK6=xd>MLk2l>FL*M)RNZnpf1Nu8To4=*$PC)cd`-Wh5mzJ4l9 z_{VURECskFpxqOov`CO1zsy-1truzJ=%kmjcQdo>aeRxjjF$MM-LBboOcAEI0&Lg@ z5T53QQd`!hX+HN)KYNbf-iIS|0EI$w(o=IrnLXN!rusJPDB&%LNXG?@xmfcb1M+qS z5$%v&vsehUvQp@)|DWV}&d>6pTz1SINgT^;M1R+9j5VM&7b2sjWi-bjWqP)?s9?OQ z3O8aNj`4nn4X%J^W=*>mMgnPqINV&~W7~Syw+2duIt+&L4WLJ?O52=y+C&C)hGKF2 zNZobvE1eqLu2{ZyCop-9)9Yp22=yA)wYRT&Z=O>Q_S>rQrcL6frn~kP#7P3M`eTQ_ zlD}3u2?!v+X0B$dO0)dPsjx8Y_>6SYFZpheaJhV1!Gn&<(VBp*_C&xSKW3LR31L?7 zj#_l}lCd(gpbnV0jdI%f30bkLmkdPcs464{ZoG^!yK5G|P@Sq{o_43bpg2ZXik!Kq zigm^GtvV?%zV}p71>Y!i;pe+Tl&|t} z^*$93Yf?wIR6cfF7frzZ*DI@2%bFX$bc#9=F`+01V~xc=1)gIR#jVHbBFEjv1%VC zqkU`Z1S43ucObXF=8<|n<#E^evIFXI(sq%Cd1z}g{Oq!mBFx_QZlgeC&%>l_yd+Jw z4B@mb3SBD_=|2#2VoUR2v^w?gQ{@Wa8(guteR^E*tzzNW$A@K=ZH@a5j4^B3tW&SH zHW~!V6d(WW`L@LPJ|&#tpfJSutC7*A+hfcOmrVFZkwudr{m>YB6*>=Y9!6%oSF&8# zJ1O{fijZ>hr{J`uM-SnKj+U2p*Dip~hAFt;3*kHN-`MjoDn$IXyDQl1yfH5g)UI}} z^f^_An}OMdQfdF1JD;IJJ+_78oAe$MAPa;*(W0u+w);WC+jacp330y;U~!B@{nA5n1YX2 zXpbjz;@`S9+wqC^fDCkUfnq0cyJ|FW5$tB0bhF*fbmC7u}4hX!-zt-pyLh-FJahu+q)F7l7VAO@H7H0 zVGCY|cVc8u>KnWmuFQ8kZ|J9^kNxO#eFNEC>Sd#)=!5VXI)Z1q< z1Y-?E)|5kV@zvv}u62=(daK5Bziy`E^1?=vq>$v8?H%}OS|j;YuJib+i<02mqk%0m za_d;z!qG3V*S?VflV^ahZe6|NH%t;rX7d(iJ+;$L-B9x+yl?Q`>x-b;)O>Ok!E;Dc z9 zE5lwBxK>&@n!}9b_h50u=-7?~^fKo_vd}ZlAv=?)tyC`pZeWpWCe*$y8f1X?R zk^J9cFC0FgdW}AjX98``XC*1>zm^7QlAIz6ScP<=~_7aG2>G6K$8C zI9!z_j$(SqBm47=5^sR5YEP!X)C%|SevF{wBDAe&AVVt)%6X&GGW9H7kl*9!0A1Mp z+(R#>?2mF05;ur)XKEsDm5S@l%|0A4xZ!A*`?Hla@k(?k!W}+UJZ3uzp2=|har1y& z%7|6Q0cdi05cqxhzrpM;)Lk9nP}tA_#hLn%>6uJ_q>qlzI0(}4Ub8!j(NQc)m7n^V1IPZWI+t5BA{ zP6mdqZM>OLF!gm6ZhiegKZbMSr?)aib}0iPej?a`aN#^+xRm2`qTk;LHopjEQF44% zBg!U>lk=Jk3kZqrF&@-L_mnnzTPHTIFg$_Tv@C3exp(5Iv!x0!0!#H<8+YflpQ1#Q z0K^1*GT{l_Nb>>r`@rZ0Sdc8kb|{Fd5!qBJ#pV9~lIz9Ujq>`T*8x%a)I8HEWfL!v zy`A;g38nXhtHcmX7x7jP_eid^SADQV4C>00 zoj9+%t%YqlGYBMo2>9pu*~|wtdB{KoGZhy}Jo2A+ikG-r?f6wfclSCDUt_axa|1=m zJVjg*He|G4HIPpZDL60D1-E^@7eb%kwlS40nEB|jR$n8>pi1)C2R7nJcF!-m*6<3+Yv?xf1_nK-SEJ2E@T*DZ!+V7ZJ)H z08(qcm0&G?8OnEwBtQH;dH}dEW0ZqkSbLaFtzm!dFU{(byh;rwNG1S|1h)F4&KnSb zSzss^Zj2A@wWXRgVs_2-HPYA8xHA7DwKp-LC%sJwZc8N{ad@4+oCq^k_i4R0h*xx1 zJ^rz?3$B}z3mm`vI;0gn*Jdq-aeW4N4()K*F!ElG83To^Bynr*1E1R%FpHn%375VAgzkL;HSelQsh*2UIM9IzUs}h^hBPM>V^1f)`V9Ef;Z3E~#~mucFrR5*Td_KtCE9@HG$A>I%MSpOUJdB~!e2&ME4~#xL4UtW zRl&)pS~w;xE%2z1;ldNqo03Zt!#3aU_d%?n54E)1_PytT{hp!4jmq(XB=E1w7$+{_@J3FjvftfZaI&sH>Qzy zc4IWLg9H7eBk2K_3io`&==tkS)7cOXV&UZ~X;U3TE;%zUBQNpu`+MifCoONM``o1# z5DPEPq(y_UvN(3ZUO!P6f(ukXDW8|x3RWf&HH<$3&vcxR7`d>-890fRH9wWuMcvw0 z89q!Mu)V!X9nh-c8`H}sl0ll4iKdd8K*w(jH{ zX_J0O)ANQH>zI?)rF#LP<;DSZ_hMvyE9{t){682D$2%pO4D0b{%>@~!aQ}zylvR$D z0(8O}Hj5=YEf*bn>pNOn++$OEkVq{8=Ou0XV0Eo5Iiyimd$Z%H(zG(s$|@7L$`axR zCTz!e)P;RxncjEstA^yQzMk%xjO^I65%C-313>;-dUwNXvzUXk;kZplp}0J}t!1yi zGw^VVw>hk%gTGVL9koPrQoQHKpMXsQab8Nj}Dxdw$`e~DGY|NEk_-BlqefdZt;r{Up6h&3>zsNe4eIL1-t^TXBc+4b&oc9Foff_n@ zvxHq<2d;n_FV=3(a($Ppq{53l)%1aosggY}UbTIQ!haBOK*VP3R^D_1SGBBQ2J;M@;_L z0-6+Wy#*R;6Gtfj=%Mg}g=pjwjJB=5aUyKPz(ZL69f}HdPooYD-un|p{d0*2_aa?6 zrN_=s8#NnS438e>FaLZg(H%_R8O$Huz&ks>I;VK6E=|M$5lozx(g9i?A!ps)%7Dkd z%3y0N6`huH^E&wi&{l*K9AE@|Tj2P%vxe1chI}Is2DOcKT)|!VubcgL!ui9U5M1m43VOlaS&8Bm{!0 zeBv_;QOO(-IFkGg_)77&9dtFNs+GI3yUk(SS+wpNuIfehoH3q zPxwNgg@A6MED}X!$trNUr(^#kK7ad4oO7qP<&W4Lm0yT&;h!6pr6=3VYS3136jK(- z-M{_H*8}g$Ro?T2r!H?j-lP20YmM9Hy$6$CVh3iR8;5>=K-LdLm`wFUgOKM7xM?0W z+)e8Ul@Ui4n-zc6sUtM#Sqs^sJYkMO?eNQ;psuP?aFpkNvEv7~Rm}g6{r(iVLqlGX zmFy9Gj)P^tB+TBMwP=9xyy9htz+SEV%wm#b{;joV>?o65ojQR}xd{kg_=7fKi$r|m zJAZu=O1DKBSpNBH%!swjl@WObIw#=$OGxf`oU&H&!J`WBmE|*Xn*-0+u` z`c9H2M_+;V$Glx=N>DVDBeXj0_I@CYMuXNT<2*CS`d)`)v^`M+=5&ehgkZU@aY0md zAGum@7ftEgUDsY26XTDGE8{(Pyk_szZ=oe!FwmErMV3Y)53E z4j6!@lL91VS9s!p7Lp5F4P*)?wWAt|Dki^|HZLn@fkv{z{RmRzo5^)7NQ{6zyAGOq zk^7i=t<@%uzP9g_427|U<#;#pVu3#q8}V!VW<~$ZUzd9=$umpHwgwKpJH6{5&E@S| zY9qEs-8=LYfyc@jkd_@owwz7D&lj|B0Bm_#Qss}b<#_*QGqiEmVwm{}6{drM-5^kzo-iPgOeNoNdbdIqST;btbc%of)!gQFuB*Hp>& z6!U`ThBZuADY94H6inH$W=H#78z=_;jVo5~$vFxQv*Lqyy z&91fDv*fOEw8hb4_y~ICwW=_JJfX3*n=mC7kn2uU7P7u~%Bn5pjk5vTdIAHiteaqE z()b+gqbi>d3(BVa)|Y|L=l@d!{!aByLy;3pRx%bO9)~C|o>_ok(t?bXx|XQ56DwOK zdKyT{hsaqH44-Y1r6(L4dM#DzTi>p1UoKN(6K>_UdviGaxqd0g*ZAe@(_c8!I}Y6Y z7d0cl5;m%jAy>BZ!$6`H?5$??3!adngiWw#s7sXTRU&;;dx-0-Ql@)on6*__rMh-| zWS@Fb{r5nax23fNe9+eaZ&xX;NJ>1c-*MD8Kb#iDQ(C*n*Q#c`{q1%LV0n4+O}!Y@ zOg{RtGv`zxVPIqK6?mb26at~8tA~=Sq{Ia5cD(TlX9@cf0ic))MS-n)`~;tw;+(@A z1I8;rDD)0_$B0JX4;mq)iP^nGcG&BKt%)drgRPkMOqJAGDvL`U53E}0(!XG$m7 zFy)=MY6;1_ng1oo8cXP~NVTVhh;r>nKgMO;mAwoN+ozg4JS`Ef`JL5kN&kx+Y^+6 zB-ICSwO=GkPWUf9BPBP)y!PtLieM55YSj=7nDtc|k+nloYsAk77y5l;b2~p3qmH-Olby%eLV*pz6 zw;?4dk%9Zoa7}u;%wOUB{V{z`Ij;emaiDvn6dle~DUwCo7wS@V_?1~f2|xX{>B%B< z%WmT(dbng;YJasfbHIppHM?x@Ex8SgT~VU?sxPF{KI@a43iq*81V>O|D3lB}l~vT7 zevm#wqRMW#a{1miPYONs$l^yI)2{b)9$E>AKW&pww;gi)tN+$$niR}6#1=X`4?Hto zF=JcgX5mWm?`>F|0AqJMh&yywh0tHmh(+0N;dPgJTs_mRjv>vg#3qff{-C+`8nq%$ zM}&ri$&HrCW5r-fK%JGC%#t$M<>5@GkbHBHn3TdC;~f5E^ux&WmxyP|^swz8+A|66t;T;xup8)c3_Pp+@2o!fBOkZnWK47dmiK$WL@1sADU zx(ChPFD*MggE*eRvw0d7|H!l}F7mWw_hLfM`j_OIneQoPF*w24pi-@8q3A2^KAK3Opn#k-tEEOOkO{s`Rel-O6F)#Y3W-1$#|%EB;H!X_eecuoqr5=2GO; zRET)Yx!nkj7OCqQG9O_-n-MsyNxoYS4_-EDy+h;*vM)YvZ4XpOr}7Edr|5=6^T}y( z>7$;vdOuzHUUnXxYk~gx%i~tG2;)ClMg2S2ft{?%6yfl2z)U@RuXEC$T+!l&UNth@ zM|71^Mp*dXJe1(bH=nRjiGm3v&sAk;$`u5e|m^5i-EW6@6Xcl z@wRL9QG(=Z+9Z5MR;M-YrCkF|InYsNr>x-6(n)*ZExZ|-iF7a8_uu<~csY0Ub&M?< zsNh5kJC)G1ClBuPyTF2h;iAc@ml|MEdJ% z&VY0gn|iY5ApMm_D)GXm)yvl!lzzWY{L0Q_V>@x(qX(ASTMkQ71F{r5`*w!DaqE<- z@|x=FU1lOE*#H`16=skj5pfGkb@W#?Bot|pLhHr>Bg6Jmjp7m+sgL{}?6kJ5u%k$% z1@<}*wdeN52IKVRTaSzuk%Ny%TvhnHdCdng|Mvhqban2+^hY`4EW!Kx;; zF;1`ciREUdZskwYKhvq#xLSb2SyqHD%>QX3l-d4~!q=*>H!}hwHGqUTRmiSg$^pl)Sx0{Ggy_Eu z;(8|t|8IG-edEd>8Rl=n)tM_}nd9i4Alc>SZm|DE*l4@8euq&E_hc4$|w0v=Y)!@L!JY&%_A+Nlp zYaTx?S+pn4RLY*z^~AUv(eQa)!ENLl=@$+8sIf=vx_D>{kgc%JbQNe2CDkJ|@$bSX z)SNvA2i?}c-E;S3{&;_fETA(VS^m80DEp2q(TAB&#x``E{9-ONXgrdrZd`E2AJ84g zg2HxCZgiub!wq^i^0QVeXIn(-CcOUycRqX*uyFiix^AV(`gN!*^&Ti_by|HtE9L4{ z`0GBFi?x$mfV*4U^8>OaK|YJu`&mQm?*gI<=*{JO+}s*6*6#Y^Stibv8Lk|TI$O^y z_J{%Uts1Pem)Kl_klU1SqZ=ZX0<-PbMHG-$a_c09(JM6XhPVP$K?+}_DVNKNFgpwL znF3!4)3+)0mI~=pW``Z&)ocmPPeu)*^ky_){=v=wm@4&gE8l%LbXHLlsqU8E<>F_e z+g)t7)cfJOix7O=R+`}UOS4^cbRfx{oR~3+#}90+u|X@N|9I_Um%5fuBjjQN{f%I8 z>wldAqR#K1vhNW}hq@@W;VW3eG|WQr{-4Y1YPn>cq97%^xFM5(jn^A%`lx5|no5mP z4MRY;R{n)^!b**t#u_-{4KpLp;h9>#$mH5^tDsq_lL}T*`}r4s3JU;xPzi&{W9#{Q z7XQ6%?AfpMe$%AULl_87xEFj{{!^VdhK+dem23LPuNNHjpN*g?5T|3d)B0PO%fUxa z#BCBfYd?n`#)nv%;ePeVq?>>IeYxpxHQ5HNQ^p)mQ~cP=4G|0);-}POHT_uG%ipel z@y*V8&+L-s^G;vR&*4a(R{s!jni*7T%?!Dv@|xK-ZbcU7&&eeL1GjNOWmYfmMuS^+ zPk8re0vNeb46A((W~IjHh?-FO$M6NR@rh;`BI>&eK4~pFUC3*875;glld=il9nyG9KHZ6aMrr^g8e zGE-d<2^9-#xc-bvYI>2-NijBric>_tsZaoFWsHYWI;(N?c}POAXW6~%l*wyy@MJi^ zt2rYX*4%LqJ-iQlQI{OH82kf3zG;KVs#i;1ESDp2@7Y{$1x zGatGoGI_3Dgh}hq5h=KhVdG}bq6EwGkZiaQegbb&|AFJa_~qXKGUq)_lKwR!H<%hT z*FL!jpoThXyd~6^_Cjtoki8>dmJGJ`Gn`J$J9Dow0V%RN$0l9V9WVU9{AmjeB~QWG zRF-r;zrZRalH4~&iXsxsVyg}#z4PPaWvHwa|5+oc_7`r`oRK;mLI$Ok1iw)4ptzP| z?8-x@|Ga_4obv<&Ba9eO%G!m*4E5mJR^j2~mo-&BC1XiAC`rv9-@(T(kgcH-l;*fU ziuycVDmg6<&}?$;JdaDz{?@28KO|j8!2n6yc(h;&y@NnAa41C!?ub_^%-5D(h5`Kt z*BV49zL6=N-Qq0L#c11G$mZ6_uQmkIE0sxlnAM5$CDYJBA zI{ZT$*Oewqn0y9UT~M$EkG~>AOGO=zz(2~w!cR)LyjPb_AWGZlHCh%oN$Zv7fqKsE zx|^hbZ0OCx=e?!AoNt3_QU(|=c7CVx)u3cGO3L>#qR=}mW?2^?k5t~;9CN*|POMz5 z9RCYG2V&Wu(<%81dyxu*=n{XGJe9uf2SeU@UU&odV=_>J%8=2r#E*jc@bLQs1mF`m z)9{wAR%YwXHKZr)FCS=+4@qS3{Esv~Y>P5V?bBEED71N>$XUq@SHV&8 zyDbVJ54APVVs^SV`eJaafQU?(GO% zt^=W3)MeJz2RPMWe>*X_i%L$%&#UX9_P5}hZpc+EhWcxebzG$H%boV?w3>f-ToZs+ zBwiC%4mlkybf*lY6fS@3M$;->jn+M>IZbI)*0ovj4nGGeoSI21NF2P@WGTZJKHNU= z&rHZ8w$TLyo<0FVcsL)QxE2xp18f%cH{Nh@MkWykTexP-Mb$K*iE#50vqD1BjHl04 zo5z7R9bfnw=RC^x;+LB7MpPOf4yb_VN;6ww^w9wiK;QBy-xNte@)iu6@+( zGROHi&#jBiYp_pQWI9-8xL}**rJg zA`rIgw00aP0~Ab9Hzu4_X8NNuH$3wj2-~7bmk1@pjySoVL>i(;DuTKwB;QvW#2oNn z?8b&T8~?aYq@vc!R3Hs9Dd#zcX{%3eyK(%!aQ=7u2e^CO(=MlNjP1`0p0`r?#U$FI zc6P*#Mx&5_eC2r5J|4aY7+1x?(lgr6BDDpI9EPa8(omD>uln%~B*8J}b@7HcFk}BL z$C*=DgtrrpF3%Taz%M?jM7u4%Y?60aN0_QUjFyjl07|xu@VQ#7jEJ5W6**!U*8Z&a zb-Y5gK{$^Ph}?+wNNaT$N?_3s%Q$axjVQm_E&cuJRi-p&eT6gdY|9EyG`93EsKRuTASy814Ohw;omr4dS;om{;RG|BO`zfYGWy4w}+?1;B} za|isyvP<{4@r*jqwf=>@!50}8k2LcS5I}A=(F6{oguCX2|7PF!@uL^P8^Y%uf1PhQ z&ei+=v@c;C^uFGIaH(mJiq4sRe3&wSb%@aMiu=>F8x+9gE59lxz#wiF%P9jJ?UVi` z{mwhBOmo`PC#<(Er#-2oTH;H1afnirysTy7nmC`pWbMENxpXY6eDn~_qy;8z5V!?9 zP)!y)Mf7?$BRTF{(En z?+kjf;e`J78Fl$vuDn0x3Ewb+L!nOM)TaonWt?`dmzWg3+Lo-rMZ;ioS-%9E|{$%ApTL#aTXDOtqn!gp2ZpKKo zTCW+n^$h^#j^P+ItEoR+{*~^GQPhxv;d3RV+J09dexy-9ex-^} znedA~!cJSY#KskQk+ku@Z53RqnxCb}D!lGF=BO7*UdBkQnJt?o=mhIpt`suLb757! zy;ZCS&4%r3no5QbnV(Y7FfO{3|5ex4r{_2`WD;!cZpvI<7+xOudR*{wvbo z1z|=UbBWRS8G+yZK5WH0qv1J*DSw^|J6UpDfoc1ANZC4u(O!&5Jl+V(F z^;Xdayd1qU{NoT}v-$Q2dloxcz`wI_Bl$CE?5<*^Y9jEIu(PjK zIkqEyR20XRWDTbJaEqGAsP`z}U!wGml5lgA(>+)7gSmn#idh%czWWQ@yLVhln^K29 zoIZ}#$=#5CA3ov`Y5C2hfQtNE*=T$?L%i>$4zOkL$FEm??iaiGv+HNV`c%1&|K7H_ zZz+$r9xAQl$lr0a5XaG2VZ{K9gp)G82`}&vejgVasaHf8t;vh_a-Y!GNB1_d^H+Rz zq>6@cY*K8K#<}ef!<1FD9Ji;>(-1XWf|wgin3w%I?+HJTgk1K*_)xf0st23A{}5Z9 zqJ6LM@hrM~+f(}~AqIhg2pbPNJf2SgRB=v}gyEP7mVT!)e)V2KVc@RBmUumV7h)ph zr}j&O=BTRNO%>a*>IYI;`qCv;6IwNhJPh`h}rz5!Q1~A%4G7k$KlealS~Be07sMB=4-{L78GT z;Vu_)f7;I9*LZ<~?|-G*l{*l8XB`do8BY$bSJtp2oQ8#y6QDGUO`LaZh#fMYL{U66 zav*aP`Pw44!9PZrLP{eg^fY}pK^Xr+%-IOiSrm$3aK^$# za@DnQFdbt8M%fztizSvXe1^gZ7zp{3POyf?3F=y8y%REUELc+8tM zU$KQf!0_S~!PeNY+|iyo-l$dI7UvQ$6NCBU4XR}Y+z=~rP>l6Of}C-<(imZXDSAXm zfPHP*oGdqI&aw{o@r>Vj0%w~wYdd~ciz z?*Sp$`8EGdxMit)^lhvt)eK#)y{gKQxu>y=ntd2k`9No-yVbKfc-b=VU0oWLX+lF5 zEwy4}s0oGBe@3@Cs7^)iT@$}RUwP!6I9o@MaL$;`oa`HV0jWtIe<$lYORBa{zH5!V zl;JLiP)WyZ@M`f+(6kirOSQFK(?@Ea*mG(qC@%VO# zS>1lneFfqg-J;|Lu>r#%zj|-r&Ad;T9Cf=fE|Tl zr+0EQ3)?=k+JjISP0zq1Re`r{s4el#spwV1RMOV=Pic<`10si%>&8sWo@8dT-kW2V zkSGJ0OnSQ1B937dOv)DAtKHKBrf1E6QH|O(cKz?@2N0!9@yic*up;=sd5DM6bO;R4#_9;3#)g&AM*nry~ctWDOw^Wj0|(^oBw5 zqekOc1{2%)_`rl+TJfAAn;yk1BlIZ+ zsh4C`;m3p>prbS%sPL8aNORf?oSk0vbmAd-7H^2RqLkhvFp9G;&+#1~+}=2O>$}2!x4V{cePU3BWdqlSds^;X9hg zA}_DM*0p~~dr3^!BaZZcJNgKY59 z+ROz(CY%>w@m+U2LA0;ZGuEQ>K*>o6=&&3L9;VMzsjl%c1&D|76rSwSa{(*NIn1tD z0($Mo9Sh|8_bBpJX2K>?*;(l-KMOqZBikQtV4))eo_`%vsSO=|J0MT150aoQcvNTO z8Np8mD6e8%j-ER+{sv8cNFR?mg}5u)De>nF#h%x2YMddJA5LC6aHj;G8IOj?1IB2~ z&Lsp&g4BmHcOZ>MaJ5VH+3ipp*nL5-%XxxR+AeI^2*i6E!K9t;`8a&&AbXiv88-3p<}HONq}()y)G3r3@7pb8F?D>H`f+yR@2X;^S-rk%>&W9+9-A7r^pnkC9hv z0HnzDK??2;Ae9tvRQRACF8_IGik8$AHL)nSsG+?7>|gD^H^Ny(KWDzLcssRK!2S z?|Jf&bqcwW+dN-ap^F>f(p#JO7_z?PGDZJ-& zIb`8OSitVQ@+5aBi;AgstWpdS*uo~>&@Krh_@(H6-2m6d|LSata?$;|h8TDBehQe} zU>};ugAS9u!L{fkV=Px>>zQUixiyiaqprwLK84HjKYVTC!+OD>#=Dk1Xnm=zo zu)W6A9=_lRP&+4#Ct9PRD_}Yg&#}90`*Wm^)uj1D4^nLl$s}&)a+rw3=I_`_!uxEp zmzvsR!WLtj7&b||-{8Q(cTAh!Ne&W=Z#+Wbk(dU>fruojX? z)NT57M#<|R_$Ar>X4b0;Yd=|n`$zVg2>G-e_*7P9`UR_dEFSPan7B^|#|7E;GeAj8 zmk6?*^4>oFZhWY$T8djP+-meBS=&L`=N9bDil54jv=C?R^+14 zQDq$CQ!wO|Jl;%fX*tA+_iQH+xeRZ`xmU?*dVF#!-W2*CZsxbDmShcV@ucZWD$SYx z3uE;|PJ6`xm$N&Hl?n?w!#2Y8NhK2jvkU5C@BTMab9ha{*oqMjZd76MWaV%A(Q^}> zfgm?bg9DKx^RG4z1qYTN#fiuaOHUe@IV)IhUqR7vAXyfe$K}w zPx7KyK)oc55A8It;bf$`qgmdAPPTRkYy#htZ?~Qmw|alJ<>ltMm2fZV$);$%M3>eW zo~<3&LGhRibIw(Sq8AQEJhT!t3`Fx>@^BuTR5*lOoB9X2>C-+DvuN79{T>5E$rG9dlm9- zrwWHYE2)Jf0<0#oA;H}?kvSt!O%&!U+m<3NdOR*+eK(XRB5>grvggp^e@1G-W`NI5 zUi&-O(O?bKEtYalF^)x0GxBgSd@`RIY#2!osd)Aqs&XFez%3YF9ul+fwM+2gk`t}U z`hxBuuNv~%*xI)l54V$Yg3Fse;ILTTLBdX#AWqm5qwENB#d?v!-`GG&9Zti9{;~Tm zivjIiw`P~uvCZTVMe|9^@GCMDpnI$a!5j$P`)9M#tow_2lNMJp2SU_cu5kqd}Yp+vA08w zj~A3byP!uU!qVQ*%MLf7{8}nI_KhB<`0cC)jYAI5`|8R0KCyY)h#12UIyX)BtVKjMO7zzN(Z5g@$7^v*TdR)!+RU%#=)(cdP zw@$NI-HwlTOPlmagi|QoO@p#Ij=t8`j>vde0|Dn@`^r2e>eiYhJ--YZneHE2%gmu{ z*4d3M4;wM_909^u#)67SZPv#4y06ac60+d6+`A`06?AX(M;$PRO(RAO^aIPDEF8vF z#-!o57ek^ms%oGeFB@z9dysi0zN;jmY3#__bn~@|$u7X4B9MMx4zku`VLpfDk{QmP zCS;zpjQt-+XW#;h;%C<(%mtHbV(yI zFm%rV4l_dxKi>CG*lV4&*V)f=U-yN_CB+E~(7)bwP!sa8+fA-qWT^E$P@_vR2I14__nL0~<=*c;z1S%!qBzMMvd=M4~VeSf0ruqr!g)f8_TmE3pXqmy}W zGSjyvWttxBduwmaznkw{hX`93*P2=X{sZ888zL=*8DkiW0Bf=Zu*eK|ImP?RSvE=w~@D8}J0DeDiQ5p4 z9`o+~)wOKk>X-GrYTfICooI)z>MIzH0My`sEJ??yV4`g;6{EC4puW`-r-VU^}rd)zJZ%qwo=Y7g{I^ zjaItCXyGjn-(2NQ8dL}17uM`CAG^NX_S>;#KT@j(KBdmy9qf8XblgHUy}A%h`r#H= zaS=V*0dcZ$Aub_lTLnL;X7JfeQ|M^n8n6{kFrz7ZqIO8|`SwVcg+!;*t8@-g-N7?j zlXzV8uSrwa0fA(-2Keu|I~ReQop`p2DKtyo2@_q1wzFsgseFFUXMW;e>~ zyAD98{Z{4(K`4i``k;vW&!vgRW)BR37c-!RTawfN7z^uBQU!0L*4%yu<;xpV-th=O zeft>l=Sln6e%k*Ys&CL{sIT1^@s{>5v%go#VgHIcV;xkbrq2ch!2J<3Szsk|-tOw8eS}augX3x}X};E| zV6X5VUo4olmGK1JTt)HJ!YNmxRb1p&sz$|VY&})uY6+B~XjAjkH@u1=eauk)E!_)l ziky!;snou9*-dC+gKP;L^_a((tfoh%9!M*%F%$C?bTGiRY@p4NU3?MUjusBl2g*;j zEKT(4+zW}XYm7fM-rI>>4GkYxx1hOAY>@mrR$&mCNSQ3coe!_PU2@X_&9KNH%<)O% z0=I&=7ua^<=ivQ92z`^C&e_G)z6SVmUGt-he9XT7FAb0qIG?^(sor)x@#MhjERT8EbtW)v0Ww5fBnL#TSvsfD?kpd)mreu||Qf-_nAq!o)rM^j_01*c0XDl4C&& z!~^b)NvC#8J?}nSL;aU7M+(@$z5dBpHS?O@LQ5geN((DZtO}aft=Ff`h-y;4d7)3| z^b53W5e{yR=tSQWtC1D+M)PPXA@;zFujl_W0-Gv^1~hg?zatHnNNmDb0A$6*^Rh9w zP_SfnqK>mP#4MZrqw=9~d#2i0()kh>QJVvEs&2c!q2}A`>Qjkebb!*@tNS<0|6irl z(`EO>b$qbqX**WXC|>IHYkx<_J8VjYR|aGAM)k2GFNF+g&Gn)=cikv~$t0Z}oi|kS z7V5Q*kVq8zMhv7sHE{y2jT#=Lxgm_d;(nUia`om4Nk)C$UV2u@oNB1K9nDR#^*vgm zF|%er>ymv-!(8iwgXQW(8}XI{6K((UdeOoc_pQmG__^8jN5|~WTZJd!NE5C*Y&M*T z=bM4HbkLE!yw$5iBCkC2&jlnMiZIuBk+HZ<3XsKKEnl7nA5xDYaY4?~P@etwy*F9un1QxpmLxccIcWB65uVkJKFzk5H^O4@YGndSI! zjjYdYHU0HE6z_eM@zmXrzF7BKe@PwWz+S^9EU!LB;~g+ zdsWH$H>|PY?2)`|qkeYIsg^qwo*c_<*O)|G^x=Vamb?U?x2lv{?xD%#P zYcCsnxo=K?)8zg8YioaONqK`R3r6o#!1+(hfXQ_Z z{s1}~Pscl3U*lt<>S#@-j$r-nyGVOAFRn3n5z=B{aXV2kly2|%|1TtJ_3PSBff0f2NztkEY_d@ zRlzRCu|I3LIny%yQ3o1I9h%RYcwloVn2;8|dR(x)6GLK0o?t?P#U*^HJF@ z)T-8W4QkNFj%}h$jWF2->pfkDNE+M-XZ7!4VX`F}=mk{5l!SEIZXqcSGiKDpR#OA7 zt_8M+7u?3_dcfq_+M=krSs^Iv}n#Wz0{&(mn_EpG`(^Z%Qt^X;s*t4?)}>HXruPV1zQX2VNkx!)W3}jM!aNw@Y7!URkz!Yy#$W z^JkO83#v5?ct4&ApWulL_Z;Vk7I|zY|7$8BeEi%<^Di`=$0yi?Jk60cQb1I}{%d|i z=SVIEJt;PUE6)5>kDq5Wb*SFp*$Im7;?BY zcgDq%Ekz(2alm{0M_AVLCN?;<1$Z0VlqffVRJbphGofqJ#Owxd5%n9f`DSs;5rQB=lEfPc}E znt|7RC&@t|5YVuqlYBRK=re+aY>YX*dwYi~Ew1?Y%r0&3FClGRWj)}PiuQ$QD7$=6i0l11`lf#u z@jv+O8KY$GnopHhm8cOA{z>L@OMQtTOwm)v#D+;7P6$rAa-0O-rMAP0rqxU1Yvk>@ z36B1{%sRbBR2U3zMsj5W7&Z#QM}Brm7!$X6P_)Zz(^$zrUGy@Q>$+}JHm}iP3MBk_ zN9Ww^S9$$n?k1Jb{o?tai^_N_3Dsk!G1dmItRvH8ex`@fjfdM``_h9S!^wk)ja9xL zI#kXWJwVpip`M@5lSHewI6HicG|@a6?R!E^*ZCAQ&+vSZ_%`PNKu16?qHW*g{uh^7 z?-wPTI{A;etUzd;Mc+=TF3R}%t{{I?-0(9Gb;Zi?~vp56gOlJPC%1PAp zz36QE%3s4;2X^S7_3_IyE=c{Uw-rZ>k>Zw8-pY^8@IPxUgFqY2Cj(AIY=wU~Zw?%~v_jGT>&$ zVR*2M$w4ceBJG4-9UWA>r5$ybt=en%jtG;-7Og)N;RcZk`H5xzh_I#8`JF zS9f;KJE;I`3;8cVV3;^aK5l z8g>12sGtfj!du@Id>12IN2`ljB;Sa|32H{&2!*))mp#ZtdyShLUx}kbpkey*?l%FT z8L#!(+il}XLp>sc2pG=h)iF**_jPL|N8XU9g?o$! zV6%GW`0f!*3J{%*KT!Hzxb@tB@1Ur2i&=+$JT79cPmn?)nh?%TBSVs3YBK!_o^uNK zpf_C>Kg=a$1@O}{<%qHD+)07bE^s`1F=gV$^J0^C!QeS(xrgqCp54n?BSJ2e%|Dv6 zWdsq=>*5bI3UzELq4SPkSTcJR&7v{D3Ebq(Rdm7$Lol6Ur<6q8wAhbWki+Ht;LPcK zKoi4pbcsqZTov9oJzpC-XD*)qoZGdwb~?(UAuaWr)b=wpPu8cGBi*e zC*L;V?D&`kX(OLH;;=CK3*zNrHy5yN-fL zE~x+SuDggM&UX*mZHVo-<>jo?U(S8~(!a#SlIrsKLshRUQyIy@#hr)bGU7mk?Rj$aHH5YTWd0uE- z$Bk54bm!7WOc;1^2LW$<#i61S7?FS@j0vr_Fl1HE874l*&C|EB=?Z&)S@JwgimY3< zrNTA|TlGYSb#<(AY>m-2YsZh_r|`x-d zP&5H(-N_dioymw1RIYLlm=cfE<6oL#bNLUgyBEx+Z>~ z^{)3-eS2G-?{fkE_nb83=Z&wJ>WjPdb0Q*kY5F1+WnHUOc&xRzI=G~1Al>9LLhbcv zxnqcWBKWDKJ=r#7biblrX$`8c%HSkRp8U zW_oUDvv)-jxWU24X-+z7!mekPu8JNvLB{1iCPRHs74FMm*Hw^|UW?SxR!b>(ae$e) zg`;5F?XC~w4*S6M78Xw*pe|Gc4-#sW4u3?L7Xc^RLo-_@4m&RLVH&=HJF-)!&A5}e z2;cyKsliR@7`mwQ7=8SDB{Q149_7?uMbR3Sy#_|yodmT9g>ZZgSXyu4^rWM6QMS*ew1BmCfc^zko=5Rb& z0Q`TJ^2u2d4S&Z( zI=J9S?iIc7z1HL5;CLQTH}w0d_g^ z^j!UuQBJo?^{$E@+Mc5i1NC)ar)$0rS@yemwDm{SUhU&5f598b@ig*VyaDd(j))jk z08%F~Z#Iu}x&PMv*j|!*q9ChCynTkU&d+ZUMgrd5uh&+WLi)0M>{&43#VisA6 zW#S3N5scDfoJNaZQ;KQDk03wF4%aDjHw%CD!S=>3l%c^FCa2c0Ebf^xuDBF#JE>>XZ?ixth6Yg)-Yx+FoYWg04!knrxkfz!1^51aMB|(N`0^P;FCLvuio%bGE&n zu*%^9Gm@M~e}k#Gd6+%$lj~gcjX2q*C445gKKtd}wJHL~d!c0Fq7sV%KJ z>i($PsBJCps{v31{Xi21>Q|HwAvH&DP7}WLKjudYJVCX~Roh9w0c*QPUOJ83GFo`k zb>!6VQ5dNkJN84cC%X&86K}6Ro*&x=vI!j0tWuEx?bumEy7@wo5vV%D4aBwKFr~h7*L3OKYyUvTbaC{K<#e_wrmRuO%%=g&4^)?u`4DTpV_E zlc`~64nActVC%g+NWm5IeSan9iy*mdED&ge|51RU(_&E@5=EIfa#x1yX5po8i0b`u zI;JcOuwPcux(ofA`b~8&AfLVD0-% z*Y*|}7&+|O^ZfPKfpFKFNh~FV%|`Y_)^x7oqXpef`)B~Q`mo!IJ19D5HJCOuN%v=OijBqmZ;gF!P-E# zR-2-}8ug~7Ig2&6L4d6VC8`jv?zJ9O!#L-$efZm@8R4RGp$%RiG?oLGybTgF-%5In zPGnzNTnVKw>iUu#8l9Mx{Ki}+z#VVszaNYf@Uw!;KCB^XgOvINQ;7A6BhGL_Ohdcv zaF^`vq%75@lBx4jkr{VRc^}FuaUiuMKKH9aKz`qXPsYOJCsjZChP7}l?OI#P?)$U| zrp#Gou1tWQ0ConvhKIhgGDj4tkHS+ODsmRB4UN(ibFVx4%Bcr6bT(>V#YWyLze1 z=;1RW3@bsEu$OkWHspqU2ELzFn@U|h9Wx=0I$@u)!9G*4{|wBFib_ z%)7md$q$Q>e!u5P7zDAe2;9Ot@uxnZE#TIw{$hwaTDybfcyH9vw% z{~|Z%-#xS8xpue`8TMMdy2_#GLUn+csfLN-gVAP&zm<;-30Zibx})!3WM3ZnaORXT z@~zzGD=DI=EVwcQdVEjc#t%x^iqU;lf@ncF&NEGW* zR}g0pynP(d`4+HN+xIVEon9L1xHq7(=&}y0&O9A{;T&4; z$E+Z>7|{>l}LuDe7YES(4$NkrhKCw!f!C|7)7)C;HI)hED4!TXhl-?Dyz?5$5V zHdbE85~OwcAgMEEy3myUNjVK=yI(gU@x)nR1>K*pYTXbxrAZD`XWYi8E}V6L{x$Jr zbU%7S4DspnCT}{ z(%Lb=G?qEwNN;k{#v|~rM-?TDkhSz*R>h81JZpc_Kl27lRWUr=%IXJIe@w+pgNY-7 zLGIVHLg^%Prp>uI%c_!93Z*Q*Z<~B5;z5W}Fq*qRQcuQSTH)S2P0n}A`|NFv@`SbyP6!wiOt#=S+9=p^gU|!UZFv<8BVmJlBO49?6JP`d)Cby^`f5;+3*%V zXD%22g7Udgm56JljK9%6*VZFtTKaig^atG>(Y}`|B%==v$1JA`OlUAixdRx^Y|D39 zd*szx%T*8#;l~bNK9p)leaQzNPL{N|IsEvWy$dZujvdTWEFI*Y&DpiobME{hzgQZodS1w{ zYbhmBu0T`b(d3Lya+R)iu_o)k^Bp3=8U3y+6T2Fo_kjj^QTuhCfTZo_Um;)MJ!TZ` z`R}tlqR(ua#APDJME?RRUEWgvY@T=MsUQc;q))YGU520X+aK?pFH9qT2E`2w_Z?qy z@`>@lx~MYUQS00`{3m^Qq`nkC!-zH4nkD;0cze$K9p2tk6Z~sB-4(fj^Fy5)K>OFo zH*VA=dQ!R9vbwv801aS^|i?}Wv6k1$&;Q58%sz8$OVc&z20S3JrbhEknWe^X3anh~JF3sa| z@ZmO5Z2AB_z%5=8I-0?EQ5O8OMW&aY-PC{5uAxAdl*fGj4dUf!oO4UO_M0pP`uUKI zPRYisQI^>tpHCZh$7?MYu9tFxV%%wF-43?juY4;eSKFFV*86KT>>7MX1K$&7!A+BS zv>m_eVbWj!V~Oi(yGNfEs>J9O zFXKn~f$y;t`B$s_A$qd*C-g>^p6yOk=*#976!|aEyOll83Gbf1Q+AI9JbIQk%#5A-(MRQt zh_>0<{lJV~-5o+!3qF~Gpz>1M>-7-D)`yB-mNWF}n2~Mo%&3cv;eub~X+M(WRONR7 z(Kef@&9MANos}oK(T6X|p7;8tA9XZw({Dps;lV`E5JVVKU&eIj+OpPz)v#J|!e37^ z-DrjxSZ11Fu-mESFGpVX(g)t$7-8NiN*~x8ay#glF;%QJ9M%(bw0HWr2zLn8oqeUw zVMcIUdIRg`&gN~S4n$)?AdrP@#+?c)bJ*^8Q3<I?_YN$UPpDUP zwKP%c55Bm3XXR5Va~)|{<4NwQvpR60?51ScK7P{n`0T28cq3D?;#AzmioD{j!eO5{ zF9>EOdtVwxQ~i*KH~(MzC;>0~_YTM44_L46LA(7IiG$gE(`}_8=ZcyeqEtXNSzbtF zYClB^We+j2f(MQq@*}d@irW}VgFj!##Y~}c@9JH*eZac^Nn(pIF#?I}`rhn%M7`rv z4`MQfgFi5k0*^C{RnSf|`MP#uSf48MIjuH!oJCR4e}IU}GI=Q;?KRIe7FqrUwr3i- z8XL~kBF*lOK6~%5o+cTT4m`qcEedRuyuh0v#z&d0!l`PVxDnA=WEV8w<=u(wN?D8j zeeR5lfl+7gEiS|Tz>YU5Nsg*Gd_~89+UJ9i3(Y;ZXGrkdH<+2K1&wqP`*kSyvYTHN zkLza>*@NAv=yoT?s|Ic_cJR+Tw9)-C?w10?X)yLethtq3NRSc=*fWp&46cC;sKrC6 zZ`%8Q_EH};|7BuEcQ!|Y6I=NHcT5Jksm(TxqE{u@3HBoefm=|Dtl-NR!Ebu(xOgUR zluu9cnkt}9E`m&MJ6QZ|vM?ra}1nX0&~7bJPMBDn%Zp1Y42Ek?;RyOw_!i z&27id3^r?vg}?x>ambG9gNuvRDtGu(JFc@76YF*4o`P9`Z_QK!oh3~l-1d9 z`Sb4OOLwVxJjof|eftVmGPz{^?QLFji(G+K$#R&~fT?Owi*>(rnGiTnEbcvZi{?$V z>MK1qqAz2m?Wg`-e~2w=yhDzgCJkCOF)T1CJzyG+50qipxtX{J-pQNu?dr8tfs2=w zTwGw9YXR>R%cNyU`TiBbem9}=f}l5}TdRSp{I8IT+Wp2(%{%LLRl!X&m~ml=anP=5 z#i!;xlGcv$$RhSQzeLU*OsNA)EB!~Ytc?DxRj|J8&=H?y)wo^C>xr7R>7-|=1ukZL zV4JtHc@v{#-qn5L#|OMenyhTGC2!c%dR;Vg0pGn4Z-x)e2h`K&O)Dwd6Y`rgzaCY4 z)G)rfg4Ha@-kv=>us99VR0re;nPd_V8H@c9RIZ}-=$b~2(Fr`z-Xx^*l&UCH0m-OZS^?b$U--WysdpmBWsBrbqE zxOI#~ZS?ZTKlyRL_on;dyUKar=+VH0Q&yZ$0a9`t3v~fqs@??4TuC3ct_lkP#CIO# zxWe?U=038${wLGaKSF7bgjIPV6wu%PtB0|`2KmJHCiCwrL5tVG%6zQqzoSQAx-9L# zyWH}eP5ojw-I*^;slD8}{YO@U20$~-cTU|via(U+JAOSS*_Z?E-`?2cUQha+?)OAO zna9L_ouYoZL@qjP)p{VLtkot^_7GV}82AUokmoC5cu(-!jt2JVhR8VTnEPy_`J=_I zm-M^6i;cq?Ey$+9#LcD%jvD+|`2R@eEHCMa}Zj9A3ZQpHdY+dvy;;EQ-wjlUTk2 z>%b@+1uvDm5nTq~pUf(E;hFeDG$TY;jmmjaZ)i?2DUDyLD2N};DO**jr@Awq?Y64P z;JfzKH3^{s%74dv{_zDI>h^6*Jj>qs&dyuvDe|2qf#k*=P5D8Q4R=H+@0{KqLwniE z(bdVWxz?BgOR>1?>~O>M?{F@9kCF3TfB;WTz?YC)^eT`Hn1&~I&FVbDeZCU4 z{OKfb#;%xqhSf3M`OCOkZoqRJh z+pfj+i!HLtOk91uV6W_zfkpN??M>O~vbOn8>38Mz;u==xc9`m!wexv|>!A0U$;hMz zFlRSM(+{D)#R2Xr)aVfTxge=(J%M&9{sC=e+$t&SiWpT%5vz;gSYBx%t_o8*`hC#= z36^g$Wx(27n%u5=!7JMRw}mWt7;dDAcJk+^0v~FxI<#DfS1t?BIld;*L@0$J@~APc zz&le`joZ~-*dMerg4 zBy>W5ZM{)X{H&%$WwDIFV`tz>(ijz83T{4$Mk^`NtXLXfz;hD}4t+g99o<}pLlg;> zpF5by*4)J4Ez$GC?`JZEi?aG@_<7YlBZDa@@l2HE^UKIp3U*uVA?@h6vG%PYoB2!> zGTIwZQlDt=RvIiJ%nf5T0lTgcPC^acEgqS~oG`(X=ZpPMY5#u6K0rH!-$6glc z^D#<`@7!hMbGrh(J+6`KDZUNvr?NQYD1f+4tdUC`+_<_OOng@N{K>nzpH%9_x=i0V zpK!*K(vom~D^5w_C*hoqk~9{0s+@LoOh%GQSL~Xa(k6I?Jnb-t9-=QhAkAy+_?GNe zdl~PYF&VL4c^$XgltUNGj{_^TCYFd_)dfv7gC|)Q|0Ct6Du-H1^z&RWaiUJp`9Mb) zRGc2j30O^>)mEhX9@h}~>x8rR5$5}C>Wdx){-1%GgYgwT{&o{9w_Alje52C>WI8C~ ze&7P62ubaG!7xI3(;tJ@?wo&FCO+9{U`%#<5|rtktNW6>4nGHnIe^c)k|}juJsS1Q zep{!&9}brELR}gtk3ONBT>{O;7=RoMgL#|Q@DldtUUv$0f{6whc4%{> z>RT`?oT`4BiWjU2V(%ssBCnb|wNphbMLxJaGZ&%BKTMjOwZyh&97H-w3nx=P!tL~N z<@MEUr;JpGqAp~tBoH320bKa>L&L?_yMYW)MU46lBlfiFQT^js9eWIRLt##rFkQHch)gA^t~y3IhF&kdHWG`A!c`)~|!OiO=j2v`*g&ghvQl@VM z^}L>52dq|i=hA@7zW4uo#J?|v`2kwF?p~^RkanB}g%E3wBbsZpfr^@6+#S&m)|l%v z5Lrk*9z~Gvni1))C=Ai;v&?3gJbj=x?draib^UK91vuzbplN#_v|23I8)yU7)r%2aFeQ7RgIlkh= zpaiW%CZk+(j3|R#0h$1thjJ~N!7oq8Pk!0Ck$im<5|dJ{FRP zv(jjzJxw~E?yLowXQ;TZ2O+V$MIC~?=bTMKG_`o{{(8Qedg(Os zXdRI@PD(%q2)-Cpmwu_&ZWKR#82B zlCc33nDyyuCx!d^|77eBr;!+uhp{Oh2-Svf$jMeQeMUu|d;jz6`egQdH~utS=Cs>t z$7UGl;y}G8(KCI~wdkocYSqF9)tE3e=nXTQuh#A+8JMwn+ac03_symFu0s40g6N@P z*HsBJE|r7wtKn@Kp>DCd4m3HI^&h@$L@PtPQVq#w#BFITj^;c6e4sN86rPIMNK&{h zOO@+qnJnc!Z>32*+Hl90N7bawv=z3}R8s;v@2Ii=>sD?zp{cIollJDhzFzHrPXqB< zrFG~WMs;l=o@IK>jAzOtYj5NvYh#^i!oFxeWh_lqJ$<1(5Y6zf+wI-9vB5ggU!=AQ zwo}t&k1h62Y$BBEb~oUJP-}&OZYm(^pM-+pY(A7BtSM&6AnyYg59C(51Gwh}MGioX z2=%)wjH7#@Q(&jhqgZTp5I0R&)63dlQnJpOK+WoAiB6=)4ZU=0dqP_?W7rqNz21f= z5Y$-@_cG^5oIwkX`-c$h%!Avp4E+}89W`hcS1&G(>lek4fwm_9#Xmakb5_zn^u#}q znR^et6d<4XKeP4aOGs2SAnu9NNd(s@VlMb@TPc5D-}DD%V_#+aM;2Ow0YG(?GZg ziCq52&a8W>Wn?S7N|@KG3D^;IM4*dilQtrCqhDbC*HaIf5lGLH5W(J4VAPLyW$j+} zrSkx}Nx~K6_1Ejb*t<#08B=Rm|H_p>na;_H#?)H-#-tY;skpLOOEY&pB~H7*@B7j3#>=ascUx=^zG@qT5sQ;_-dhvsenFw$oXS%3PRJ>dU~ zU0W0ouOR56?d0ucGZ$Ca1Gc|P#JyYjbK*>V2qw#|38KwwUNVwtLN(N-Gap*+yQk*N zHC$_r{8TPCB6s$cs<1>a38`ZGE|}8UD?V)(ER2muB@T65yKA570FrqdwN@fA8tgF{ zy?xT$L)OrdExUNc%|Y2mMby7V-*)mBA^9i|yQ-NS2p`7!xC4R&2xARjZ zE*{slQF&sB-vbpyeE!PocOml^U6%E6V|@O-Gv5R$cp>C~@|fwUwWNa9U93=ye?=SD zOMekBEkS!y`cV+@f1nB#?F46ztOcIV_aD~WIKmUu^z!=ca^xuTWjAd~$+KZhPERcd zttr8&@T&jqJ6-QxbG7IuEZiwR?FG*HqcDoRsLVIpoBN05cE?6zNM{0WBk6x<53^H+ z%YO-4KiJ-N6(R%s&&_Zii`F2;1U7kFN*s@wOoTx&FU^ie;7Y|h z?T3m_j_Uczv}2gop1r;_ks$U19NG*ieWbrfT+ChXe_hjb9VWFA$?!@JJ&3WKCt`oI*J#;K&8J=%y({2gt zVz?hl!OxW$)Xq*eA=S>_@YtNLrR$Kp<4&8z0y4~e@S?AaL;Yy2Tg~$n1M4ke*_qc~ z`+RntlVQ(17IR4GM=t<}lP7jqo_qb^7zy_i%mUaE$4~s?H4yo##3!)uatF7lmo(pw?1JyX5x(!c=G%J@JcC5ZED=YI7P^*j z4YI_oKCAaZgPoCm^01G)J>20F<~2*Pz(;havdY3Sm-)e-C&U-U$nCq+;*R!&Qh%B?a1Lr%%94g4p?L`)Xe`gE! zsfWS{E`vP)9giew5Z~Kqa|=4}OpSwmqm0Ac3@<_!`8*fbXZ&c}i$aGGe|SIh@4P7V zvFY0Q-wnp7L#MpRHpN`aohD-RNL|ZQ9{;kuMJ4AXs`0ItAxv{}LeDJlF<_p)d6Uhy> z`Sd?F`%!<;u4#Tgk$z)>X0)0(p1qvUyezV2o;UXmeR_+B`tUEn0DTib90c%Wl{h}o z!FhEBu*>@?-eOdxL+ZtOR7JT%SSox^r!MZ@^x$2k*H%vAIc>E8sTRi^#191z?=2~S zqGdv^*;y(F|C#TWce*@$LCS_cH$P(&m5Q26)PiprINMOd{&yMZa#D>hyaGa^63AT3 zs`HP@TqFcP8YTdTHe(QvezH8V>WjBRRTi8`AqlUutY=}*I)KK_$P7Bbjy?<``JQOBga*Y@|87S55Q!c5NBwW>D>BO?o!R!|KL`ijiF`5ApYA^Qmpa2%R9Wv(GHT$R0Yi!l2GOnZAx?#a#{6>TUDI}sqXe1eEhN9 zx1Newcr+Fn9_-z>^iFZ|aoTns!KAxuE0!*#1PGA?=&pNgm)hwTeQlR&81?W`;_bfO zc`MmAa|pKdYQJ5}p!v7~_RI(Gr3b}OR{A?l4_HJ^F0UOt`H3C%nkSef%o zT|7g5j)Tm#H6o&KbG=P=yS&*Fyl*D-8xdY^W=QuYap45QMK*&o$z^4J7^DzXWA(5C z*eJw4W&5z0zaSMqjVzrw8ud8-g0;DcBlj7#hRZugSyUXDjf6?jw_ZZS>E&3=-{@VxWff!6bA|qI3Aq(cVs<;((w6qb(5eTet5pPLh?M^}cq03C{y=gAS+tY~J)}P>$DLj>!PH|5iAK1~L zTi3b7X01C17jD&{_|vcZ#S_?rY!(h@} zWP#_7fn~Id0k6RNbTz!f)=&kE+tKz{g3ZLfUUWQ5vxr`=#fY72&)_PSe5+YM_+-um zKX7-Jzj7x$i5___cOtzA;1)eYgh9<6p8Qb#?OnvHmf2&~AR1FXpQ~XpY(r4@juMJh z@F|JJ3Pd##nhN@H*vH%s{6|#<1m!!hR{+lf14*t=mEUUKGwl;NxFT~O4QQHWS2RA~ zswX{JbEBURyy{Wp;t_j>*ym;e1@@?lPaF$HRyv!L1@kBo1M&Ged3qtI{JVYP! zBDjUd7#$vf9chh=UShJ3%%8}@2&;G8--csM6CZ~V5Kl*|`FmAjJB2)EVnCE5HBWVR z+}T+22bVcNsC(3O6tRI>=obFmjn<1vEZ5t466@`(aygr&fSbk3T{Cg|^!1J((z6fP zgz_p?mmPKwrE3|?2v#v{LV9-34CALV0^SJ*-Xb51sM4mJOK6ax z0IxWk?UJ8&;<4rwD!fsyVJ_*f zdEhp_0M!!$eD^5Eg={(yzXNsfYYgFFd-~iEb4QI_M}DzuGGho2R*=JtaY9)Ahdz$i>msR6=kWNHXF(7PH6Q1QFIo5O@3`0 zwveA7AcAyQbW692fCz$s(kUgX zt4Y({oXqJy6T54&b;vfh$2?D8V~FGW*t%+9^B26JNG-R8d2>(R18{3+5cgAaas7`o zE|`uDc4UOiz3$(E0TysWJ*D8C_;`DLb>>N9%yUt~R4k$VK9zj8{1ppv(E^ga-PjS; z;p^j`thf;TQt};pm*wD|p-6T!NWb*@UQPK_ZyxRPuBL0saA~d*rhbdd?0Ml17WfMY_p*MMeSoH4ttE(~6zmZG~aPt>! z&hPQ6t$XDzJtj1IMZ#9FTrB1G;p|F_9;US6{8=fgs%Egxt1AWV!k$uS`O1rXZt8*j zjp?w0PDxJB+d7-CBY3&8Ab+V$+U%NNGn$l8D}>$swfsXRl@)V5lvbE)xxS?6aNo+V z{o!xcjo-Dg0Hy_D_lt*g-d%uRwGW@rC8+)22@@lR=gMSr67~jzK}{6%8$xEp?N%j$ zlSO?dA)VPVEQyw{g?!&M{94%T;F_zz)*tA`0{5L6&IGr|yE2Pd2Rn%u&q0#~2Jqg0 zVO|CH)aj&;uWm(K_q2)=3v6D(d!y~^IidXj!7VfahhQqSh(oSem4>S2tn&7^OY5u; z(3W3ntVScHNcgTuYQDFPzkCmI!HSsAJr^c!; zir(J_rn$M~lQ9t=j6XWFhJ_Kz4f*goPdo+W!Vu2M{wkuUzxE%{%5A^=#2hhH#bb0% zhf&Bn)mmwFlsn#n>4V4(H>k?IoyK&h85CMN4NmUl5|Xn|O9HyVS5djP5ffLLAkA=z z>CQE}2zk>P@dpTrkET|S4?kYn%&o>_=AJ(XPU_Day=?8!+m#P;^K+jzOSC=+JMVY~ zIvlq6BBu~a-~O9%w06*D`~{}n5cZ6o#UG(IcBS7FEMb%wGM;07cAB*;O_&!gTn>!2 zX3w+NCvlyCg6A;FHQhwElpEeZa&gTJk|M{?QPh(YOSsLYu}cfTXFhVrx}@Hag~l=g zm0-Ej?#$H<2@th`YJZl_;Xh-quXRg*i3!}0BbkczziAc>h)1u|Y_6QCF1{heCCQiM zVWhYAOg*i)D~k>i8mBvMAa#m^A zfn4eeRb}}fJS-V4T^F2I?{9|uq`kC_WFxb%v5x_K+ha-eUn@kSj-7h-jl=T*dM5KX zk7pvaVMR;fy^Hgfj_C~QMDEtFOAm7CiS`gq8%=!(&BmputoxpQGxPnfDq8P;s*4QOIbOeMlH`0wI?gCo0e%Kh`azFE_JGqhfp1 zm^0YqL~VUX=;TDKPw`i>Ro;kdb0lqF03=v8EGwEi{kR9A*NGpcC0*1wPkL^blAeK% zwIEf33O(Z2Z|hlKfP9;H_Wtpvd_C zjOp(`N?M7*wN0YV?Yo+v9Q?_m{FdM+){i_wkQ-(ohdzd6U3_+9iB<~5a^{)p>#VZW z*9=9sV(L*V=1Anjr+%IQ%WGE8iLm54TeYI6?lq{97FftHM`P>+5qDm(P_;KO&JKYz zY9w08z6?2*oi(>V;NEY+YLoMp%YH5{$f(P>*;RaCYkE21Gfv`%WM4Y305-Hw-B5D2 zYNcbOsCfwjH$SW><-MP)+EZ6Vp3i_>9F3dmJAd=tzCF`{$vk6A${9^ zk9J4Xeg_c2hGt2Gnz5M zFkSB4#Ue8ItkT%<74b2fux}e~!TbmIvtcdW>%)4Zq)(Bq>{G=#`UDAatKfc9R-W&9 z4UY!=#w}XFbO6QSa>j(gWyo5lU)s3Ku@o_r=sk6P_vs6Dc8=%Q;}xif`6=>bA8yQQ zo!-Xp*tEV8X1H@0*SuFlCi_3(k&o48JVVZE8zZadQf#~-k~@+!Ksx!jc@`Uyzw6xQ zt@_ud*ZG>K-l53%NSE|EbfYc0DRj(W0Ps4dcv-uf0xs{`DLL^r|M0;Qy)Rgdv&J7; zzdeUGpP`&64m@YkR*{5f96uNFP*QCcd-=jo$G7i(gg&v)92}bVbZ%@Pz}|!d2&PQg zeVOJELS8_l3sL1bn#xvhsr^cBL(TgxZC!aLEN@xkb%+}Ayq#_~?VfA``mCTZF%K>d zxv#kmQ0CM9=A$?SGTIFJdl)?%aZNoOiIz$0Fb+-H#!mEl>lWs<-Dr>)DB)Gg0sjtf z<)x`kJZ|oAO!Xyl_-TJP)-I#XPZ>`20Oj-yW=|(kE^D{#K=Wy=#_7!4EggXzHc@3N zGy{2oAE&Pha8V9p(j01#qo!p_iO7WC9lgNep7&H`#}&(yCxu$GR0?yFk49LhMJ41~ zX)OJBbDKGqR>;$0cX(bbs`AC5WH_|pQgA9%Qp7(>t_nOEeRo479zCq6 zu8{Zbz^<*jh~cppMU?ZjGGry+Wp$ZUQXE^cEG4ey$G4m)OoU6ox=foKZ@{FRAi4nQ za$eerhxBc%|3_AZq_YC@w9E}(@A$<*CtNA1Q_AEPWWPyr`|5D!F*8fqqUt*6YP?hh z*jC_5JQyjZv41u9!r`czzg|#5$oHtJh%l1!@G`V1I8RCjoiG0PZ6lV}NiOv~Vnnmz z`^EZIvsXGc5{z1u$tRESaFcZl8G*yroUgSF%D$(T9sSW7Gdkno;$yKBVmeV5uW@^52p?pa1NK3(uQe6L|OpERtkSl|6L1n!Sbzgdk-Z_F=R8%4Kpgw zAs5gMv>in&E^{~434%cYr;6uX{~t7Fc33Hqx4fyR)Kk7sJ|$0`N3-dr97Y*9N7NQi z=eirUcRQ;sEG-wTZwrJfg+8p$4BGh8k3{Rfh%wF*e|uH}^$YFh-H#}U60grZp)S9p zYG0WSjmx@tRqD2=+x2}PE_W|(EOh2mbV*1vr_FBisT44GFfaw?J>P ziz|iPV_r}xxQ%K;thi(8>gB_DI*Q-+3#pSOg+SuJHv$Ds+AnWvR?BT z@P6YJ zFRLlRs&4LdFqJ5c(i-;g>fOs;U; z+D)st=I&D}g*@Z&9)GoMVe_OynmIkAs!qk=weTo9iMZK>@Fl63>1NVH)=Zlo=Z5rZ zRi7i&I+*G70k6dTSO#)~LaeMveu@O}q~{n|zA%5l+-9M|l@XJR3uBfin!FOd>-v-l6c+p$C&@uA5m36KyraP@ zECkR$NgJ&)I=P6wqQT4pD{Wfc+!;(fDJzcnk0wR1rANv`LgGC!yfaHN-PNtwKtnDn zj@(X~G*Q)tRo31+KI1QmZ9iho@1pm>z^P!DnYuus@L`3g+W5>rQ>NZ8|A6^hBHwPR=TzR-_u(H7_V>btOYDww{ZP2$ zX~@~61KSH231P-ORcZ*e&Ix3w512nnVP=K9wwDubWH1JRryu*gpZ_Ws0y8K&ph3a> z`r-(RuqS#Oa&be3&7{xOEMd#NTessDzO?S;9$v`+&LkjppWFY%HF}TnKGLlGKTI`xSP5b2fkBX^ zwprX2ei#i?;AuOok4VSsXIGmRT0PU#4`vuPJqR(}Ud;B^mY=9!O7LA-L))!-LCsZE}i+bp!9l_qZrTJ*LB0dEG%}F)w}+E286Uz*)IpM*KIEEC+>Y2IhAy=dD$}gRABfvkEG7u0tNd3h9qu_Yct9j zi7Iw@}ooMX|u`}j0p2kZS>%eXxU`>ET~8gXvZj?-IG^i`pLDsd}6Jigot z9uHqFbx=xwl`SI`Sy&}@fz+j95X4#xlhNg6Xg0)u+Hu=~-^&jGZKfTCGb7cDmZtc_ zBh5<-%BzbQ-86_8M-yi;R)9Gu$tEv-e2=(jq3N^DzcU9dk4{4Pqh;bkT>{SI=LJpz z_hhZ(3WMzTdgtGQ{?vhm*D_85NKd?{_{#O;;PU_=`oMQekvs9@)+X&ogP^U` zD5*$y%efk47KAzpUh7e!&|f_fQ6{PN!ge@JxT|gwEDqzpo<$^R^udK-WLIVvzmoyC zQPDMoJe?*~unKcceN5q=Fls67_|>9;{3f*?ZJK(SF&$s5shUtI4R2i#wm>0Y#E47V z6y6_c0hFX{%KGrD2(2y4#)$}Dj4vTH&S2!(_m$7isW@;3jld0+R}V28)Q#WZ**-Y$ zPC{+U8@zWcFH}&xjPUcyo{?ETctW@tiZw`-sx)Lao$@QxUGxCWRb3t4fHn#2g#P`o z(viD@+&)Rd&Rn%JmM1roSL>Xig8E`EC+bL`I`&A%i?ki4j+4!L;^T#BaBr23!D>IO zhTCouL{C@lDTACEiSn{7&g1w)W|w0l?@rlNd5b?`iOjL`Z^ut@?aP}B!MvZf9Vb<- zuHy2q%dGb^x@iA`U4}W_`IFAt6b$6fz`4xP0|q|eUGU*$;)X{W7Zzvf8|%v?X)2^y&?u@`E*x|6~jOI&`^O>C=sxRws3F%|q%RfHB+4tk-84|pGDA8*bC2#*d~#OYl_5jeR{G@9 zuk-~i=v^{ovk5;A4#o(1wgzc-0DtvnQ-x`~Yh3*t5LWJaSCB>!bKB6iOXA9D>$*OZ z+9jMO^RTS!(P<;AK%|7v)_wef-@=UHVvrd2vw;ETK=NGW>o{}2jYmaLm`uk&_QfV%s&vZd!X2E0nnM*Ep}GK z;sb-P4!PnBZL%1e?Y@*3X&NuDD3{V})?5J7BvPRe-uI-)(Azl_zUD$FZ@&Wn#`}x^ zLbMO0NQQZguYPRr`s&|h%?*^QaJ;haf-#P00B6Q_KvwNXNppB|8N;I&b?I%4uo}t|rYE>5Oc7=rNwP7LCizIPxqSKgp!~v-Z)Z;?m9G4f;%TV1Y ziW`qsBz%P{>**6lV;)%08V3uhicWNu!#`2CBV*wz#mY**my4r-)axqV1-a+l-ezO= zR*bA+KIk3$MLZ9&k92u5M`H8k8CioCv5nI(9f4G!E1Hjuc|9JT72trl++hqtPAbQdOeGo z%6YT8ynATO|FatzpeXkhf1P-BEFBG>Vw}DTyjvjuld|z+gAj|xTEIEF0S$M znZ|U$n~$MxH=(XCp5tP9vz4Gzx5Tp{zGcjVSJg}Ta^vkc(NE8QFSn7soDS@j(|t_M z%usK2QfhceYt9c0t}gmO)n{m{6OCMD*NXIg?uNe;(VS z7XSp=U)weVMx_kqr?}&~Y+Nrupj5PzHViRCuNh=?*X3iVPjj=Ue+2$f*xTi2W^g-f ze4z%KY1!Y^6|z~3(5X27rS1PvqOk}R;GxpWl-`33+5RfJ9J`%lF7&G1!1=rK?`2pU1c_mE({;Ce&(!9KnnT-?{heA3R41RR7)?pciW=uW*HA#1nuQPN~asbLI{baDhk>ZM_IZ zI6wNAgFtpF+WEXRCqmK%5(Jv5l6B!^!LHKFC~n@D#88tpP*7q*)9vzSxUZ#$7^#+>aS|O7SJN0 z0=4y4xOgb9pd*P`=#VH++lz{rtQlGi!*a960!`kS*n|Ng5qH?`cskQmYa5wQHu~6m zV8Qa>_(lHC8O7`vM?Mci3Z%Ce2Ts*yjP|quOZwkkLJ6Gln$>1{e=ub-N0g=Ndvelb z9O#OM)DOA$0YIS&_>+%DlJC_=4;a;&G6+;*@3YD1lBkb)2&R{x;9$9eaQneA^ z7yY(R_m$Q=J!@yTQv`(NCRW?5s_6-^m*-U2%NcEjj=O$`mGk5`S!a{_oz2=bWc!Wx z5nVXqQ_bHcDpRp#zS6t}2lP?9Es&fA&rdf|{TtN_hPX*YmNcym$#1U)bNR^iFxyP4 zAAeWmn)j0kxIwD5D7zTk@Dw-fCX`B5Fz<(XDsUY-P@X=RePsBc$f!EDbjn0$EH*x( zqDm3Q@<_tM-`?Jnz1dV@21(lZLc6TlD=Xg&4^PSFMMM~Ug0k&iMa3`n04CwF<64hX zT(&?b*#pwik7o&Mu(n$7`G~^989R~h|8CoSR!qpz*v>QGd(6!8=fIFBl3YH~{Z_%5 z43FW%2ex)PJwQ9$u8R%oZuc801lf6MFr`b>xG#JXxyo!Bv@4i=M*;dzJC-|i*^<+8 zqN}^@a`;tIvqxd?ov)3@ssS$NA4DW_=7M-22dAE6K_U86l%0U^@@?Otu8T`%1se>m z1c;+nJh}WJ64g}ucni=_8IE7q-VPZDF}^QlyZ9))_|>%F5%5atXdF9$v1%>|^K{nbeK027t?l?Z+nu;klJ z#(CxPtHm4LS#OrAtf?^D$eOOpmbeaoR~8jQmLqR3cjJ3m&x0sj-XB$;oZJN&Lw1tK zN`OwBWt($A=eR6LKNGd;Ri^FuDIHdZr>E&WoA9{gUA`Mb|eWu$Il=W z&pq%N4eyQ}0Hp35L$mWUmrdwoJu~fdI)|p>1K|7kz{!p{&g^BL=hwav^LwcCQ=u9B) zN$a_xXAtm8fuym#uFoF#fay!#)BgR%R+_!JA;7lqA9;yU`54dZs%mR$;XnLCqHgDNiHYR?OkvQD| zZXl&@@S5uluD}h(?O7XZ5fvQfdMRxo^27*ZJ!b~e-I=N{D%f|!Fxfmay~zn>MMsKQ zN`nCSyq?tmD@$4eM)Q82%#3)ktN+L9n4hIydF7Et@M?!QBWlH&1)jA!uQ!zQ?5$@> zV@(Em!-z1@pQP$;?B*opGW0#|OGyWyU=C00C=%~B^&tamvTH*{1L@i4TCtFX#yPR2 z-fZ;%nW9N9r(tYr&r{>}4Bi{+6E+!?6p1_63G08`prQ@_Lp3`+MU`32IwYdl8;OmC z-M92ymcj99Ui1n^4Z3yltq&xpI=DO&26*!&rh5Hx>?e9QL1znb@YS{qBPg(|j{VNi zg-XM|oz!P}ulB*Avgy~uA%7`^gq2R%wHcFixrCfc)x`Ys*)aT>Ac-8-#zovIG&UD- zYG?Z*xJun{{#rTn*iRr(>P>Us>G=L+wmgp$KJmEnkHNBaZ*h2-uXV!CS1%L9GI6QR za^laTpIQoWUd(rDy*(p-M+PwATlCx4T$Gwky<*#Qz_x1q?`_ZE?ve>iV9-;gnW z*Jp#_gKiF;!I&>9h!H9$5+wB}Al1*6n3|gCX)Hi)4fHv#D#nISl>n{0d>9qF^ZTXa zy)Cn;rC;tqO2GOtnp1M|Ume6&136!w*Pp{6t_w056M5-X$0>^7`eJ`6PnyuLW#@w; zw(vZQ@x8mYnfGmTeuOpVdla?`0SqaI7mL2kiR{_Mzq90Tc#ylByg3RDi0@DBx=wLz zs(eebijpo}4^FzmErH~k#|&`FYKQSn(Gm7{7j}RRa*TOL4&RLkkSCGXvsGi&*1>U< zhXre&y-2GK4X<|M6|QH6`QZzqUx;ui6&9(QH^ds|D(wp=R;RNS`@aa1$<>9H{ciPf zcOW|6m$g5=sj+&fNZ_+4OVw%}lJHv#$!(~fYE+vqJRh~L<>{M^bt`zt^$t80XW9{)kEi*@k_<|+Kr&NO1q$-ZlDhYc^ScM8e4jd>u9dKY%G z&B^IvA3PYfAN*~JbK+4~UIfGF0gGq2X+PebLp~pf&6M~Z@^bGwWB_C(95v#b6a0=W z62=lgI&dWU1(9oF92W77;Y%{JKmkwR_Jme0gpy`)*L|MQnm3(Hn?q5cRvT!qjc&py zd4l?^&7h!|egO{Ny#7@JO)-}K(0jDkKqyBNoLdaK#w6$7oGB3-k~jbJU7R|8G&9ue z$|7LW>CZTKGLq86>wOfD(p-~j&kO4Mrmbp!IZwV*vNyKSeFGVNZVfv~dYW;klRswUc{{6Y^mlS7lw#edeYps~P#D%+x7o~m1dOj# zd(e4U{+w6|7*I#3(tb0@27z!Ro?u4s%t#cQ=X=s)sTM6|akq=Q{U#@G{%6(Ms@Lp` zUdc^Szh^J1nzzj$gfRp)62)VlmU5#SmwhnIv`{u@idUgad*5kOaJ@hH8Mfs*!>*eG zl}+T-u*-9g=ukKPfxPelwd|}JfHq!GU^g**RaRes*6wV5#;7UA7?^9e9VFHOqd~qc zVZP`uk7hl~rd_rq&d%een}0AM6KJSz7oS(fmd!{1Qr~vZ>Br*ZgJ-J5AGfC$M;=Bc z78^7iYPGklj81SdfPfzhSz!wJ2vm>-l$64Y3qEPop7t|6=^iz2w?PBP*&vmRe$Igu z!nuRuzAGc9i_5_oxjN{~AuOWRJ|gv(drLQ@%lGMA3Jg+QPfghT|Igf2rN_Iw-RB$^ zG_n_VQ+;^k<*V5qXXnyn43q)UA!&GWTV*}4FqFy)lBKN$5y>)qslzH5Ih7(8D*%_^ zvv9rx*Dg8+I09Ph*-Mgp9SF+^ANEcW)mgo#{Dkf6I|{qYL{zSOpHXF%Jl&D8;)Amg z8)$VEDk+MvV``ukSr=;b9N`X^owXA+xq9Q&_D`gk)FUa*AY+xLb(&rX-mf_FF8h-%2XMS>E7g7@1FF z3_s|st&cnHh4`8)+RDX^{H}VT@QfUn0|29UPQx-rI#geaX_LJbcPHP;`AH9=A0A$H z9#lm^9|yC~y*|#|xA-HIwIEyz?DJTbRTXO0P|0P`{5{A-Jk1UZtB)2?DzzCk^3nWt?(~zS2pjLZJrWHZtB-0rQdZ(Ad+|linaY$Ez19 zATmJ}F_E@tR1E2(R_euw^>r3Ld~>&EwK{Y&8)~(Q;@K)mJoBc?RTDVpNzYAdCX}5& zojgSLM#S|{61WS_@B_=>6O@l85X!fNQMG};4MBP-NB0cVcd9bX)UhcS?q!}WYlkM{ zcFgY4u1#ZA3{ScM=C(_gjbxuFl{(~IJbte3~8IjI(x=h~gOzs~)+>}9G{2e9eLB4?^( zMz^|-P6G5r`}UsvGk4#X~SG%SW;=zCq6z4!{d;vf>u^?&Y1tw^yqS@Y|HK4Duf z8+;bCpV*7G;^aRbIYb=o0-h3#D?ScVp}IE3O0dE5e)Y}XeJ#`eH%<8am_FOt_L;j$O<-`c1+vhz{d&EGbZZxVy}7 zW;55tUR;50)Hr2jZS{^!lAJZVN0K8pJ&<%CN*(X|=D$(WDBC|88VG0YrKHwxzO{5q zm8j3_bfNok%}w3kldsvx_UOlcU6O&D+#a`=Ny=birP2~cy+*>`wh==)zc0r(UrkOf z^ch=V_)oUSug^Rh1f14oNLaeO2)oEMdMv6>FwA6mZS@C9YDVIh{=8jrU%+%kC^LKt zc!7N@bt9C}HQA$tNY_$;frDu~-!FfR!oA&-wDco}zgO_^sw6PY61QK%`fJj-G#@)l zg%}SN3NJqhKsh3Mj)P=^HsG9s@EvC@Zm2EXli<3GLD z|1|u;_O~m_EwWv!aq&g$!m0E#fgKmAk${jvSMR|VpTsTirye=`Z%%YiT4JirP{l6i z+qC$zld(Tk0R8~f%!FBXX$GZ-z_SSv$($~!Hn8&&cI3p%DBI8gi_@OD=0o?}%V%-{ z2+gCqj8!2tkCgX4x6uv%Yy+d$la24pe)Ma*%Y-3U|6$-Yr2p2n<&SFEMo(U}C_@Tuh@>|imuL^bN zL2c2xB&fnyFP*)~yLA}BO{0%-kC;(^l=JVhn|h^k7Zp#y!PZ!%WQj_&0QIxAHW-Va z=#oJ9Xm~`XKHkC0HC+U+1`P<}T24RbzJ88BQRw=Rif4(={K{O?P1+Ms1Go4-`SIjZ z5^mNJpcE0<;!Hz-E{kO!l1-bGR6L9H!q~@#iuid@Tt7*Mq$bnGp3~X|G*L4(nA6*|r+r!IK1Z?yiTKLs#8C}96i&boCXF`{- zWsz{SXeeqyouMX!{Y|XRVZM9%N>&;t&xQZCWW_X8e(~fiKkog1*k%RudfS@RwV)9r z(CljQX*DhNDlw{#&GP-bzsDUOG0CRfzYn#VL}I3<@3?_KWOZ~AnY&FFyRfZsF8x`D z4*DDChoU;tx55IMu(ms|Luf{g+4(Z)fcj=1^9!&Bea{mqkXq6JL3TE*cEaV=BR=u_u!bfJ&8DILi%SFq5M!uH7& z``*tt?&u6KAo!XD$Im&Hx~gcOLO2ZHK)$Rj1z~ct9`O=!E?d8vo}Z9+>3|rBVD;qd z(SYml|6u>Pa5uF){~)nb1@D#ko> zEss3>2$YfcW85*D!V_`}?$j=BmiGZHYj&ItuYV&W)B43m+LMU+4u{^}aX|Dm>nH6< z##kP0B)!o%J&jAm%KzAFHz@y-az2^(%B${~>_;Yqi^kZPTRDL;4D?FL$oHqm*EaG; z5(4q`ozz@bLGLoXU#%R`pZqa0wSN>HDkStw`Nc|G-sLb~8Jea7Pv`r`W74O9N9a3S zg``xCexK1!7nkoktSNr}5yNVJlZK+P2r;wy-t2k|%?)|VvCqv)<%XRPHV%!0zy_#$t+ob-t6vHortz<3pM*E7Xc6suJ~bp=qAcbH?f77}M6{ zYPPwEvd~4v9$l1hT>ZjTu)V(;!P|_KCd2r5JH#&>rQBzfwMJ;a21TBizEb(X(mm+# zFOmG{sgQa#5YJfhCp6%%oHVTx)VMkR&wu2cT3ZYXBj4cu4tdmQgYjbtl#27r+O_h( zo|i}4#+GB9HKbxsd-SefWZrt%ZxvT|j{n;g)0DVc^W^MYiM#(5Z=*$`5_+Z&badd9 zhO<5`L2z*Q55rd3EaV!nowoe)Y$wsiDJ#m~lReUazF376p1#&FBZ7dLo@3-+U$cLt z4_eaMq7TfELUkCJwtogT-r4wF9#sz2dvQYJx3b#v{iv1D1rOCgZ0Aa0?Y|Y?c@K2o zukKfJg;9%5ckD#*mg!a=KH?y$(I*E=mKjCZ23jO<78AEPW^&rxX5keG#anZ<6Ez~r zpi>th&{@6Xk@GonrUe^Oy#2k^yGq5lfBR+hX24%>&`Lr4oqiUFP~MV_JtM$yZqbxO zGFpo5G6u|W8mtMuu+nZ$b6w7eVRY@WK=B(eMp^Q&eay3*gnv6c-lv5-L-W)aCb#Xe zyF)5>X<}V=4ZnSG>JqTwc{wEJsCp+Ll#Kw4`HZgAFjIBeg=D-ur|s=G0-m`A#w!hf z@-rZ(Rz?!aS&t-TU4p(pHw5OwD(@SdxCb7z`rr$jNg-e*)nQ>B&ro)=!#S%t)tZwr z?MkL!lwXOfp-!M@b32lXTfFT76Fuy-AsJcKFLwEjDQK#pX0>b-{NKaC$(PZJC|$sw z1}aAfftC0!@tm_P`xtRo)wkPB4zYXnsuevU2Yb{bSzsJY1Z^-RSd!L zkA3p4nyhJR^$vw+mmd0ggHsqxMu5U?z90pK+a^ZmHBUK{{t~!UspKpzXP&FE5Oj|- zO&A^o|1m%3vJ3TxSX&b@_GuGl#bUKDvP#;=VPZFQmw zJuVd#BcaHu9u!-m`g&(qh^_o;saZqDMjcJ4VW3beFM?z2A=9W*Wu=SkP2=ImWv_TZ+A0h8G{{Vm7u3O(a|62XDpunO8yX#u z(EAmXiM1ZKdLZBBDT4#BbLw^vlr(>>)Sw00Pp(U4`5-iWGqK;=Zz&obdsTM*P!FxG zii&zij4`;^ALp%ZFxT-+mrdV6{sbEFB_11}X&5Frglud9INiS5q)2p<7+ctfOshZ# z!J?wAcf}Jpr#~lMD3KPxZ#7sFn^%XWX`~J4b=%={Hml)uXacMtd)6~-SnE@ zN|qr7FdJ$WF7cu04*Q$1y(HTcRjlT{f%1n{a(u}twduOibR7(Ox1yEjw*#%hY1MP4 ziVvF4?zE)zg$iq%AJZG&vu#Rd9r`V{+=3DCOm~q3lW-I^qrrEi3aL0{@ zi7WZ%d90@bYU3n7+?UEQbM4a`a(%~KsHrHcy9aY)<0&x zcSmRrn+;>Fe=mRVYHsGK$G$x%gvx$`e@7TICsl2|jp1FI7N^UawAq)nMgqO=s-$U$ z`=pnX({Bcg;|&ATM88BbBwOuOv3pke`Wydc&yJm8fvS&@p0KO^g+Pj=RUjSH+dBBs z=ecQ&-V0yLt&Eq`-CWeU6H&??Z$gW%^O}~vTZ$pO8jvlN$P%V`VwF=-L~dV)>hAlV zuy_}^F3;i1gWotm4nNUGG%zPCXD>briCWh>dI}m$?!-jT_)7%|2r6&F5Y9SnCGhxZ z+j`rZd0C8p=Dr@R#$5<}!ezZ`a!|KX$xZ0kzVxQt)}!sV45zp^)qlPa7Bn@{Y1IaF z2k3nX&DujVz_TIvk_YO{d^ujiyPrN#?rJqhuKyCpwrMCOL+9KZuoMo;v1T>SR=0?r zMsPYb7$bNV2W1D!&}x+p(2IV~@~aH}E4K)o0YCeGFc`4xJI9-!K-Q-fh2r zX6k@+x<^}o6i6nDxo};#61%%IPF0faPkR_6EALizILyh#KvS(q1iSKf9KD~KwUCQf zTwE*~EmAeJjeLn~z~77%N@!%fV7XBx-LN5MQJatC>C7D^;p6D1Tk$DAy1?}^}+V7ASvJ#X&}v0M2xj@C`mhHp_&;g-|& z{+Y!PjlEAX<67^JOWAbdOdU;Re1+UoLWDGEY!v!dTGY1z$+VhP|8}%Bme~8fyPDTK)JP@ot#xzy9KLun=7qo7ZQ3Q>1l%c8 z@;gDWx~BZRVaT=bBeQ?$4AfjkUxlpm?GS&?jJ!P}kk9|n0U@eQzqmID2t|bt2Rsjq zUfImU-$L9T{xLd5shd+wO4EDw2%TzWtWAqQf;#~!h(Pw#UpiYR+{fAR{h)% zTiJhmQBmCVcX~LHu-4!bDUCn!_$cqlFFg&}QORoK& zjJHbE2$x6TZQwZ>CDNvEX}7@V5$|9_YOJQ?ZoASTG1`#|>~i+E+W%9aaK<|~Ize|O z|Hslc(VdRE$EXLRNeaoL&Cv&0b)bDNVCB+wO zu%yQyFDdq&FF5i6xT7p@Z;Fc-hvwPq&zRV~9Mm1?10+2;;x;C)nL(t3E%8xN;UJev z52xTiJ-oochklmt?#?f>+%YHV2ny1vDNm&2wM?b`VJ!DfHZ8SzLXpd(qbWx?4M|Ge z@6jT{#4uM4$#C`9WYqpNpuher%j`~rNt2*kE@6(4Z1Mpx=~g_w6tuWrMAsbSGB$n# zsNZBoGf2Xlhjr=#tT-WZ{#15V8KtGN%?M&7lQ9gMS#!_5fm*%3z?n9U@ub zv*vk;X&_F~Ic)=Q+s}cBE^G=7n}kx%a>>~CQu!po3wsYr`^dR^GQID_L^11}C{QKi z8n&2GDG1%xMH|`CSe3cqD~G^w{M|z_etYGQHzLdh50~CS)LXniFI#ubXtaUr;)RM{ zkU+{x1}gaq0WBmOTGRaCR^toAv>D)Wi-HFL0v5Pyg_DJ3jDJvMqW-1Tj?fZ13gYz= zi(&X7k^V{f#9H5qSSaxyYT3Hl47@xEG}hdsQrW+3rZKJwio$htB~N(<$E^#dbHl>> z=u(;svU}%Zd_M^HZRbXcC%I0|3d+-74|vX(#LS4P{oJVtd&iGL#2>Gqnw>Xs3RZyQ z!(S(q>fmjgvws+_LawRH@H*vB_SyLzzXH{ak6Cer3v#vhsaU1l#{4fox-_-Z2N<}n zrmMSpa-x4q*K^y4$GH}s(4IWCqqc1a(4O_O>*xh$Bsw*7U4FyIg%m&OtPG z0bwZ`KU3vny1EE&HkeiVeEQelC_V$UCm^x3Ai~cjTVP&*{0#ohM@a8M5lIS{p7kW; zM{?evw7(4pAc-423@d{#1A#QhamwE2oOsX9#qu#8Gnzfw;0U-U3NlC?XLhOac-!F4ylzzf2CLL=Oi;7F1ycq0z6-Vj% zl6#0K&S?cbFjZ^~j3Q0Bnsb83RScO-{6ydZ}iStRyZxe6Z z>fH)7#^Q8^riHf zb22=oo57YVB+(PN9qp(PR}(7&Kh z&Qe|g6{-!I^Ut+!UEP@Cn%1Tw?qX1k{3C_K_=_6lm)PFJi+Uw}*H4>Kz5%u-Fa7hkjtcy1)_^=4lp4sGOU&XVW1~YJfph@ z3(;pyG*@rwr)fl`)+hTV-@(a21#V9+7TL_)xNLV`r|s#3Rp>a6d@ z<+*Gj;CKa>T)*Ua!X9apepw#V335i{JgY=z_kS)D^m}=+`NIABmd=pV)mxZc%BL^I zcj!4PmK(x49mY4)8%?=mou*GtI=RkQKBEHX^qOI73lW?EEB0T@+K|M0HS3-%Z-M%W zNa8zA<6(YOeAqQ($je<`5lHs65&Gy5K{XW)1EyD-u7VXY%tH{84E8w<$|*zzOz}s>_jw4;DWTX z22?IF@yf+M_&AF`U&$#QVd*#n;ZN4|jdf`ilfh}~|E$;Bqc#rB@1$CB7YSeP%6i@b zpqmBSbk_`(mDf$qrcZPJO$3SOzofLiWX_j*)fP8qnV7w2*~4+@lG8aoW?iJI_zm+L zww#rIbg#=gPKxWEL|o@TG5TzoH%g%!ls+Hed=7APP;PP#c%-`qbvT&$ZA4*pvEsI3 zpgx-a{>~`)t}vXisC~QY{e8FTV1UXH&=Tvt&|Zd5>k|13oU7^GGTEW}@I0JDf!*-@ zK7kva6%6m(+^lEo{zPC3%~)sF(BTg43AW#NXzIC|ZSocj!Albz5U(jF@SI9#49n>G zN`BkmRA;Sj2(dt1GQaEXHHejh)GmxZDmCr7aFee*5DJ+Ss>)c!Ef5Qt;QV00GDOP0zRa4=Tx+|Yt_$s zxv~Ge@ofn$aMnBLm!*@NT@*;z?Ee%E`w9Vg;uP zEZJy888!7b=knNqk?R1tTnK|maR+I}5kb72G?~@s_~buX5yMY2D4C43rdLi+girM+ zAq66a0VX3Bw+*}O?9-lJn9P|84^ks8-L=cEUWdQSe5`a*#_hL+57sowfFb03+A-m(pJv9U-N-0bu0+o>!Qe3 zD$pq^O1wJ8~^ce0)dgZJ)j1 z!IJIFj1M05y|+f#%sLS;AcpfrGOeu>JgS)FwU%;6r~2OyFm&Z_>p>M8_>kVB+G4N% zeg&g1tg}|QxrNsfi8I^`NIyxfnSnQkCF^^(&mu9c`vwzV3@-P8N8)u8?R`epNcp-OI#!g@TLb+U#z-Yor>r>mm6xZw!gA@oan7ODM7gYK~lQ=EbIBHilb9znGSxa)!WY=;M1tAo3ra*8VUM~kh zNGrf4?Fni^;dBLe?Y(v%ft{?OiXQ8{x_nh!qYE#^=p1P!@K^bp4tlLOh2^A zcY0dw4O$8w8->`LFXf`3-btjJ)3Yv&4}Nsgqf5%*01dG~+m>Zp09*M*-$xhTW#eWJ zJJC^Js@|Yn>UNUZ+~r4F?w)v)5#lc2b{GjeM$Gz*Yd(VL_y#a&b+ix-BB}ls9-3o9 zxIcKRclq(}g9`AVwrE2Kh<-J@^EyJ%kQ?$Mpuz99ZQqi;v9#nSAH`D@cZ=C^lohl~n%56&J3^0iC>B7`@UI zaj1O+z4_~k4aC}OSEoh1rj+)?iBgDxw0mE>)IXdwUDz1XeQ^nKd*vi9+jj(y)ENO5 zRN@U2J*k#kx*#tt8@eLv0OZ8oo816 zP7cJwBCMHeu6>1XAuewu2PIEV^BI6ow}Vo)n;{MI8B#TUTRu-J*b^F*nA9>*<4w0K z)loG|x8jC$+ywK_D zNqU)y!gg8G7^)?7#6 zG?kHkw`QZeD6VZ^sxlt1?1H4Q>izwO$Kq2=LQyJ>cC46P^lO_O*~D*eirXs;_Zozpi#&2J~D4FB8-osGO?0#pcpT4}}HT%U%!qZ)q*yH&|r{P=Ro)HR#atE801@>TSjWZB!lOO2aE0)~w;ABtN#>K4)uz)HIzc z-<>uC<7@f%t^W9aQ}7ux<0v>K`HX!wQa|R5_dunl@bt4S@F#EdB?~O5aVqLApZZl} zoX+l`N7oalN51+a7xRMwJUNKDBGNv1*v}k!D#f5g{k|^No7N)8VOzuyVS|1;+Z#s> ziJsXu0}1aIEgMsIkug4a1|73j>*RN+`|4A8^t*P)95i91uUF(raJIdqs(!S{BF8R? z&&TTCE6$<@1}{|Z?gn#rEN#5o_X@=B>{Xqw1aF|H@BtPFXIVEqt*@;oeX-O4Brasr zzj9@TSUB3C`AuA>a;EcIKJFalUtwV>5ml0*kLw}Mw$bzd!>X3k)n&_kgxpW-Jrtq` zEr!4%Cr$Latfu%OUGIK;m)p+CX-anLzw*Cw6lMnODaR#Xeda=j^OpIf{z%>v)!q}Y z_gXGiYk&JeRnmPqTzu{6O6W5``|jFD^>Bn*u$Jywzi*A4ms-feOZ0j5x^b2xy@$5` zX3Rr5Sfdnt6c@AUbC}Mdysa)lvxo}m7r0Bl&+rS|Fut=Ts{0)4*e)UmjK_ZTCy8oa z9R}Eli%B|A`=JdNGodk|9nnTmsowGASmu7SLUoUpIG^g&Cca&l1fvdapOw&KHP3QJ zQs8qU-~ByH(KzFQilmUaZQ20-Z)3FIMrqAL<&+0Xx);H7#XM7Z&`w0#qB{LlbwIcb z>-DMXtD^Mz90KV=Ax#O+z9Fc!fE5cC1kN&Jh1;g(t-bl9d|fu`tRyoTZS28tnkYub z^(Y_SK)PSQ*G-{%9XL?CPV!w4;1Fk=49$Vg(wQ_6jP)0Z!(qm2= zYZx$bCoV^qGpOb&E~l;l4V0UUdf=X2+TjD)9bBrjZ<;x1fm9ms*^@~h%xpMNWj22J z9V=j+q5E-ySa&T|23_hez%{R++i^SlJsm`Mqn|!T;IcXY%BizW685+aYqJ)T)?^MO z*QF8*hb#B@z=Ng=|M2NXTeQ3l+B)jN{HQTJ!PY|`xT+f-&4*YCSkra<7wQ9-<&q{M z9IQQLAsHk{2UZt;>yKVyY1{-JXZmeD&mnOf*S~s7TU7lYNxuNsGs{HnyX}xHCp+~A zQE7ot{8i^d2x7!^f4j=kyYI>AQkxH5ZR)56C8^PRG@g`=o1r?DkEV$%!I!v1kjr|VAac>TVfz)rF1 z#@$-)J$RT8qd-w%?O`gzQM_9=0^_wDHv!!kTDB(rHa4Yq&nAE^(|WpES(b8}*nc74 z2pLvYqqnK)cFpSEvIkIC!KQ0Jfl1~Nt0{K%hU#9e`REt)XR=BGq=H>YzX~%b9euve zWu@4CV;X|P%*cqq&c98$1m2DqPkNJ7>NvKBz~@Hl$|piar%$8oI1+K-q*v8$#)er9dk&|x@Gso=pwjfaIm?=h?!Yxmlpf=W$GDW_P6QMe zeVhKx1Y*1|o9MaG&l7=x2%Rf9NwcTAh3cdoy$4uLLW*%G?!|~;aNLeUWfu{3#@576 z_K^AB3m2{ct1H!sfjWVK0jvI@rNnD^|Ff2L2nFAC3Pbl;A04=(<&XKda@2EM-}ft8 zK0AD;HeU{}WP$m@t@Eaf>ZwAJIN!$Iw}#LM zRDHC6dAhv4SlBbh%q{zhwBltHDi&T)5d4@(#0}||i-9|b(1+-;F6v^-bb-b{C}Wni z>hlM(_NyzTGHxApEpVxyQf|i8*WEH;F!-BJf!!{&8$fwK+PBBt+legyuo`uU=9#`4 zQ=Ye*LgfU%N1RHvkf!hZS;bVZgr93)ivV|$s3#_AA0_plwGS@KHUx6rZZXMl<>Pgqh<~Iy==DN|t z-y4HZZu)m7U|~KM?55Kon;x~yusM~%bi;>U5Ev<&k%=61uzhN6SatFJMfT?)gJ@>m z%M;lsGDI5P8!Wh0YIoLlt9WMPoy$AZVGq#Aw;${cLVi2sz2W(l@2dJR9#Wj6-0U&C zq73f{1SUaDd^Ur|h*0RGbw92Zy~iTy2Zt76zzPtD<=8Sm4{%>8Sb{P@n;Xyu9CY&6>DRo_lyC* zYO>urtg= z_SG=*xS!lZ&^s#w!{@ScmLfeZ5B8H>VURzL5YC(^oc=QVApK3g+qWK5iZxfSPL-9* zxa}t&H){fwfJ;V2WPk)c9+YeH%3&T=hHqH*@1Dy7wS_u?VwJ+&LM$^Wjsxiz3iV)VlS;~KcWMW*hiteI<*5br7)bN{KeeE`M({|<*@ACv60&z z9D1V}h0tfSAMssKg+Wke|Ma4eMZ&IlKiSGXE78tcYPpim8=LBOJp4Yr1@4cF*i3Qb zxyd@?OM`$A67-W&YRZN&e|~!!JM2yZ^e8$s>2I=H9!z31H<(!$9GFm;KMRq3Zv6+CiB^MFM2Qq zoL#FQP;#IZFWBlDjz$=Ud)ozYYsi|$;GAvQc$836`Of?@v5&hBwP7*OprF&Tmbi1= z^H(KHl*y_Aj~_A&np^*!0WSX$22fxI`a#sNiJ$pXskQ%LcUv@pS?b-U3Lx}Q=F_h= zBE9Ad1)QiM!05wnu-GMA_G7n?QPzZKoH)~cbOL%8W7W^F9@AMpU1J|S)@)+!Qog+Y z23`CG`^EiXR80r%-iO^YfB%uBh#`Qk^ON#kz;58rc;CBKb~$H}0InVxo=LUL^1xH{ z$3YHz>+{Zav>o5YD(QL-e=%=%@9BxrQpH|iZ*ubAq#Yi0Zrh?yKk~{? zF{mbBKWE9?ciB+WTz(GUUK}%jN`fQ~#!7LUR{nB9Z6~q=48!z_8<%R_oW@Rhr*WWv zas7$yHN)5s+e?}gJj{+Rdn*qaQhqTrFf_4rgg?9hRZ+dschx|;L@HGmj6S3G;?GTZ zLa};pAmj&oK-UYcfTABaE)y>kmS)$#msF>EHoIe?NY;}qlbMf*2k5_@6{J-U$vkM@ z$?dxaWJcY>0VlYZmr{}on{W3YUIwpbZPESK(P*C8rUgGX*PMv?L=Wl-T->CqPMEwm zds9m)co)lBlM8u>z-*0Z#2Hj$EiUw#)Ya#R)%eOYTW%S9n}WKC4g&Wz>>sKDS;|&b zT^H66dEuD*ujDbFUj}QY6xvrQ-^k|pir4eKwaGo(6``u8-Ct|IeMQ+JbHh$?ITIbDI1$x=xN`wLCVPjWy2KCtRNw4Em%$sx$jS z%g>*VIV3en)KjCxpaGgPkv3*)&8>!aRs$!F{&`7v`aAV2{ch5N`Az>+I^lG#y!w1^(=Wxl&3bM()T8>;8clPnhJ*|@Wx z1)Sk5)Y0W&Ut)|cMaM-!K)r@n-SHi6agHlMZyJaI`{I(E!O6$$`n|`z}dVkzR{B! zo4xivm!`{K-$owBubxVs?^uh!83xF+Jy4iVS{rdqc@Z;=6vU~Q{N#_SqjiAYLB1sb z(TE-yxy6DVlepmKiG6S1x|wa5I>k;>ne9H0|1a|x|8JX5*0U0neXXV*>_S`SAldWc zYnF<%?3=b_*?U29O=}>dxtqY%Ci7d_%*Mq(uNkXAzpc%4Zl@oy2Kz6h3-dLMC+s+% zIATv?&mVcz&v0K;4gc~1nH2Oz-oY{g(X1+i*OhI57IG()Zgwbia=udZm6OeBa$4WU zj;L@K$Y%lL7K=+?G#m${PXEQcg~XJ+R*2@wD3No`-w+54hbi3}oR2=Srmj3gp3Rzg zaDT5!!@lO&)d2sO|IKMd2pM7Jq@S`c0~$+^2^(Y4r4bjU^A_Eg>oCq7^8|YX!}&p^ zQ3_l_A3|WlPXF?o)lRJzSNb^TRhF_7TwFfNHY>Qqd(NY_U%KB3+!g;!@ss%mciXk0 zoQFE*5@#e+u1y7S`S8_;1m#^)H578i}tChMGdRY@# zIGnqM{6UwBg4Z5G^u9W=kv*Z<<+7=Djwqqq%H1Xu6gD5hn{%3(yGnf-fC?cfH1z7< zdh9VdvOczZly|zSNfa?0xpOa?Bt3&@bslu|}X-r=%H9wj!6Gti_k^w{Z_M8D~<0b^Zew-gU zUQe69t$mJy>V3Ur8c`L#y>EbawH>4QkM7d;+VQ@_2Sa&PYF zNU&O3%X5u`3~*S;SR2Uz!gtq};l{~6^S1Jr*=#$1RKJ9eXMw;ES77TOra0CT8RMzv zdSLT87fs!otA+>9qO?8L7QP;zRgNGV!`YdJ+OEH)g^#FJ6bDI|PjLpg22fP_b{63U zeNS;cG?J~RtAdJ`Bap}=sI{kM80zO?%<`CX-v&e$aBqLkC3Js#BI3uL8wtB{j6ZO> zq5sWCSGF2|xOfTHXX`i>hDzvWy~jI_J7=xX-vU2u4}vfrHSwJvE^7dlf|YH9AHjDJ zm$u2oi*EzxEUf%&%RNpXAn=fj@a%T~itd{(=%ewO7+JdTUB>|3?pgVA8GXxd+e?|? zu48F{a6B#}Tl}umcQ}DWK!AOAt%bmk){?9M&@*i*wIsiDIx`IahB#56jj8tE$nDpR z=7$H+LgDXf)^6@&l4tgPPn(Lrp?epEvDuTS;wy~3wZ9nxPpt-i_#!N?8hb#TuMZ(5 z*U7yW@yfr$RrrqQRY$BANWgzJ)UTX9TN42G%Fjlaq*WWiA<0~kpQrmjNh*wxHG-wQ zTPWDi>`Dc>;hlpb#@E$98ga2UB5mjUs~Vr3>&^y7ezAE5nBPbOrgM%W3Ul~m39}KP z=hc=2!$Us0*AA}>8=j-6TQwvUsaI+LQfYzMqZKK_sg?v4@Nx9COV2Vk(aM72XieZc z?|#EaI^%+l_`WdeX_GzAzJ`adbbT@7rXJ1aipO$_5Ljy7WBxPn+=oBYM$32Lm~Ouc z>ZT!?*2==eRV+k@rV$!3^nw!ng-zYZStqd3u7Jeax6zG?IV3ALUAxzUgNT zHB0#@Kg&1WpxTcr5}C-Z?`V-e)9#JXZ0Py~)bS%$U7o*_tM+I%absB-4BvJ!9<%s= zpBM9B(UIZ3rqy`AEJ~RoTgn0suvZTFi4wG8Fh9e0bgfcp@EvcJy(dtr6m81F>9+3|Q(d zOo1RjKI7m^7n>+B-U(2krhjnLooCL$LCBzRzoLrKX3goYxQSLEHRj^&M*mtM8B*PY ztnp5}Q*8iyl1DKdIK`0X;%oQ}m5P-d(M1O>vFm50FiiBePuu8al>*ivvp#S-Pf2~Q@Xkje4=Mwp(QZh|WF zV)J#}JZsDP!P{T9O{Kb(Tx6TVlAVHz7GKanU#u8V_EXUV1I6tt{8{$IikVptJQ!C2 zE6p)-h?;vR>M3O4%MPu_Vv`EqG;d;P|4I2}8E7rn!`J*Ltq7yBhzIVouYfwgebmno z_Wr_e{@rLBQHFsYy2f<>%xXD7FxKMh{~0R+6>VhffI2Q%JF_;E36~ceVFJ&U3Xmu^8=k9wp>B2O_38B!ed-?XTK0Xq z%zIvC;i%>g&S`rnT(DjaEgZS*im=HjP|$@FT$+qo5KAk!jH}juK2U?gy9s}*#y@uH zDE95veKn<=DjeZut9F|)ZgG_?d*2*!)iXOrzk+_q_J)MFT}DiQ`Frf{Y+_b@yQ-?i z7Qg}NZ1ug}Z{Qr4xSJkz_`rMlT)dyzJFpV@j&bfV`p=!P3kkpkjU{jGd~KrB{*6?K zo;34qM>uFjhDCC2Crn8q%1!3sSv#Z9a#~XbQMR0c-?Jd_KTlJFTTY1qIpV+G@$PKNvkz!$%+M zbfkGPP~9Cd#HPpUymd*r!xETl6mi9xvy_ByV8KS2{4rKPDGLb_YAgLuCQ^Az1Hd_k zdiT5)kF65oH@6`xubYssBkpuw@(n#0nH^jhIIhQCO$zZ1k~5naIfS--;_xdWY>7+_ zd(t#Auo+~&-Zq9M4=iay7OoM-)2Wg_=Ez{NQd08wl6NjdBG)ZI7NBsK=&#&aft6Df z$}Cz+(nKzfsVmzuL@4T>+o}iLK)}r^QcyfVufa-Yx6|e4l+KzBh}swyUFcpQ=%VZ@ zk<8#}wV3(5xEcMIHD$eHL4u_u=XA_0HbQy5Z$)wTQadv{g7pyyH5u@K8!yd_#>6+NPtu+Pt1s-&KPe!M|T= zT}Pxx)n`t@*iiggnHcA$QPRPs{Ghk%KJadCOX1>~-iOl4OFV2>e=3_68*Q(*hw3f= z;r~@geNCc3&}cm`$=yB&%B0SrJ=sGZDxuoo(d|%Z;4jkmX_(!6Hnem$Ip?7IU`LDUUxka%{3XeF>8uLpr9_Nq&vPImcilj?l{n-1p20x&E| zQ2S$ao>04KaHECLfncUv`v@sE>sR)fZy4m{VJc@Mkl%g>^(&8)bWk9Ku5kBaK6lkq z(g%IC?dqrBdhRoiLSDS#Ump<`z7~5U7X`XzZkJi9Sbl_h&Rn-BdT2V{{8;yBGk$FA z+Sq?9fpv%*m#7}uYROm}C9q?t7=@zJ%*4)-xUrk8>j_oXZp^JUi!Jm7Jg;{g*T8D} z+pZ=9#58YTm|>98xxu) zqagD$A}9&@zk4Z8j3Aww^!}}KDe36hxQqKMkF-NCt~7V2wk{&RCY?fEjoyw~dH1{! zHX%FqkG`6k2qWu3W_KQ;TBxg+)hooA*ysUwKaE~FdXE=JrUW~taLtY}3$BAMck|8X zmA$9oAsjln1ZMwPjpxLjLFrweXi?WRK0w;?7hwkp=fAI7mCzSX&1Ap?leYueBEA8RF{MSEiDC&xb4W&HePbEwH?uN({^JFaNP6@u5v&*EJC-6}M5 z1Wi=gS}$HG!-L>Bo8?%Exiwi8;M%A$E8-A$uS&;+3+8Zz@J%JOjlzEvkNHE6xEoY% zaC~vpL1PPXesku55<2wxr`Uzp4j=Mk5bQi`Z;jp{4lWvd@Qy6YP#{IhTOdbHF1r7` zxl-*?WxoWlQT63nR4ih4$cn|ot5bt*_^bh!^_R-=Cr^4L zozo#y*-td~pOKnW)QePx#;ux*4&cW#=H7MT;BmyviRL^tF?gwT&BAfV~H?6?Wzi1oX9Yegu8#@m{4JdWtk1o3UeYD+P#);e!3=K0(@Nc-zV&@F+T z{Lvv$N%hG)yt1ml?&wBT8)ly{S@++tvnyGs1I1?PY^PQ^mt&{{by2A0yWvuWM&tGcNTRm zY!9CV71*4X5cYWZphqh1i>5JXwI}h&h>Da?iWY$#<}LkO*}J>bn(M7Pvro-jzn6OL z3mA5REZC#if8E5GV}!?-+JB0bu_dy+vKn4@W;493w1CIBC9{6`3Nqe8$NaY}EBBV< z@#E2{1lzaUc5l?TpRrzQHKvdx6;pKldp$__!&Sa{8aDU5Y};$SqR&fAcCG4lvIEbm zIiWDX#^*A3bNNrPtF7tQQH5tm>G4!m-&Y?mp_X1=&aXb|-50&|la^^a;`m|LQgK+; zSamglcNds@4=x*IE)eetPf)C=`!YBA9~o21rAJOH-=vAoae5N5?BLev=SXfp@y)4E zGSWG3>pG8{jT?*kgEVn1x6?wN5Slv^^jWp1+U?j9gvhOrUI)?W2K?Mnjhfb!dR%*` zuJ?=IKM?;lOF#j17W<&TE+fzPvDO4Nlp68pVWbH#7@@c`VlJQhE&CV5i;<=h}Cfp&zk8)h=>fy)kc9%$q}4Fo%E2b^T7JtIjFWLYgpqRZF*_(h2NTHSXT= zTENk8N%ZE@o2@L~Pe1#r;ahT7YP(OUC<_2@-4XOXcw*zCbou4WiQZ{Ni1Ko{6W#+S z)G@x~&{+LQzR=pf1#+vLs9d)OU22QK%_$MPQ-sMaw@Er6VMn51E# zguGao4|B8xWqxDJ3;GK=!qe2olu|ppHU=U7`u2C@(9S=)eL{r+bG+BFKP6k7xB$bZ zE2$jr0CXBEL|<0M?~h{KA{Diqvg28&(CO8#)Mk|5IQVST+P3{18{7Wa$%bFqe`}le@BVcPmpT(b5s?m12=b=3^+d& z3YcUi@z@CNyXn4G^qpV_MV&cV&Bn|Ir59^}vTRlg@g7C?@BR_ym_!;7WMxfigp#6R~SQz{IJNf~7dc zDB!+x%^=%ahQg9NRUgxl9v{G>*}^HPkv}OUDtlct;5sa%iURzhJ za?#8^K~kHrh=(9Pdj%FZ(-kdUlq&ayX~DBV$y71wZ-NY2o^^g1m~x;jaOm5#eat>a zp+Ymzo!;(zVhzxeZkieMON@6R1s_sT{o3j|-K`uzG4slQNsQSsnil}(i5QyKkfFY5 zuDGRBwsfCni_)ci>LK>tCHvK>_TGegb~S_BPzUx)$bUt1tL@0D7|{+|=vNRmEqn~+ zECH~DhQnuYnDkj%_1ASZ&N@SAFq#kU0A4Oikvg^ku2<*X+IjMYE{10;7(+{?gud0Q zx~MYB=mNCN_PYd|6(hG7gI~>7ZCr9bWrj?;uM9B;2<*hyO#4MT+;6v6`@!MJNnd>g z>R)K~Xn%HBZOlFDmn7+p!Q<*Lm|;lI5c#epyo#Yj82*!dAB-sCLg^x(VkjIZ&>@;=v+;BMZod?@#`a8|?XT)K<(82E!c3|pHo zmzsjydKo4Hx;1t2N+#2cJ^fMWB>qc?)-9Hu8k01fv1RcfWEymHk1zd&(oBZ^I1i=( z1}zujm4j+^Luuy%oI@lrSt{mmQb=pcAmgjZYd0&G3!Z6%Kd0Lqij!WLjS7i`gPxL+ zq91)(8pyt;1jDo2ww-@>be5=ldpD`79v{LxTTf|m4m$03Tl(#mg6ryoR$}OIp7Pwy z+<*FDcrYu|Et`FG@<7jqM55YRkI@B?{D5{h4Q19!g;8s|O82-G0;^g3JEE3nh4jd^ z5^Q(PKG5Bds}7$0yJUF+V~CA=DW_t7B=1n$Q{y0%ux{i-jVm}E=HiiGy>BfrHTUBU zxIVxq1Y0#@#CT`-=#VGZuV($&`N=6}eV5%RBtaskwTHOuD1GtdKly%6miO7fE1H%* z;@-NfAuP4y^(1-Mqt48C+nd|8@Gax{y`_z3r%p>PjWil@(dn(4Ndf0yhYe^h4OA`Z z7_y+Nc2RHENe$t!WdzeVAk9}|p z9j>NyILy)2=6t!r7331dkQN8=&X=iLqmC_adDYzCxJX!>(XO=oU{daZd zqQu|3e%!|O)8_jkVk&&D{8X%XcdGwQ-$SGIjzgLT|FwwzF>9N3oC*Dek?Yad_j7H? z6e;)v$JEw$K=9yP0obaiDV7rZIL7-ZG7Etjo}*IVG$P9BkQ3OF5a9lve4oWis4+R9 z#8yR5lBMmZKM7`$vgHCebnO!@Ebdx6;E>fe*+;`hxqeh-*BgOu9ozbIm^7(LigNLo z@{US$>}{z_8((!3mDvMwFQKq8w?1K$U{q+4v}ZT}fR)X1h;QbNU!%{$I)=JP@-h<= zT)nl$JJ<3r)+NL6m!5;CQMgS@jB`!J}rzc}LqP|?c12)dN zsY0<>LEJr$pMO{SQ>7N!m|STThogO+H-r07`>>JrB)= z@icWrRjs_b!`4eymGvCI6KrhCqQ@a&u`@dO`bxhPKwyg7lKK$P!Dn;bH+x&w_FJ%a zgZ41lg{cJ&#-Kv+9VCUM%VOt+E#&3Pl~$(gBIeYZ2lC12`uvAC@o-W;%f;?O$nK<& zkPw?1kY^L=^w5`?AnOp8Etmh074wxeN4f0g+1amAGh@CM7!lY0SrZIEQl&r2y{*2% zc>oWL*Pm@O*PlZJF&y>#1~eu0rv$`upd|$BYKo(Vaj$FdZgR2OBK-k z*!E_rvNv!2XltDOm%GYk>nqWt<>lI>gICI2R5}3J8Ta^n7xQ=%{=!!B!spevOB2|U z-j7p-b#$pHti=V+MeQn5mc`!gm;lf=|&-sqWDzPk27GFTO~g+%h6V zoA?DXvbAnqzB<~-yCRY%>cLT$&Ymi^nC!o`Uc|ANj45Z+r(r)xA^gZt__A+o0?>IO zp1W#rU!$6JM^DCo&>k}UwXb!nH)qP}qNl?FLGrPq=IA`0Q43kjPE*!6;nCKut2@eg zY_yv?26xS}vEF|!XkGxl2`)tf1M*3)yI z4EEA}D`ePC-EJ*jpF@^)(O`d7Ahw4YTV5~TO)P=-=n7G8;;XDL_WOQ3#-zkRPczLb z;li5fZzBB)O{I(U@ZQtOm zRc~|Yn@4h8J07&RBOQ^h^{|ZM_wp}(`OS3fyyTpR6vQFTrE_+te1yZa5I|g>cc0_f z7aJjD@7R>U`R`Tac9ahwo4J?pW4L=@BCmBD*+AVOPO&~rE5a(D?E8?uqA7r-xX$>d1lVp#-vSulEbGYvBw{%#a zf9C@1qpq~%>ObZ=Vbl+L-?ww?7>9s=LCw|RxZai*#9>`}QQwzWv941e&_L1U&un)94S1rH0VIJ($<$-a7-;DRwRwWNI;B*XD+j||saWi@$E z^0HLzoFldOV!!V+>EepoOe-rSG`rf)yy|bDZb#i;A@Yl6S*uYw$WbP?g0Xt*$jXTB zb65Gb`zAmq>+g}L+iwExa*3x4JD2}zyd?a!xJ`^zC?5?rBboE=4eBHU@8d%c8qZj5 z)*>_Q*tV(-#aPyE{9@Fc)q9OxxlH;(fgh7_KM)p*V8>icWAXPOXw?%*ZWhdMJDqdZ zQt;SMKi~giOWKnZ5jW6wKY99Yh+ob~@zsD|46qDC)_um{&x5R#>r6uzpU`g(Sae*8 z2PAX|&XL1KRrL}nbW~Fx(UZGKP57heaY-dB5C*tGrgOaNzNkE!P<@vk4g|r3% zvF4eM1vJwPcot*aLc#uF=}+eeM4KdWYkbx0-~I%Wt+y!5QwNQ?Bjo%eT9#gOUIfq%xAc$H>PvUhXuBh5&$pIojX&a)))HuPu#-Leo^;7lE zU`$Vb%NxO=I^$9N_1(5Jh(KpEfcp&m{GIsuZRE4buOIYPIQ5*MZ%Rw8zfqsFclkrWHmx_4;qF z+m;V^!NH_i6SZOx?2EFv@o`Xz+vqs}3nGS6FK{@-Ww1CI?H!5|_1x zFQygRqXHFO-b-MYF1fWs&fn?DO8-9`op(4}@BjZl9jZ0kYAK4Us@ANkE%Gi}Rja7l z)ULfr5T`Y(injJlQF~LH#HhXZ2qI#ygdij$Ki}V<=Q`()bFOop`+lA4IUcttSrl5P z$&{boj8dmJGkGJh3t;{GXnFu{t;Jzf97xDpyzJHHJabvbLIS{LKPhm5c;2Q*~ zh1$4n{HDZym@?&cBWFx6EKB2eq)RJa^l`7qlgsMJ9YIRH(!F#@#H-R!TMd@eCxPtN zu{}!YFIY2nf{O&_;@d<)NMYj(b3sP~^hL~(v(B#9tyQw$@FWYQ(oNGNgbw{ct)TQvC) zqX-TS1=v$STR}mh7I`i_0%!KB^*ENSaa{OIUrUb^R3S8WZMuLFSGhr|XCte| zN|Uu43r4+H?Ca-_`3!$x!$9D zLr;LK)Vkx6!%TI;R0gRD6m<%ot8R3=zP}JE*|q1GeVkJgPhs4za5=8Eo-kKg=&G`e z)SNOY0BvkQIA#|*4J#FC-;rZgwN#~X7wLt5y(NK~>GY;fC+DkTzMQ9Nb9xGz_aT=t zKyZSmYGI3w{dVep!(Ufys*JiLv(9X`Epp9}O%JkDMq4A+Q}F8jxSaLitOvLN^xw;s zgazYu(Y(02)^BrHw48GiPVkFM-ls1(%?k`+jZ7cP7tR0My~3kj(Hi7;^j{c`EJrp{1waW~{wfVM~A0(k|N! zw1%+GgU{o?Yx)=V@>6E7LXxQ6C-V~il<~~F#W+InnZq z#YfH`80Acq-RM?C)kmaf{csLo6HSD9XDkD9Ma}Oz8BdMcUa>gF8p;4GNlotk*7DL9 z2RZvbf5z0}4LqgGbjcm>+SrIdJ7$xLt1`t#`Uo(wn|)_b|yFG>0@eEr3gHG`2P zczfoKLVzXRt3XM2b7TLRK$+oGQ0g4d<4rP;LBuq4tEG@59-iuYeYouY;f}9`Q}fH+ z8>_XTejm&yLfK76?Sc>SfV$n%-4-;sd4#(_Y-$xiodAEu?yD+}N+W0Z-YbY^*hze| zXB8YZokTfQrO7+L*7DDvjXB5N*rJ?XwMYM+7MOZRCMDU1*ZSZ?8H*QV@^A^e(h77f zv)|E|5}tUHUaRE|L=1j?T_eh&ibhG~cczl6Qj+mjAV&bX|K0_-jqSEu8v{1T%|36& zZ`4a!nO9y<&xP3s@a;G{CW>9N@IR?PSYel9sSm;mq^iyU&R=Wd!D(50`Fe$5<)qo< z3z9)3A??qSfQ8iypUX1?uBy=v56i~_}!GsPhk=v2<+@)r|BI4P2$#A}r) zO4BD^FJkfI`9J_?KPFi1cEBfY%Pm%0-^@Xo>Q{E6dAL*K#4o9AKe(gwYsK+j!#F($ zm$q?>>?MEBIY>^K(j8L{k-9=l6RqFe>!O_P(vhLvjwkb6gW)Z0&W}%&bvHTcbtiSk ziMNNuc(G59*zSo{R4w0aE;)6VIDP5A)O2=JD#xKo91f7K{Nr+DB3&X2;+=GCb} z?v)=V7+foBQGe-Vxh8qxsC<|oLz38;s{`uz?q`tSIP*EXZ;mW;)Nid*;(fd?jQ^NM zclW-*Ccs+}9i*6E{l6gNuC+0azW`dn%bRkd$0BNOFF^zyXXYICBfB!={X+%|&~z56 z1VMW9ewZjMZtxH`orPOq9+or@CMYJ@4&>vgg%MikjbQ;vKERq1WX{5#yKz<>G;Vn%1T1jTxe^AVwBb|1@%fBj9+ub z<>A!ErGOd1ul8A*9m@~cgcX9!x&tBQDKIdAR@=Ei`(t^?O)tgs0Jr+8hj^IPIF$Y7mZXv4(fuV%>3rx}?AJGQ~%7z;CE z`>EC>n|AN#-Mnjm)7s_C+z?~UyV@#Xo1jP=iRf=?X1x>V`}Y6z3}${lf94OjsBbvA zS=RkzoR-bO{6zdM&sF5b|3h%tCvM>MULo2KRRQ!uQupuq2+eNSgkOi3=Kb+wF7uoN zdEIIb8Z%HU!rlMPtRzi)z_Fq%YDyt2XZ8%a!|#s`&hWJGKCb=%gQBuMv_(1^*|Fp} z7W;BafVt_A)DYsuTMs#f!@T-6je1M1SW4-L>th3wKH|Q!VQsc@;#9f9B+#a8sXs6C zj7%TXSsM_LlpZ8J^x~<_lHsJX@m;3Y{QgS55~V9oF^JOwOD)q7L3mxynKbhsp?tv0 zoo_fu?;pP@G?^gejQZW=(zA?r4Oi^cFQ+sC684<-7DH~bF&y5%H^j2WKA`U z2owP2=Uz{BB@^qePe&I604Q>Za(UNY%txX`CG%K-+K&jCjyv%~E!ulQ*4vmZeC>WH z!_iuR#^y3EPme~7OIEXu)?C4AzcvYvVClEp=y(xrC%a?l=cRQcW?@#BE&c|TlkFej zkwB(UxEScUqlI)FxJmsh!Yshdf@m{y?i!x=*x8KWrx0N4xCeOQsBm)LlaiwVdLC0< z7n7I@)|BM#F|UTXAL=h|BYK*O3RC7zcY@e7=l=*1s z^T14<+f8Z$bLe_U4pZ5i_=sw*s2m4Mej2jIEiGK9hEfZ_V;p7GH_YBLr<( z1;0LFmu@3cruRO!i4$z0TbPXX)8VGTJ(3#$)30~S7!s3-ZCPuRtO$FbP_{EIx;BMz z>)u`>puNn=3tqzIHYeYh=Ml9#mn#INMRl z&r@-bxi8&2ZZeDIK8dpx4viYCE?dLn%LmvIT1<2}%Thw|ck<1;~j? zIWO(l;|`RVJ<5J#&&E>eGoO%l2hK)6#QmAev&r+JWdsmy*M6>T*{!hB-fe7!VGoxo>N;Y%A`0b`ANomSRr<|3EZKcg+>BL?BO2qC%0GGV zgK_z2fxK=p`OEM_8F_fgjHh-Z`%v^8ahBcHy7-%BcgyPY@|L|Prl$eG^xsbW%GWcn zmN#rA^RZ@l?C4d(3xE(wyfJkG8x=S2x|aFi&K8nc%JgxZ|Njt#`XL#*GRV_CYZ{(= z)t*p}Am9ha zE_^RtTmkaC#iND@B2zPyp{C( zw74~T_{CF2T5q!)#Y+Reu^4CC8R02Cy!!8bswzsZ{o`)NF7>7yHlFF!_=KBImn zPZ@nyHS!SoL+MOXu|?5)OVEG%eL=c=sZ_zZM~=A?K|iJ;b7kL%7m(2xVctuV{=7$z z;~n~C-I&ttrwHOj2~IX7w!*fHI-ubB-2Cgl5*>RS3R%$F1Q+M=$u3`s0j@Z2cA39^ z)%AV#u3dYh-EWKxcf7_>9ZFAzHFT%Pn`h|-?X-}O6n^-|rc-8lFt$0`RiDULw&VG~ zu{5Sk3$B;-wIvC<0g7+Jx-)0z)b^?4=afOUKP}$py!LX`#vxlCE6i3kyNH!KZP{P~ zI@Q`?5#L*uqjjVGZy?Q}^11t$l}F|$umgXkp*yqbT<{E<{ z+CQk5oV{ki*=fWR-SVNQ9g71(Y2V257mmXiuyAVbI|w_GT3Bf`?Z8c~`rUlMq#!Tk zOWoQJv*+O=3Nq};izO4BU2<+*`dIn%mbd_h7Ylforw5C56Y34xUvRdp|HgvkNmZ>} zWv@Nj!^w#0jbLf@qrFsJ2NUm(wwJ; z6aUDHUao`Jgp<1}#}yb~+!9jg*cwXu?+<(-taL9AU-7{r{*Fwh`=2K9X3JUrB%Wv5 zq$dCkpJB1v%Wzja1@z#LQulv}CNyT3DFo4xW{Rj62vP|e7TNyByI0q_gOTy51Cx9sxr z%DeEa+v2a$P2o244vsh{Hg(HwVCy@7a#xrAH0g%M*L#`Kv>Ko8nxF9 z(&#MzaD#uw?mYk5`7IE&RQZZD&o~AEu_&# zJqmnpL}Rd#x5oB;$FgtDv#_uujdR-DaG&_>`Km{Y(*y~L>X2k31UYuB|JmzojsUn| zUfOK6zE7pK*fuQlfV)D5v;xf=BCcP=!is@hAKk4?2EQP1QG`PjQ{juyyFdY-T;MU0 zc-mEw{viz;I(o&SLrrK4;c|$U6UdjrnMtNC!~HlblP8_R4D!l!Efk*`&Y)ZcqAJne z7UHl;G|r4#4!gDIFht%%qUiF@enF}tI^7pQe8)i-C!45yLb=sJF+9$yEU1nuPG_y% zXLjOBZRopI7!GU{8y3(o8Ym5}ICu^rCseQR?O2IFXQR=(aGV|lw?#J@4d@(ywQ$2U zG!q`XwO00T@3KjC;DQg=1X{rvf@a3lqP`AZvkVPS(u+@7qFT`?g!5V&^=r|vF;K34h^viAw3ZJEoYCkjZjrUw z5{<_W+W7)cv)4uP{v=8B~4?V)k!yk|pp-kb_mOZ5YmC!cieCrwUZ z+nsF1TFn1!4{8>o48NL8wc83fG?lFAHB46wllPtu;&b=FkEJbBUEu?=Nj|7pF^6-v z41aLhInJg}P+t*wQP|{H)SJIPV^@3t*+0&4ehi!)O+*YD1Au@vvQ&XHz~&?BJNs)+ zgO3)`I^lPZLW0sH0=1Pz(huiqEN>|M6PhdFkn&Wh*klN@$d(%Vd!O4&a!g_*a?o8b zLi41ml`KgUbH&5xK;lgW;aQr8GuyIA7&1@n!`u~l=jykROQPuaDX=zN^Qa={G389wgwuXsdp?zKFK_D=brRCXzI15J7pB~Sd0*s=4oPxvgNLZ zY!2AHR_i)34;y?f=>6T(R-%yb-sK^t9SgV;7#3!}pHA>&ajhtWV!wU=3ih zVcL3KAG9)M%$a#1!2RfT3N5n-2>G@S+TDsx#JeEF$;u}`ew$rR-`x_F;aWe?_ky(L zyj-`7KOTQ{cQ0-D<4D6pvonv>OYx!#eCBzk?UkgpYhATXL{XsOE35_i=<39AKG2_h z?u~KA?x3W>AmRV$r8<7CTcy5QisMNlueIN1S)YuK0LKnm9(*J&9s5dpCjDbR5UJrc znAT~2l+8!KlwKzOcB`V+dVBccj7#6*9MrvPVCrL|MPdo?H!L$PV|TXM);+OXx30H> z(W&^#0?*y9?9B5w`6ADkv%Ha;cEG=DS`m~yQH0qgd#z_fuI&xxi6SX)i2W;JWgqq{ z+Q&b$Hd@F!w8{GY(feP1;Ks>a@Wq2ww?d_6=2R`}94Kar?#HXnWTLE6{g?FPvM$-n z)BcnT9b_ys7gaNvB+&n;!~)7qHkWq|_>YV`E(3^WPhoCJmJi0+;~1tW$Q=^CqX>FE6_lZ;pAlZy|B2 zFAq81?0Zl7Qu(2frF5C~4VaO9ZVvTK^{_jxTFjo4QQI?u+2;*iO~=&4&8T%nnojA} zBzB1o*641+;Zv6+zSSfFz-|z|&J?@zmHF(t7^H&yTso#En3{QO6)x4`8f$SG_nzW) zLit_qz8nsLuP!g|rA2tg8*b8Da!DyG0|wS6=y#u3q~gT+H(P7ZAwq}UWHhYX3$Sp% zIYrG*&A)^^F3;e+R96NS{!PPt`iFgtVVLz~rI-iIZmE~a^vv+ItH7>uL2)Bc_()^cWVyu5v1?40!pYlVCxYe z>^39T)tidtgL9~lM$_FIPax0+^fM&#zfi$zT^czae@y-Wlo|Zrc zvu$R{P9fw^Vyeqy9vq_iog1pP7zQajE!qRFiNm^A2@jjnfbF zdpG>t2yD+$#lEN-%y0_Znezk({~FFXj6xPQ{(xtg3=BY(~Gqy^Kz@NzHBV*b;E z=2G<>0B(4X@lUsJHGP}W>nod09mLR<8LfFYp%%BXBX%xfU@C5>#p?2G!+(}eT*7dB z9xbABTXksbWS6rY%&mPvGbEF72)BPfL%C2UGBd|#ixKEruo7pkCq{^lt5AAYhM1k$ zrN*oE%`*sR_J`%#N4VNYiZJ2@=VhT%e8n3Gsa=j?cYY1c)WJ&|_MN9q!e;na!Z}W{ z`n|Xh?!U`iL91-6yQD3-@!9X620rYUSFAVN*L5*frF}|`Xt|RH{lq7pnNG5A+_F@Y z%IRCi@T%6&>}X{4*(nMqkduvzo|&s_IeG3 z{$dk@=VQdgD_~yec8)7Zp3*8nSnO=1gUAxbqusBq(RQjp)m7Hg2}s&uDpoWM$Q-Eo zXmVy{=n)-rPruX_IbpnUraic`D(>>of9)2vX- zvTrqpd{2*-X~2e+6+TFp5rt~_TlW9$R8G3e(x{d&pc{Z^=L{L#f$~$DpSOycODijdiJ%) z5HAJV&e1zm1v<@;uei@`i;TV>9wk*sd9f;7m_FWm4oYLH;oX(&R6wntTL%OUG#=nG zJ2~Z&r3OMmR&UwK1@6^M)i_^_PG0o!or)22LG(jjy3qwDy&t0^|_W?*E(S>f$3RV zo^`l$o_nxB=kBNs1q|uTz-lHTr|zo*9OnXfC1300N6ovJ&_BE57dwl1UbpKIt!Lf? zgII+1g7DY%!6)Jhw>~5XYA=i4FSzGSy_whyuAaKIc-Uu}xP{arg{c~}ih#3`U2U&? zOA6cF4<(SzwBF4U$o{Ra-=;}>`z_j=K7PRjuH^G9(lP!n@Fi*o!`LEQUVwnT^y+_O zJ42n4H$PZs-jSbw=I7JuT?BZMnYkKVUu1U2Y9h0rfW~SwtTP)Nj%nmqfo0h1U`q^kJ1bAT6u&zEmBLAr`_t)SWE5I0$nd9l%6KY5=Q}oCrMxivY zEh)wQz9$|NzF%bL1$)ubSF8F>@}V)J&UJRMSW{tg1zmy zt-pj)V=;%c+vQs+dNaKWs$bL%Zm#Y0Tmb8HK1fe)0s`p% zNYyqi^7_al9s5cZ!#`~dcW-OwmE?M6QL?-q zf1JRkvctF~#u-J=m2TKyn9b|2w*qrLbS^GjOp~h;Xj`uW4?m2s7Y(9ru|=JVpV!p! zucGrM6JNFJ9nxGDURv?tyyDk^4ewrj9^uev=8!B6g^{=+VUur0i6G&}z>c#xI3>3b zW^+5ObLXI+RVwRD(*}n%5N5?nTQ7@RpD3#u>fJnhvT$&&Rd2O0l{JT7P`*6;eQCLe zHwuEe+nC=Kht+cAT=S_;F2=+}__q3)!6-d7WpY>K8wx4JY)($c(d7b$K z0#>7!T0{G$R99a3pIo*~dZFADc|1~?K=v0f=!wWVE z>VUmCKXxE|G$3XJVzTSUCHz?aM3t?D?IFg;#nrD=UxdFiJN(=>5gy|D%`g0LL*Yn9?IpNJ~SI z83AnF3nLL^!!lGp>hyP?Puk*kqK0h8Iz2c&w@5WnF;ArUniIK>@JsBTjN1t%p|iR7 zHO81WYdA46oVKf1Z zOZGtKVm5KkmM<1|5-oQyJ5gS>@>M&fg?Z^cF**x4I#!vMAo-t@gMU zsNvuC;khPu_TWqByau6B4L7>8bKJa*|Fx8b-UOuuluR3X$^6|V`yZ$}NrpYeH$PoB zp4dDW-7+H{fTDV3E9HVqg7o$azzP}a>c5)F#sdaXQmk0R6u10qi z-M#}E=A(U9CCxC7)tjttn&@TkIdG7`L9rMhrbvy|-AL7#=;;c;6hL8{LY zl|2-~AdX~~4n?Y*0@4gM7Je|Y^b+nca`AL@&~s<#W*sD>sdKy#W}lJV1Mlj?{4n=n zzrs@+HvQ?$CX^ikX$y$| zbv{&(S^IGsS#@oN=Pm8pVD4@s@2Dc)0kcV7e|P#U=OkAyPytL_ah};O=;+CEw*Z4? z9G&LU^W6+JCW>E6KvA2b~-^KCC;V)qZU<{Cxomr!H7-)(I zG4(iI_~ZW85tHG!T#$b1a+`x z9NFQuHfzB}hx;ArjM0y142W{v4@^H+kYis=giLH)*62TuY?sW;!lW(T27<%`Zk?PS zkG&O_kp~U>-A;fX?6x0C)}vXP%eDV(5AxNVJ)HMOQ;)A2)_CUj+d*s_^sApW8&{E1 zo(yP;aTrs!FMX)K7w4?+>Y3VAliP-$(2z9eHRLy(p1eABZq4_MDX7-VB#dET8vD#u z_>5%SvRr2%+;y=1*68KT1~B55MvG_K`dT_kRs0aP-c&cP_rF@ByL^@0qKs2TOA(x% zoPSR+2%oPTr>m)z5-qpa^-endA0-ecO|<0O_TtcY2yM^z75Cp(e2q^Kgzgv)9x#g; z4S=*G%Wk?@sXJ9E+QXqkI6%at}xXY> zoq`#i-gxX+qS<#&JXvo`&yVn8`8yzQg1_LmUDH61L~AW6xS-1>%y zYV75PWqXzX{GLW_0=M5w@OE=>UvJUWN`9z>h*#K-6yG89iiFd0Lx(mpo}4*&l>G0s zKz}JYiC@@GiH2Bf`4`rZg?QLla5}hmCutH=on#7o;IXwN4jcesvWm&8+lxcO5wGsKNlK+>nC5N_$r#k z@ca#G>p}-VsTWO5>P()!1I(ew1ZYBB?36rmI+T&#Fz=8&97zldZ-*L@<$C5Gx>ieM z@*lqbyZb>zr_6U_TaC@S4O`r{2OgCpD$vUtI{~cNG0&JmdQPyM?NB&|<$qHSE_@-H(z^iYox*+(9K>R4D$Y`3I1fWCjk;D8L`M)JhU~8n2kr zlD6#Iw$0CV_bI59TQsfiW|_`Y?gRF{G#&x^Q+ra(Q0#=1k?cc7t|0%fPA?kdeAQZ5 zpjKu>v?rYve%1*X5!K=Q0>f?zai_^ZB*_Z1Pa?Xv^X-C0-L2n^8+)!!+C?@qu=3$~ z#k21!9;(5L*)__yMevIX^xdQG7G%~lL!D_^fs9TKDan)tmHp^N#~=oCWwCjDEWgfe zFO2njhISA1ci7hWyTy49=#iwem-?T6+C|5y2WHyCAyuzR1fAuBkqB0)ix8*ROJ%`6 zw;R}G4#Pr2t+5*j*2C8!rc$GRG5|IEc}_H%-g{7i5q)gGzV3~ z4MvaPf8Gz#<2Gb=jnp<(JuSW;vIN!?pmm zJPQZVENk-8?-jqbV_7bu_2bWze&R!<(9`l5j~AnKARf+C8kdio^MW-(6)}srl=F&D zW~-t7_}*Ica~ng$M#oS00puTBEyZc9qnuaEW9 zuVd_|ANo3Wlpn0#9&Y!4Yw`Fz##%h5r9Sa$+XbNuY#I_G#)+qG*EDfvE(?wbBgWAE zUf=$%sWo(Ez8vA>b%xQL6gy9Dhv8@{nx|G{K}4g017*6$Hj<7{!iF6>JIQTcPeUTu zJ}JCA4vW<;2cjvg@=KXnxZ4?+E^Rt^;L@!m73o;cl{8J&D^|G5d&g08*F7O~t23qU z%rLtMnxW~x8X=k+UN1lvzG(unpCdjTXdH&RtnV;xf3+0<`Gq@4yFDKj6FJ?%(WoGy z_3nICm{NJuR{^;@?{PAe#;-SS3E#1#j~OLE9d;*CK!wxb$Su_u*zH@Q?ub!mWzF z8Ikppji6bXhySi*@>S0U@+<(e#Vq$NXG7AYjmIdS4Ke-fOdlIWrFjkm;0XeDxI8k3 z)P4hqwbX{QWH%L@xmQhsF5zU3blXGQP5g$<=!Y!AzVWWI<*?Z(MB0g0Kkhqn4G}{L zP0_Zp^-CW(hcWVL$r*PbaMI0lSH)7qkp8p^yk^IHuNy7OaFXV<{XtKsMhFGk~zw zCkSiq9ZYes+e#zt_~{OtsW^^f=YonJJXD8+v6s2&l#GTj3!XKLT<(VOC^T_r9#T%r z(@jdK2%!#LR~ByB)@`Vw`n^^wthStRNXU`Y4d=WQBEUJnxY8U^#>U1*g%0`4b9@6w zB#7BbXb^{MW%@Yfxz{;&?IbWjCzxRqHM?}=yYuLefWSQ_XH;c?=^Mq8^EUNghyV~A z^I-D2dLDmefyHM5oJN#bMfiHA6iG|}1N{7uxf$3!5hRK7Csr6)4KPWuJmVFLKqyn* zr-1D5nl_D0MMpSOP{~o#FLn1T%@Td^ zOc(Pv^M1W95Fh7iwqp)?P3Z0KJmh{%q6}*ANm(zLxfxt97dF`{Vk%E5^o~LFr$7Jc z=lyw@2K+S#_bgNF8_P0=KwDg2h#aWe9A`Zbcd45J|HeHNW7@~bxD41q?(6`ge(`Yr z80fI&EG;=^%+Q&LWkwz25MgeedrQw29L^&B!=I1y{-+z98EoIE_*VF!8O)uZ7l%MGQoGz+q{(WviVMY+x-8B~f41d^pP>lB9x`E$bJmr7g9UfbIUo zhx18`X&HCetu>av%f&H7YiniR8nKbkf>#~u$|KLpfBC#Do}mt=T`LDW$g279r$s{6 zy?@NL#67zE;k(t$K!kt4HSJ~#bSU|8Qm*ssce?))=YXtj8hxY|Uo0XZaxO~}iNiq~ zLk9dIfc{2p6l{TuRu?W z9|pkzE=Y9&m%kmM;j%;euy1*(UcrKtvryfFaXPNLV;KI98eF3MlatG!I;F=%w`Rh% z*l!4?&!|z3Udd6*58(U}gbn&*^G<$O58(!n_|&miUG}a?n0hSYGyZcC#hF<9PJV0r z8+{bKO%RzkoafsQka0G2Y9&SOI6qU(f*ioN9vY1q`FZ)B0wOF}NqG0|WSJQ*rWzQwke_Rb%7(`0j9sOtiE%5kqK7j3>6IYFR8o?1HxG3{ykrnBhy-t7t~ zSZ}#b+WVOL`%nbIa&*GfVA^Q0FSUCMpV9f~8v*v)*MrxRI|RHdoM*f0d8-jk%A+R* z`!9yqi#o1zd0FbA2DG0@Z${G(^}55G>k~Q|pox1gchh0G6vhJkd2UMb+@*${;Ps)f zFa)~g<*xtf^GySeEgfwD{+GmGla`yLNRTX1mJL$zV=$VCYQgF=jwOT_w`yOm4dp8B z3TO>}&FkowwK{dX$Z+6Wh?CMri$e1QL|NqAY*4Ic77<@{^#*Y+2@)IQ%9c-DtJ9QE z9=$94IKa>HJ?DZzu4?1me!O|&S$*0bTBJ1M?^;4tGJH|l{3i$)3rn%)FQKk&ht@2V z8%u%h#Y^~UBG9eAX$4$Q3%nfq==L@~MOB>+{+I_$yW8}3Yv6q1edUnV?3W#}p zCkrQ!$9g5?rBw_~ezE^X`0ir>bIt{tDq~7?i%Y=A9KfE0G*13KZ~-Ita{foSov+wc zh#g?BG)+Ndc#-71wiH6Pt*OT$7fR76z5vu`l1pRvUa_j?>M3i-=9(zzz2dpQt=VCJ z%;0y(kx3|mTpXZj&ccjTXCBPQo&9AHJ(b#T2|2>!rg z%e&Y?`$BYoW5TWOhz{5`^&PCw=e-_+zs%2_=<}S>gb>Uqv}LbDaqZ4;dNo%OyEG2* zET6Xt8^yC^6!2eIR(lR1sWBy0@KLi%2-?E?RxA4Xr! z>v+F?*-MK%m$Z?(v=e&SORA$!Z{!bYYyIu3pAzmt+OR7|*%hDKrRpcm{)TSViJ5f- zs$e8zFsu`?1!1_syrh7cfzhjVzMeZuZH*6P-dyB8CSwN`Ta4;1A;tmMy*GPl4>u&4=eg8hC{`C$<7ezwX*<9Xo6F&2J* z;NXrLnCE)_#PmYm{$<$qla9b?>YEYB7j$J+vCmQjZJqxJc_vgoqxcR60o_=tc46EeTBOX1KE8~!V<00Z)zDmf9>6e`%@RfEL;dey*0g}SZIm*~DIHvOsNb!M;*V4>a z`+EYJxo*VBN9tLwoGtikTuwLirz&yM-JEA2>OTV7g&OWeHO5EWSoU}n4UbazHJx-L zP9-XafZf;XABBk^nv2f+)Qr{yWg*MGZ#LJ^m0iSfaJS1y61XFlMb|H zN1LAmg$3gVXU0YgVDxouKtUEILpGQG>o=beOqOVIM60JxUqpb`=tA!fO;@ho-GM20 zVNT+{RLFEY!qXLyB;=`zsMk?!c>u14x)FMv726&t9Q|KP3;r@d&K45xvK-Is;Y?VAhMgGjMmk41n@`ui$#agz^E6>E%YPmKqW$(S+qJ?mG4es zxZ^p@;v9MWs@^~bQ)V4r6cARGy!YGT*Ticw&W$#LOr2xHm{X9;D4{ipz1z#rI^-Y7 zp26Lz3&+UNfM}LIq{Am!rK(klt@oK&AD%~NEPGTZi_m}!FD@}q!_8-pLpujRfMI3Y z+%GCwu-0n80pld)~HU9*1h!OHE+_~)IpoSPtR`?+q*^F`sjt@Ka- ztI;DyTSrs_h#*&098`=&z(2!Iyk+!l(+23B%^GKKqMopwLGy&VBT-a0gGYgWv1C6; zs)eoA0`&SI_jJOW1FznDi|O=%=v>)?@^rFjQovXCE3Y|YX0%H$4%hg~f@ z3H}Qmhc<=A4679*povuV?zD>}j=A61qk}d`_u}FpE?3QIKF~M=7TH1DdNSRD_nd8myvp+bX;(UmnDFpk_$9FXuM(vc} zqP{J++oylJ`{qhFE3QoM0=$YOA3*=z=ZS(14z2>f;+lz%%|qqc(jh)uzzzEDmO<#= z3+b!de!ojjtJbGO%;WjLC`(igWjj|{{FQJ|K1L5Oti9NedMS->^q*-b8x z3K=**{-6OobQ7&Dz8~O`Iv_ihzOtdyan2d*N85HhD6ge%HT-H094GFSD;57YQl91D z8pz}hGv*w!@m09-cBG49kk;~FmyKQ*qe~S(qRDw}!@}!zii=V0gG?-K5|jbB^#&KXcpxb2XD5pdc9|2 zajy)Ka+JBpc|)XB+_7Q-b>zFEeRSJ`aS44H+u5tNt@L<~L2lZ*c`){DX|_qUF3xZC zACJ2`PStjfiY9w+P8AY7KW>-2@4ON+*2kCoFgpGIfs|a-5VfM=ai@jsvZmp~^q=!T zUY$z=6nCy{+0&M3&~g2>6&;w<^qH6kPdb{~S5rF~@24ytHlO|9x5x(GPOIy~ z2dX$LaYvo%@bGDS!L+tqewi733y7D)9HRYl{=ZdN(&5Wu@bLd5>O8}m=-OzlC?GXb z1f{Ady-Dx9ihy+Ky-DxAlZ;AJ5fG(FM-h-7={*p-lt}LhJ#<0|0RqY4JLkvwzh|zw zX7k%Z!-d5fe8~LVhl|5!olDWTC#k_|H-&6{>SDM0mK1#USF9kI_vazT}_P zapFc;5PP@^7uyC*nW!*4&$6#L<`VWOo)5C#lsyG*dfih8j->nBrHtEk<(OjFp8UvT zZ{naOIE?3q3WyWr6+{3lfr@yB5}CTOW!W8~EqY_FBzM(Ni)d&Xw$Ipun>#4zZS2&1Ox1o>WdOvy-i^Dyq{-{Fq^H}JX+#@mi*yyLn?-hxUIbA z_LWL0>pG#$;^52nn8qq4s7s(a^5t*N4P>4Ojcy06{37ZL02yhJp`j8E4@{anwyC}= zT22s~N}R)|5i`8bZrJ3FOXXg~SnR^H*cBo+e`u|R)G>&)!}&OIfHD`rc0BiH_uIR@ zGF6xFd>!hZ1x(+nbQ_RO9Q#P{uWUGHolBpK`D-Gqx}^6jTn?2AeZgb5PYKw1cBS z3p!j%R7d@}5@S$1Ab*FW=HlC3Y`l(Q^S`y5mwOZY;%j?jmfg8s@u8}{`pR?d*fj(5 zA&YcfzU|^NbdAf}Ux|ef8=4mrO2nqaZ$3|2Mf#6q%(nwN7WKDoA?GAv{T#?JFQmuC zRnq8!6Bg6kSn1>_o7^9arDhUeoL{GI`mG4Rp!ED!BmEr$_yGI>&gGiAv&_34w~!I3 z`tmUY!ZP*~W8HK+9kQnR!8~WX-gq%&Og?kuc2B3SkBP-=n0ND4>>HvY>0tCGzH8X8 zd|b^}A*oyjoOj>L3hySs#^boAw(5h+afj~r93T>Nx7GK$3d#Ep+U`ti-{11Qpr(4Hj7)-VfJ%oeNfk7sK)y9yB><9RidAGP36y0=2( zp=I+7CC000%Qxrt5101Yl+wAzjEH#urFIx*}lNAEUdG;-@o7YkGs5Km(Xs#~m|dP!gB^dqA+r@4o`qAEq*ZO46MK)@>w^ z?BaF9M@qncRHmS4fATTIQk-1P+Ga%Y#pGuyzYmD21o+S5&9=**GxlC*U;38&ipg>i zLh4-!5{ZAmemq}HI7Tbu&cwjVVBzC>dAl!BJ?X}XXy)u(>AZ!#!yRKKtV(O^*QDMs zujanCs~eXmW6;A1qZK1Mt7o6g~M=F-_?ABuJl5_h^5-O-lFKNpgVC9cp5xpY!+fOqvTG^@dP#@uHp+> ze~RB;j;>CLJU=VC@@8=N;Z&A@{kV^?L`5!O#yM8$m1V@TA6&mg!$*07ZFcvPPKzZ* z5R?Brv>yrrSL1vv%w{2qn~`D*(wz6!$sb#&!j^wCD~zrUiMOekEQLA=%NDNrm~zFE z!p9`bx_@7V;?$BCE}kp#Oao1U;Ts(XPU^VZ2Qe=9HcG!3!mxzKJXv3bM4Zo7Vm?YF zq`DjvMcTcq`uo}*e`q8Y#iN_U_HqyLKH|t$Fp5*sdad|$y?e>HNDPztV%W&t)}*m< zRP(_ULD)@auSa|^MLnxybvQWj=jqZ8$)$AS>&vM-MJV>b)@IvNdEmG5i-TASe`z}! zr(@iNl0v6Y4fnkw`>+WDD^c}5jGDu6yZpu8AD7vz2$rSxF!b-pd!j&Es_g6O|Jv3# ziWQgBf2YkqUx=vE^qO=N%EK~@jqxv24W6AUPZL@c-~CUA|34!*owp#*!WgTHWFZqY z!+fPR$uiJ)7=lRz4&D{I8Sv)7y4H6Guh*gJ$Cl9%c?{nDIoUptPoCUkyLGvbhdXoq zHg_z)BZ4&gF9G=fABlgrWZHS^g zn;Xnb*!4-mv-*~d%9e-3gOi*o&i#p>`9Obx`7Jy_T90wt%U|rK1jmJ&x<>`;SXNqH zey~IOG2~n8Z=gCXK(r1|+c0C(dLIG)GSHbJ(Vi9Hx!lE|Hx?RLksWuFss@jD>7pvF z4$*$^G2^08qUb+T>ZBQWh)*xmf{jNYyB1rjjO<%bzc2J0TytVRl$|?#sd^w~0l1CJ zEl4ChR6bI*5Vm3}a!a6J7T?GB@pgEs!yX-!uxp+>y1E9z#L6%d+D&JMZYs+{F!^EU(#&C-PJ7EhvAu6Zjp5bz3kv90OzG) z3!Bgn>rfH7zaas4Z-^{zxD>HpZluUwt+ZYCvB($2Q2XVU>mAkU} z#}&@+e>>A&;j2gprC?QQaYWiw1Ml|=+t1L%UxK3f*iSO{0dTk8fC3htlD-k&CEpYHHDB|XVq_JY8TMrgv}N}2 zl6^!}Q}%^-*oFLSH_9vx$XUgQ$l|qEjSQa+jNeZcBWfc;MQ`r!YMANf675kH!e%;} z18JAok7FmQ^nj&4nyAL!6Bj<=+W6uyHIiNKxv_9gV{*y%j>j78ne|a4 zF%gNzieYJW)ictb%GsBS_`8v!yZ?2AWzZEmJQ>s7&4WxFebd4Y>W9jHm#vQ#oK&O4 z%*Wo%;~7@^Bm+8aj&fP~3-;k8y<_VAFd?SB`q+kWYaofcY&Wzzh~Fcg&3N4C?vCWLi2#!-DMNT6hEz-CR4tMLeaO^>IzOICr*FuX1=Azq{O-= z!Q0wxO;8>{qlcSBKCWiuS}QJp2qs=iV`v&EovJaLD)HW3>1F4w14oC?E{8EK!`DIO z@YEM7z~?i+b_*3f0nR8e2ep1mRG7MQ+XgjiMh+IiVAT_D6l#^V;ZQA19X$@>WohYn zW2KjQY)`X|p%_0JSa?O0Yv^~Z?)%DUYa`Qr?KfX97>fsS@OKiP`d2A^#c%MuRiBIA zSD^67(Uogp+PCzvZXwFkEZ}TZmSsg`6-g=qWUcBV)xlkxu+N<#gdX*n-&$pNay_BBCLx@*j=E%s;;EPR3{gv_c+^(QGBI0hIz8G|M z@Q2XaWzpzhU&puJ{0;R3Y&xW<9X#}gCH>Im%lo7QHlEzuxWxT)-FDtbYx^3jIz_q` zdaIJ+{7sGZU6#(>>tBLYc)kzCur~vb3tb~!hIP-&e_*yz+M?!ZO^fFoZs#XMDiJIo z3#g@d2Iu^hQnN_mVS$?3*zAHYW}h=tqWvUhYemB5>>|sWtU3w~YZPBE+|6H2lF1JG zCMcmZvB&6n_Q&bL?6~ht?d{N`WB`0jMnjoYlqwjjV*o_LT`xUo zh5AT1!@t#hyhz>xCBe`)h!g*Pq-AAF{X7=awdN>3;Ddmm1ZZ&Dnvz-9|M@vFW{S~J z>)|l<=s914KxiChm_3kS3dx0O<=zGCM#au%MoR_O7*IolxGwnviHavMD}VUI+qo;n zr&;iV_38jSBC7>rV8D+IaDjEQ;Nt1g)XnV<>M^q82h7~}$sm2F>Cas}-6H*dw3%NE z{%U;IIQ{>W5-$cZ+WQ5}j7tm2*DjDwcKO;6Uif^hTJJ0zDCMv;P?m34%a>(=eg!Wq zoE!Pz`cJ>UuRuktC*wDMbf359y8TdH&5=dWqh~tO?8|wuaBQ|aZ6vET`9%vP()s7|diYOc0 zjNqr@-}w#A=<}%@5sZmT5a)M)TVX5mRp|YdV}rz=x>cf=yXFupqqMG-AIE@|l>&I( z(L?8NwAQxb5YRkRWf(rSl-qpq+9C2KNZh5jxFdyd+&B+#5WN{Ncb}EDEOcdOaDm^q zDnY;=ysb;GUr#ew=)Ky&;G=xEE>QfAg)D7gYO9SO`lt8zWgm+fb1*dvE$7^B*k)x3 zjKztjSn|L*9Ha}KIwuFe**@)%`lC9(x4fUT{P+;F0Jt9tgU_-n2snIg`&X|aYrgMs zTK-h$Z#v=d&rpt73V{}Sa@0kdtk;wBB71|&J0>)ON77V#_AC)=tZ$aHG9RlBJW?E5 zk9x4kNH|*d5q}|!6@8~jq873Q>d_aJ4Ye@3_{V$pXj;7H=Mu+8ljeC=7N+QPs^1VICId@b5!!)1Rd;^Jfin?Tm1> zhRrL*zYy|3mU>h@YfBSaviR9tUt}FkcjWF6>`^P6#w{cxL zRFXpn9jHan%Y&GC5+MBG?QmLEo}TcW?B2iqw;V;#!H`taR>{8S%CoSzWm=sesW?!) zbJj@AEhL5c?mHELV{X&GC~kB_@1tk|w(xo$L$tbt45|-wc(1s@Q|IgRUELq_uDtKS zMlYdKk6G{+s9#>1L(r|`|*4A|aVXu#~ryD2KF zrBmtf?Wto_I8SZ+B$*`ny=e}$OGBd(`tbcSN-iJv1N)6RQLX+`p3^llIglqz0HB*I z_bZS4Xd`JG`e2=layDx>=~T41eA-30@N5D0lz@JP0FJdfKGDDTlJh-kvS&Ym9G17N z2V@$8#8C@PZ;@SS+exv>_ma2UuQG1QFMPPG8?*H@jfdWuc)dI>?No?V_%0(c(p84#?6Wc?}O&r zM+Ga)2(Ljkud`bcr*N6~(0C(6eVm^@u%Wa3hxN43Z}#NU6aq)S8;e^5oru!@;Bj}m zYQSig1u2>+4o&uu*nh>~JRZo6`RZdyRViX^!9Cd%Q1fOu-+6Erujp;!Z_T!5igIr2`gyeCl`Yy%!iF|J#|Aw7qg~W3BJ6 zKYTckD-UspZrUs5%~xwNGW~q_3-jp?-{MEixekQfXo=r~jHJkE5SE1#4H3z$D%kT@ zn-VHpe%}*H!b_xtv;_eqyH*?51^tMoS1iSQTlSDV^X8-}aVpj_MQzYV0r`!6UEta# z;k|avO5z#2h{Pp@Glh33!;OM&Z(g~*%gUr%NI8$rno{2J$P?eO*S1b<0TrX4c1>B| zFj-+*UwNngVNt$1!W6_MySmc#12gaST%WI~kzi2Fi5t7vK?5&;iFD!GIUCPdb1#Ps zBo`d>Js&6st#Po=Sin4~%!PIB9ozgs$7^W=ibqpA%0a;Xu07l^mj+KNFYr=q8yayO z+pUZ#Kxs*MLy84Gx6M_p6i;wD>={k;8gT5tA?h( zf7NbFJBgql)EuLicdT; z$Ro$lOU#;j?3s;J!t$a2eX?SywVk*}8!ut_W9RS`+vi0Io%^+MM3-WFoB|uNKy^J) z$dya02SOL@2zN#zgxlgOi;dNvggk2IvY|qJSN&66f;`(^H6mdj z)gH9Gd?x}%<(RuyN4kJH;y!%3Mpspz0*YI0jZ*UOs;d6>mwp;68bONu{tczp-D*SW zbEP=-Z9!VtrYi0k3mp9Ua&51~1{Asv|9+@qN8nnO&Nh$VL5<#1JJj-E>)k7!KSlwO ze7 z=Z=7q=h{^3J{Ef~|8nBn(OuwUx-J&^N1PmAWpI$9oRoi`1qE6N(Ed zgY;ptq+zv?U!PuDT5%~j^x?sB(BO{K3ywx@;8PaIqED7XV6%M*eJpUR2k3*xi`?9Z zzc*Hh6_yRM+-pf)ujSz0Zqvi$E;QI26?C7bBpij3SNY7VdX*%8tzjl+^f@<5_6^LP zHh?rvrXz@p4LgAoY@nF{h{oevgZr{;3{*)nVcLPDb*oCcYY-66s}0ZMVDr(AZzl9L zvqPkQRf_J==KECZohZu?AGzp?4GLc9x`iNF%H4 zEAOp3os=w^hF|Oko4K69F*H$?q(VNm50p-Lmkb{(?7yyxeN<;#k@iW5m!gXGd04SWSZSxA5eqag*ZdQ$`&igC?i!;Zh4tTi;~5d=q-pm= z;Sw9ja1=EED_8sMP^!V?-r4d*6)wx3WnWFVHMBLmk6|51>MQ)S=CTda8;)K~l~S;J zscU|(f)r8es`Qd@#gAIOVdad@f5oA5%-u2Ada0HyJ=L$S80$r<8qT{PH?Cek9YLEt zcp3lTLZy|=ldeiBqG-B6#?)noaJU(1QF^>Z|@qUB6z-*bkeXKk+^D2I;K7D}!S zT7$BD!f3JqgfDZA^nmZs;Y$iRz@@UXK^C*6(W0Dupblv^x{=jGp=cw<>&4Xu$uXyN znaW8Od2dOB$`Fdep?9{Nx*#T8CMEC|EvZs&Q1f-zcS$xnB5gL7=I?KOE`h6g59y9w z2kKkz(5Nn&?{)7kJ}o0c+KG$l4dC}1axxKvnLySbj98A2spnF<0-q{wIjLGa0&ahG zK*kPQ+AMI6vw_R^+UR_adg^t_)tAo!aiJ3vog=32ShLFxI24(Kh1& zbRetlt2yShrJ1Xm7m^&7OoRE2_DDvAJo1e}rEKd)g9ac!%a7Ju&~FsbM>NrU_utbxjq|aZ$}%KX7BB~kFw#zG zK%QTln?QYYl1**zqfoI{AL1HVrTC1y=<3iuh48oq(#!#y;jJI%(597TL&+2l+qtXK zr5A3ewH9VclEYYbwq~rem^pUZJ&EJ&k5&IKxf!noa6odXl!KN?BmiCi#Z6Us_U;P5 zF&dqe_euPT^7OtjZ464#l_3Di5=?24PY3}5(D0@OnH zX?-YsGQ?*J1Gw}IBe_immHK0vAVCf3G?Y~pt&Xy?gs>0``pD|%XcNB6Ul0*E!0`r;~>a5jd<{9uazU<$=&7b4e0h7&{Pmh`9aXKuv5h-qQsTQ8mVg@+>h z!l3&{Uxu}T46EY*mTfuU0S0%4%lq}X@;D!F2vDFs*<0SO;2_zBU5`UU*Tx6e#x(5X zu=cVP4f1P+hT|2~%VnUn<1gQe*7wEV4`w6wiZOvNtFARPJ6eu;qlYwo5wbfSWJV7= zn^zt&mDzv0jb25N&$>6h);Y{axop4M`PzqApAEhXc+(1J=_$2-ncb$s4M$NiSDqTT zkRk4eJc_r<4~8s)8x6th!IZ$r+(N1w27eF|F@T&8W7M=q9{BO_Dls{ip(EdkOd#9z zY}W3I*@r&P8aS)56FJ{cHhX^4%yk9chafkHSNkf2oj(Fz{~o2mtwrePKkAN;BD-Xb|GNvz8*cEvl`&lqZwvY2rKgo( zPD-wb2vw_8Xi2u@EOHy;;H8Dtlg#VzttOyN4025koJ|wq==@nQU)Qe{07_HRW&5D) zg5OYX@*<6@7f)S|?>|y)M~E$F;C6M_$FY$a-wmkM1x?+<$y%n2`;0rElGx0x-SQzQ zTu|o?l)L6v^AL)|?hp&!RlhpJO=^i@Y!WC$24JzR)aEy{tZledU?MCc5&i;~O#tB) zqq%u^$2i#(jG&*LSoQlyW!|-_Bq`*_na((}rHPV5+@R&NXC0Tztn`_+R_{wWSVBv) z@wxu#Z0eILZd<>Zhe9;uoTq-gY(`SFUIT3})nqeAw$cNfJ8L4f6ygK)`m_x4uz%A7 zIM&xzklLZm$K_L~D}NchfBmA-T|nFBbKpP7RgespQ-MA*B#a@E!SK?T5*x>cbZX{Q?Vf=1*&r(&mmqdAa?;o~BPo9i9p;oFJUqBvj1qeA<>PAJC;wkzdd#tMrgvN(0VoJ-j_PrW z+6T^sADEP3L9eRT%eY<*S&j`nZM+p2_GLqBGf{yM?jV&#SNx7zG)TVuT}0{6w9&{r z&mXUP)dgVM9sQORhQ<3BPOl}^a?=(B>^o&}a0gN!{C!kjzTZdl0xH>rt zP4CsIt&m+3;|W``=>(^APAb!CR2%8_DyQ~fgs}RvF%i4R#RgG1=7POy7jRSg1X$lA zzxq*+c-i&zT_^>^GS>#cvejUT5V+Th*gcr0P6BU~(q+ls4R*g9@am??PN<nR016wYq++Bbd` zFm{HIc=*2_j!DzGRl=q4LR2mgVfWmaM{s>J?qggy%i4C8{`E+Csu8 z`1n_cB&1YG#jl(_Sx?EJwMuQFGE?W+!d+T>kz8IaBz?OR2#PI>5G3zOU@*;AXEG(8 zef9W?syLPTlhGsaqQ^C{x_ooJcuWtP;Z%F4{#rbyC4*NB%GD@7pP8F#TkHWm?NIt% z)XMcT1()H4Q#GWCZOj65knG_##VMVi=kU*PIHyq~G$X}aYF#34Mi)ETI_@W!&=Hp_ zVaqC%#Xtg}krbA&;MZ2%2m{{HSZkGlNQI@j*{RG-D7N=eNlay^uBDvK*rlrnaOmE+ z6#8@SdAkH)(a}Bo1ARA-i$d(L1ZURLxX@l+B2Biy*fO6fF_fcWEFJWCaYh?;pOJ-C zHNZLiXZb}J_TNd~p+YuTc7Eje$-0%|$H=)JVmmOJkMh6nTvcB~6qB7qsx$*6--xGI zS@;-?nb_v?!j4zwb9RZytedCYzu+;C*o6bKvmq(ikcJ0$Z>pSui?2yp}y z02#dZy%pu6M6WFvXri}6s^E$GzxImB9n;ACJ+VaAfm6K({K#+CJ7r>clV76`sqz}W zbI?jRZ)FPib==fzcI^|N{wzX%je7WFbY zy@mTNnM!3G?RLcm{~fcB)&hOYHj+`6fjN>P+TzCVU^(CJzraO6(CxPCGWFlyb%V;xV&A|aI54Ql~g^L<5bj3R|4$sWX+phI;8oJhpeQ)**xp~ zre>)Byn0;*G}pJWOEY^gxAD?^+*JYfCH1EGa>-Pu-wKp4U%NXBb&SYp)iHS(cXGBz#S&@ zDAHc{(nBi1Lk}4FEENtw^UNY|ATn+?K+w{m3sGHE8*t?@;meDg5zc}q^xXkv;i~@T zpzJYuz%r5s8G^I@-WgMCuw!Y*aIgw7wFvu-9L=jgzKm8*jMm9bL(I`s5jLKIPlynJ z$-i>24DVqE@*q39qnm60jL@B$4^$4q&NW0u=JRg=Oh0c*`z zv8T7}B(cO1Ox?nby}w}{0r3uXlb};b;A+@nU|EDop}1RKXVNEQ^6q|F_*drp-4=hrG9zW}r8umo@Z4uMo=oPz&52`J z@6u2~x9Q#~n_uvQ;aj7)c2XSH@F)J@KQ$TF5z|I*jpG-M{>mVSyLsBMfSRq=YB+FU z>E6{IFJ&|uNzN)YK{I>9MMKE1Fwl+V*<(-nAr_&hT3hu6b_L)06w(!sVh$emy*z*x z1*Run+WjHVWyaXaS*Ks4nL#)>JqSJVFG$>0zqNy`9Wo&FwsPmT%J@LT(kmN9)n<@f z5ezgCmq&Rv@Vf2NMzcnXd_kuE^=DxJx*VY){4IH^`TZ$${cFRFg;`Ww70H~*!=O-_B!W7HSdlGUtd5e zreGjz!|>aLNL~O#uD)sMi{tz_6Bb<)#z7ClM=FDk`$W&3~zEh*SdZWFrXr_qeFGm zXX51bq356E1$_sdBWW-HNUVIj&*p`4%_6}K7sLdfo8`!@KC(6yzU5@u*tvz@59K$_ zE03RyRZm;z9#dGb>^8Rf@ET|W!fH3cXZ;sE@?lFK6?wE>ZT7z+$X_ZiH($=cu2%wV zEowRmf5AShU2q9KoZO~?I2dCW0{ z3&sq##$3w^G>%BmlxPXRw(g}XPTkOoT4Fai`q>?enOx6Vts zCBn%pr|kXDN2^eYa$I3c!=#!rg%I0G6X2GM4a&%sOaBAd5^wQKhrf7HxV%BvLhYK1 z(~$T=zg6JF6ab`dlyDwBaopNZpFze@({3zcE+!8srNoQnJRU42k*ZtD?fjknyr88h z)C_Yorv_x^e8#0RL4H%6`e7c+3*zJT<8q{<>SoL0OScfVyT5|?s{`G~S8bpfRqx+p zB{+HU#$!_-F)L6r9ShUdE$5_JxmF;Vag5a&f$^Zi3Br+0hxEF) z()Iu|Nz%V&^J$VjPnS+QzR6=(h1x?zM}Gsfx*ubOiwTR zb>0o`xg zS<=#r1X1RxOg^{gt6n)tYfS(`Eew5#=BVRI^|7POv>Q2_i^_E>@>yz(b>|WD*ZSxg zdfc}gB7saBW?~y4jc=da{c%_uqRxp~yw0Q8+%aT#yDa~(Q?;jI?pgFt<8@z5?>mZD zz~{vqwwW@IK1@x@2RrUIjzW)O-3(pX|C=9C`4caupVYv%@!zUGV(jGE1J4aAk3}XH zB3}_q$@%U@yy8={2hsmHQM5Oi2y!$S`Nxka+xpmT7=*h9r zSLq3cOiqQg3Lc@tT1^+|)l9Fu$^$jw`G9a|i6t*<>}SQ|b6lj=HT>}FHL3;qUpq>g z$eAtYXNFLlacu18;;%A7{>~Kjy-;Ah?VD2muO`N*>bEO(ad>an)w6)U&h=Gi>*Da+ z|1S>3$?9tFze#WO$k0m`>5sGXql%;UXT3X)rycS=OTqa7O1jzxxgbG}C%6K93l6fI z4JAb|rGJqlM7OxZ4ZRA6Zwd6J6PUg%($0IbGOBoPSl%z9-e6+h_pUdaPy5IC-cDo+?2^9MTx6s0(9BR8f{H@93?^kLe(J?)IL&gZp4BJe ztk^*0zhh-<;q4UVTW{uw;`<-MNYM&8?ZeaJD%Oh?(!HNAdVMldQIMkK;oBihL`cao zF3i8aNi8B#xVs(|k@jYc3nGt6!vAoVY=dklIGKmv+Lo%U5EL-sb)0mkipKIEqTNR#hM;&<3uE9ls*w2!SRDx{@XpB|8iThYS*&KfV69Xddjke3p| z0Ak2I?0W5)ntc&{HC-r|)foQ0#)sWFZhOVLkbsNnf28=i<5qpj+kF(4;(sYekNGdv zJsKmvZ`1JAbuAm`2n9WdZf>ZHgxTxPWJ7%y_$vv))vM}HjB!?W;?k2jQE5w=`wD#i zh$H%KU`jd~RgN#t*+qdBIUhR2CCN#33l<#uT22*Cb#SF!gV+cb47smj5qF%$L2B*t z1?RBngwWQNwY-|p8s_X5Y&AA@CX|m8lQcE68RM{`v|rmNL#)`F0P;WwNj%r;TGV7+MTOS#PdyaR zsEqdZNahDQS{(7ZOS8|{7k}3@C5!TtZ=OGdV2c0(DHtJXu2xMznj=QJC z>6EODG=DJJ^WIeG3v!#3wZ1)L95{w`-$NS@PAU_vZBbeiZWr5?GilZnCr3eaSg868rTS+B#$9Z1pm=e+7%!4JCdhF9QA!y zIO~mS;e0_wHum!pnp(@IFd!!Lc1WX4h$~g=h@jOc*D8HdxXMA(7J~#~DuV|C_zG1| zcezvyd_mN#*peVu0087;2!WR&wxcx^P7}7=dwYfERa>pcsF>Xk4&pwjoF?57c787_ zl0o5Y>69^RU5$v6aD}Xl>kLA{*@51&RoctVA%-h5nI}GH_U~>>i6{6$!BoW`B2LXZ zaU%XMlJEx{HByQ(KKLn5w^-B^vLu6W7n?CI@EO%9vD?e41aQcBSW_)lar~&z!SqgR zCRw=Q(dz=n^!f+Iw2K&nD^t_fWs9nm5Y8pIOxCCu)G4a>y&k5R4)wm4WBII1${ZYv z{|O4I(_+nRu#J$~ZCF_2iD_65c{7^P=ed!@fF-FfOVCCpt(4?^C_<5y)FN?)(+%VS-51Y(45;WME zg$C6>DG=~#!18IpY-UQk1iRg>-O(W)tt}#a{DmVRwB1vR7Cg$bOLjSoNwOO+Kd-DI+_yyQzv0#fK&LkF>E1l z=imymIuAaZJ1;?4yfGh2*yF0=>A(e)0ei9bEk$ommY>M93AkoHQSh@Y^Zct>8Ykyi z@osuFUUZ0p=z>Ad6i2c7FMWqcl@!$}l;X^jYI&#$lbWYsnz;BPR6=AeTDr zi+JqpV?Z50%XSnrVA&|Sd-aaSw)(pW8G68RxD10FL@LY$U7nIqsoUdBj}fkS?t4a7Nn=wfvBi;M0in`+m=8gA$nTdjE(_>vvvtBBa85O za1EU#--Y!(-%yM+^^%LHn!e7zSXubAe1~{tgP2KnzqPED21syJNI`+KG@qx7|Wj zzFhrWlNWRzCKzft!w2P`8qwI5WooXPL&u*#JG5;urce)@P$cLs}3QU}_JkJ7f#K=0Dr z=xVb)9@MsH7z$$=Duc-YUNKs~a2RAX={~+{@g^(3nVVPVK~Ow8mrMMyj-GO7rvI`f zjs190NLS{y0Z5yPimnGn|v9m0^*XDQg)d5xL?#U96VezT!o-g>KoeN$` zWst-ON7Xv^ZvCcNNE$+C&8666<4ye+558q$cx(_8cNb7A!j`}Iz&&x-uKU}Fu3ydB zplu9(1R-4Kdl6%+Y|`msM%u%Ji5v}-U6VxRICWzbPVXeHJ;vAakvY;-uZhOG__O6o z^K_Y28%DH`s{o-+2Xm~91URVgFLs5zvT8G)cF}oeh+iRZMOx8)Dq{XN6PMLPj#r22 z4B_>nvi3`n4C;L%I&X{n`%(-pUgI9B%Xsw9y}EVQ^V!Lq-uJi@`d%pNa`lG;lQql| zD@dfe4(Cnk3xN;5>AClWqxydPV1=?aFPK&@lASW0C<9cwk+rx9`DNtxzhT_=V8i`8 zA0;Wq#7b7D3vEFP$WF=(?tmllrC7y2+;|$=#+3g+hux2Ac1Tk$2mjTO0~G zJhiE2yWEf!VYS|G=C@MCcgYGtxh%6?n3MzQ#@lpJi z6GQRtnSS8UpOrASc_NVFFc`+B1nCB|1stz#MPM!!S0T-vd0}VqZfF7UP zgx`oq4({LS3%EO>H1P3n6UyU6Bm=JO6aP8if4{c3`i@HIzD#Fjp}BRnedEuWV0J&X*R$V>6WvW^JcxI1@}s3jh6F81VKU|?v45MQZ%kK* zgz6UmekzsLX*foM-g}!g%)(=IvzYSrFzc3fUgwel*TA=0$O;u#;f%Z4wf%D5dyPuA z3iDnE?PBc1`aW`PI{VLRiB*faV??Adush7@{%YOgpMoEbWKBLK2bp(vBP$LFsDEcH z#m;|5oy5%A97dU4b{4^w>Jb~Jk&w{eH{xSBaDLNAicy~P8Xo$)D6lJjwjup~7sW>( z5=iGnWHmi)lelE&U&*@93twWO>r`FrT}vbL!5RKg8}GAaI*fN6!sH-1Nq68{|3mlI zZ8l~VGl$@d~aXhUmBYemq&Lv z_Z=4tMI9sr>wIeOfAfA4{+_Q*^On!WeQUN?RT_iTJer-f-qS^|o5l@~mFlo0@foeg zd-AE`U6r)VdQl>+QQPZ4Rz}i*qx~DqglnJ<>46l-aX}ce#&Q~291aIa4n_oLgL7o+>$r(X;E}OI{W30_w>I3*ksEbeItQyu@Ql zS+8K{TUQ0{u1yNIMe0^s(Ypt)lClSF#%q>$9G+@r{<&K3!Y+mxRarch7-!tS-a!-W z@RKzx%a*{u%VA#?vlVr(#>H^l7TT9CeV`#Eg<~pF$tfj|jji}+^d4POdXRBPwWV$k zx)b4WnotsbzD>m;xqLRw#!M`I2eWQSy7CXs7gTA&k*(YCrA9zb8MIYiOSKMpd_y+8 z0H1FQkY%Whll_(A$I;@_BNmI}>VpbtcjY%ixd3KX6AHyHC&kT%pIxjj?9u51rqQ)_ z_|{BrkbEegtUzEEOe?xOih6o%eredds+|x-Ve+R#Zev1wo{4MMR`Tx^G26 zqy(h9MY@|KQYtah4I(AoIWR*=$4K`KLk%@S4#O}r5C7+R-|zeE^E>CmUTd$t_H`9L zr(XwR4~g(c`8JNy%g0{{2GZhBiWjbjJ>SETL~-i*pn5*!noND^EgdqxN{T*M1EjQe zotLcv1-};F8!BlEvTx0lo=b2#y}vwQk5u|19&|zCI7}IBpU3SSg}? z*j?-K(m-GT1)Rcl+`$;`uHPC>=;G$K{7qvzLE*e5ETZ)lO2-PJ@M<32RO8M!@w9(K z>0t55dYs?o`~S27%MXYXl6T!UPrplk$#<%TwO^;D%iNT>B1x+3fzao#uZsbs&*vcg z9noa)bA*v~r^-C#TUf8cyq?j=Kwd#LCRnfGfIk0nL=2aE1t{iCNgDl8iA;Nt1RWDn z;6@mz9^5_iue6$)7;qT>i2>%@#Ar_U?vAImj@O-+@a9(%5Yo5bhgef zawPSA$8H*njv8kxRIKP;kPdh5xTBj9BiLL?D2*C6%}^6cW!X_Rg8^t@dF*o4ceGlU zl3VUVFeej@Y+*SceElACG*R%yECH8HdLEJY6#H1?CoS||*o2#@Ac2nxRqsJ6XZ~Em z$N!qX;fi&NVV@MFck5|}J7&qPp4vE(n?B^vqRKC>9L=UU0=-090sXmRro1yaWso;u z1IBF&=2y(WCq9it0sR8`wcBBPEcuTZVlB?v$gIm!h$|hX&&$z_IcLs?8Fe1T<2SwC zrG)kIvS;qIC3rE4*>p%DPkg*ZU#33}=*?Cd&U?Rr`QzO_0ViH}$NKTCvxCQH-;s z2K@n6Z7j_3SQ#y(PW4M-^&t%0ZjX#3WMjs^xSmLIr^Td~xzMG5W~4sz9S=`V-^su8 zC4Wm0uXlf=vJH3`i|UOvsP;xi(KoX+3Pnn!kK=dWC@2&-OqZr!LJP}O^l|G$6{lsr z_kt`PVtUTm4(BASNb&h4XT1%UhNd5T-<(73cvk({?^3qAf}AOW-=ptondZ$!v{V5? zJIZ?y*4J@!F?&7_n1y>1or5AIdn794X8-ge%+~Fs7y&O!sDC+ijgw^%Em_og^NI3V z6ifORPeyz8efmREe>_p+1}A0i&mHB_8=TM@;J(I4Np-Yx4MSbsXV3#Ij8pT#lqC8| zM1J}e@e|MRWtUx_ZRPLK5#25l*Rrp)&iX&2{Bl7_ikpjFrGl)M0axa#=JKtm0nr2D zwATSujKH7r{W6lei0z?uD;Qn2iF~;uF@|&~oBEg9?_irVVob7xWp8LL;rXM z$aMO;@3PZM4{CJzFpaHKY&Rcxt>;j?LU1W0#!qAX2#kqyG7as@0bETn_2AnHQ?os{ z+7cCZ$Xr_EE_Mc^o3Dh4KDw22&39E(p*=O|sXmN6+%uvC2OQfT~8#VkANtm^KVQU5K-B5=< z4`|c6bQHehep7eX`#bcayYv~30gw9fu2Jh{P-4ald3C``H8zWMFRR6nfGh5C9aK44 zb>v??KhG*Xgz2)yop5s$x_-(nnl)c4a(`+D5u zeo3k`E`|m5x4Wo4b7b_%%8O(IAi(#mcRRsLgm|{fMSV~ETNj;r)^Obb)x!mK8;|h> zwTd9m&ODV4A(kj;C2X$5_r>`vRZL6g(sM}~#X!56C>mUNuK&Q4ECXH~&c&v^S+sWZ zva5K7xmRL+wX3Rx2h{T=za4d}$NbPK+kc|ts8YOO;)9lZ#-C#9^es04yT#o|+H;z4 z52@`y;imtcU;P|)e6u_Tv&WXo7<=wvN*}`-N|(P(2eX*j7I*o$fyH%j(d`YEo+jqJdSv>GGB+$NTr>v4=PyqBl!E zm4|TK=^TJY7OBxny2rriFf5`+PH(7!a7EF?I=#4$DFoP~>}GE)rs&8?K8*e(?}KJ$3+p?L6y~ozfl0hV<8`$&e~106i3qT^`D$A z5B?jn=?{b8i;lsaN27WH160IZ%=7g539Vi;7M?_~<^-EX(7&#f>j9%v2wG5=XMxkF zT#uEx{H1;5*tg(&`bS1_TcC1X)A{43T@URuYyA2QHF9vpWYQfu()-ELv{$^tkiZ7_ z--KSq{|IOeC18vZ5{z17S3jF1$A*g_&&xU`w|oF&@^DrvC`e_f{a>;3&@D*uIBtJN zZAud(u-}}>AO!r4xJ4O z;hOtIt`lfIDd&b~ZeQBe1ETOsfvhq zzRXB^3S9$c=6X85Bf^xT?h$H06XBqkC;K_(aroLvYQ82U-O%xR=_<9a$myp^g5(2r zXe9dyD@8>punpbx@Xb_S!~Lehy%zm4cZ z!&B}Wr5DKgtQ!00*o%(ePPqGbPJkQ{T(Yy}QE8VNH;el+?kY_CS6-2{0wYuU==T^^ z2hNRbI`;yGHy(w30;%6{-(cD~++F=8@w+`9t#J?JZu%uc%AZ}s3o4#nFbh`N3Cpm+ znUwOu%q6?~_vf9=;N8ZXmvG&Ni1ZFc(g4>M+oXb>xOu*+w^U%Sdb#Te0YD;Jd_%-m z*9{#iAE?39FTG--(^1vM_P8Y5nzt9SSCzs%_s3S-@0MaBgD#abN)HcwFumNkacC6G zfuJd|A@S?n5c9LTF}7m8%k75>~LAk-s%$iA`$#J&i1!CzjW2R+e>&8li>H@ zsVLr>07_T20y=&gV`rxXlpbE|;aU@@PLtj?(wF))paa%BXRG>*#yyTOR-1O4=FIr5 zjD9%OKt(9y{3xO?xN2@{`3zd*$6dH$z^;2^?fcQEjpLEsY}1c_o1-u70##O~y|!$e zp8)*G+9gq@M8HbuH={NwQL2P9kKDe}f7^n4?#1cR&)QK*cT>_8fPA5+?kpldJg;AN z0)PyeF8e3vXc`01U);71V?O_F*?aFt9>zqxi>Az!g|Spz0%6$oqd$lGxVs0ZY02 zfaaMrG&>V34nV+Hm!zSaf2?t5d%*hKocon9=jRecdeW(@NB_;%rxbe$&KM@Yvj^-E zpXP%uW<$m5NWbbd#QQ4T^JsFQiyTrf7nNqdq5LDfq>^92A06?A*qxu%(ZrG+m!(lr zM<2V1um3}kUfSM~tj}n?z4BiW>u_U!d(a#|i*n7@6@Y|~Q9_Zo5&jFm)uzfi&v0c~ z|M^m-NVOl;a2F7f_^SHbXa5Mjr`sEpS7%y@yx_5lzuzRKR4LxJdOf{VL93J`^_t7# zQEldlCB^!@x}~<^4cHk5l>=Es-vLRvzK}?w`s0i-h7Xb>}yhALMe~sKc#x2MCP3b z=k2EAr*uTWg(@1QY>zFrZ8BhN7$EM#jEtJPn z`bBpq6EJ%0=E%c>nV=@cK7vc)>Jrr+ZTKgpCib&4U+Mq%}(?*DtESzkV_W{_v zl;9!$x-oNV>wl{JxRn=vHjnikH4t|c?cL)hp1nV(33(g$xfqDLH$hlI)WYp5`~ExM z{u@t+m}>&RL0I>Nc`W?tmi^A;|M%qVJ|$q+NS$SBjzN0|ubT@^MNniyKl*0rl@fx5>2b{H%cx z_f>L-*E@5op|EM{>r~1d+vKNh*#WH03%7Y+Bh(FwaNph<7lb+PH5}Xyk@^IiP{(m) zW^%i12YrOrKX4nfaf=O=(L$`eNnuUliiprwhyTPLVsu}AM2IrsSa}M z*bQtl76KKEPOWxTz+A~U>E>}4A3V{Df3`#&_;k)FaJTffq|TG78xCetD+O3rVg=l& zY`*?J`J0aFWyUuXC^jMlSOFM9;&CTB=;+Q|0}j1S%X{4Ex-pi&KDp}Nq0{4RRpOty z?if(Fu#TRt`E{BVkBL*hTu~Dv2e>AKcK(6M7Cd^17{F9dnPgJ?YaTn5hRJBkWl3o@ z*oqqCcVFxTb7*1%nA0|pGOCF6V-_|_d30%IA3N{9s7)d`M*)Dln;HL#UEO$}%Or`5 zTd^*t-3}fVPgPg*_}lln^WBGpC)*a=QHC&)xLoRyKg2%*GCv`i|4PT4-%(ge3HzjU zAy6@$52+b{amE>V-GX=GEb08AxwLSY->!9syLOiCqwA~*`gG4@I?)-XdOJZm!*O!g zE%Uvq;vjeye04Ao$WHco9JXc`l(%1c6W>$n=k_eGXcmFN4BD)<9DJC>ufL1B^rO~R z)xxq5a8)wA&%ATqi)7fCXpkzexkt+6M&|SVv1BQ_&_DIDy3%pJ^H6v<-4`b5HvE-G z(4kbnm_up*qDaz&b1S!y>kXo1N0KHI9j9-=5Hn}eZ|MYt_kDa7*jl4-^fb1tDmNEK z52U&sC4>uzJZL(@bfphMs zk`SIbiTPw*Sv3SIwrVuSzAM&Q$3mrD^^>XFk|3*!#bLL60X_CNx9WDaHSa8A1s zt=BjGYk?U@-UGh?W}$y~zFeHW*`(d&wsJ@7y3y^yoU&h&);Qqt82Kxg^14#LZBiK; zwMy5WxrgYk;CjPm8Eq=;qU&6QmeS5|rxg*_F`?YB$OMAwA71Q0Z1-9y z`fiF)yVeAspP^%44y@0*35bMSO6}a_?a5yD0^ls&>#Y_c)lrOtFy^P9ozBv}3c$5l zT8wo7I&`Ds(5y!g9iuzL3AB|*h|CZ+A-wgDB$ebNoG_u(Z6p8gnV48vF4(YSOL1Se zY?tc<|F$A|V%1MMj7@Gz!q*-EyaVtC`Eo)M9>rb@3^J^cy5 z-P7M*S0lHI!bI_U;zT~EI_BDmK5z_W{*5U9aw?dJu00GT=lg#Ix49NGEVq#V34tJ; zs&4J4+318)!8=i8JOxxM$5>h(OB?{*c%{pqTJYlsU2)2wq{G{!-|t_46=!>qs`4ns znD<@T@855owA5&5CW>xfj(d`meBKEtq5QbqU?h?PC1)?lJUF*$4jzndnp^BW-~X%x zSRjKrs(;f?1l&USGq7mID72t%#oc^Eobr)-L2p4+*EZ&45V8D`f0a@5VErI6a5u7_ ztBBa#r!H`W^z984e%!5*w0ro_dL^!_W!;U&Ctn`h*=-Zh`=`>{$I`ER$qxwE2spSt zA>o6V^QQl63tA6jqdU zu6TTm>0DKU9$E?FmncCHVYxl37FYZmTeK_^+oQ5J*ziw~>=7API z-SDFbm&C2Tt!p!1Vlm`xV3BSwB)W2N36(O)0*&Nm6BZ8=ZL&MI_~Nia8Pn=TiH5}SK%{v~SPPqWm| zDz}SVFF@L5*j)&oZqOv{WopIcf#}i>zTLRUd4MoX|D6Z$QAVKo0zX_;O=omnHc}|P9LxS{?oBG>!M;z?l(Los4*mFjBBqXrfa1N z-O{gG0Jj8$LhsWlwcf2RqG8=|3)X^#CUG^st@+$3So3beyCCmo>9T^y(f6NdMO<9T zXdN?St{68<&g7XvA-&>3msxn8@|d`ByK9J#)Rb_GjRHz$W-=B+x6gB^7)USw=lA)r zR;vXzwVfS}e@M$}*L%weO&0bcwFNcq@rOvtKV1R7E#@2aHso99^%SGF+p_Y8jhFO^ z?U|`O!;vn?beg+6qB#B%|xY7M!jgxCO~?5^r;~$K4Wv#5Z*9XlG&M|g*;K%g%TXK z%pnV7I+dmSrcAh2+~d%#^}V8TpnD|DAvgQwz=#9Rv8fe)_O4b;q7~-}FQ7R#JHemM zW}B|=IV!kKde238G2K11o?uz8=dbOL0HV0i&qKrhovXok?Y-C~Q0Kt|p)O$1ADW*c zo#e&9x{2el;Ghm&q4OYUj=QjdBnjVPxon@DHWngvZ^T3+O01JuT#U0ST(z%z1-XUm zRGvFME66WnYYPw<(`)pbdlf<2E*;hx2;Va0&vrVwPg-?u;CmZaK%jd~Fu!gMC}*ZJ z{ua!^yZjYl{VmrRSy_Lip0m~usV57Cg}I5HpPZaOQSSSwc+Y-@R6L(HC?)zNC0~sg zd&~I@7q4?*YmI4+j>EX!p`gI)k}fQ$(5c1A_ob58C67*7ZiF-I{Uo2LfXiGQW^scC za5$D28I14kYBYtHn~uM?6O#o_gsvawn&G!L?&KPc6WsnW;7BDHbB!pKk>%ea#?ZGq z?w(!as=_x`L~JbqFZLRK-OW~0O3hJ5j1}K}%i$R*LdP~YaXt8A?0ojx-sH8F=jM`p zzg%=^)bmNv-T_N>^)ond} zL*5kU8~;@iUVh`gTvkpH0wcA0wv;CL(GiR<4xQ>{mEdp^${V>Z6z=%V$TiJ$iU>D@ zc5L}va#I4=b}RVIOFj2K-m1Ma_bFGQkP6oMBGvOttoGPSc0_##2lVFv+g94xm2~AS zP-$nmhlB8i(R2LMG44S?yTy7X2%FrSDPkymPc>}VA}0GIr2E+kQ6Gcb&<}eFA&ss` z?#E~^6ZP&eI$-qiwxX$t3DC`t)fBg?H^Hlc&SEE}nG_;41nyRYDEy4bakT-m%WyuDG+F{gtcPz8Y=i#8|BOi0PL8l)=HG9Ji>^|WRm zjGlRJ8Yn_L5 zITypCjCrcF3q#AAa=rF%kMSK6-h32wnY{46nW=Dr1Wp$|f{sNl&H`@d?JMopC%Rjb zH-{Dyvsd>7obP_5*wHH)om^G)oE7;zjF+!Vf{oYIgyaPFA+5EK8wS6Ry;CB2y2xPp zPUU6`8)IZRD5a3lEjXiO(Gb&L6?vcglBHKrmC7+O)mIiH`Ci>Q6{3PnZI)~bv(J+S zTLU+50!>QKY_D;PpN#DNNk@CSp9j){$d}h!PeU<(c&52L=ic9f2)uFGo*wS5nWpI=*1fl<3+-a!aBCV(auj=E=(k_shfVD-+dC?) z&5ZqiX@Hk=Dx9e%UYLcpkPMUC@pXIGc5XS zcm-;x;w*e|d!cXs+;Xtg|7yZ(XW&je+UAK$>P@yCN-)K1>imM_v-|^In&BC?6!Ba5 z2_Yd?eBo$wQK;e<@$m5J_WVpo4Xl2x%>RK+d&XQ0s+o;E(Eh%f!L2RN%uGP+mJ<_z zZ~Hm{W~O~IM68JsfX}zcF+OFLa*cHC6?iw|7{zl_yTdO-qzh5bp~VK$?y63SDmoO6(ifSvYrW>K`*hC*|&wZxNyBFV{28r(8}bD`a{z zNgQ+#FDHd)7V54UOT86H3Qr zE0aakinLh$a-(CF9-ija;DH9WRT1HE*$W4f%GYew864lM_QdKghESrdzj94AMbRmZ}pKx zW_#DFV}NK57U``#eoXf04u`@og6%z*g+4LIgU=@(>7G;L?DzPs7`5+8aJ1jv`hU-C zRXctvu$xj4T<_>T;6}ZooY0v`dQccgY4-?Y<}fF6oqm)wD_P?>Oq6P*C^B^f)61L~ zF#h?ZF$ePvGUd*Oho*nex$AI36p<3CECph~dF(W?HnVs+R4eLd%Ki;?!j(O?fUp~+ z`HKLi5Z+n4WRB6XSfXVmit+qS4#BI{bz}dtnAotUGQAtJUB1Eqv3?7 zPH<}7<6b9Lzw?8l@U=Wy@`hpkAogWY_A0mNI`ss=o`+dPPl|{Homf8Q)}KvObY9 z5gSB++(fulchE(U_X>h`=zB~N13SZckMf@%t;i=$Y74iBorCrwj8a##bQ(oELfxiL zA}lY)DnxO(jpMP6v4ob&#~%s$0I$U1G#K&A-kQwHW%&^iYOaI)N#{;!JA5HCzHf9U zIB$)FDA+-ZBJ+cA$H%G_gHsprDB(!PjSKN7E%65IHjJvST)))9a?M`YX+mxFB;fYH zxpUIyerYxr);_~AgXRqEk|PvsPrIGd0tr9x{$GQ+B1dRx6OxS0y>k99*<~ zWlmiGj7ABsm!$57J?>FOZ_j||b~<%p#nKt29@TW}LtY73yTO+`YAqBoL2ZGaM2=;} zn^IT`^n{@Ue(5o1*oRql<_O;*g)E$lP2F}{8Ff5)pDnpRo@v$IPn%o+%#i!9C3^r# zYN&RQvLFHoNr}u&@%L?Xr0}w9ka@7j1^(39WEeT}x$C1+(sEiAIyc~FjqB#=9ivp` zu<~t6Fr+RV?eQ6uAXI!}sk=Kvfi9Dy5HM2~cH(BA`CR$rD~lH(LmbR5z=H6TD+uaq z1#AK>#GVflGDlCFAeX+j8`TTU&pyNZss>LI0j`|Ceexc``h}&JKQ85laJI%3$T~RV zB|iQx5zpC5qH=>XHe+*MTL`tm&07%d(lGr4O4}1{8y_-{Qc5y|{k2pvt6wGGJUC(t zZaE7r->7|q!rb2yF`tEZA zff+h)kDhWF?3*MG+pMhxZLLI&VKOZlwXH=DdyBY|nPy`aWV!7`A072qJ={y@$_mB( z6PsyuIFc1Y%3iq>Chg3N;P&C5{%{(dYMSx3k|j;HEkuW}dP%2+g7y zQiBbs8>u)L13jHP?h&D!MFxRhq`*=((sVgM63LpFwU zPeX_js^l)MX_Wgn-QWb5zQNqut~eTW_oDPuGwRxf|Ir^#2|dAJELGP!swn>hCcWjk z=6hOh!op8`24{4Dr^gMKvX390QtdrC4#}s{*0pp-M_;7+EvHO|yYmZ-&PAIlf&?aG z-tgG@X@_U)%FeR&Vs3$^DS(ZsN`mF0DEF2dyT55IulQq>e9QAB|Il*x2=9}LTWA*n zTLrDrjZO2o!yWoy+Dftl%-rmGXxn7pwbpO6`Mvded<}{LJ?~H@^+UAwQLMv4%EZR$ zkY|Bqj(Zy-Bj<-)4P#Cz%!gacFl^|SyuBS@L z_kg9Yn+#&NoTh5c0^D`=hvb%oOI}`dWrk#cg_i4W<*v7(N{20L1{3F1tJt*Td21O@ z{S4C2PvxRXFm1QRnOIrL_lwgjJ;8k4@v3m4M^H6$)NiELTmqfry*qRJ?C`@vVbz{uFaVn#`$gn3MoTtKNBLO0(Dh zawyC`)YK2jD&yKa+OGLLsww@;rWbsnrkG;c@k5QwypvvktGT|BsKRArS!cQZ!)uLe zd74P<6oR;$wmDr_84C8q$8J*!;V^mcx!D_vwL6`+7OMP!pmfoW(7wjvjT#z1NEYdE zZFVa9>>us=lC;qP&wwo3REfamacQKrM+}zkx)%gKpNDvwZ4?s7?m7^I4>3j{ox;hg zgCcVMj~jcpDpWI)+Lr2lHhMvg`39)b^s{TuJ2My_Z7CMw#XZHdonDQ@_`s_jD<0o6 z)M;Ji@aKSar3~eMpp`;b7}FM}rLMG45~HE)ZAp~&x+Xt!7LN)(Gj)kt`Wm)( z*SF2|^(_3s0g-ByAp9VqIz9_QSChxx8Z}CQ-vz2aK7**k*JQQonK55A$SR5*9XbRP zXgzS8eS9Fk=?_iP92t-lSy!TCd}nN~j5)t^7^E~>JA8MLJq#ofUeWOg`Y2?+ zvHF)J>*Vol>cQ`64pWT1ZoF+uQN&I2;LnZ=9s!DC-G{dYPssE3hlM{>L2K5|r=N68 zq?T;wT5h%mf2(FPZrT6YV<6qFov6nR+|VBJGGkQo3&H)k2y{c{q>_fmzvVB%M(_ie z>78_o^N|UGXQV@0b`0x}ofgP_&KjLH9N5`gHL2zGDC6y@qZd@PzdM#gTl^Np#!vsQ zUrP*IG8I->wh_PB^;&y*2tlyk<+YN@lpQDcc;4?u`)lXr1p%Vf=3{eB0Z<`8e3sn^ zPsD?%g$o^yA9Wa%8AS{u>%HE^GizA?2tbAh+IISU_w1LWTKc;`?LsymGLJ)6%sM6u zQWW598K--xQ39YY32h#O#K8O!k#j16{p{0-93_lq$hF~vlY(RHH%g+^uxOHL0xPV4 zA5qUe7oBao_T*=rr2K^QGf_Y?Ws9FR)%*tUVZ_*Bt1P{VrUTFVX zZD7wR+rU>UHx1QV_^L9Ml0MO5WUi=drMArj=F7f?W`%8}?hO12P%h79K3d1G8f(XL ze=ojV?QqIusc&>TNA^uvHjF64NPYS`ia8JibpoB+GK>9Cu+m8|H!w6?QI1%7VG(4Db2B2_PU|u3_jR5VQp~A zKF-gNjXUAWBHY{smS3)DaOw3rpJ2Vbraq12<`8I|n5L;vV_-NQVG1f|sOp^PGm|DM zRM2u6Kdx^-mmC)Tx-u5gam&KeRKB2A1Ur2z6s}|CV^(+R-x|)MIZ4MJFbD!bv`b(~@m3_-Sgj2P2Z@ zWZt;jF^3cnBmdzOwmKNM9kCww_j&GbzTBacaIn1BqC~G-X&l#86^j%{HUFN6^XB3f z?&^@v zJ->avGMmYQF*Ds^dxukt8HLmchtYMwj=Z3hw0!jDAo<(kO~Iw?PV+6k=9k#o;Dvu# zS-iIgqk^jH~@@Mh07irY?HYT@tn)T*`OAFdaglRaU~344N$=E(V36qW!m?yaXa zIb?aw{sfwpzn4m3K!frKwFZXEY%8bvtj0&JDo6E6tg(#I6Q#j@geNeGAAv&=BIt@y zWj=T>SywrWKku592wNyEfAp5{90xL#>2w_3=1RAuBB9>OX(!6Zj1Ux!(NE96b4&j6 zM80`B)L!M_-q{pEU$?eH2Plh5^M(k7M{veTn*0sDkKMm)O%>cCOax;EktAwIF1agu zE&ie|cV5_7Ydnh$eBeV)lITOcO%%HL(Qo4b*VSt(4m@$a!FR@OE$YM-D8e7sS3lrj z`8c8e{$+!ilwQZ@-Wp1E!@Gggd611>1WFfr3bk!F#0n_S)-?XoZVrG5$K8L<(+VL5w?^LEW= zum)tQ`%z@Gz)t!RAU)r+LKx7>&~{m}0*i%Ggy5XdKMHD0W$JWXH78E*Y?kU^^ckD= z&QBKbJ}F3jl!&-ngp8;C`!rCMCVR_;e;c0{ESph&rbO*Puq1RApMqpQ3P)5O`dy8! zOK2cGb3er%^(#7VZYYr^qXiL0JYO3RE?EYuJwQEu3kvAo`}id;EHG88T$qzu+fD9h zmbIEto+NZdJ9D==i05Lt_0!+i-}&xl2TI@1%bMSQNLwS_F{8(5VHBX~_F_~>pv7fA zL2Y?YwT-u2pkI5 zF*ogD7SAf&9&o?;H@)Mh)d}|W5cL>G6WfjaJ{!PGWlv-5r}IRwvEx-_p#pkDt9uR0 zm+un6w_vCxt9*nvTx5_`R?w|pg{INBa1iUe>BE-GZ>Q1%(q{^?*TNpl5a)S6A(|vr z>sJN5%52@c*ySKxY>`2gpNu-|uO%?fNVi;JS#UQoVSuT-K@6^dVMivGYNE1iDCT$< z7C`TA$El-`{Bh}btc3KO9kTp}(O0)0wg|YIwt;&%Q-FiH2{j+*t-qAN?g+79lF1^{ z5|p4Gq<0?0y{Fi#BE!Tg60zh{LMB{|nF|WbyF!tKbXHR-9;(Ri@z0j3N!{g#7RA{5 z_4pedWxDsgbk&wrX?GMy@{IQMD_@2G*lp#|24^-xZj0|h@gNMkP*H~L#pX~P> z1yiio4ok^+!qWj)|NQ%Lr-UznYYxr^=IV*zu-}}fd+9A6PK|5b4OvF>G&}>Wp-CY zJ(*z8(2}RMBQ(&}_zPI<*9siB5jHUmuIK_bsTmcn9E~D)if%MaS>y@^b=#bpeK*Ly zu5EcPxrpM89Wrbym!gKq>+9Rvah{hB!%%zg%`#WW)F;5IQebkU57OzLRB2x?n^ct6 zZg;H6K+VvXeC@W=KcB00z=2$jy=n@jV(~~Y!LTKzCkK_`F*Rx63^&{!0A7fQMfFJ% z#&WM4UUSWL)7s28Ay2bdw7ck_t_F!D4){jP33{CvkY5>r8wNpZo)#ouhw6KMOls^v z9Y!KH5Rj4R^5gFm84R2N^}RiSWNqEFw566;x}`qsYPv_q9!!@OaD&xPUCgaEI(@Rp zFGFg1w@5B`z_2kXlHHijF^o2&$K9yw(=$;K1tc3IB$qatGOlfa`-SclJtlY>?IlI` z1)b$U3oY-2m{_68;+b0U3x|HBngj!;fh|8m+=U}dJc$no9 zcL{E~S#uu2w_tg7b(L>SrWAQSX8KXYYL)le0G+#os2)c(&OORf&HywLu0wp+(jEUs z&hKk;ZN}%g3=Ajkv?z4F2bs-xLh|ozbL3+LZU!HJ$c~%{UX{ygsYl*(aG&m_6jm1i z7Lx*!Ibl5wo%WnxghEFwn&Ff?-y63Y5^5C0{#Bg3EWT{zP9J_&$~VQ_p&w!3^nQ4o zrL$o~y2R3gJug&&nOcePVU~lg6m4Pq;~&;f+!KB=u~po88YMxZh}L9o%-yV#%v&`d ztRPsGg-6TcJ=*UTL@mPXL+U)aI4Rcfz={ zVcONk>pc!>%LK_4?}9pbfpUAip8Wi%Q1ZGgHFb#ga}Q%5$D^8h372RgKKZ9?fT9&r z98Mpm;M^bE>EUq$92PE@?erE5<7VLFFk5t8A9m3C%`XwtQ{&!Wsu2-2ipg1`aSR>f z)UC_9bS-8XxW|w-$|YSRSHjek9v*2U3Z-vIx)2V$1y<7cg}_#aqx1jGd%%yfvsd5R z^RsdrEt*Kr79yIh)l=H$Xq=aTjvQL&h0&Djv+bpIak)}90Rk>zvwN_eC<;XD|L({r zBbu=xr6kzNz;5%8-n)|CF^ZvGFP7d^F)6P$+ta%ZQyp$zmPDerVa*v};w^$m@ z2Vd=>Oamj_J1wrHBhJ>9|82M*S?cG(iA_`>e*dM)t^O+61{?wpI8(c|*tLLMHK2{d zBY8%o13NL|^i=2zGQN!47rZQ6sBDgGM)xg$`? zS`a*0M-%=@MqplJxLgJ{9X!H2Wh#uR4`hOgln|%BxR;=BMp=qbcAioh?(Q+WM0a}m z=M)lWmO8Yv<+=cDpULdtgg;*sUb)hW{a*Y?O4v6vPQnZKO2En81oGa2EM$@4Z@;8x zGM=gWCw$Cf?R(dPf)iRFCnn^`e^>!>P_FKl9WPHyQ4E|%XAL|Lt=3pdN#R8!2$XE~lPemq`s_tRFgZbc&YfarioP`g^!ac$t8#_LGtyX4o3%m=v(}=+W&Tf zn#DVIzx=WHQdp_3wHAvls@&b~m=`k5(}`;D&SWe@$n-0K-h-wu52c_WW8O7%eN{H{ z&sz!6+3b(^{2$w?N-_DgcH&}(p!rZn4fQEt{vwJmYu1^!=cVw(rHl&e@F2B@q!A8s zX-sAR(!l_IC+|VGCGvs(JbJTWJ!Z(h*YT4g+U)ygs;PiQ{$7jQdhZ=CLap9LyrnHt zm-bHKUaiebV%mcXrBS!mXMIZf7Px7Y@Muf3H2KcH`?2(A)}8eM%g#eO;p+C)ic9{# zStz)QW;UnOs#m|r(rc^t4`c09M7Xbe^NFj#>4;B`Wey?s?i^jc1iEE(b0}Rxmw#o{ zg>a|xE1cM_7mOe23Q0p5`Q%0}&F&6{MRD)kvsnCRj+pxG{j#qcJeZx^g1|7c1kg6d zfImD)@aw??Ppjl;D|R~QOI!Eql2n0~;KJn`R9G!RHq|`6)*P8mm!SQbbM*AuSM;uf zR#?a{g(wKNfc3e*zgX`*9#q9&yqNAtGa<@X?CzV{LW$J~+ef4foZD6wu|+lOm=qgq zrQHK}E0Nqekm5X7#Ci`8Wc+q>Af>vp(yh)tORlMS?JveX8n!PMNqd^*dLL-4$tE14 z(zqwG!DZ{<)E%(SM&i{9o0lzSoc{w8}q83=cJRaHjp^C-!}E zT=-}^xca|^uUL=v&VFLsG0D2@`$=J|TlBqqVz09yD7G2iPAN!sAoQe~qfLD$aKAUw zZR?=4yZ@MiutZfUCC!syBtT^mvTa(kl-!(?M;M9+F(<`#YPk&w~FB0f}V*MpA5UordB=EQWUPS^^Wh4k+Z4@D;0`IKDnK{hI&KscG@{k#NuvSpz;y>I<4X<7A zAHE}pKK*25F6BKvW9)xzIk(1P|0a9j_c1Q|82woG4_yzlU8e?m{5M3O|7RSzt^7V2 zQtt_O3^=Ui_&Z3^yt5k7Y$fM-aNO^>@h8mqj}82Bh@}9?UM9UE3Yc%W zzy24^<2X+74^eSjT%2Ix=0|G?)m&Z&F&fqCec7Y8I;!mOsm~yEM9H)~&c|%I<$_Ef zkLDx+^2@5rGLsM18|Z3YyrVR~+^w6w%QB_#`$0pGRqnTCrLkdO`MHouUKW5-}xl$k^85Ch7XCNR>Am1 zxNC5pqnIy7H6%mn=%kf+~6e)Pm6)RBSTdf#+f54ZzD zacmdorSGCdHvK1{!gK}`oVxdK0%pu%LfogV?!UO`*ah8!PpDafpD{u2F(|q`*gyQ4 zT}Sh@a`{HAyS+u;XWz#xm=y;0SuRo6C_0SXfhyPVsd?@_9pt{b3eZVaN-p9*dHd2j9ZVYONe z+b7DFN(Z=uJ1od1X60fabYQpdd6Qfz@_WlTv`ooBK~FRa`hPe&?|7>J_y3oo5Go=2 zQ;N#U-p;#(L{2Ds%idXsb9iN!nPiU>LgulzW1NtAGLL;6d!NIx&vE>Ge}BIIef@Ji zZ`bvB-0ydH`sS*dNtQFf*?Gn`E;<0i;24PR1cuPTWgMmy z4;=Vw5cS@iI<(~ONX!lIm+x!Hc%^tYu)iYV|KT6ZOU=auHM~8to7^O`IZC@&aJF6k ziG#ADeKoVYiLwn|d;@8Px6I!%KRGCIE-%Wc*A0Ab!6p0PKBEKhg|e{+ZkEm{Jf;+n zH@=gg-=4{5RrDRa@N``V{x4GO&!=qA0vq$2gFMNoo#GWi)WKfuoIW8fK9gt6Z20c6 z^2L={j*|@>JG=c-`KVsaN7WzOB%FLJ+l$$@(c8*aD9xmf=i>X^;6H8b ze0Zc_wcGRvc#D`*J+vB#O!M14E-U#71L_qg0;^lMgoSx)u;PiUg=QyCPJf0jWO*yN zjqg8>&)c~z`OO#6h_X&McC{n?YmNr9VHkHU#ngbTXTWFx)?#>TE-tt~u4J`^_O#DB z*H0AkjZW_*Bu-R_{{*uA+?a>eE_q`boyGQt8V=ZrF=*Ze>jd;bpVeY;A>H{pk?XB< zx?i`{alOwhWFDi)O1-O49M*v7!n|(Qb-CBWpy(It`g%IgL@@Q+pTn>Fp(k(jyfx`E zxB?gfNRbEM=LNM8@!B0{v8+kilPY)ywV0DJYQI=EHrm?l*!a`hV>tnrOkXL*d;P9< z8k6+GjZ`N)G)$RfY6oMFM(?%=d$gv|0=J7haKdF&03WaHZ z*b%aGs_C;7HdI?%;bKc|6CVC3O(v@cG~LhiHLOmX*8`9$?W7$6R$|j8BAyO*{K~-K z33eLIj10Dr*u(9+AEE(OGj0UjnZ z6zf4IS#yrOxM66~y$MSUl(o9S4Q(BO_I`b7lK-mD%Eu{H9Xc;TtYK~Otq$)pos)DF zZ*~8*a#*Wr%VV0R*4GC0ZdBFB%TjjY=Ouck%3bAwRY@AO zVYR{Ux$*DB`*AXSJb7j~P`?>2QggApu^-i&RGAu%Rzuv29G&gvftp8cUF7Mz%kyYh zbmPl}ti+;H{IYV7-Bpoo-23FKTX53VgKT_}Xf+M0s;0w3r5nCbVLcWp1!r~W%-q^j zVkOqt*WMa0WIy7s%fkUCJxJvLqJ73I;4GD?BjbyjwK!E9Y9aaEs#IoXC4I5y^{%pj zfI;5^{J3XzpKuHJM`_VttlwE=bE3CEvxT(5{pS*&kaho$UFr7$cm><}sN21RI?n&Q zu~t648+=5_Xd$})b*c)GZy^ks4Cae@jP|ugqW3D((jAlF8-U`P(h;$Qv!yT!c%#?~ za4r^qynNsh1FRp8JDc}zWLI>^#{6eByy@lGj5FFRWMLc$I`%eMViKfF8PW=V>XIoc zR9W~IR0~&ygk8q}QY@-iv3=f#ou`~7Y2+NHr9@V?A02XjE_TS9J{| z%w9lzn1;vWbS=urG9ZQkVjT=k?=iojFECP`kWHk)sl+B z8_+~@amlQ3krkkD0-vnR>cON>g;&tuIywjn)1xWVnR(2=-ZB-?%}=e*u|Hjz-X~yG zv=7`@hEg&u8ETp9rjptgx;ee%op6KKlUQfmbOCKpC%G6b4nx*?+5MTcaqmDYFuUObr{#QqDx zvI`HxL>jI}$Ds~)!ry;=6Bs3-2x2RB?WjL@Nv`FNtwmo@yD$vO$l1OT$3P4k_W3F$ zoql5;QoLmbR+~0VqIJ&<_d@ z&IiY%Pp@5kVF;vz4qB`A4YqcNdil2z^7;e_IV_`^CzewW?9G+K*zP0knIf9?46+)o z76w{8>}85CVDqp<^*NTK7TTEmm%yERhtd(Whr|hlD3~#FPJ3Isktuqp#l!ng?!2d% z;<~Br(d$VKJJTcQ$${>@LBIjhafZ)DFZ4YI8+Ui0*doPL35FBJdv^)b^xC^5+)&B` z^kZCTB1%yoH9AkkCP!>Vaj_V5D3cPA;1EA|<3k7P0mpc&BCt`{v_}UEJG=k%eEGkI z7arj*8+lKE0NtiVmoWLYpMJwpgp}I2j*W_h-dH6)E2wWzXDb1y{@cJkx-g}#lEGk= zb&`dBzmREUahKv*G?q>VCxU}+^Qa*L52R0Z(6Te^0tljC4!?qdTdMn{@ z6U=1;YQ3`h2NQy25Yagb;j$#EHECcAf=PoSq9ar=TV@7=e^_ z;(>1A6w2MVJhh&l=dt-QCda}*arYzKOk*Vj)P$r7GR$GeU+1M`q2q|zNt%CMaTehF%ftTW^=J6QAzl5H@NhzM|ra5D*>3v!SGey$&`)1 zl_(0OvYiMt@G3sBDg5hbSQoTw0mwQAofhH=sRa$~|C=0|F4d&(8TIS?9Vbj+Dd8LO zCYMZfL)}7qOzH=bRM=<9*|p5ly;m;ccq=oS5DHlO?Tc;#Q4x=mK`C#-nOpMAF8L>d*^A#HC*-;t^oyi2Y~W0PxCS9B zuaB|XGQZEvp6MTDLu=;!mwik@E34A0p2*#6?IEHej~MmNN5Blc47{`lW@$8d$6eN; zPKsQt-O@JvoZ|Y`$P`%@7r1AM-)z@dIYFQq_**1b1M+2~Y<+XbAO;Fb{L4m8*Jv{6mRcrMuUsD$hI7 zBBT46-miAtyx?e9@Y6DLjG!{aC(Jxtj#!TJ;e2~x8VNQlANC8A3Zwj(4Owff2Dycl zbvv3hT(dV9&TypOI$?EhyaDH3ta6ncXxv4;IGW)o>{L)XRZr^d_V=u|>-16-0KO=N zh~Av^XUg&X)+S66iZn6*JCeOeC=z-j!Z1h%lpgFq%zSDa$=2)%I~~Lk3lVp zAhDJ^L0qhBhM}H})#|82hHcg0QOmOM(!$GZnkVe)jn?-=Op}oktfpv;OoiyD`x_{mULd8Jjx$gEQxo@%igtl-&JnZEL+k8 z;TJ~tPj5N5dJMJP#C|m*k?C7pG`cGdPn>tzD;Z@MG!BQlJQn_d4SMNA0@b5Ci)JFP z1EKLeN|3tCiqpR?f#jgVBTM8&%PYvbA#FeJdy5t>=N(I{+AA7o%Hc$S=f2{|fd;2s zjcxA=Xx&6%RX=VkEMAV^?04v~(w*9Tyg{ziJgoU<|1G+Gd;wl3fV4P^lsVg&R#Xg? zB~GOcB^$p8RA>gF|E#mGN4$N&#`1RZ;tvGBQ>busG%C`4F)Rk$#y?+HeaVJb+}V)LUaVY_c86&a>&Fpc#*c@>j|J0}->HMn zW@3r^w}cYC6YZaFC+b+c-%R-$|NMecwD9x&gO($*pZ|*(`abI+Rl|CHXOoL+=#|GoaE|p5HYaSPWcCHcR0f}=KkCPuix`>2}Olk?>kHH9WUj4Wm+U|@$ z=JLzk$LcS#1tZqXDm?PnMlCr1v~~QhB|C4(DN*0z7_fUZLzUUO&<51BY+1EM$Bfg+ z+So32>ZnwnZz3#4plmP@ew#!EQZm^Ox}hWrAYHoygQWGw)q}>BTP;G{em8M3mm(CeM~>D))h+E&0sH4?>A^_ zrn*uO&6%Mxv2Ttm4F-u!diuuS%t%O1?t@Yb#5U{i1A*7O#iB>qYTL_S__q~XG4-aJ zz;O~Qhb2aY?{{#FAj{~_?6je3RcVZvDGs54i_i1N!B}&~uMb2GeXT4Op8UX9=1au( zT!KiQvcgiF{{CXD+&-VbU+$Ep_unzS5by4Ul5+ZBW-EE?_MFA@JkAu4S39rlIe0UE zr)ROT*#Htu0>6YZ{#!cjE0*XbK&tn7&a??X^b-!2Fa4*VI`ia>3?DzF*a|ByW=B@s zjm6sByKsoLm5?-xm*2MX27A`ZZff#?JGdZ4ZT})Pm!6kvX6}HOa0a6L*|FScyUP^f zn-M=sMzT=NT1LB_sdyEq(1O?D4P~JpmJ;_OPylQ8^QVfIe3>qj&%nokH5^FRj&yG# zyP2piks!4#UKJSRkV1{gq8aEzPlR) zpo?@*Fw|Od!j3il6W({>f1n8yjE%OroG_dc;e)b5#!6Y;t#VPEOHnKylsF*Z(KY07 zH%UqV>mWJmSRTA&xaO|EZ#_CW(DM3mB2^RcPha1)sMC(>JI4H{XTdPChI*ygMa@SS zDH$v1FTKlUTH0-=yb7kMF7+WmJ2C+FgS~`xLVcg3=~HR^*1^i?)IiGrni-BAxEfr0 zu-cGP-SgkNO&1BBg)`!zgQ*!9{UnrMmA2ugV?~+`T}Y(E?BB1^&l3k*^qRz0X=9-y zaCX{3YY7IhK_h&(ve6Vm{Uo7c%Gw|Ja zs{uQ$mSc2Q^Eyy}*dVe_I6$gPmF_Ro6tN4bZHxC$j?Wr`4K|3(^bIQki&B`Y_!}4h zS7cIjLn^`XZjE1TqrKP6eDnM!N7L`^cC7FwOEob3J-&Do4fAO{1sF}&+AogK|NonP zm#Bs+cE=Xj%}VTb%9+wLH1O!|v-@xW<=fXE8}|Cg=C>yGtolA3 z(`$5|J9niM7M#u2y1^4tD-nbtP)ndg~C zbm|!l`>MMb!qn{_DsHrM^^qWZP9;=DNFVMu9@(D^@AfMRRX;grEn6BLeDvJh!u+Ea zUeu$%$sYjWqvJ0WF~e&(_C9~NGv8$w<>*&2uDfSjdfVAH?&IkOrnX`;W}M}FoEO#H zOab*vaDR@o;SPbhx~J5%e)M0Gu!1m!OoxN!JFMp zcJwTWQwC`1RvbWM(I)YuD^41yvM%>ILQbtv$?mjD?3j&)X|&kHTuUtHmy)! zAd04%9F3q*3_zzix4TwKXG!K`dL$}7o_0pN=S*godz^g7ZDz*jA0vO)2J!sR55m~n zhdu%>!X*Lwv|6KyC!L_0;!ERmr-2u2XF*hNC>FSd5WKi=byKvq5mL<+B)QkypGL4g zzn?M^v;r+--u7ggcX4jfy+`qRWe)6$%n~1=gKol3Q#ChT8>F45{moDI{+D1YL-Ow} z;ve2RA2H#dZSu~y2uh)g-WEAF!B)(nvrV__K}Wsz`2O%U*<@GWaB#S&gc4ITNB0^D zg%T}0`N3deG~)4yBm1GqH-8#)Pgm_F$A(u@Ga!28I}ZH-PLc0lzR6OjtN{MeEs^0| zK#bhg{%~^aUFFZjPRFCaOBK-4<77FHkN=r1=}aa7rUh(5pK^WH?-=^@a)qM^b~lXn z-k)R^g@3p+J4Y{Hn7L%mRhCkW=S^+}A@5Fl-gstl{OV%6IbGoea+xa0A1^D2T=J)zuV(j}^EaF}pY z_236-C8hs4O*3gl06G8L=aSr)AlD*Ka3E>u%q(m-)y+`|29e{?y3Whe?iv{76{k3V z=ayg77;h5;I!0cQ_vS@%=5O7rqNYl{?h>$*2Z8^K@tmc`tSJ+K;kjT=Iw={s-v3S0kNPN|}+JZluwfoU-%s_|Nj?L;p7V>%P4b0luza@qtDh#aEa z+RsonE}!LPJDF5wfQl!Fx3n&ObF^pD;%UXt&5`sE1a9~{9P3Fxyq$Pd@p*px{>D94 zW*L1a(x+mkl43wV1C--<^^6~a_}zkStr-VnMz!pmn~NQlAOWFURpz=y*D5{9zh@AotzaW!Dh-K z&ZdmVv}^%#F!F9_rI)2NY2!s&o=`W&!KZ~E=KP%IizGO6ymZ0HWAs_T=Rxb-$8Z^^ zcO=VzsUr3|+13S$_sOrq@qs%VLNs~HFQp(>A2U8nZ;uW&m0Q2^)E0FP?<`Vd=^S0K zEm_u93={BgOBG{b{7IW1UwJ=1y8BsF4W$PLtabtlJ>D&eg=Z_XW2;x}Wp)HpLbqDS zomz1|oc_d*mL0ZjYLT7J`Yq=2cP7Rf9kXsR5ohF7qmIxd%;2qS%^RORvrn1k(h_ykxg=h`osChsg5#Fg z;slDxNcknqJ4mRZlJG!rv*SK54+J)!nyPOoAm+ZoYuX$xDAYPJlVDXv&xH_ zUYLd0l*HE{>(Z`9YFDPNev)a{kJ@70aWSF=4ZoS1c%x3JLm%L%8=|L57u5%*NT)9I{#qBQ~xI%_eLi0*og-Pwm-;+yJ- znp|A6nIFt<$h?BpL1{21jdg8drcNwujkqm zQgu4`(NDA;yW?U62=%Sd?1}aaK-y93j$G)G>V=!Llxw`pkODN7m@VIB3){-@V4jfV z8hNkbx$;r#M|KB#2fU^Wn;7zO)@D+QKFgNoZ{~7)b8Lpc>G!c!^GPT;dzZ04lr!GA zKSdY2ZJRgD1W7?gdC_)#C40R$mf+k0r$inH%2Pu9?N2(kmd_dADNYUnQz#&*W03Ko zebf`iOIYpSUtFwu=bNxqvq>@HXs$nDWG81R{GPp=_v+VBLfi*ZzPp~OTsm-d_laamXr>S$ZBm}n6c}8cn%7kr$pQ9 zCiGL*n+?x7gIWXCMCbvEGl#HFTXh^;0494)FH=QDsZBdof>(Y(g*nFTzYFB29ha#1 zX4GQP0TpDnFQC_p5OS9IVr#)Us98BHoOwv(B9Jaya%TcRT0_})Pa5}#r*k*pcL87R z_%s|eNw4X(xJQ#IWJ>EbUl@vYF$hYaXF60`N_w%yY;pWjk_kBHZW6twmny_0D>$M{ zy3g&Nj=npD^_&ssmNvKWvF%f3WoG3r^#8F)mCd&sZE>h45XN4+HwlCZ8QG_j(Og?TQW)txWx_slb`| z6i5f|^R&5ye+2F-{wZ7;AJS~amUX;H~$iR02~9I#GBz0CXDqZj>( z8J7grHZ5#`BT?`hf^3)l0O-EAa$75aE$ghUk7>3R zVtn1qN-WZC@JW7USo@8~@SC#7e@bqD+W(@RNH_UXVFHNavOW0<-rl_6f&T78&Z&0G zc72YtzrA)&Kcoatk=3Uwv0a}9c7sZSPSsiS-W|zwb*;la-~5M{wY8k)bsf)OY8PN@ zt8xfakDrs2x{-Wuz9n-y=~Ha|oS#)%7D(n@v&!h_@lL%US4QVu`@E(?Oi|XE?#0%D z&7?u)Zz-8U&c24euYr8xWLM5Ld$**?t8nU1k!5%}HcIKBpvLXjf_pE0;6`Rr*plt=zPAUre3>%BqGjJM&kWb{kVM<78+8^ zodK-*TZ00;FNRL06c=vrmdEozjBGITQPk`Pnic8&H2AoYZIvlRCDDa$SI6J?Z2LYH zntt;X#)kAhTAIo^-!F-)by$p?+hiO39ognG#IBB6ao5j3nyawQnX!Dq;WvD2g7Dz3 z9D!-FD&!fsUd=EaQPRTrv_^uf$W{n3pr1PoCy`HOpl9{er}^m^(`4dpi8blW{d}Dl zVciVY#%c)j!y$z$@S#zTo(QSy%*aHu>-8=MuvpL3;Y8Ol#BF!+)AgI0H#yG#xAx=y zkkS=*4`FMyPHc+vz>{D(qH3p7wbqXJc8g#OK&jB4BZ zbgyM_vs-Pm&~s6!Q!GUqoD-Bu2F~pxHY$AGMo)VQTWWNdgWkBB&GBtc5KJ21izW0Y zBkbrZEG*+jO1qIk)=#n8kJV3FDoN&#In)WC)V6l_A60$&GvxK4Vz=T3P6Ai+5D{L8t3ct?i+BUSP25B`dwa_tHmhDt z2NefnEp8*rRhKH_H47P?I%Q{1J2W>7)sgwv!h-%YuA@I(QW)(f;DfQhHRd03KHdK^ zA3VcWKBcAXv~cC0Fpya6`UFVv`EFd z3z1mVUHKljqF^|j>Vye8#gz!(OaBbOjQ{xkA z9!I{Pru0!v(LWfV{O%&Simr4mXOattdI{!pQ2X9QBH27z|4)GdyjYcjqI^ zC{x3(J-R60vvR+*(DzP7$LsSaHw^9O%qTCb$c^KI3&0%yu2lH+yS5BIlU|)YUVmYn zUeXJaey6XGwU|yt-G$LL^^+en*lWkQNHs;h%msw<79%CXp3-8cwX`3MF*hw_@Q0kp zVm7Ei_|C_2F5P`WH40sfvju|g6~ZZl|MHNdtyqNUR;#vstD$UtxrK4jK%f`~SCK_? zLki~&#OLO)Eey|S^JX#3B>QpPYhPOLvW!x2SatBA2?~hu&!M(=f9*I=t9Rch%K5Kw z|5BRF{?pwDYe-%pqJB>D;zJHIi8l%IJ$5`RJLx4i`auT_X*a>fHC}98I$Ar%&Wj9Q zi{|aMU(0n#IG@=5tk{LVFJHQjadYWkt7CA*K-*#ve&G%3@b0}r&!z6m#bC!%wI$uZ zT@ROHqj6ux1uYWF;J>rwueTk)5#jUOH7AP zYKY822&j!-y43$It6!yGIF|xv^uX;U+O!F+<~N~;n4o+*1wY<_`Y^xA>plZvPfOES z0GH8X3+J0_r5>{l_ZjDGv+&nS_DVE`a!x8u=-ZUS>m}#+e>Eh(v2ubfiB_c5kDFQb zJCM4yKBjftc=RtJWQ%ET*O(C_$~x(+?)fP(vj0~{A13nNq#kVa4W(+WqT_p~M^r}R z#k&3>&B=yH*QlT)VCZ0`KuZr*L{$dNj?NBIq^tY~0e3?&&et|95Y$27)xc{QIo)TAHYTlnU z@^|>-bV4cUD@ph0_g2?5kT;(TxY6BiWiG(=L}Z;i!u~mk>vz>*qk_lr=hfoPkWuM)7jDT zhCm-OMI@Lv8@~S1(=>xf7ugmnTFQQ*^kXQ6hqC15;RbzY2`Yvg%=&OGctH^*>IVwP zZ%sfxIzcqli^gY8&BH8^@xxl_UXSIb4Jdy2G;n{KF$$3> zU|qF+ZF@3}l)m_GjSets^z9T-XHrnzOLDcV)xQ0bl5*OlscUr&ZcpuH8968S_#W8b z-*{~GgU2m2s;B2Sa`c)P=fs;>oPmvg$p5lLwAbmX6XsKAHN;og5n3ZJ{+((`^ ztzEmcv>f9J?I|l=)Z(~4;S%b%Nw z7ECR5zF)^hWiJXke@&ruM2A3`1m<#=fU~JMMa< zl1tYI;8y9Qbo80lBXAUI4v`t4xe_f#0-o^q+5P!(Z`5R=$Bl1$VByYb8Z^VobFhRZ z1E)mFcS-*ZYv$$P?}(%f;T^(^Bu*3%ow|1@+6;u4kd0Bh*pCuM;wnQej|5ZX8#>vm zlIcVju3h5e?k;FZZK$FxdrUxC?wxFR=?~$Z9fJa6ZSBP}=Kh#=LGar~J~6r-U?M;& zL4crcVgOPyJWpAgc(#wivU6I!tqnyzvuf=U70C=iY+N{&f9~Nq$-&;_G^aZ`|8j(h z0}X%A(*fdWwfUh*XpXJd1;^?OV$R9?zdE{KY$9!++n>-&kW4h+SOwvZhQ3<66m)j^ zJ(RuM4$ZUNK}D@Bc1#Kj?&}eBNy6ClZPj{G<8AJTO-#R27L&pjFZ~lc^!e1 zFM2gjWlU=~P0y5`F;Q3Xgq~4wwXg3a6>9E$mosg%PP-I~6#Xgle6A$jd@Xv)n^QS5 zWuATcwSL>WpPHRehUW$anQf|5lwQMAXZBfwgXgT^`O35HZ>{e>?{jkS0r*b7xRu%r z$=)7OCUmM~+~9k3(do+|{|kqSCeOeXT9-=Ah7t7Fh}yZ9r34FHt=b#jp8^63ymdZ( zirPmPT$Bd^Fbm44pE`!61N_RU>3z0*QKoeOqR7hb3-AC&U)TW)K=*dM`O3Ab%=bU4 zAgcnMAWnT~#Tw2Z!mcoI+5aCH;P^wjW!}6?{+3bUMoho^lr|G>|L|!3^A1D$2TXg$ z7(b;|o8q)D7?~`fx%_>tRzL#?#pvIhd(d{ThND36tFJ|SX9xvkoU8Fjw@MVKT}aBf zbO&n(etj$o*=y0(jT&tEQJMI2KNIX7ZO9->->ieGe6f)$QBmj(7JDJ}yJlfoOk98YQr=cPJEsTnCO{)+Io=nzNz)$Y z`B+f-TQ9#Ed^Gt&Vl1A^X?EiM4Fx8@Z1DW~+W7-`n6D_^M8=sf3&fn>4l4Cp$I_=evH5kUvxR4eF^{P$@p1wq5}5@}k78kj$QX*v?$_ zLV!OjcgIHzmJi~_V8Qvp0!2al+>mcnZE0Jzi`TdJi>$>tk>4F_1w+fxmpcl%f%d~m z8ixNR;p^N`KC&BAy*51yOxk<-)*KDWu@LBkta3lavXlwbA%7x$ye>3wt36#;_P6&= zEnkJv#1d4`zA8-;DZw7^WUNL6FxKZ=)u&JCZy7TJ1LrG;QIq#>D70D{LTD7 z{AKfafg+`oWo39;G=cSaxRq>z^WM z3ci07E9KIki=n@t10)IWg=<+o*~X=$-3k7IMUSbd)S)!t+?qN2O7DG6E12|s4bD_Z zh+W9(KNXKFUR@z^h)&z^BgH+vn#zmRBKYJ z0nsBM51I?i8v=(a?9SHb5=lEcZQm?Urej`MY>+XZGINh^WkYb?U?<+7^8WE3Vzv@; z=||aP*?$Qw6SNWeZ&`TXLA}7+6`o33@S@DfG|+gD&){=FJ4Gg*-vSW$>s15i22yU` z67P}yK-zvLj{i$Ya9((%;pe!|fr{y-GbGuq3HG%)8qX=#QU{vL`5xfzPwoU|$>qlj zW^mb9b=V12VbAlAz7d01$&NMi2Z|?D5f5_dbwIz(BIJl&C?(jY^y#I;}bkSY(N%<<4u!uaQ0pN~T)f9|f>zcerp5A9qT zuj@2W`@NwH6I@ODNCBFs&i7_@4bV2o%{co9=T@Uf@N31peqs@uU4~G zru}#JIka4zY5d+bTw&UG+OC?5(eU{B5ceHD$$Ws~sj-&qnXB&r6h8Z-d*N^GcWw$j ziGVFaHr>_N%E_s8@Y`dXUZEA1%RtT7;}p;d3o53r&O*4-r~upMjoyD?l^#ol}z9LV+X zHnRJ2mrOcwL=AiFO@|WK+IP9hMmA@S-#yuQZdj1>bAM66OC7MX!HeFz&+dNDKh!iD zd)-;SAwItUJTOka60R4W*ZI+M%aQt&*|M?K;6j({gNiQ`z!Z0kv|lXOvm7Gj6XKc} z5KomieyHfI?Y2iiYyAXKqNp)VK-_9DaIftt(lPDr=U0ygHZUEG-q)zyGM8&(7H#qV z6|UPUB}05`!0ekv*qwwKI%`oXW|PKt80)Do8il zQUiP3bPqw!H`o%QJ!$tew~yj<@shGd%VfF>n^>duxIAwJbX;LfyLT`|m+X#|d&nuW zvx+gLYJ+U&-ebaZnKfiAVuK`Mk{|}2qte#M#ich0?{{S(Dv|r(Tu9T49_jfz?PpPJ z+gzHSFuA>I+yhS+tEd?O>IX^32}6dU^ZW)7@=YGUtK0CeEGVXit>gK^Fr9$6OecDN zeKVJ*A}7<_!XWIaqwxImG5VqT_jcBA50@65`+W%Czc>1cFGxHz=yCtdtiDrqPD^sT z@VDhl0uE-b&>W_@J9J9AL!2p@mmV}O^Xz_Q54J!zIuq%?E_*=!(&hEjBb=d}DNj(1 zbg5nSfq!DAD1u}&GK;)imkrYmMi=IUfRo;(`bAFM(OLb2s~(g<8&Z!)Z;>7+)zhGw zbtF15dGYKG=gU3swNvcm6>u)|kHssaq^^oDz3#PT6=h}{&_P?52#}<)MA+_{kLLKF z_R%g0)q0(ldEg#?25;pzS4cC1)5{Q&8c(iHOYmao_iNvBRc~FWw~_EvoMGt1EmdJL z%_vZdW@g?3m(J0~N5~gq(!ap>$Zlrl=!HC$xVbOEg@ewt4#8`gQzX8)P4$kUWve3> zyVx&jZyvh%dOME4GBi%`(-hDAkz(?bS~Nza1#-I_3#|NHWCXQPa;2%Wm*p;lJHdlm zC1;6&uPy*AX&HA%dKHIT8c5_cJy{(P2TV-_)OuNLj2w3Mn?C3nWxJudwl z`GJ+lmcT~MMO*qAU+|?Ur2|vko{3?T`1kZzg-rh`qC)`ljM$^jk zK%^4ekqQ33D#g*`jolp>C3nE0%F=#=!DJGUGdmc|qs%YaT3o%cX;-AsUNSMq=C8E{ zuum<~SkxXiy-;3oB>OU(y1=YeA7`bw@q_9*>zf0D63RLeEBIjdaZ!+oYR_T)CtE5Z z^O5Qn4)e9dBQfssttXuO*N@(l?!oSqD?NZ~&ri#mmtUWMB%zlR(Wesp$?}q4;rAEN zB^#K4+Cy?2MQWc5_SP@nfZ6CBR1^~6tqM&73zLX1AD%*KcyE15)(HV5h!aYY8Eii8 z;~}F+!&|^r=xF$L^Mf}E@RomSK|R)!IkV{1$7H|Vl4#9^;d`=-`dN36XK$GsD3ty# zw+ND^f0@!6vS#P4JR02NTE|1?V5A44h7E7V>kcTtl;+)#>0~i)uv+>Z09l!{p$@Jv z-X%Fyt$fS!;=?u7f_r4z`@T+BX%MtBgqi+EZgxK|Y?m~32+I`?Q=OnNqY-Zn0 z>-3}jQZB;#*XG#0vNYV0<49i~$-~Fg_L<>Nek}G-;h2$lFOUzL&bi+jHTx{-G<$Px zs`(|;0&hHi8uoMR;|pRvv|^^azyLfr%uRCrzePJ=Wx&aHUk-RT#?t>(J4wXoT17Up%ylTgFnx3sYz+IW0(uOpL~a8~aNjEY+h`DsfARi~Q|FH9R8ae|vT zRObw1sychJeo%maAw}Vox}>r$r!X9hCWYyWqlWo|9-P#?}THyZ$0)V5CwxjwRO4)gj(S z?WR>nbZhh<&P$sf<#;yO!)*tnRR^t(hgj|RouI9_oab$0Wgqtuxh9%)3tIZ2*UGRL zPKOgTCu7F=viHh4<1f!1IvWj?N}>Hm_r4k{dzSH&pBv#Hakmv8KNNAc?6|j+=iNeV z$v)!_Ggt$HW?miQFg`h=@e4eW!{5C@n?L7fjdes>tGCaFl0J6L0V7(t>|w#G-n$)} zEIAb{N?#(}zbdSNK7)p2kJ7d+f08I&@~nAVkHnL^QLvJEMXuKDuKQi_?*sr|=lXFP zWe?{qad9P{uaQqp`Hcz#igj4H9vgcnaE*BDf*pWs(X^U(Gv6$2w4z#1W33Wiu*Uc1 zRtuYNM-pZD$+>%n{}{YF@hE9}QL{pl*A2K?&=>~%BafZr ziVwgtCS<7kyA`H0#{T0_!(HEBv@{N|29q8VJ=xWG(}Dv$DoOl4FBFl^%>gEAiZl`# zeEIcPFGD{GINn0d2v_}Dbja9<-S+BdoKET#VwFRSg zAal!jcj0v?LUvIG?;fQ|0E|NWtId*g7uxsRbWZuXq$XtH+ut{xq@G=wQ7}BD2K*&R zn4QCOmxdj^{<+V{13v%DWi$P&z%%})q?StzbDpRv^6_|LX=DGt%KO=^7rA%*Rn>Lu zgKkGZRW$aGQ5?q?|FZOeKb{SkHCrIZRRVvDkFB%k!%jo1Cq~ahu|(8lUfs_?Tm~t< zl(Kztn@LunY9J&VeqN~{d&oZkC3f77M<-p>a@M~Vq zd|T^e<0{>UxAXx8n|)w>H>pdkAhC-uDwS#sH6J&;OxdJlw#P_4&*4ki%Zi&Z+%eveanJ| zDX6LVd-ht}w~{-`4E$pRK-J7NEiq_d1`@(mZTg-EMN*WUt>l5VD=AgzRSmvnc$N-C*zqojm% z4>n)|(w&2i(Y?WdF~-K>ob%!R_I|s6zvq6QJFe^6iPxE9<{f{%Ge+Q*zj@-{1?{P?`1y4Q2^e5g~0}_E~xlusw|Tl0!n=etB`% z&3cOzgO<*h+rG1RX=6$5+59zUBDCeV?YxF65)(9v_!VRrCzTcA>0u0ycENDxtpbYw zO6j=M>MdL0@JIh_2S#@mAAbPN7XOa>%%mJ`42q;v;9OI|xiwVf>PjYB2?uHRI3z~6 zwaZm{Q=L*}J`o&oP5=s4bc!=@@`#Qx^He3GS5{S)0ovR(i-1U}yT*ei z6(Y~QoNSfG{gvfSFR+wz#BnOBy3L;BnUv5x03W19|$;m2+={icq-R z;QGi>YnQVU-cnn@5U(=!qvORU_}SS!SVehfxvUyL@`It&a3~eoZ5M$C1e~5oMzD84 zu7A|Zluho{0jKq8fN7%_TUV44CS<{}0AF^0DErCx%Em=!?2Wl?B@8#KTZbubT8Ksy z#CKOKZ=+dwLk%R!gk+eev=l`+)a&-gsl+(G;1BTugVvk3rs_pmL{%<2Z};e9kbSgkuO*|*?KwfaAV$~8F&Rp#dpA+bkO&GngwX!97I zPc=~K#lI2g=Ua4;W8DGV(i{fmO-2h4P9&SVU0(x zG)W!$c1||#g*(XkHSWDVis5kPKJp6XkDv7{5VH-jtj@DDX9W^-k<}u-G=c+@@kNKz zS%!t^g)UQ%bb(J7Pu7wS)^E8P_$YR;G(kf5XN=B*JJ()`aXOm7*Ew$TRH*Pw_U=xwQ7%SO=?@YqpgAq- zloW%2BtM-;EID(ZX}7V0&{u0vOU2y4S@y^PV7jJtADK*x^Ll{9w#j0a_#%JU z2u{n3Y-c51@?c+|I*ZbzOaZRt+oSfX4Z+_wgfx=f_o_QZ3IFtgTk=b^*uW>{r(>iE znQiP{yKkmVL@K&Txn?3urM!mG4<;9#!cZ*>$##`zt?_h__OWi|M`6P`pV;z5nM-O6 zqcC0Rxm3{;gwgfMiJ5Nrs_YIP#lyFLADFPnH}!!>ci~Hm-cl~dT55&g+9r;yra7XQ zaaCzD-Iza8jkX|^e7?qLOgH2CE*a0BttcngEuq9BoZ8#Bek@%N-nw~1*O?NLFF2`2 zL;vforsgSjslOjxf56Hs)44?AONcAP1r2KJ6)x9b*DvDkGz||cKUxN{?Rq}308lP^ z;(g1)bqmEwHQWsBc?DOqjcv#yAr8}dk(xearJIKPdZ`mx-7#s$Iqttl^Knk`>6GasAEO4v}QIE)d1e3;nGW&9pEZMn^Q00!&(=2qMP)8f^~wm zS7>PJV|mzyxF;|n3mptY?9yJ@G+d1TgcmXg6Y~D~Tc3INi)J6qci>i0H9k)8(@wKU ziRoz67}o5#CVoe0Bj3IB--u z8vq~hU{ONRJHbp{u0o<_{oTpMQwqjituib(!cn7|zIij4rc}48_Uv!Izoo$e6gdLg zj=@}JA#1yV#&dbIqrj0=uu_Q4w)TR4y)mESa^B-B1nx48A!J*FwdJ5+wzVpPXGTA6 zGz!>kFamYMoAw=SjcWeD;iL7e9@HpFpU`T^7b0+>#lGyAR)bX8;P^8$+WVB zrHI!=Y+76z7<@83<<#=8*iH(c!N3xe63pB?x(}VK+|Lq#kop-|0K;uYt&&w4?Q=D| z$Cbp_!QBs~1{^eS+-FVNP4NsSK5a*T=z?=iIV35~v@hHH=nhVUeOg{|>^}+NqP(2q zJYHdL59qD3|Kk4s_{+F2hS{lAvFky)KfK*(cWRFM)QCizfnB1%*tod8Y5Kt4zkW22 zTTcRe6rnN;xW-VqdGYMtVh=_Wr(eXZ4)%Tt-}M_@yc0cqvq>{4N~f=fXYb0OiA;)y z{0ykJsqlN#WlWuVVr}Vh)BI-4U{2lU%Q^~^Wqt{%+oA2&R_>c(5`{16pX!+A>zxSR zEOEH8f?9haX-M7@T7HmtYwojObf>|Yy_HkoeL27OAON9go6~1yZcEz5u=}br zXjD!r@G$N#4QAz9b|Mpsq3!T+0+Tx^I;&&y>5J3+7oja;U1?)E8Ky$-cScRa?8PsA z6xBsOolxXtU)&)0c4DZ&iltcQuz{IWEtZoVC_uQsqD{Etdl{U+gM-l=fY#>J52%K> z=`1IwfhRF2wzu^hgTLj44SuuHDl>3+2HwhlfQ4J#&K6+GA!h7s){QU~T4-L_WWdur z;DQZacAqxue&@=z9OD0#Jp9e~>X*RgdFn}>iBs<+!gr*tIhU=4qc*>k>oVLEz1j5= zV9g78wYAC8QmcD_(rD=-{OK1lcufiMsay3Rc^+4ZG!hKWATGV?U{AVttl=eh3m|o#XVI(>S`^wmXlZDXjsm zPK9&8pVV8c|BU|k7ZT$1>+pP)!og&;tvKvo1zwf=#YD)qo_zYHfk$D<3w%@+dQx3QLPwG`W&3>eAgpI|qdR>2mDIG8;TP+~ zCu6Slg2bXg%o?e!zv_O+sQEIT%3#_>=4aB@uPH;D)>0HN!NO%`IlrMp`AB<&w=*YT z3{|m!lhjL4mX9^HR6VKOFzbs0{*#*jW0-WB9v^wb&tLo~M9Q&BptTZkqQO-a=U~O>&0E8mPT5s(^agZaNS`W+Zkb*6SmH zt?w%U-8U~#>mwlkHf`W*76v{~>T(s(rkMc3QNuY&B6?5!7TfDz7> z{F4lZqvpnpol@IR;~c_qqjkLrPmG097xr(FD|{F)Id6t^O&MG}^%%-jKk>pz(}1$* zjH|GWRrs=V^)AL-V!{xfCu}=_Ps% zLAaa$;oLh3uTDFnvnL=2b)Hf`OE6TE&J{{+r*NGvaNYKnN zqR$q8aFAmN$z*Tw8LU6P7qV%tqI=Y>eeSw^dZX0Xo1+2QI?doJDI{8q^+_MR#i4L! z`Ug)flP}4HXc}Qp@a26TO7dwFQ~?JVb%Og6v`ev<>L+vdra-szM&>1KRDbzZo4~Y# z`%!JL$J$nw3PRLUlbuRR>cyUN+1+f4VMtx~L!LmT?_^5?2kM`m7)=F3{l%)n?hZZPHxCg8{F5A0^6-GUD5%4$m$APb`KY zTMVG!33T;zmzwL3JNRaL$vn6a;H{_M<+v#lSrLCJFNFGk^`F4^EUf%}NtgNY_}Bft z9Z0i}-XiI11q&Z>Bc;v1C6QkSmGb{d8{&Q^e`5}nAE!X@$Pf9yP@j~ZhpCkdZshZ! zZ2;FeemZm2K_-)THIV_jA_7b>*~lm@6LQfH8^Tn}zd(Ay)m>V8R56>dV;L=R^+__; z_lpfeF~4xjir4=*w$*sZ#DZw6E+3{!vgQ3Xml?R`+tCk1tYomnnTEEuR3Y93q4S_Im&iI`1UO#Kx=UriITY(CNd zb^KPfJEz7Z_GdDMw)V`!W>qF?S}?NT#7(yNZI$s&6njqiQ{^MlWS`Kh&x{+Xpc?hZKW@(1(6d3eqdXW+tm6kWv<(~%_CCO< z-g7Bl^0(49_uk$&4XjO;hU)yhxU=}ggS5XWmjguxBe@E&{7CDrtVPXUfe@#uS7&|l z$U#{_Z;_lcDCTyc@L@0yAnG`M_^d9xKk{gB(_LZB+wVKF{H+ajWb&!=%u{I2_J0Cd zlYXwWK@ax}GM4&-egCm&41&}H9Ls!~k~6or9;of=n_T$rM~LPQ6-oAV>q1^lGUnOj z9@s1(oMRqcJ$~{HbB7qoesz^Dukh)m|5@&($3@w8dq_S$7diemmu*k` zWHO&$%{iympn0riXOA`QcB9W~wSEULJuTDz#I;$a!Kri8>i||5vRE$XD2CU09jq~n z(o}j@*OWE^HuHG_oJ2qVi0vOgB2&|J6V=+b;iQE8et5Y!pJaD67`1Eo?Trjcp)tsj z^wUM>kC-SARBwu&FB-f+`|U?Ef+7IlMHQ_F`a?>TVAx-K&B=+l@5nd33kv zGmATN@6I>!UYyyTPm!&DNc4HirF8Ix2#HJqcjmMNx+7eY*EdnS^^&vS%@bQOYjphX zri&tBN0%Okeun}LvhXZ)vSNBRyGAt4_A7;8{m>#$*_^=kHKBl4LuJb>Qi)m60GYSl zJHlMaa?2}#;jqxZ0kCpP2`qDCW9I`VaK zdi(N&DCMYn#Hf!kf62*`gZj7~>ax!Z;{P6hgv~=&ey01IBlQZ7JxCcnec+#z+;vyP zyd}h~D?axqMgzp0%?h5C<4qf)~0i@gAPSyk(0ETVF z7kl{`!|UR3RDU=^W)VhGSYg>>xkV?<{ygCRso0Bbjyr67v3Xn3zAtxN7s#{>-o@Hy z(Jp*xkd#!Yj*5rSCa*#l`<-jtFy=}Gr=F~k5BN`|3Dv%}5y+MzBv-WW7t#D{7v4LO zgR8)pp!-V3d+@Ta+q*zl^QHcFakqBLpVXlnEp8 z7J=_0uri+x%XJRjw`b}0oVGSw`~ly>2695JU}gtv>~$5-x0yB|M$1ngG3?K;`2W%s75Z|9Oe!X z8K>ljf5@8$j9RHhzCotzUx0Ja{|bZ+JP6rf*&CM##eCI8p+Kz9j+e%rvGNKfE~o6p zlJqNBGm<^ybe`2b#IWdO`aa?CPTq;<^p~48Sr)AtC%{_diJ+214*r`P)U`S_H@e9) zua?J@N|MaE)n>q3I32TKee=ocnXQVd8uWRZ+KoL=C0j2tW+E@kIi$(w zW^nWtx!tT~#MM{FmMBo*T^Jz8RE->m8%c@XDH)3j()A%P!k;QX~WqFcl;m_ zwBbv_lE{M(9D9+??tO(EILb0k>ivZAnO;)*)&PWVus2>V`v!UHCxPO9#BK_hN3}G0 z+44%y{=-4kKoHy*HrczYrMWmb47u^(qZGE|E`R3 zLd~OpH3o@7&2-Zshm1sB5Xa`G74l;5H}$g@q$>_Z zLBEfY8UVdA6O6q7&KbyxP(-~(RhY^mHZGLS4A9ypIB9G=50`d-^-H+fg~0Gc`1y;s z8x_y5R^w}Gcsr0_v*N3GE(+xYgjooLLPc27*=K zW96#srt%oJ03ic|(8S)vqsHePSv{X5ccC1m=gpT>9q?6Qvw2h>$tU|3(3Vrr*_>dH?|o zr9>ZRw1;kOr6(?D1ZW`{VC87f-jvS0+tI5jNXYAZyE^V#ANoX}k1jd&*Qa&M)Tyj) zoq?u)2Q)CQSAcR-JXl5o7TX5zz?;Vv%|4GbH>FB)GyXKMasEE@SO(;@xix(NBN6mo zv>ZM&!EV|)@K>$kaB+Fc`#bDU(O^Jz?lQ3=^j}Y>p(x&~1l3kW@44`aEpGg_mT1*( z?N0Y#$ZsyMo{I!Nb_w%$0rZRIVq%3HKCc>4pLk5K5WJC4gyT(#0ZXt;)QAstOPav)Jml9m9d8h4tAOLYJju2bzuO2 z#sY7#0-o3v64P$&YE?9S_*_-2ut%sa=B90n5CUOof$Y)E=EmO{y2J(E7NpPolUqn3 zeK<^?lk+ z(pBk|Q(RQlU`Tl3@8vr+{K(d@-*Vj*vf#C0zQGVT0_8J{vhKM-9%rG+{@>XfuUg&h zJ_VkAHYV3wAY);T!l~`Y z#s@wfbRpZ)Sird5Uig42jWwA=S)Df&L%S{OdpoJ8N;kA)a=_{oGFSFyw?5GZ5emT5 z&8%nRSayvK)U!GpCI)r$9{w4P$u^9m(kQylB>%ye4f)sVR8lJzd@Z&ORGEh>8D-Nd zCQ`fD2y2&vn{%S`ZE_T}HL;u%(dU@VRV{u76wAT~;G`7QV5rqg(QYT)io2bf7gj7J zpDEUq&=VIcW$sTcn5%0lb8ux4`pz7Pxx+!#7tTQ|WS|~DRACwIKqz+$)sJpAf)2>t zQkLC#YOi1~Y|CUW&I3a#$2oJ+VFNbu$RF_gXQ28OLhU%;CKVZ9-Be*q&vrC2_L7WXh z5tO~-=xa~ITc>!x=vkp4DEv=O&!?e0r)BDDUDBt4lv?IVr`JZbHAy3wY$r9tA-l4- z*=gPM!JHRu$KQLVLdSyIB2H(S`sfu=$Kc0W2C&rwz8vhXpX-~Vs?ds?$Z{}BW3Y7- z7}@cJ_``vb3WhBX_YuC6rAb>RzB*>gdBPO6%LcAp{~n(qHBYYx+N<^qfsMI>Px)^4 zrimDzX=d$5+GAMxTJ1s&u2$E6(Q3BWpBcj`8R;M8I1yMC&R-rL()bsRoP7>#IX_=I zx?|8dH}mH@gbOZhbFUr$d*E2Gzbc!%#G$BX=ZWI@8p8e=R{}TqR~w`v z(L4}qM4K;>M0hze?{6BwFSlJ-ykI#&JfYWuP5U}G=j$LRqy9+(Y;;}_*(j}`7*Oq2bMP5L1rm0p zR)$s(PE5BaAV>YOzR}8^IcKYw&3|REP1wsNOU2TK;G@@gATn{v*+6}I>qRUMLsnS43s0}ffLEBU|6tgmEUsJrY_4*_ zwX9!Td&r5|oRanGS9>sb+p{Lyk`Uq5OJu8ZL-(AaQFT?g@2YR&o@!veLga|qa;Ffer&6Ok_xQBYg zSZ_bG`02>4gP-W$;-xoIDO9t-f76b_Ig~$mM*mFL@H8ETY4rRk--`IJ`k?CRh&67~ zUUs?mctu2RbT5k_Ip=vk96Py;dUyczuO#GeHVFJBQKZD5(F&Cl74Xl70ureqXREjl z2F%!T&+I=S>mw4l_odi7p7dRyFoF@(WFh=bfUWd0qT0v@M6esN`VB`?peZxkj&4*k z?`*4`x*s2VeQ`LaIr6JEtmp1L#xn;vq`2;jiZa$$jwNZh%00_qzv<>ZW#6`(Za%s= zb;Syu>;j-hoaeR!RtKCvEZWK-k|wGHVdAPdC=d2YBn1$7HNv=o;6F=h-S>SuiNJ+h z3UT7OxYP~e<_g?-Bus=qhzrw)P8FnUaR$D$?xV~QO{5QoS&eC_%ne<7vg705+Sv{V zGt#H{`3KX_`wA6zvuaxm50)EA=aN{ zq>sWhqdo)os z^rVjJZ#MN{fi%NhiN4t9*Ula0s`Z=U}6->L56J zVi;#p3}dSU@A5-z{7ZqBx&O{8B;CeexBPR7;|>7gM*ANtE(`X@a<6^5KK?c`Fy#Ls z_s3WUHZPFN*>?ksr)H>a?8gvWcheE$bXA2$FROjBxk+zTazjrOn+&GKvw%YzM{ot# zd~HhR)va&p1d;i1335CS=E}_f{I)tj?vWagK-$-dZMYe%C?85~5&L#9`x9WIW0pD( z6b@UlU<;nf|nAq-)lALKZ1o0!%u-j+ts)l(wq!?tCEnv%d8!{L2h#na^b{S$WiE_{vdrhh6#9`lIv zbFmgrrz7N4JO*#fX}152NzV5SJ9_^IfE*3A!gcheN~_y9(}Ui)Wls8CAmz=tek+u^ z1@Q^m^ob2CL4Pg1oDl04VbSHty-5v^Y$|{UeYrfY8DJRggpe};AV*~2{xZmB^ zqUe{&4EEp0{#7-qigr98Gai-a)DYA&a#y3x%ML`O=;S9D<_1)KIWLFHeAUSZDEEhw z#m@&S7C7<#-;~Tls&o%#?#^z(L7>!0CAqvVEALZs$;%%6uPl$84z|1t@r!5p*;O9d zV^l2eZ|FE4mg%RI+and5TUCq|m9o1WBirdX>@SmN%R1YyWA=*TtVRd*DwYZynav86m~9}-xf)MFsP8>G6g z^2=!OrrKG;y99cC%5RgKiH_z$$NQs*HaP|pI`22W$@!8g!CrdXPEZL4C?=pFj?^9N zsu|=T5H+%Lvi5y}W38<4qYPEoOk+4xG6TF_(W|tM`Eq5e8oCwe>j!9Uh)5Ne?g=&a z9r6g8?tOes_>tE4-Ci|B-uz~wH^tPGpcr!Qh;Cd2Qc^o;WM7u}_gQ!q`Ii2lwS;iF zoY9N9pPg27zLRlKqVfW1_2-wt+axBu_V2m%6m%6ubGO7`ZH5|xzGsV7(&{&ANjG2$ z6`OotHVDgbb+NKAN(5TY3Ovu6r{KFbS+q9iHjMRVRuBbKx+OZM1ki0+Iemd&yQrUk z$X*SXBhAEt4ofruAb>1#mrR-EDHYjDOrua6f+ z=6BEQMB%MFz>$sol&DluL%9ZW-biXl4Zw(`FCalFm+J|F}9|P#JFvTP=b93sU zK5~~RYli5wrD|SiX5jG=&Xk=wAG>&J+ynum$e8l@)C$nyy>GIcuP}dBIcPWULUi;g ziAKkm1=+J#0r0h{Vhi7#-q|_->nrS;8P>NIR3t6@N-GQJBRoKIk=+U^Ddi~jva!6b zFpJY|`eNJTD^+M9`$;xJw4*0R(npvJ(&$>?MlQ+e5G&tKZ+#i|7v0kV7jE~Hy)Bq6 z%Tu(ymLS-xYe#r2os2`w5G{^hJ(2e)T8* zS&<8!ON^II+6F6qiyJ^0DumcVgZ)0dZ1!VM#M$6z`%^&4FN zm=u{E>(C*(q)c2SOMD}$w!Sc~@a8u=V)2Q>Ge%8jJ%reefL+I2b5=U2^W26VtvU7? zMG;;=GcR|ciAt~#dIcPDH+{;a~>L=ePwVpNR(~P4S4dwOv2k(5?1Zz zIfIxoK--1)g`?o$Of?^^FjI}or4ecqU+=9fveq*<>ltnyCVxwVWgF!=D}&Ed&*uu1 zJpafIc|D)CeJbZ}`mB#N53%_ID9s;DR%mO@o)@=|2$MXjp z@FC*s`)|&+-=54rH+t~rQCU%sHoMvpA$WBEA_2S^YL({m~M>bfTNe#5Knu?s;3yD)X%uK5@Jvp?%!rxC91X(ze5X0Y=TDrB+Q`2YI z{bf8TfM_XNvG0@)3&x%L5WgtLf2A|HPA*wJWFBR$wNrIvB!c>+0ndFRcD;{+QZ82) z?`(4Bq%CO;5zex(X+dD-NV={L(v&`xUVfG$Q}Xv(Zv&T0!qg8UYR!3dPu9lDG+_4n zqB*PmjX{Z=GYAtW+f@6On2B7i{=X$iY(N7nQ1{87$t+kM7z&N$MKtXMQ=f<$g^+OX zGZgfnbWS94x;QKVvpwvGtxXSENM53&q$Uj}uW0mOq4U{7!sB$bv7fMdRM0Gk|42Ve zekAI9O~bKvhCGO;st0G2!5YG(VOG#Q%~2&I)qBDc!sD|g&>R-IB3m-)_hF>bZCarQ zC6Kf6k1!S}gj=|$^)V-KVBS-!=}yzrj~kk&h2qxc@|np%ywkKubN&F{Y_P1fiGwnh z8JrG|$HKeFQ;25WAcZ@6yxl$YnnJ}sp=fzfb0u{ed`?gM22Tj!#1OG-H5yGddMP;W z{ov63zumQF^|RA?NtLp%rTEcIvf1UDX0M5g{Wj(=hkW-}mJ#h0tdOtzrx(dJYIjEU zRTiTOeQLmDH%i$&RkY`xZ{j}bu~wI~y@E-6B=pTcN;2veiIK)foTn>wth}7;JJ=b` zrngyiT;h^idKx{vFMnFIAMIs`y5XBn0k^xmiP1r9WcGnvE3Rye;A7oK!IRSxx#yxq zX9>YNv^36rJhXMB%|eg8p8>d%%+l#%nEaZiAfhfvwLKfb2QeR(DKl5Xki=lK?r znCTD5WEx=g>GCNBX!@L*3-){R&SdIKiMKz@h4S+mP`Z7$mKv?z_f|@NU)gc&@V)mm*}$C+sQ)yh*`Azt1X*zSDe++fXrEO zYAUd2aDMPW>h#q^xwG645C8P-I_~2|sY6d1?NmkoSRb7@re0rcDYbb1CmsIeW9t_# zPKmczrJEPN?^g$2K6m>>V)ifS+=()OW-hUx7qm@t5xV%0u#UN(-7?;Q*dOhO#@>Di z^37EKI(gm{i-nkfe=YM>c$Qh8nof(*JY8-doWgc5^j!WTmy3@+%r6@jck=C914LY2iLKizKh7Q~3e6$*ZLm{qHm+|236?o^(EmwM?s7F-559SYlt&H^omw2|m`kH8s>zxv?DC~{;qJH%|PCnKg~ zcI%5g5i+a0v>rtqj-7ALWAGJjPT0)Umh-iRQZPl%%H?!qlO?kJ$P73&W2)b*^{2tR z=7*jO8rZi@CUM_FNiTGwv#l6r0xF+uWBiyHyV{GZiz!BKwHY(;g2x z_oEXe+|JuUGxsTS_|~34KXWM_9ZbYQZVOY=_0+npov@bGUIK^4IelNE?Z6F?SR0+Ajm`&- zKQI+`V0xM-UpTcAcKO_6d)5v_G5ki??%9nBQTu@cLnrPe{79_=k?#%%Vlx*Nw@f;s8z(u;Er+i0mV(YLz!pT!-E=RJ!^tv!bep7txzlF=Z#WX%P$5Ol z@-~bRYkvAZ^p~PJdynQSJ^vZ|>tJfWrmIz{EUr$FTh{tbpMZbpBD!VvE7kn?(V!b_ zP~cY7Q&>k#YY@6KmX;Di`8ih+RJ;@^?ZM+6v6`x~_M@ggzol)fHwC+A;WZj|cJXdcs%$ULkusx%$?SdnWPYRwXoDf{V2kxe0=9u6K@OSvhk3E!;j-PPFv8Mnm~?9UN8_8 z8gMr_{BlFY^KXS_;dTv~2D2*aS7hf8*Q~#^k>3Fgs9U+tfIKkJP)r3%@g|BM(2u;U ziSsvF?AdDl6Ua)L_$zW8_5B_#{}gOqE^kRX zsufidl(MXTogjB4Qb=5XjY*Pcy3NxKie{F&B0%*?-qME9*0<)!v8IKB0Dygc7h;}W zJrv=`zO|Hp+qmV(O#5@bgTQcy3O?+10}MB-3+fLqF3Bm&iw#uPP=;a@dYUmmOU2(+ z>~~x@=NdmHH4Lg$yqhKep+1i_BM}n_Xpx)=adV)J6oh=LIMO5m+r7QNZ4FJ_y$8KKRy~6KfP-lJ@C)tLnvVu=v9YIRPWLZ*RgTPjhI^TjA9vdys9brobz8?L z<-y6B7TU+JI6{FcFBi zt(Zn`*Q6fyTuQ?FGLPB7>!LLO`ExNeY0k%OS-HaKElZ2X$w+Q$jo!k|Vg^jH`ry93 zg}w{K?5Tl8QbzwH1Ba~=Q5zQWlRprz7C6i#sM+k5zdV4)EAdW(r&JjGg163@C!7g(};bJ#AVqVVCsL4q}vB%#ZLUDqcnR921hzjpl&G)aSRDRm5)7` z9^1Cj959i7i*@NSl9A1yKCrO^Ou(NvR;?2I#&&F6gE$<1;lXp*F6TWP+76fgVtoJG zFvOu?_&j!c;*dm1)g6#gdMRIIaFlOa)x!Ow%rwS3p7$#Ax^>EQpl|ySPdZl7fQw;) z(!(x{WUjD~gPG7s?TpR(tq;LD@7U^LRA$m2wbNJBf;T9jR5wQ=-CK^1p`emtx+oX4 zjSN?y_*jm`D|rn?aJ(!Fo{aG@1PDQ&1tIrwTI~8?XnY%lA5h%wUoEW{lZ3~FACyvh%;2q8(sa~s@gEo&x9x%|X zN9(1G6kLj+DQ^#TqI7n*{DAPwkVh_jVDwsE%qJhlP-p$5W;AWL4F>oY-NjGmm86b> zt%L(e;JS4eQYA1`8wHhD{Bj$)NWfcBKD9SzwB{9(4GV6YQaOBZQMN+-NQrLU?>V7# z-zY<-B9}2U45`ERds6w(tMF*Hkzz~oXJF>JP_BI=BoxrR-M(h3^-3~$)ZG}R@9!|s z!wV%hL4q5XK6YS!2xk}Eu*kpNF$BUKke@_}W8`paujE>0qyN|oWyhZ-&&-Ik+)_@@ z{RXE3PBph#sdaD|FvhEz!d1~S>tih&?T|O~DBYy@m)9-klAa|AoV1raAqU4~aA?Yt zI;GB2Iv^;v&O*L0EIJJHie3ZG;r=hFLijZ%Zmy>NRn4MXA-#=CWFolw%yZa(i^nx; z^WW)P3fLar!=jOlp}%nXM)9+!UULDNufE=C$1mJblRV2As#LQ^Y1BneH^KbY^39m( zjKLwY66`a^&sl`8kG!MDXGWaCFYOE%=GRL5Re}BMGl8MH6=XPj++=|HKlB3VH*;WZ z#!l==7CnkLRw>U7Ya@)H4HNxGhhqy-*zG5FybEh?dc=PpAPCMsTASa|=j1Q>db#W- zLR0Df~B_D&i)Mx2~`QfpC3iP7^Pi zSA;c_AK! zYB?O9sjHc@Of9)_Hcb!=k@lZ$<6cF-2vRU@Yq z^S!vX#yNAD(#IYwOQS4QBX(V)5^FSuwAk$cEsBVG6Z;XP>umhQUo9-85o>N zV>O{a5!tU3?c}?ObrdzUMr4=Y%SAjQ*jRTPKEik>#l=cH>yOZ*+Dl^~66Q|qw~V5T zNRuFIgs8ngo}Hj7eg<1mtkMBc-cT+3+0MeL$R?1VwJ-&qM6u&OH_VZ&3@hW-@^k2p zn$0^}Z>wX@B#8D_hKq-_^}2?ycJFcg+h^DTli2Nqza?2tudRo>3|d2m`nkT&1)|iUydZRSYtk(vo<=s^W zYk9z1B;yQZZrH9DWGSVQ4RY*r6vB`ZeFB-Y>O36reZE*9Q5`>cA9USZp;#=CuD!?N z_q3G^h|}$qx`lIgUOvAcnnRZ^)u~eAL#SMiZN>FzMsNYq!HjcMk`j{ObfMjYLD=uk8MENWJwJNBg6Oy%-%{;l%Sc|pBuIM7!WBSd!r&}vdy29)5}|h5>JSw0;Rz; z8!QAaB*14lV_C++U(G9WcmrI952yRl-`#FbcUvH}=Wik5y;;!qW?=ULy~yw;>~J!) zHK400SDcp4#V~GqO;^F~xz@$mra?C{nA|=|a?!|L^_s*&rD#|5j%@vkM}P#s-8;2{ zGNJYA%%@e?F%?Ndo+JzlXKVIM4aF#7x^KDf(0VA&()aSVs#`KuJptpC$y4Bs?8%+djt*iZ_CVUWE#pvSeYop*#7hde zTmL6k`n%-WHp>an+$>G-Y@&fM|CdLm<>Dk>h;!Uzywv_EzGo$;u%w`lUUK#mV%NWB zZ+F;Ufb(=>C1awSU+8HF8Tb1yJ2Vy|J8Pl2Cc%T+GBTEXHI9kzG!GI^yW|%`+;}i_@y&ZyO8l<$<>7uNDnRp11ZH_?#t#$o z6Eahac{3gva4a9-^Tu}PaSmJs5HVVzY1gotIuv~&zYZ-xN(zKpQ#&b9rv_d3>JH2< zEj^STuCH}1{z}X5g1E1;8o2NK#@DDzm=5GP>9;x{ZSB0cTpNqTD6m?b${1lb7b4{o zFlR*jjsv>0j_Hxbvg3~Su# z1wIS33tdek;yTjv{*nac5BIRB7PHf{PiMB^)&@D#%k$#`_PMUJAC1>d?$>e)QXOz= zaMiRiM^{&OxOK;ZB=Yzo+y+~kOS*7m1%5tbhcdgM;!Y#H#v`4(mq)D8s=q;<%pK|S z6_$U}>kf~X2nPjkLS$P2iH^b3=X*Nr138gC+!9()YN6H!o(sW6dz8FXsK(_*Y7HW- zg2}oJ6c(*b@RLC>C7YdValY^sqhsMUN4ktdBNXcAfzQi2u!f8r&XBu2Cu` z=$_Le1DbaOST97bgo5YB%#|J3I#x6HuASdPId_Tg&pC$j{O*1a$f=ijWBB6E6eOGkfhL z+6*e(K%xl(8K}x_8ob6UVrzEq?QGXT@MI;Rh}@-t>fD_8CM@(T;G2Gs{knuFgU5`I zYW=qDU_`TLVoICq<BM|DmY2giII{>0iEU>j2v3Qd_O+e?Q($CX4yJ&bXA-)hwl zsHiA20lj<8W%T0dsrlL=ZmDP0-q?{o%-<`lr*TJ0blYW`~%(%<6Y=Oz}35$<&iL@9D^RpscVw8bM^^Wj!i_P)ma_U#nnfZ4@G z1&6e(tHr3CN*y|C;tX_Ine11-5bglHvBEg>@_ejZ&``&%>kBb|I^YQ^S3Wv1a!5Bm z-}J8{g6o}oIpqULVTg^aDtvvP09F$Juhiekp*@Fjg_Esq8B=zo>GIJ<`9 z?{Vs2W>WYMZ=-k`@MYA1dYx7Q)C4FWR!Mx~2w=*0raJQ$lRaXIf-1(=K=xC@t1OVT zygo+@yz@kQ&|s~~w{ks)GS}!)p&UE+>{$AMUfd0#?Dz;vYi`f{DO>Wpd$7NjhU*rD zBA^6=!89r`8ruYrf-B363h;*G@11nTT%l*@x~mcO;6~O{lyyCEGB-0se%5}KNAiw| zCqDRW&l9dxJaUsw;lA(37Ga#q(Yu#-mCWmV&BE6ka^YH@w&s5iUQ09E6vVADl44WV z@7ktgbe5+Fo~1UIDYz#2HZ)&%xBBblQ11u;k6`cDRP0Vv^c5bB)B+ddV*Xh_PF!ye zLT#=y%elpo@1JB>rXm8*Jmk(!>N%uU&?zj#33M^0pOLwpa-1GZR%m4({*u264mV>l zg0Mlz{+&6AAbX)$+8c4r9Of5eV#;e@ot#andQ^_>hudULqw=Pk(A4hP>Gma|1yt`dI9Rn0zI6xU$U| z|G*|r8vczH(B7jq3X#V0-phE=dwkbglOp}7CN6J!<{lt&^=Nl+()Trpd!Z|er}L5} zp_65kEh$$ss2hqWH+J`;lTn&Ow-%U&PGKukj7KlW}I z`!S*DzKfZlZOX z({pfbdy#F<#NNkMxxMg;i~69YKk21ay|T5XPLTEwb@^uO?Gal+3vb#)`2uzqB8Jnt z)fd75oRVVnPS!epTS1B3tyFM{6Ym8-XEqeFS zr1DQ!SC@^C3ob3mM1Q(iXIpXonB9lc7{9-}-p2Lrqk|kdP@Xv;y&;JoW} zfqn@m08@kYE3dGE28u+>MIxJZ--5 z@Ag}ksqB2Ik9J0q|^E^`|`>WuZcz4~-735pQU;?A(pW;HNk4yDQS98}}KeA&^Xj)kT z;S|)d>e||`L5S~_kOn661_risxnSY# zvN|-mx*E%i--utg^G3%W=~;s~mUuDS>F$XTT2v`;X_m}=xGWK@Lf#q_st4PRIHuH4 z4)2!`3X7(lTd8}j%(UE`uNIm)DgmwayTP^w3F?=Tb$^5hFJ_zDL!Vz;%RR164x^>n z0SS`4KPfBCl7>jng{+fYc#smjfSkqy!``&ZzDC0%#NLkAgv4 z=j`s*XbDk+`k*IpW^y$pmqP?aeesXWgj~5@W?BB1&8(Ma?Xa=`ZT>AFZwC2|L}^?v z(9>BmtSZCJFj;5%{h3LHL)Id!FOa3w)LdwTy^k`NTuHCAj%fHaL4Ew$s6r*g8OcF$ zKATC%;tQKttW;&?kZrPA%mJQ5q0aXfKxR=9Su#_h++W^5~*r(W7gwf17L zYQBsruTkPl!+!-Q4l^C+Oi4;kJOlVOd|ZL|Jww%`@vl?ChQ`x_o9^Zpuvhe|S@jFE zY+M>}t_>ggs!%m)3hp64A2XV5`T-U@zUMzpLdig7s(tI}vFH3kaMW*p7%6VN zYK=-3J$9mvIYznzt}n%q(me%x4}m975 z6yv13NFlX+8dRQbSAGci%H0k2^=7fiWn*jNfp6X2 z)uu4UpGXtw+gNMhMfyPJV9YSDp!D;GgtD_JviqxXMn#yZ%hGpAn9k?=BM~_l1A^#& z*7s=r5A~2wvnp1=1qer7Y#xm;WZIJa<>d9ue*@?!LuQ|&q>fL*hJMPO6o+BZbBaoe z%0ERK1~)*cfpEvFVDUf$6nDq(?~-7w-Ji32jbBDPu%?4a_#?AI+FbNu_wi(Q$L6#b zA8iN2{nOE6bX=h^rumuKEE#UKES#EfR3cvWbD?z?v4sl`cM_5d8gGU2L_Qem#6cA2 z?wDzzrMP=tE`x?ik|j*K)IQ_#8pBe1sDP;Z4qY|J>l9`$y z6t&tH^{A>VxqmQjxT2lTG)e50o@}LcJ8~HO<+r!{STz^@TF@S`Q;y!k}y7*H@6 zsKC|2zTFLqBVad=c?9W(QSXC9T$p1jrb-d=@iQEH?6m`t8QXneQIlCnd^!J&Y2ykH zn}H%`v_;dDG|Na#(7s+EHRfZszKT*Y)Q6ugf_DuQ&JCF30uo5>*e!y{6kV<#I4tvFu6cDx}*!FTO{j z5OjUud5m_`Wx%je%89=O%jcB}LbEe+hPd9|IczU9XJ;}=wX^U zs&{l<^w%BR%XiwDUS~ucHGpcq&J^ZX;=rxxb+lTqVFznE0@1C@<1D;>X40=$S%-|} zy7N-X&bOGuQEaVbW=Cql=!zJM5=9l4kF1pT(n}Qxw zzVx_lq9C!0dn8V}ksQ0MNBmemO;36Xf*MARCQRgj63}@)zrqgJWUFB(`0^~bR^)(JP>uk)`iud7+(5Qa9!1cdG zLQt~vDRK$$xcC!?3aU)qtv`*rT$nXqvI3ut>Dr-JO7Oe6aASXCQ`}vR~Gv)fQ}$fDm_D#gz44g}=TlWW~tcvwtz z=GT_F+Rkq`3kxIhk;Qbo_Whd^x?-Mn4h@P}NE2W~cn_F7cP7aySdDYw__mj>_%`1j zk1IewIXKNssDKW)d9Oqv*$z~j`r4bLX7)~e-wKGe?oeyX&zeq%!sNZVZ?mNE8Eg~w z*?w{x>Z<<({U&6);)wO7WYI+Hr&xR)0odYdW5LqOz9#EDma-V97x&}U-__iVUY}R~ z1o+h;I^VuGPEkPUSVh;4QpP@Ee)9}EE9z8pzTL&^DfTlA=Ig$9`nQd^b!;+B`O z&dAKQ4%zy1!DC@FQo~`FDtQU$+g~#o0L-@TURFHBHrO&Dz6A1~2UdNr54bZ&*zUv+ zm&Y8c#$PwJ=s|pWvL8{~En~iPC+&WldVOoO-fv@?y_VHBy8TyNr$cg6r9A~H7Nn6& z@$Dj!dXM~sExFFNozzO-0h(am|M+HgR8D-BZ|>GCa#Ms6HjgL8RW*Weyf&xvSb$?( zCFdS&O*CMnDgTQ}{qOguA(h$Fo_3e#wlQ@kMydPEt&bA^lathZVF6X?%HYD!lWklV!S`!LyHe~{fK|({F5g?%b~;O zq@nfhPqK32RD*@zFGU;|`V)wSAuQv4b^ z&K>mh!Z`C7chc|X!w?bcHmMo+M%gH`K5Ve=v4QFJAeGziaXSjmKd*w0?+B`5YdX~R zK7K?Cr|((+;d10ox1yW8qG0~FnOqylH2m9Hq5w0kFtNcpk=(mi&K9eZsiU zcE+iG+^DEPX}DX!TpcSf`$iS^a#QfU%n_Rsa{Vd5c0BvNSoINH)Og7Gp%$n=)&1(3 zm0X|*59FTWp1GLPDV9}DGIw#`@m86~OTX2-`;mr{m?Tfi@Ifl=LC_I0p~~d5&U(_1 z1MY%}w?`AEH?j09U6toM6P@})b#wYdkr0pk;H=4?@8b4@x~@$=`~-SE@$)TooV_-M zX6^L}P%#LviCRDiFY?M}j_SEJc@tH~HPCs%Q5#e_dJk{Qk0Wyf*E z@DRIkbgR*1OHjUGWhxi)XIS?L1vX#q{ztMClO3kj8wK|>+?1w#k6;vhT_|C6_%u0#M0R}We%cv4a^)Wx)KHwe~RCqe2ar@ZlrP!OyY^cyg z(|~0de)7%62y~>xGFNhD!jm8*fGc96DreR*mpPx-USw)W_Aj@!R?k8K~qvN%|Wq$3qT*EbvD(Dkk(Puyj}uy zNli2d;QFX593e~f$EZ4v8z^5lbT499`Rvo*RJ#S+f4qp}`C z?23R>;F%3qi5#x_A<@FH6p~UJYDmwXHW$_9H1Oi|LwWG><3%-`xcVbKi5H<^sn?(< z&6RVveWm2Uq#(Lxl*HGCinoGf_X;2f+>C++c&;ZM<9TLBFDO7TGe!yvD$j7j?;4ey z<7FWerjVCAezcSJ z7=8NZ3z+BZwL2}B+i@8qkf@*Yw8v`N{qUh@Yl9p{Hz^HVhRP&jHglMN0w%WSyP#h8 zbsdwHPiCSrNe|PiSwQT5QX2L};;~~?V(^W7KbbjyVLXYVw`BelwR@bKb;`~zXeAmB zmWMa78|F|iLF0IQF-+Tv18@`*I1Xe?O*pDMBno%$`Lyih%+f)4gL@5N?qI0yCjS`- z)_goRt>kjnKrgCHwGtP-kaRtX1n_0HsU^SwAtivF)N(eTJ#w%Z}4ORNp(mw*KysZMM{o zHGK7orTqx$)fcUJbADj-Rbk$3v$M{za4Kwhr+9VR()gpBs4wuXo&B^iRhhX*rIA^j z#r@iXIJC1DX{+$UB`B|PKwq3`4 zR0+hCeprjGxCQ|I8{Ap2Qi-D4|&(iAiObB{l2*dO97c4`5P0Z2FLsYO2G+(jQ4c4p+!YkhN{h#jcVMV^ zo0F28wPJpnhSqhzN{?J@LN+R$Lu_G?JG)vcx=gR87FhrAXVpF5H~I>5S5!=j1mfCq zV|8_YBN?*HOWeFO)9>q(BR4DJ{Fu=-W5ZQW-9~=5Va|DhNFlzgI8(V=?+`U?yt>;j zW{oz<4eV8@|~R6CArA*1SGAJ{sCphs@-rgII2fAe38A(`7fdJCLutzB=O@ zKC8Oaw#_dpwa~Qgz%y>euQeMSb)0yY$TTgrPCdwx@@zV1aa?t+{<|m)${zQ5hp{4A zZIbfZBpg7BQ<}C_W$Yz&f=7uRp%mzGzPJK#y(%(`tn6$Gmf{mw|0=My7-wwilGK>S z;31R>Z3`e%-&Y|kKQnf}`@L8SY&c}AG4bve5_DWe{F(OX%u@o`bnk0Bys?D77cT7Z=H$HPEdRX(E-L0w5IR4FH z^xW~ExLI4>?~F7or!~OJM0({J+Xp0cp+)J^@R3!YQpA6dN96WMy0RiZq}BW?{rQ2c zFtI^-yw`%_X4EUIULIqUEQW%ioX$_r1N@M>VnR9lruA@5!9G-1hGpeBo}J?!4+}G9 z@L8|+F`4qu<6*f${~fA;M6)b69r0*kfp}>bW*>l+?wb{ugv1wpI1?LI1a|!s=Q0Ne zh3%}j{7Q2E4L+axEKgv|hWdKWfzzYnO>HUP_ANbHPKP%ip?WYFD-Ew0OztZd3f_m|9=@-53K`hy>z8T zHW4+SgV#Rnrk7mAysd+xzqi{J_XGGFh1Gbyj9cP0gSakpT>S|_ai zvzLgLD%+vMVcH&L+dV<7dtPYx!&rQ>0S(10ca}($=W-UAd>K-n2t-$xEr}xPO zW$p-uP&mYQDqG674yRkh~*^(e}!b>bZ6G@@y~3w7||uf zO+;-!cKdBhPc#7kd3c4dgpXc7gs9Jc0v69)vzALpxqX* zyG6=3g;wQ>|9+(16Sg62&Q6RqhL#aEVkbiF@~r+aD;Y;8)IA4)Vpb)}ikLjqpitZy zlh;t3jMvzIVFJYzamwxP;{r-*=|x2begt@4CmH_fDHG~>g&No)3EsRMe@Lv5y3Z}S zNM?<*0l1TuK^?^n&is}2DX6PZzeAhZj_VN&9bSXJu*9TIJrv(bN85Dw^rX!uM||KM zd;eM*-?_CvIt4^4-PRNWj81Az2a(7HmDH|+Rhn7MxZ{SwD!`_!@h zxDU+Y+`aKW++ilG(hF)Mbx0sCyEfRS?f07ji;QKa5>oyb2k4qG-`F`~&R*gKp1hX#<1oaitQWyL+$4e@0H5Aik2jg`o+B)Wb>bSQnMAi9@A@kqbk$BeP zeI=JG%{m~hh8PpxqAGP>P)K#lHt zM`rpmTlSv>azFuE9nrNT+FUnfu$QwEw+q=_oE@46VMMR8TX;J(w2Ag`vsz}D4uGdM zEuCQNRjE!8p!`k;a~=fXvGHqSb8itNJ3^2L&X|=*50UPBVI#GMJ2^ch;g|+FMAsBO z@3YG+w#Q5Xz6`L#bfyW3J9@W|9m|Q+WmZ`a*`RH$!!GQ>qlZs@57^mO9&b@!?t2kF za;e%FB4T@22VJ5v>fnx#C5Pnu^2?8FmC#Q}pJQ?BS$N{z(LRh1X|udzbNT{`~7( z5H69gLi6#fx(menC3oc~ zk0HB^yLOKXf|pi#CVb=>`xK#4E}uKZ{3V;8?YdaGZwcT;|_r}m!IFJk(#Ma3|DMw4QwLbg6#uE)q@xrS;{9Y~9XM_z4x zK%K`qggGhk3GGg?T*=XW9<7CdiGizUUJGY{F#JZD=g^_pr$R4f@BD;lf?CW4hrFad zzM2($)m$%J8ThCA|J!Yj1t94Sy2lRJGoC81xX{X5zZhJ@eZi==|A4k^AC zL$X6HnTy`%{xd%LJ(y%Y*>Kx*yu#?)poYx&8zirJGxpl{Ih?tnCUczRujGBS2Dl0n zn2q9;CcDa|OGkUXq>ivvblA5G8l{}@k1dMMrUKb*6?0-&K3@w5I|g$f+#2dte&yx* z|Nj{EdNI$f`P`9^n*nmQ(WZVe%C*N2{{*R_r?%47_Lw-&%KXn3{9O$lt*&zCo=*Z= z0WupVdbv|rXT;mS)kD6Av%)nIh)n24tsLSAp78!@_MX^v?#U(JDX*Nn)xPV;@L$m6 z;vMSz<*L&@itik%jzTf#Cf?UOLyCz@eavL=60JKMc%u^Two^0361C{~z~}TGImn9r z{0!W@VxCnxl;g%Gr7q2(3;L@U1UgRGi)cW+o+3jPUJG}0k2~mACd7e|^;-qh$eZR} zx;~E?rI@&V{*nBTJI)J^|5&Vi#mW+4Q}@JY4!LqQ1sY|S1y+4$E#1MwcX84r!` z@?SRk!c-E-Kb>Bi(j>yfaT$?DJRWO1`>!809Oc=we*p2gV=21BggUp7ZJAiCMYySW ztNiQ`_kG+i*<_XTmjngfLAf4Oh#XXQ|balY$64z?A$fs?eUvw#w(jxhuB5(*EUFb7=f=rKBLl3-o?hVW;K zsaewKn@9)hKj~ZWVdHnA`8Xwl zEVZVTC{(gD-t8Jjo+&S>y1uUd%?}>kD42ri z-59W`%fQc?7Y{(6E<0_WR2}*WabTRTMbnG4Zhf)+RNiuY((Q>?nQF}Ly z$|Y+px%s#zDq!8p-tn%I#sg}#!D)bdzo8NRTngWh=UC`bK}+`Z@ftk^tplY0C1)uAxPL8%;(FrBL^Zh;^0k#0gRUq65}rlSiwdIICL zlk%MuICGd&7B{jWAjjyO-KvOb0?7bo-Lt!Rp$gNVkBNauehNa@6$Anz4_l|5pt5^Q zfw`Qqx79n^ zmRho!yy%~ltWCeNa&n#Rxkhl<^x{`9iWX1KDY%tE+?wYr6Fcb70qhcU69iT}ugV5> zs2Q0E!he1(Xf2RfmAZHS{??0;8vIkk!OYtfIh+>*Rp>psI`3oGz}d+>ILP@d&;if8 z=^@5ZK6LcXLtvFZHe2vv@8x|q0mMkreI?3b4i9{jM@VkEH}jo$swUI`H@fX(&NbSr z%`)_!yNrs%4Feu_0PRNv{90cw(HN@9N%Ylks(Se-jlDKM0{Cq60SW4$=@?@*7s<3a z3iS2-cS~jEHa=!CQ1xtS4zipgO7`XKA=<;wB3JSS87%HB^%ESWr#eKBCT#6{8XVcT zbbTec5TI0YOt(jincNDetBTa4qy?^;sKr?YMtI9eP(PT2b5T>WKv!3V%ZNk{X_(NL zOy(5$KQsOX3@1CIXFgWlyaX>h_E+3Kn_=&1?sEo{n?;3udrejhPm!RyP2~x!i$bzq$>cyq7&5DLweeF?LtS zqO&H;hSMc#82?!XVy(`1|K{ajiiXF@n^dUlP=)8hgP}vOT~SQ7=PnDziW%908vC%a zQH4tKnkyw(>zybq)n(eDm3lKzQdk{_YM{#>p^TTe7f~yPK82aqQgJ~>rU#F@R+@G? zP62v!T34F#C4BEOns%st@w3oG?5|_@+)8HC_Vl#6`)co6CSHp(3AfE=uZ4Ukw$bp| z1uyW4^vpSY?C!`s7mAYQw0%P5&#iG5m|sM0Dtm!ph$4qmjvW@YCqk5Vu5M7=VLeqU zAR;hN{$G~QTNzZBmw{YQ$jXuT=vxr5d)}`&qD+dUHV_z}|33lb(Dvwbx$hi3d-lY{ zw9FPJJ{-zr zf}_7?Iso+<4Taw^CzrAd43Q5e8Zvt6-1^{`5Z|NMnSG@`s?qqaX2}oc1C!iM9DXu% z=F&x)wcJaQ4u5l#;6;A#Fwc*NMLu=`V#N^WvB8~;RADFx-mu?>U@La-CeQyR1>rwH zQ`DPG{iF!=5C4r(_s71mgVVj5aie}31(x%l?F`MCC@rF>-KiI2?v5rC3q#&hd!BO- zUM9FZj_~C~#iM5tid*aehp!aG+DT}l-I)F4VeIt6pwD~3cVmaO{p)4td5MD$;+2lc zQslXQs|9BlFv0dXSwa6=FnNgIm~9~1MR#sl<=5T;igq=8jV$IAcDsN44Vx=l z*-rIxq}x(ZE2=|uRmx)JX8;)L`~GzAQGFku#EQ99enmFE~)WwDe;#0tO(GLNt?9G<%A`_8r!(2LOOK$bR$#ljl+>xIL=_>SKqx`@eMSMPJaGU<_?GI zHE6R#^%IZNh*NvO+pAcc&*I=$;nN$lIdS@;z~v}l`rb4X!r6Mq8>I4clz?SC8a~1X z2QnlFy|$NT$u=L%NTi=_u@Yg6I7NCUEv;OUE7yJ^!xA?-R|vZZZ_Lx!WZcQSQLrL! z6Lk7{$>{XrY%w^NDD%;I`rnwGim2+lYY6M-6Q(7PB3=+9pS4824NxS&=K7g=2peN?OQ9hN=fTqqoxj- zM59ui@?8PXP~*Lt5SK7eBF5?g&?1z{7x*(_y6Le~CEpx)0z2tV>X{f;Sye0DQeZ3J zrsjzM$>;S2>J5trv#A(-Kp{tcMq@{w^IOY@th{q#SuaO2z0^M$-68n#*d( z+(S91Lxb4Jr7s+!S?6lys|_w6S-5-0EA5s0v;h3vH9gMpQpn}Eg~ZqOJ3rl+r>m!6 z*xRYfIgI2inKfgtT!x>GpV(&8pRcW| z%h)j~#QmVlD5iI6Y(tlT-Wz%9?Orm2Xd( zVYT{Z-PC~Xi@NQqdBh#zKh_!ubF#2vZUBFy+3=Ip$X1D$rz!B6&CK~6D6>2aKD;nx zQfFV!VnGgRF}yo4``UVqaeGg!S*NA2`T5>MB(Znj^l2h*Uf}RVJ7mG^>esMr;J@_! z9}E7JfbwMIpQmv2CArlh+ryPa-fG&boUJcE@CvSqby=@vdrn056ZBdMJ&S1>S3Cl^ z{UeYw(6-$ke3=2W6HP}lT^Au8Ed?!xe~kbmPuk=CY>KEve1hl4W##BJ&mUE*>jsIu zPWI`p;Wf_B>=jVm-P5(@TAOo#Ljk%YjUxkTTk+Iy%gKi7VdQoXKSLN|eYTVe-tH7@ z+o2xdZ-p5%RHCDUaA)_6_0_}HIu@dG!ib&Mhi%)6Ynd``&}-BygTNH-@7v_CaKx=VQ%rLX6H|Vm_g3wpSfo@IeVs;o<-rp=NDQD%x`Zri z4@hTqO(!}_O=F9;zM4!O{r8IhcxUQ!=3BXg^&3@>>URn{@PQ`p+dlhMzMN-TgWzXM zHCaaR#$N@kA4dJiT3-k1kM9S!xr3{2^4c$hg(63pOI2yLxa0dCm_PcYd>ECo*f+CWlBsl$-% z(%}`a>tq#)(Qmr~k%~WPy5wSTrM<*D&&b&JeM@F|7ZPyS{&fIk?*CKawGv(s_F`QB z`Zv1aDwv!|eagi3<6O~A`=;1J=jXv-x*(p_DlykC`MR;S$;p!ozP%j=Dw31vkc(rd z576^QreOv)>}xzJZ!fL~7$r|JZn9j_sW@SS^JIgGPjS$>W_x8rC~zpspJyQcE!rZRyqO-hpYUv0Y2Q>o2U z)ZKLI&f?{EF5LXCSV@mEoUCRKOI?(6rO1&NmNI-SVuiygLB>JjBAMH;?V&iIarBIGBO}=NEP9fIve!7}-1W)r>6{x=(CC_a z2SmeXQRf5JgA+sv_mpvEYD~W-kd=C%c4Jnc`9_Rh=s&PqeHz1J)5Hi5tw+ppRnHB~ z+hIHK(wwq>3lBTGCs3Ebx)d*UJ4(HcmqGnA0_edh&$?}Qp!tSOlT9V`yp3HR1&ct9 z$9&~Rbxypll^C8wARm=DE|Sm>Ty2J`?4-!{sy)b+@;n0?YpM2P85fNdhzP#;hcder z#&hT|Z42r9yE}(mrm%YLF|E3@AhG55hVPf-`0$9@Mkxpy;nl=czj1^(Pefr}?yZgj zqKY#on>ShWpr9GuRwpT9;!(G+0G*&}_ zB9q1Eyf?D8h3jSfI$a!Faa9Ixghb#GSrxc45Y}%WFZwNSJ2s@k^dcPO+-%2U=}}6I ziNHsM2RIOxgoXSIirR-si~B=)_#Du#|B@V7^j_BdD$-+V^`-6%`WL@0FAu2&jUy|v z4sLAzS697tG_It{zHXRPx)jxiSa4vLW5Z0zc|2r}zj3Olo%kDXDkL>#0f@)5jH#zJ z?)v$?aS(t$d*}So_)IP|{OMU{N|m^id4BwM!gW|ADaVc%-%VLp&1nsWsK7m=03A=k z_u;5pZ%XdQl-;1a6S?nVXIGD9f$iOnUp~g)!Wz7G$5U<;yZgfM*D<=rQ#GQ7LE=cA zF7K-Wu5R@RNQsiV;(>$+kS9-ezaK2~mIY+$Wc_*ZGHh;OBu-3P?8yV`x}?70xFL-p zi6Gv}Yl(>D+d8@uRZ0JTUGIT32&k7?%|EE2Jwo{mqHhF~q^yl4$WZv-s4%=*+XnfT z33xAD-n3`Ard-KWMpfT>)&bHh<*3j3Gr zyPDF+03~)jOt)KRZtWRrdTH^|SZDXxj@fz`H2LaU73N~3*7}L|@s-mlcyJZSZy#8a zBR>;Z$xQUnR++Aq)}dD~`dt@h?A%0f=_ulOtgu?zuxQK^>U7G}RLfkO(@gmz50ex9 zay1@U`W3)MRapEBOtB4BF>qQjLQZnO*h3AW*U%k2oEZL@VrHd^nf`c+_<)=}t8_v}z2`E+ZNykKO<9|Ex3a6Nu-(%#EEk(A?vAbpL)HRgg9j#9AHPEd zTA97@yIC;=^hKJ39)9}9=MZs8r7d}7ETH%5$z)x8Y!{`1KE#e5w+olha1M2fd&7gG z^-B$`jIgM|e1?+F#|SzxYrNun3I3YKB1E!q4!3KTS78Fj&l?Tt1B8m>ET(~Pec-!M zDn&V4^g-iJW(jqpooSw38JlAEC?)5DK$H4nJd-J4`|&j6u~*i>n<_5rKgptv@3&X# zC&e4Zjy{=lgQ@$#s$%DP3-HR5@`&}YPtKj(GZ4t%&l*n#ij-0b_j zMF3b6|8V)6`}lA{r(B#!%1tuiW@hTo0@a1PM^3haN^gHqp{#w@)uFo%t4__A&aj@E zn<)uG#;?wr8>T84sg8fW`?%t6t7%4v|B}LjmmaIS^7qbaRc&vhpH?q1uhDL*5qhlD z0#5LMO})*~9|c{|ZeU{BePbD=_sZAI=S+d7FFW1`+gOInC9t-g8C4h|UleJdtEd|9 z)3)}ydoc2rHH)6r@QdfiUJhMc-Y0JM7WMXBC(_;>$7_5Rw4@!xlMH(pcC$;PxBuOT zhbB+;9cUYj3SsYYindB!hd^^A~ zv&v#Rc9h@IyvC>Y=P`TFLsW#DRMgz#(42+|CXC)Q?ce*96H+_x*bG;%HB#0^pbc)-@nADhsYFKC z*cxLcz7jB*1-`oJpZiLp!FIjLmtb4r-s`$wQMpUkh#z;;ffLAU<3JQPaec(vVSdTl9v|c(5|F(QiJN^@b1Clq9~dfaxk=o6Q-u`ooX-)kp2xia^~8MF zs_Jcc`qG7dsWzr9HsjG*=fF40MN~>mpMb`^Fghc#%{LbQx=xlH>!tHR@wdGwM5(pv zK1u8$x$jl1JP2dpEGS?L=0-79uFla>z_*d4%wU2ycqS4uF4XMJ+#PPyjsla3bMQ0>V- zunW>Uq|@rcF({#d5tpw#_yW&!UXE#&_BS&kzjtV5O!%de>a2LRdO{6Y?~Uw`4BfHM0+_hQ)O`2Z;l*}AsB1d^XSY4Y|S$*riX zKNNQPcXVUgeC}kl-|J@8CR?2fk{cd2iDs))R-M-zYL&(DoBeTPWNhOo|6BG_cAS^9 ztdv;JnGFE?e%EUX^4AvDwj*(Pk57Et5j5EJw3wrf$63zf)VD-vD6qGqClIflT0Y6< zI1GKcMl>^xsA`xynj4;xzZu~9jGQFC+H00gJkbInlZXtj^az?*RWP6jh7CRK?oC zMKUZ1bOSluzEBk{6 zm{y!SI*frp4eHw1von=6RBGqrhIz!+h&ifQLWEL}@CthHrV~>_j%6dKArttII^@1N zPkhOCD04}ZZ0yWwLd!&d%xxb@fvnx6Zw`mPJI1Yc!RG9vgiB4<*SWbywqH6D6(gV` zG~ll(1FlNAphw80rlHt!)#vTNzZSYHZi_u_8|Zv<95x^Td%w6} zh)LsZj+>Hlf>UOpATi^X!RR`oy#l1X7qXE25w+Rf_pv%|FnGA?O$_oY92)MzM7(Q<- zcsR(KTh2*+{cn^K{&&O5c0R2z^X>_`dp~ zsMk%IEpCc_B}J51hmhBrd=okRR<24`WZQMVnK9lClt<<=)gEJ+&iBKy_5K3_Kkj6$ zHi*vT3>XWdat2<)xfes5vu7EXHR_?dJ!6-q#k06QQ-dNDMqwyNz;v%p~ur$Agpj4Z{v#eZ}d0GuKmhgc7 zYN;t{tB{i}KgIopr@z|n@*Sr)H6@8RDR@U9xwH5D9V-tnA!m<+uaJ87%9kM40vb*VjiGaGZe7?%V zjeDa#{Y^l~AIaWxnZF{9o)CEAj{QegTbDDB5!twe*bcjG8(miD<7F- zqJdudp_E5oZADqKfpn)|0bp6jxRJ1S_5`LFmW}zR!P+l*^h7m}_F^xr$;2d7=hfYW zksDH4IH!9hl;xQ^$joogsYaFAp1vS`mVGx*{wq=U}m*S$b{ z-%Mn3NBT=lWki@jb4l_$L=_uEA9s(vnx!WdZz&M}j^Z8jre_ifIF(!=zqWr+`lIJI z#}4GF&%PTe#K6~VhM>u10IF;7w>qsEL(Ws7_aVm>~#Bjn}KImy$RG^mQ{&iSrINd?8781SUHzUWDXJX{Mwm3*r!NH>A8TIo${8a+s@4! zbq@!Ra7xFO%>kbzvO@-T56v3*>Sy=^afxX^)qEDzn{Ltp4X?21n$-T3aPUb^t$SE{ zPcvGQ8x&6{e@Dm=ZI8_GE& zOYi|)04^#jtwSqscgXrZLZCVzm#HRG<6z((4r6GQwGiMBTkwE3EQMJQJmGwDbB3~M z)|&p{4HD3a+%u|7=WgK#g%l+K-zgt&yd4+laLv6EAYD+NvHO;ckB(B8h#AG!ncgWn zdQgjJy)kk3eA!n}O0no~FO-a>#Qr}V#XMcnugYF?nlQ;id|58tm#>!e^jczDY= zes8Nf3NGfAA%nhUKO7EN;Z%MWJuwJN!SPn2{Prtk_GId>|>3sM#=1X8%^nGnNcuz1JWY61Uy%lWy9k z*2rh!^!?1p{#U~;QKK2a#G_uFb3^QGE>tC$%xr;=DuS zjV!Dxrnc__=#)qiOU!>Sxz^@NeH`(N-m0ACw$A?*{V1i3n{GS{5}_|1t^rf9So2@% z|K6fg5Lep~KJsfcgX0PN7+~+ktdc)#(J|K?U`6qY6A{LgVI(Y$*yeC1*3k8|X6B$* zf4n3Fs^gjxU`-h43Sbs)<8Gl=Z;|};QDq{#dRCpGv2uU+6fd) z_Ndro&fi2F`PhZwdR&YOQpy;B~`NE@&OIq*w@3d*JA*`Niv&*h>c? zO!}1%rD!@q;`X%W>OQ|rR`KJU-PXu|J^s&$(YIzmJ-H(q;_F1bT|O_?$|G!=_Wci! z$Y+LjFcgu8M-mVeO$9f`?{-A(-r!)#E&vE0V|ZaG$Mw#zduAbaW|!rCzvYaG7?qIn zg;tUc8_PL#6h?b0y3*TM@8c~@BpREUj^t-h%Vjm zX^Ll<@AYk)nTkXv)}fxTBU&AX)%kSE96Io5qK+&|uUYdb6*Bawso{}E*f!ZXeU5JX zMF4M7>aP^{F>(Jr$9&P=L~N3EN#v9Jo}!_T!0<&!qmvO(H&^}0gS4ov5_yf zXW9gv=QZ^L3A>bkB7nhQxQlXjt7Um&u@3!ek2GA z0{^q)ebOMwaz_&%mTwx<53E?1%53Js$WQ$>dL|ya2l8rXk+Wv_Luq!;^2`)D8~=?7 zk6F~G-fr}q!s)C=p^~I8rq=1r0Ib)xtyZSNjzha@`8Jttd924VelrF2632B%1BW!F1`E`Yu za?9R%EY4)o_7ubIUN^)2Z0F|bDoI^!s{LzW*o@t-fMqgv5yh>aDQ?p>S|KGO-jd7z zW>QZHe>#llX0qS|5<@=EAS^i0lf~`HlX%@ie;l#7-Bt*5F@Sb-l>{D6UrD)-dB%K} z58e5)-8wiLi95;%cDgm6}VBMi9faDt5cW)F$gO3y#0m zr2ZW*shbYO|JN{dGwX5K$xeeqQ=c)t$26Bu^ho{*Z~RL_0*k=boh7x^=n^@AUio(A zl4$)(;SjZy(Ocz9tv2pcgP&cDs#?$ZJ0o3_> zgpnm|NSol0+)EhR_POD>hg8%1mDA5BkIR#XgXM0{KfhJ32UpHU<=r4{*B%{t_i~J& zPT3}LPPhE*lSI;)Fut_**;4*`%Jm8Zwv)7hBaxB$V}z6XK;*=Wj5Ks?RIzv#wA5$a z_Gc#m9(-^fopJXwOXZq=!7&rO;`G`n9?zt^Q3x@8t-B!6BvLvM2RG4?Rb$UZ`Qqqi z&R>U`4d0##Z3TZ)QeJ%Hc%?T2YAAKmZNd9+?K^JGE=OejC`|B!F#4JN&iZB&cKHai zsvu}}@k8{xTOEUW#?kIK8`0JiJNr|bwzV7(Q5H!^&8rlh$m0<u>!y2dMK8^7)7f-bDd2*TbGPpU%ZoKYK1-_+Vq=T6o*mj*LWeXLaQCUKs2|@^PtQ7@ylK zphqD7i2i^rij!s*`Pru@`M0mZ(yvyX;D8lW*`@)H$E_8aWD`%v#D!Lk320 zUa)V_k-E$BCPW^K08CYCr*K9&TErfpvJ}1e8unr~Xgz$FwQ#~&8#P=nKRo@Otiuf#G;i|qI=U8(zd5+)SO z9lg)4B+DinvcmRsNh=Ptr#nL*l5c_4UeZHd{iWj;hDl*}reV4|H2Wl0#EFLyAR~C; zLASZ$h#*!)^j0GBk@MO}UFPnA+Gh^jFBMY2a9x&FtZ^s<4wgD`Q(C9%kA;oxQs{S% zwb6Jdv-lm1N0#0~WAS~%1csTPu+`QGrDVgAx-YQghIH8}KglGY%)?Q+Z*tQgMskSz zBhH+=@5G=bthC3ryUXn_$*(Md+hz0uD$>PHQ_L|SulXlkK4bDjXwHK5g>|?!`c|cX zTe^m-`>SI;v1h z2Y0(Jn#;&hfkGFMMf%D^tgdePT6t1q&i}@y52eibOYZ&jczN+O7`z!o%w6l3yjhF* znfteqFV`O~cp@s9X3$C?z69f+ni->>Ed{fWZNrug>^SR4p8q|}@z`H(-3Y_o9KX)C z`v+nz7*ndNOlx7Lh06j25S8+m&$`PCU*IfB569c6WPb!bd^UL`SN~m$dKKbt5?6Mv z^}%4&)yOXA$)gTv^Zj^$Jg;NV)GYLM_t0(do5nFYy4_G1GMMf2K!}c4hP3N-f=JN& z&`Kj$3DOK3*^^_bpA{!6GuSxn8Z419hY}%jyen(?)YDwg%;!K2&mDsPK;)Au6+y@- zF_+@m88*S%fSlE0KxMVs=$OaklPQj6AO7mp*;S}3=Uc{1nHO+dYn%Mwj4SHK8(%UF zH6mt>BtN~_XbugW8^yqSMzPP>DoYa1nBfTRrG@8RztVhLq)VbY|KdeoIg+oUuV=EU zFA@7Ohw_N`Bw#eJW~5H}a8KmaSrsqM#qon1{;ZU-z^Tm1%zE@?s{B3A@vwS&X&o;v z{#+Y|fIf$kLa+E{he#H1M0!`5_jj+Q!1(O~4du|$Y{4?CrL|n>m8lyK zxu{r69B8Jy2_ZZl&5t$H;k!*~9)$=4?B{d()C9;Npn#?mFS==bb{l2371D88xj^6t z>y`2Xn&ux(tS1`{*Jbmg$qS@J7kv{kMb3%jJ^p~!9pRWpJ>0sFtCoM8`OpFMPB@KD z0UdWcd9!-J*P5{H^YM9wlZj)RsF_XEVwda*<@ne{w~iDK>oo`*ewSwxYO)Y?Sk&YB zJKu5)XmmFEY3!1BuPIm%>B!C#?D!Wi#+n;9oGB$yjEKHAEw9yuWe(LBV0ZtIw8O!a zy?s%q4312cVYu^rAnc(-sKj`b>Hz!vV%YRj`T~+B4;ae~kOXX(UUz%QT51f16$dAm zdwjzVxoycYHQoJ27h6yO=Vl3$6|W+_s7j9 z-h&4l7C9KubI4E+ex)dfF>}yyn)AiD{a5)I)k!oOwJG4XDikrEDYj1AI%_(p82KYD z#(VrTAoohWW8?M!SEY{qa`6Z1%^#tb2d8$-*`(E}qiWCYZs;N%?l|IGK358|!5;*e zP-DSZy;7YW6+Ha!i@>TMp_^P9Dx9i_p8SG91M!`-tbdrx0f<}1>`Y24OyNHXzeN$TV?&N&R>pyz%@|b#az!_jT&eWWY zn0{@k7^8)xn|*kQ$yHm)+stas3A|8{ogN}T6RT0t)j`C0BqCbshf=DF8xJ!yd$vR= zXB&E6Ih}YDdvA2=pwIQpCKvImyN-B{SF>xurGO=EUZW8-yYgrp5qcIC* zs9~M`mD;ovS-t(FZo;*eYr2?=hVRt*gSd+Eh@HhIb)9tocYDdx^*{LmIYjdaroXn} zLLZpJT@o%hNCSFTc#Q zXyGpk;~M8s_~;R0t!{G6`XT<_DHBOg99j3V%fx-&lNC;=j*pu8 zcvmHQ?lIf_T2R9;tsCrfUk?J6;G}0qJ@|^O6KBKS4w@%x=oau#l5=ODk6+n?j+<3YN9Jf80kYA80 z!2}ktEWZO^18ZS^_5{zvE<3y;sqK~N!Urwfztm@O^Hy!M*SGH#(x)eih`+ppR%j{h zVCw`eusuPPE>9ID6PTpdcnKuJ5X^RA9IM8jm;>4km6BeI6x6i$#Lyo{OeZxi<3SIS z+}l>8QoG^+zE`<>&j$bUgXX1whl=)+4`G??%gz(0n;M>;4X$m+R0mOi5UJw3GEpy? zaGu`ylLKEB6fve5&M4yN8Z8h~b?u{{sV8Brq|!%4TMbb&($Wy=T5&%4(~n5qig8=c z{gtOa(@qMbkc1$jj)+RI_uCi?6^)BN3!uJAx^c1pQc#?6B_X1K#Z=0l1+28`!E9c0 zaX_gc6Y#hKzI6{+!xC+sPgMQ03K^~;2PjHb55*^$b2JfW@$zV zOp0U*I4^{?<>1}w)@pe|mB1sB+@X&vYj4K8)*T&LpTWzOx!vLW;fDzQij_{wo-!AI z|C+h|rIZV7AFZfKL0hl*ac}oNTxiiAM9gf2CLL60blJFj@n_L zRLc3wua`11y@NV6t@Eg^{EF|b6b&RMb?q#Rzs&m=;5oWYC(^waw06oHxi*0RKiB^? zdc4{#@!d2b*_v)cg33jMBznJ+EZ8P|8CRMod>(XXK7|?TqQa||_KCC-a&xGWTy-G! zycMJ{8K4xo$tu&86u*uHjL&a{QuI*451O1lb}FjTjnOFz{zybK!!n&|p_yPY)!Xw4 z=NmBkX3GrY=BF>B$f5UJfBmPGumSDiRw!PmYzP&&ToLPWw1TOqKJHQHUl@%pbc0*p zYKJr|2YoI3^_cibIOjW#xMa8H*0*51|1D{kF8Mg~ z_?M#S^uYBpC>m9&;h*Rigr}<{1MPZ+4D1iva(;Fx2Km(yLU`%FzIj_cQt}+}esm*_ zmGSFI*FyJ_3h^_e&*NP$eNBrU)gRbXSp~*|6AzZ5Fgqf1pVY}s?GZx;LE^S@@vMDtHxg^(ZsQ>wV1L!)j4~|mNGfh{C;|Kto3>0e4pP1 zAZBvGzck8VDSOx=y7uKc6Q5*g~@yl?iUi&+72&X(VL#_`Pj+k3Zaq z#4{_&Dl<1`Zv~Iiut@dL*I!eCx@T)x{41_JP;M&OD9{lEN`3^M4uu4cq%uqzRcx=w z3bVU9tY*(s@qMG$%F#W;V|XXa1`q()*!W-wWVD^L5MVwPa^&bF$wZ!K$O7RNPHvr5 z`Ch~eMS)-PjZDgtF0lkPIV*CzVkxmc8GLQKRczi`Ow4n8;2@N5q0thm^>DMJckQrs z$#Kzk$_T*D2Y%BOl=>5pIKbkzO;*pF5?;sRf<_;5RpI&-+e$oGQO@moAq#tjid8+_ z`UG3vcVzGFpwRqK!yJsMsx>C;uX@%(^iyW84$rv$+pR;ytB`?HNuwVtQQd-a(iJ{7 z@=a3f@BXO=8t6X7+Z=DiNlw$sxsRVh$34r9vVjpgx$3@dJS2k9{I@Om*ngwv7j|Kc z;iEU9h);W$bEEiKdJl?9+w=+(yXET z^BqZnASm3HH9@-Flz(irP*l&1YV-KL#B@-Z>FVrp^=J+@L&-d$iI5@B@NQeyQlYwP z0a7Gbbo_Aq{NaI(Pn|v=t>Pat_hdEUz^VzH>0;KvBS^e zG=@f>y7cU+{qBexCVK~$|3~R`JYziuaC>ADbfMK@s0SO73@X%q5VONr?eR9k9{VAX zQL0j0h}hsK8P*>My$4QNVf@T83$K*lxvFe$PBEerul>!fZ6UGY5PqxaO|o$)%|S@t zZ6{8q!jh@q>2nXfmi6u_>3dV2d3#zPqd>$9sAJJeMRJ)rE{{LwQ|aW?5ep8GkG9hc z$JEbn1PBBQ_v>BXxO+69jj?AuiquZc$9CzbXr8o+|I~PHdlR&ukA*`*IyUs_j_59?N*MK}{ISGk5nNO-nr@bl*EJ zG8^#lj*L0ax?Oi-)+gCunQ1Sc+=s*TpyQLx^~cN<78W9Fgnfaoe$!0wIKzti5MRh| zF6{Ncex8Bv9UqYT#)bKg+F$0;Xmq!&&=~)%s0v@atf3;!WEjB#hTwstzu0qzvc54 zP#Ak0_>>yesQzEdu1jhPb})>(U&T!DeDM-YX8$@W_#G%Vw7m4rmvd@V)oCH*Glge; zvgcC{CFoj^e}v{R?UcuImiIMet9~^oY9YSMrK+3UIiJBvg$6=1NT13K)k0Tin$PBr zLmt~bT`&%Oc9D(f@EGcK%?lw8(G&=FYk-npXIWL!pJ>=(#us^?s_P=%(@?5MF_9!; zo|SpaLpUE%?Tn^;{jA)q4&AyZ1a6*+H$q89qxuwCHool3;7-`TIuOrFCI^?N8ltD& zDk9a}9W;WF*^WGFoH9xwvI*{z1N8Fkkgor)+wjyBmUlBAm3{o~X} zJ6TFKciNjv5P54F>e!qTi>6hCCuBe6eE`(0-8lUKIK1af<*t4V}$}UQ+pI z%%#kK9iJKwz12;2d?P!B#_9Y)9QR}5@^y%UqfhC*cOn`cY;a%>{x^L>0OoNu{Bk+V z)rtFj*cI`<_a1!2vkNS5al2pK>+89|NKHtBses1*?Y2A)PL_M|`VBA~%igs30qEVN z*3}F^eGktgnUM6*RCth38c|%#ZqEigE7e601@NpKWms!0dw{dx^X+(RENr{AX_S#6 z5PBEIW#yS{Tj3=%uT!;9o7B7<&FGT|rg~pNn%7p6vZIhNgf1uO_FfVUDJp376jU?F4h&0AyY| zFkA^~e4O0dr*6Yj&{q0B;I(_(eHOu>5v364qxNx+7EQnc_WkS?KeA5P{uL$nBG$0C zjlU-O`eos!OZ_i*&6W^O?X)MaSKJ?h}(qoqaR?whELCGlf# zcP%%`(_^&#k0%w3bI*L*vxHe?zNsJ3b_D6hslG1%d?+P47uwu^$S!f^^KO5M<1K>^zzj_|t4;^uboqjjZcNW#Uto#>eo;GuNvl6^x_0m9s={^^==hBC0$Qe0lq z@N|K@t@+3)xAj$}gVHi1K!xJ)z!ek;pE@iYK#*s{O<}zijgJw1r=6KLY zx%%5_FevQm`*>dbbu;EYSH{oWFIF7Vx7)@mdZuENFE6CL#=gk}CW#t73K2HMr|UOX zvKFuwNxkYgJ7gL`vfx6Fc5wToo#A_DlVpAnbI5#Y-r2+k$DtqLYp896buY>@`WTc; zA?E#VkAc$$Hk7}64^9=t>743R7$5Zhl4ki^**k3=h1(iU?kG~Jjs9<(Cm`?}j^SQr z`j5kmuT@y5ZKY>`Vq|l&A~OdlTIPGuhfITP1Un6qfkpB8((&`rKeH8tuXo~$&X2K_ zK05>-oxFc^@pp)@E zC|9|aBWL~H2Z_s3(kx3O`zw*l>Jw;=IA&a2ALFiX_8%bJv&-)hTFkqafm1?fZ^#|< zhEi!2nBwz)JIVVpJO-DOvxwsq}G5S#px3I4}D-!w&W zsqZ7&mF(^#0dg-bf+gTeSov+a7a|x89ed7F=UO*2wDS^kV7=vsMN@Bwn3%qcv;9^s z%}2~%a{#RYWO$=5VEcUfp?b^2l4R!yWtQSL{UPbqHbqI`^bij{zUa_I^>9has${T7 zo&f7d>dSO**#LV9rxhVaNfb zvc&N{7R#5cmD|#ETL6wqCMiL8MM#98Ux9(ZmA$|~+F4z6rSDqfCgilvC)8{861N;M z*KlrkR`)!A6V0t#9%T@kSU_5YHw%_AzpGVTf!AGL!_0GawTwQ9i?E2K8KCRiZD~Bb z*-yBi(h2EM{hV5Al21;=Sq-B#?b(wD%0ekUf?Y$w)=gJWX?R;*B zBOE8jP}^9=oNsA$3$aqblgP^Bl2YK`=)4a2(N`h=z!GCGJl>o zPxr>f)?bhAMM1d)B62VM??EnyCX;{^wOO%nuGh8D;k$_an_EEn@4L6R>mlFqOeG?3 zq$pRERQ5Y+e#rsd;$f&SR2L!#@y|D2>~USRAhO>*)KloEwo)V{AEbJcb415&h-2W` zhWmAAY_%nPWR?#sqXE6}P~!E(dp54PJ=riZ$55quJ~ncjm6XW>WI39nAHBuz`;^RhktwC@$tFj%Q8tW7l_h<-FQ%-dm$OB2*f@ zJH9tHWmYhMHP>ttzi}05a-dEUYU(j)UcK~b!s402mamDg=m5G_`|eT?e_&5*o1eeu zY_ywpAwuk>zqTMtOyvf z)=s})ja90BHAOETC?uq_cceDDE9aRoWoMX)hMwi9J$-BzIR4XK@HEJ2!jpY#>Wj7Y zWi&9r2>IY&sDq7tfXGC9m@m76k9YpkSO*hvbTE$N7Ie}H?>Zy#elQ@xNhA-n>%v-( zN-YhuTKLf{rs&*}K2+h6AFdxm6PZc8AD?zx|Cn-<-;OC0JVf^Spag$m*SRm_ImM}* zCGT1CiVC@Lsr*1u+MiA7$phkB>A4dJoG)7-K7IhoSOn~Rg^u)6w;hG5TqG%x3!;t5 zU>tGar(2(+@>85SkXlU~r45C2Q0=MbG6c5Pvg*9@Q7nD7caI&bB+P=&F8JHT%?mbY zj9ulgx@93b$}q^VxR&_!be-!b_q8mhX8x*-)q$-W;7{*q;(1upBT0%5nS!mmo1H|_ zw>HWw5HE(%0K&UrcxL=gM`4y7F`@It_{GR-n-yBieI=g`^a1dHO?h+m)$%@WEL)Z? zMD(Ywh0}=!0ccX^9rMy-oH)zu`NX^`#jQ&}R{6(e?ClMhHpLBs?KN>}Qy(->cnF+Z zSvAm$e+a#)x|GdWw8UFd;`u%HWQo1je9Do&vG_Y@^5_M?ipQ!iS{-)nUr2XiPVqWP zch&jRby7I6(LCE_?FAL&-$2hcZ^NDo^}GB?)uIHXmNDVKzz4Y7!Jo5b!S;>{a0yF4 z!2|37lIM}}WtAZQn$ zs5wVkS4ATu+N09OIMy1Af?X!(Z4%JnyW0NgwEz zYsEfDj!KSKQji*83Y}kbdqJ@dQg^gGdS_RC=Xa4xiQkKmKaT@Pvi;h-RebFVX?5#U z-0T4ziuo)XW0OiNArfJtO@ReSiVunrD+=s+GYgN_A&(1{P2vwmZr$5Bue;oOC(ir7 zfwcqb4RrUJ4l^_X;;csDK=}7dr@S|eQxtni;Q%H$IE7lr@b6DR+rKXaBJ@ba4L(&0 z$MmLpJH%zR^jpxURAvj)YU*5wdQJQ)1kl;Cs2z!1o#!dbR;O?_M;>I@;;EOK0 zlKSerVviifr&YKFnwVFkpih+6Tt9_@%`(?@D4c+@@2JwHLdv%@Tl6E8IaBzg&cE9)*-gsGyZ7O^>CqkO^3y+QOJ(w& z>YA;x8y+=*T|>`;Eq8ylfg)E+Cy$t`$W&66cT{xGE04gF(G0NWFMtCicMFX_%m@8HV9HFlyD4gU{qs+6dvl5unaw9VesOT!|(tS4< zL~bty6Gxir(UIRl_xf%>5<-FRlnM^_%p+k;#!!S@vJ0 z+Sgv`UMad(Z!y#1XHW6#STTN@P`XA@z0<%ytMt_Wuu{o|KREdNs`VJh%hpuB6WGGAVy^ zg|EMI;DJxvfIRzP2whZ9!QM&V-iP>)){k!)LN?Y-Bb560068a9+8A9+S=-3{4Pa2Q z=DZ0YWLck|TKS8{{DL*zSGq!e!~!}7Xk+HcKT*eYc0%M8u z{t+El_)x)5FWGmRjh<0C2pT_NXwBOWE~2rtdkj1mnvH*N$X8ck?{YsT$l&Cg=9T|T zRgAZ}VuZH=J^DLzbdg+$%=GYzG=MCBI$+E-up zTjlfX5boR}e%&+nvcA&m>EY@pgNnj2bvJ8~xe5+|40u~~&}e2b3>e!@y~_AO^G^uX zw_nMN=H=TbslAukD{a0xBOljvm^X-chfNGi?tUhJQJEJ!=ptju+h&5~oOAJ*9ik${ zhl9tDqUFnx?ImT|eskg@23%B;&@q*)Z&9}SKJsvAD6GXC)@d)~upcA*bvr3}AD#Gndl6}d2lq|w^XmnCYrctVY z9`Hu#^uxHk;VM-PsARyK{`V0CivZ zZ%(Bv5nmS(;ouZ#%|4PGnqCMX1~fqoSIqg1wE9o~8lK%{@!B1u{c6Y;WN;pW7(gHS zG1s|F-|E3kRychR&|rX4au76 z?G0_W$k|nQALv_6QOCDtbd@%PugU|B&Qk)3;!_gs4jw$G6WRqQH?#ML*CrkY?j1$; zlzQsUJT=|T!>{>^IQUB_F)6qA3}}Srt6Py+$}hjcv8meDV!}!{Ij$uE;m*K1gT0@G zd_IFgXA8*pXP}=IpGtcOhxLV{VejGvZBqW%wpxe0{YWll#qMV59QwJJKV9X3V!i0K zGIJ?ecMc`LWExY=lq%Sw2DJ(IcCOAp3pXBN>2}&)!}%iA*ev4ts2ZWdyE}YV9rt8|P{d}=HCDRz=(2bj zxKQ(_5zKt-5_-DMEs}$$)c0t}@HiT_&d*X8un&(-mw=A{^4ewvLfL}@7PtvuKL0Re zUukLl+pKS^dv$HVs3kMA_j}mu5J|Izt&NZE4W22(1x|w%#3yU@d$=x@NfnhVATm6t zNTNwud1m|WXMw?Ir#s&XrT%ZBC+molD}4aZUso2E0xD_GEgQeTlnTIO((&=>S(2Ci znsP?7j_9egUP6|bQoyo#&t0P^nHTN$|G_I~4O!8p7qU&j>aan9dJ!9F7nu1lJ53U} z$-sQIlGF9c4)FB!!{tT7P}b$b9M8ak8F!K6<1P9|t%W^>1D|$Wp3~X{cY7_nJ}oM; zIW0aNOBK`ovg6Yb!75Z##K`#yL4Ut*ETZ<2iLhH#Y0^XGpti7*5(~G8bP<2Vi}zh9 zd7t6ytB^;4lOCO=ql;N34Lh>d&~E#VyRmLAq0p8^vwjWq1usPyce0EE8E-xQhQ%JU z3!c!Ub`Sfg6i~$@m6hLU?r8mv({GWLWEy)iBWEHZ5vx{cdAkHI6>el9Kxzkl&;@_eiCypB@c$&8DDH)>=psG zneFN*8P-R0s_?X!=fjlWFDhmT*SN1CS@Ow2V*#6$O2=K@s|gU#J0Ih90)105q%c4( z#0$v$sCGxI>HvjLQ9hMj%khr%qu?Ku7AZ;c03-pk8tB~Hk>ob!#wLSf7XsHq4G&ro ztp{nW0TQ!PCRM@^1?`c;iYSbsPEuvw{@?bo!gd>jSdiBktmGpv^ z3%<|-`$61tJMnh1#rO>th1>67IyZAYLxE{A)7)L=Rq_e;bQ_A2wp#lO?wTJUXTDM!o#FB@9f}%^#MQUyi$DPxdZ6-vz3)^`5!gU_^bh5sQ%G; z{CVenY5vp)51nq_jBpe9tij3k{edbMlWuRq^HkQN;s0Jb-Brz}zjy!pjr{wGFC=pS zpI6wfJu`S++0kYInG%G?BMvP>N~7F9)66)+flDb4T12G&tY4&hlbn3>D1_2@~f!^o>gdLeWGYn zbD1!^0sXSrS7P-e_m5>k^4I5k%h3Qk6hyG~&YhjlTMG)FkE*6;PEw86ZX^I#16AL} z3ZzcDZ-;}S*Ew7KOI@*8Io$A(t{<#EgOHm)>q3cxZ3Ok|da zrnYA4=|Z5{8vJ8Af4bT|_lJkLPaDbUu7)t*#n{VLOA zJxSXE1ul%Ak%g4aoBQa#kDCUHT#Fe}mJzzFp&^~Bdyrm^gXwSLFhO9+3!Rv(;?605CMbHsM9~2 zzgwL%6rl_{*?Cj`H!PBM%c05%e^f|ocRl=+&Ayq9^}xAzJRj8KfP<&e|4k_hG{uQpO8O{_#@}BsvpZH9>ppfNk_NdU-*;LPP%8v%MNQM2P@47!?zcHD7@wfT7XlA;iX?9X#n4>$T7PmFh1Pb;4H01LC!_4hxQ5hFm4V z#f{;i94%BLIo==xt#4+|RtA|`d`|W%3%!nXr|XOEORH`NGe7nTyO>ot85D5yZ2HlY z3o^P=mcyYr$ga}AfegiPeOH|<1?UTy?yK&XsSwz zyxG?_@i-=6Nd@@$t&++*jCQzM`Dbu0t0tTojpAnuWm z-kzb{l{{q|K_f<&EQ6%ZL6cxXGaM!MaQh$p3HL`(RE`Tro5ks5;Y=IUc3OaTp=L!b7s^m8r)`SYy0+uMOt5aE>3;U`9R?nReal}qqKfTF&Sxz%jG>i;y8&yasD-m*|0UeU$=8Bh0=H4ika4G{d*Vo^npHH_;g6UIb=5O zY)U*o>H5^pj0j2AD2Mhz`z{a?!1q6n&cd(h_x=8FrIZu_kya6r2I>AN0!oT>H%NC6 zUP?`+M5Ki&2#9ny114P}onrzUy^$NNetds_#C<*P>pJH=57+cN!u?Z)vwPgdW)+_Q zS!*@F;7JTS-yb@UjbJyhkEGFVP4X#XP4AsV`K>T$7VCRWD6b$5^`RVyd9eRJ~j zNKUw2#+bvL^q|x0s!^jv0X5lU6y6+F3MOTQB1HkOuPrT z;XNAC0n*Q|HhMk-4p!Sq%nR_89b8w43rz7n@LiE_4z!_$A!?LaIl$0gzn~Q15 zXyf#6lVfV8>kRZ!^tShJQGtv=Ie657bj%8Vs%rAFdRBSv7Z`1Uv?Ud0?o$$wcoHm? ziTa9ED?81H2Tk5Rq#X(oFT!Rtx!19;C{0LI-4)lX#)oiBu-l#NQkA5oVGHH`t31a4 zz7FqONizmxLZwu6F2N(~n8-LMS&PW1-cNxGdyynh!B&&6+ITjb9nU2eh6+F&5k=%| z{@lf4Pd_6J zenSpk9}+A}kOS4|D~nL@NAOr*CBZS_UUPGbYfh-z#TodZ70UOf)?U+bT{k5 z{*9o)Etq@A6Fa+i63}v)hd{AuNFyg{6||~?RDjMxVP=y^CE6~Kp!jk zch4ovwg|7se*CK)+?Ab(qIj4XELCUS_rMc@+W+o3hpA-VnzKh7SBNYz^?_74ly@Ji z$4}-*Gave@i`y_kZrrNty5?mDbS?ik8qwlwkVu4xtt{M77VY|M3;ZY2xW+e4xtChd zT}hFpTJIVyT{4;d^})_}+c8STwl5IOpP-M0cQ8rrB3xFF$(7@T4)zIl+|da;L4%%( zhkM%S!Fm4f;QoOf)S(}K(!cCrKW_qCd^3uf(J5~>Cgm2}cT-FTnOfVvBfZrXp<>VqDh^Nc*4xPtf9 z#so(M-Xv@e;`3qaL_G?Rac+-E1x5=M(NMWpj6B#_pd4cSE%?wb$GHRQA7`%*nbJ zm|SAv5#~KWS7IvM${Q9VnSj0sMoURziQmZY8wc7p*9nX29IhS;IFsJRdkQ+}D$GON zE?r1niT~0mmC_ST;(5kSUhND~Hp2x0c8chx#S}ukrb~MYcK;S9tPi69&KoB1Rfa~b z#A3G%vxXi=geMyYzhWEHAxDNNmCReC7N#-R7y(G~_0ISyJqvni4Muu_$u!rkBl>zz zg*Eusx7ITc^I?AIfY&-uZL$5|h`Id93+U&`v4W z?6Z9-U!D4OcH2sV_y2Yl`-Gao5((-guNxwIMQlT_B>3Jd`Ot^GvA-)uXPzRoFZFKx zz^$6~02{kP@`ex{xz7v#Y+AmdiE$5>_=H8A{`QmL!waxP_Wud1r-xb?wNoSv; z2MhZq-NV9fa|=GcqfHKq3H_16aOFf3+DbC-6*)wjY4&uF{!TE5d2aNzi#lp*-OE*( zn2brj(Mi<)e!yw*sKzzqrTnET8bA~8`x!-c`KphdW1=<48NYs`tSb7rzH-S|mYnXa zg#VyA_^9E;^k4{>6T7MVHsh~G&~PEPy`cb+ASZz5cI;gvW*~co#d^0+)%QZVC{98f zo#WO0ylt6kbT$^hQmVgNI9t3qcUwZKk(ngpRk2DP{@HNT)iV6#+__|P6VT&Wb8D

7?YVr^B{0F#{b~1S(_LR6$gx%a>#|Lj3Zw5@Jt&3ATMDkGto?Kfkk~Kexm37oR=L(G;qWOfZSfJ?^Lgc}Ct|#7>)Tv+=>b%{j)z@Beq+|% zgg@l%mIAI+ScAs{anJ@n-;@!9Y&_1SK^$)7rvCHK+u-Qd_yV8SAdLQDnu2~tXp=^i z?~_>x$Df1$I4%rsk9=wJAAQ#qmi7njcazwb6q9CYM}lpb@J`3NU=qRxC*zGs2vxZ# zF}?9imfBS7f3I1>0gyC&E`!xx8RVkrm>+@$e~opw=&JjvrS7lJV4b)}+~nfx38;+h zxS<1q=;j&pXkrJKwEmuu?;0J@0(_%Gg^BuHSFwM_d zeLJbhxafE)fur|!X(VlkSSXFc_C;q~95)&d`}jSa=m^Gu`OkZ_cfzAxtQzkebTn?d z-m?h|uJNSb3R@(qMmbQRIk=nP3jes>@X^s-~~mbJpHq3Nug%OgYAGISL;3 zH2kE{JA$*$-=ai$#gso-R=Ojz)I(>JjW#U0{B_?tdTi1Fd0;$VzsyQX=jrGBQv=tc zGwBWcH^-9#*5q9@&)8^pfuP^Ye^W60jy=O1!8mIHjdJftih<8sZZeHo75#_;@50Aw zk%UqMHxJFg>$&CQH zj2^Y6M3)kk@OkiT_E6G1nGkg&X6roQg%Wqbb2%pt!avlEs*CGV4^Qagj|ZQgp7n+% zVG;)b18Vay{xtI^h#$Q%gYxQ+{2G^|K@y!K$|!clBHX{5Ug1>Q3tQrufU|73;X92P ztC-L3d25`%NL?8mO>C+%3#20vM=4ymV%mTP?zrVX3N9D?Btgq>bSMaEv)y?;sD(eS z1Y2c#mS|6I+=`~Rk6sIz`A__)vo?cUAP5ay+znSkZ>G6evWv7WMShuY^k*W3=j}`_ zV^Gs9%sEGsdHWZw&5JS4xGrvRWoQvSSEL9wRV$#;p)rC2O&CONR{xJomWfvB}ZruImwP zdowW{@0kQHZ!z+*HcOP^ZkI5DG2Ub>*Kl(UU#C;_q07Txd!?UX=X?$0aoH&|AibTV zpxrNpufh?j{T)Nyyt$+1y`kR^1^}1reOo~`1RW3E@?+IA2@{o_i}=g=xlOr<7Sqo$ z_igf`K?0VZzcabgYb_5LUj}Nk03~$Z2a+eZx2`S>RMyDer23ipPwL&TBj>GCV!|}5 z9zG6+5T`)Ko2SHo+3t+=bHY8+B%u0;CZdY$}ZL*xjdWCJd$pl#lH z=(18;|3FBM!Vo887@vy=!c-rtw(bc+pGEaVOj_tnhA4&HVRtyXZ&@>RneE$A6Q2o- ztQP`yiS-6q3D9n?^k*05*^VK9$a;k}(T7_-9O)luKVW2b_{|}GAN4~kY}RMA`?-P; zb*2A01bZ{gQlXlMour-M{!s&De0Un?;)Af65f$92OIuQ~YOy=;L@uEgUS?t04tM{a zlgv^(P{l%EE%a_l+0wOR?6misdHYWHuVBClSt`M;ZqT)WTp3k4D-UG|wF-NjSot?7 zB=*_j|43~14bD$}c6u(z`x-L0)I~NadBz=&_NKnOm}Pb+g$4*3&*#l)AT0Mhy6y^Gqf500r)_~r&_E>K&qm0?fiSamH1g?rEf^wUF%sgK-W zJ6cs|fYviF)6e1vTGmQ>o_{V3orHZeRk>Q%WDQ(~pSGS%4Er7<$7$+k9Lh}%q=ljb z;g#ZqLin)4qnq)c1>aPB8SK$KQri$xU8#B5-H?ba^q+Wi#Xq=g54sByaw^f{Rq-|V zg%LXqv`#Gou0?o_x0x|5EPc${Z|9zVb=TmR3?C0nl58P+54HC3_t|GI{&DHUQyqU+b4HAZ*{n{?(mOj zyq}p_yXe?1!97OYJMuha@s@7APDn(Cej&xp>feoDRBF!eyA1aVY|?Jq(Un!&UV~i!U2p+f7FKX9N|k zAj3?v_08&uf-6G*#7d9fDOPjQtG9**%0%EF%vx$mhN)hUv|mD*fK~6}RKtij!p%$n zC(@=i=5vChp@1^g`A6c#g4VHm&G^v@|NRe<6vyDV40K)V<^y=2A=(c{0#`w&F+cbfV zg$KsxMb$$g1bG9H))~(!D!Li}$+~^byYpr~6keg{t57M3rh*o@6SLQ_Hrcv!S{N|b z1MqO5#;iq=q~KL80cg7D_pS!*NOu2+5|fzP=QEmSQ2!4uP)x|{3Vz&XV2<39wRmKt@O4C9Ag|{JDotG_ zL-fQYxRaOg;I(|gZkm_I=XUMh8m+*_Vc|QMqtF#Cvi!e6TVbgEM^DxEn}+bhzq(ua z@qz7u|14IV%G6rAepi~+#)m;Mj@e-lAi_h8-(98) zM1D?NSEM^w9ahhxe8lrM!^}fpup*-5iCNs&GlyXgj@HG-q4@pU(N8TqZh}EuK`%rv zHW4C%**z^p!+B$zHh6enUgsIvPtnstn2({#-KYB_fu%*D0nv{csZmO@QBnmH}6xDHyEkgCN4DV>2h_)Sl-J_wp+w{)Fy6%=;S~c zEkqTwf3G77y?N$5u{PNrOOhN#SV-9V_5Wjdl8xBHuYI~G@M}}BeNO)0uAULo7FtTH zJj_Ws7xM{wu!<@EpawzquSd5FD`Znl$`hlpV~VG6@NfB+US;6TKO)B|nf(Aoq?)cp zNt8`Nz7wet_iKu?n>CA|ms>)2zQnCy9qdtl+@^rgv`tC8Z2ZP*iV{jtfz6a zrT3w0=Unr*(p`WRB{6rKnL6rj9C_RaRfr>-JAsleMbV|`SIa(@>@3b9k6%Fs09o}NPuoNok-rWzt8FlvLOOMN?8WBzLVvb}PK2r>Smp z4Or}~tnlCDFiK01VO%Xg1u^Tb8Zw0cqibT)mt^oW1It%&7(J{nO4`XXZQz$rX|Ppg zPUX7e?{LjqpX(M3A9p(Ovlm=QsW1CT+OQZkt#CAD1U7?}Hl{PCV+fLt(lsW$ma*_c-Zt=#jay!f>Mc_H{`_37B$jN1dm2QH z&hz^=T)cI8o5b4a!fI(?U(&^s8rcB%q29mH`4O7z!|p80FOrWGG0{8-FpZT3kaqco zYEnQ=senq<7g%T>{Lh*HT9hm%lxmKINpXF0WnqiO zLuD(ik<-F7@Z?Ljh!&f&(z`Okuvb^c>TY_IG6XO73|>KzgF zBGzxZwRG&h+g{^VcrN(n0SFABEe>=Q9?OfwBg19@*)L@Jt47BLFBNaZlv*2u8@xhE zkg6kv4<8G!PWq1I8)u4$5JKfr5)>SX&M))KYu$2)!3&C_Y(k=kqh1t8q^=>A9~f@cG2 zTTLdGjacDAlL}0Z8hPIsM0RZnc2wq!mSY^>;Vm^?ws5jhZF~hw?b2^3Y7`u`eih-qQ#38K(T*?Z9L=$Yv%U1uB&jYQh zeL2oH3v&WLNimr;Fw|CZRN2;ZG|3|}`n^hz0<9~psecBMBa`UL|~+{lECtgz=)u#FMfiZ^N$ zsNLGa#|k1rP{|0a=21Y{`tg!@lN~N1zlbcY5a6flz~n6#r@BQ`sS<%L_HCU(SRyc{ zw#h1x+xZlOkE@IeZUR<_?k}PXMltZaFA>q zHd$X^;pTvQ9A>q3P5ZH6KKTecdfkeo#Lzyzxw)S)V0a?uY-kT-=(ri7q9X^D-yxXp z_wcCXsu}cVQ(H5vK_aQkB+4daEPs? zdxrUryC1}ffTgw2edx(>;rRlE9R=;gy=K=Kt(EVwdeV|@kf=;pqn?3%R}P#;!E)!- z02>^&Irrxq(+L#9o`o~LPWd|aR(*v`MeWeOY4tJhhIg~TZ-aYb;q@nGy(?#gb<;HH zL|CFaxFcu2XDukiN7Vt%Y?u}Eu44HRq(G_88vv{4oQQhh%1UdmR2#B7_;e6^CL9&> ztzBUO`Sg}(6Mkqy824LSo22R=R&jvr7;ZzWML;Y@A zy16~gY#7yW5LWFf#z$2cesj{a=3ETiMs!&?wMNfaEd=E5Prp|9b`MsxSe9ttz^* z{T#@1$YXUewvM~ky$It=FJkbB@i$C>t|ZP;3|I{Rv<%FhA{ggaWTX;(Z#_QKt-pjuDu$IQ%o#^)OQ|wjhN2 zBvC7`mj@y-s#1bmmul-^(-JbvrI;7ozo9@AgsOqz$DC76)~$a*LO;v0&I!oCuJ!6v z4A%vg(53Tr#dMl-lpgTbJ1YBJf1eBjm^He`{giRc3fVq^X645))9NZHI#HPz-3|wXu9>s_u4NbNqR-cQDs+~sKRL+ z`gve^1AZIquOm)Aq0DKX3}@upsS<9xon(S|O*gos^1?_>Y-gqA;A4@}nB?K?u~OA#V24SdstnjX$otdH}0&{C3` zdmq1Hna#(}#Tx&v#twl#`9QXU3kbSAUG#WVHlUyBHTI&`P#&F1Fk1Uu}zkC$o8)Q@D3 z9N`Bk`iP|;4$WB$AfRiPtoD&uVxO0wZist|_&xPx-wv+*Gsm5ImbSzpt_Z@{s- zzex@~sH@mX_Tuuz7YqM-I|qZio#$p7e`RZzcgBu3V|gmz7rn-u%VFGQ$M=l_{6tlN zLMh|a!jQM(9ej?dV ziITkH{jK8`FQ2jav*sOK*AREN7*L{ce6K|NxR2e-p{8F)hi2WeY)LD;r`gh{9gir# zZg!%AaKtCfXgu!fyt=DWWtTFvEYmClEXTC5al}p0SRu7Yvpl}Il$!B{+mz;JX^PAY zX}V}T<{K^6zPcac6r~}pl&^>pCYmSIHjVdI0wqe&bERFmn6*NY#HjTG0N-?QjQGzA zM`IAUqlD$mN`tot$*UNr=9V zz|VeM>a98Seez<_e2d-9&eP@{{P?L#1yvevqNPz;;-`#!wL_hFGH4cqd7D|b@<}Wa z{VQtAw+J)Nl0{(P1DZS(7Q39y$Nc5L_+@BEwHZf8KwpMF@&*oF&GxD7=~ew_?yiY{ z5!Lq1tqsL$h1-aDm5Xqw1*#hIZ@x`S^XJk^eWhNzE6QCL z`McTGAIoBz&s9q_I%3gvB(IXrm>hZiz=LL(#82_Rt}CFA6Fqgq{b=m{guX(%50j`s zZW~K4(d(uVS!gaSY)#eS7h;(I4E$-2VBGHMK#J2C$nD)Iwdt~Dnm@ZUVew?hJ?NLK z9!-HC5L&AbI{LPk%Mtl9w@34V$eLL%kie8CnFxKNt}47f6bBi+%RoChp?)+?PZLqn zGI~AkDXQkRhs96z?aM9SUSy<+nqWRJnZ68=v#C(tZk^scH8^-WpP_*7eChQm<6&u| zCnGKV$T+!T9-JF8Y2pJ8AHR-+!u1YUexzVn zm+tBLty^1=Tcmh-r>+-vNALElhr9`jxhLM-wJ|=gX*p73ojL!vpOr49NobacRXZc1 z?3P>c`*hq%jPpdrlAFZ2EnPk}aKY!_Xak(0zgTZpDwN4zZ2E(t-yL$A7e9A`iV6r| z7vgR-oq7rpN8X2z8jmPEQfeWjB>A!Ptc*j}?({MI5YKm}3 z$~Wl5bpG(x2*G_`FG##BupQH$cBGMAuLN`C>#l1)+22jT{Gn?{p?hP070<{ZW;PDW z18Q5`_iV*zvGytd9*66r@#XYmYrq}M*<){iNf8_OPowNU`QPP-awD3{&aUvx0x-Xy zx@33pmn%#`P-ECuqW2lBcJru3L!WvTy`Gc|OF~HQEKkWJN@N8f`iS>oVnMupySyAo zH~(3ptrv?!m45!{7)=5MU*P!%&2NfQuZvZWP{S2ak4BR{8@&IVy>{XUVys||DNDw< z{a~`G$htH_M{yF-!&-KoD}3=l1OY*qcXXK?IB>Q28C$PoJKWZqz~&?R(0RIimyd5M zW7$_O0-xU4aSTvL_3l0;)kc7uC@TBfACL52xS7;4ws()jCPeNzpoi6~yWUCQlP7JN zP#3{Rp!iI8HT$M(skT6Uv?f*O|D=8{Mf^EAdg6}i=mCYOJeWt^UoykmAUYnMq!>Fu zRCVZ9X;f=qe*(L3~&+zyB6fqYSOhSJC=b zq<#1Ni`sGrL+JtTxuexUFpalmhan)k;uNYqz#{ic)%_9E2`iBH^&gejTxsPiFgW?< z-8}~UR%Pl`++t})*+maZ)m)^a2UdtK=w^wLn#Bx14j}^)N^G`*p{zYX7 zddt>OJEvJYAUyi{2oqH+^0Ss<&o_*$j17@PVLPHZIty`=cN0lx9)V@35BoBfb1Mg5 zaL2c)O(~T84WBfh*)ZheM{kDdMP!=?GWLkbHIEe&*d)TBsP%6s#V*g11;o?Innu#~ zNoIxT$HWa`i-SB1t_bAQ544eFbgNb~xKGSnzF-U}Iqos?9+JW}Zk}<4Arf3sTWK&R zy6PQ)KBdo2uN^VNXjeFKJwrF$sGOS+LvEl`iKy>EWCX8Rt4_0u^9t8uSV1ap+!jp2 zx1Bpa-w1zVi0S@b>sL;woW`Wik}RP{=i`s*3_iw2tIxuJ#cF<}e=^Zy?a}KRj{T9r zUknI!Uyh8B>X`-posiDbMJGdrSA71r#@pnwXEN~0{UYxsp5m2ORQ>7(Yc5ceHUsz$ ze?duX28@9`_01hNdi)})4NTZIBhZq+-1i#E0b(mHKY^H&pUldvsk8Jp733wuehXEd zF(^u&jP3rL=5~iK0T|@|b#G8DBN_f51Q@ZD2PxSEN}QC+f&9ITlyhs0Ui*kv1_r=I z0$(XZEsRx{$m&Qhp&l;HK{mAn=^4)3L-2=`;##nIrf~%1T1R!qS~pem<%7oL&gUBc zbG?~7cOrD06g|&m5UVe5#rCPVCg!y_d9MF=A!z2ActlOE)r|^t8n@PwgMhiR3~+~0 zA7T6`dtAKgJeDEmxkm=o+(e*M0t|YbpN_K5^o7ux11p|}p$vKbj`QCEL7~=kP^fl! zj~8xl=%8@(W?JV#4datA_3HL_@a%eCxV7Cp7RphgyU|`2v`gKmT%+^t`HjOfT;5BA zf-IRWn0cq4h9~1E(=SB}<+bArfFtk9MkC~|s0yN!;$lzlLKyXQaB$Ew+KB5EpIFIr zzo_=z$1Sn?j`t@0Wmdl>#9FVBlTUTqsl4FIs+oOQ3`s2M)6zQ>arW`?1n*i+Vj+KL zRq-BDMM3?i`;1=rVp55|lRr|VOKj8c`yNl;r}^;gkmk=pUMUh?@y?MC0VnrfxxGp4 z(%I9du=RfH+o}?M#m?ZWTnz+qB}Rc(4leplmi=(DgBZbf(SCPv=HqeG$ejGzhZiCz zzXZeHOw5Z_WLmp?!lwE+-)KA=_v2m4t|3S1b$;`h6W`>A_Cf7ENa>Tanpt`Nw!e@! z@*t-U@u~Q`7EfIcmiS}HzLE4?A*Y>h<82T~_cAwciW zjqfE$?;k|2$-dZN6N)tL2=K0+KKO6}rs*(=N^S$yI!F4 z(6xzm=;deOMmP#Vqxh4Ln?u2Q?kEX6P9%f;pCQ`Ty0QOlDG>~S%Y2nZ!$zr%>y;s6 zM2@gRI9*Udl>a}@Zpu6w9Og9bO6VAjso>DH>ASdOiR<)EqtPI$%!^^Hr zet2Q^2OMklZh_e>ggK?1^Qxx?Y}U2g$ZsbbU#4TGI)RC`ZE${e&o%vI^>O@)NY$a! zfAdu%1ussXVUy?2tf+$q#d=eZ3V6jaUzqx)WNI2CU%&XKzF(8?{qn?MRIYNL{;k(% zQ=tFK48MsNe8ao9lmrkv5jo{<8XkpSquCivcWP0ED_b&5a;K~9W<0G$!$0`%sF9|Q zS4|WIFMw2<@#0ma453&GB)2>*6Zz-NP(bH$x^wwUq$Pqi$M*7UVDV{0+xO_zOX)Ze z`S?cn&!?!-pM+<%2+w^W#`%ik6Ml4qtJW?Ag=ffOMp`Fhej@xR}wX=FBlQm3- z0G7eSlc`u&zX`8z5$o9a?1Zs|7RwU7HTmsmd0!$y>ek^Vu#36A)w`j|K;?4Sj*nA; zePOHHU+%f^yI7;u=}SVoRr9moE#-UtRxo#IlKyQCdjzljbu^En+h02ceg(%ohRz7m z2XhiDDIPA-w2oMVWoH~P<`IwyP_+giM}y>N2@b5K?B@(q{RknPxMr6(HVcz{u7unvT^rfjp{{@iorkFDa zAHDp(e`vxZ;Kx~looGW9Psym$^BI1hH^gs^hSyx5&?i}{&c>r2b|S#@hogC-1Ctm1 zcC<{8Xxcs*RMFkEPz=EEud2=!1-K_SBiQ!YF zv|NSwS^nd9LP_W`F8D!XNx7}L6iggS>#Z2G)bo5<`Hgv1eG=`?RSo?6UKXo1-2%L4OBx=R z(Y2wR{B)~3ANr+V1sF;%J@1W99ly!!b%#Gx`G1yoCfWmoGO0kG+ju*noJ5p;JRM(D z+FkX>;v(edTCbzBIsikaR63ig=#IPHyyt;eBcl>PPWFzMq=2gsQ-Zq#t$kdF#HAy8 zEM)qT74n+4=IU^{ttRmvpnpR2I>sWM45JG!-1MNv^Hr~C4ri0+K z+5-^9D}CzB2QK)slGCt>CD)_OR^!_C=8Zb%noJ}@oTLJep)Ie%x8fc`3gQjb!oQ+u zyduJ4KE5r<`Ymwyos_ZkeO1EIPWXi*$C3g|0Q7;d+!*l6$|h&x9FyR)9GX`R-k{Zf zxc}|=hknGN=)%<>{%qXewT>Klr&_Q`HW)}(R`G5U8J+UD=aYU|gNGL%#}B+@BfZG~ zxPAK?k48Zfn*Mnw_FnaX`j$I-Ng}k%(8NtI^_ug)lF6n9hIw|=S6~&AXs)NaKNc< zD@8ZoUfL%1gNuZ23V^o|vC*&1{DWmvkBZ|Z2BZ=mZM5;9*XIxf_;hqh#=fWjr)|b! z>!t~-Q-H zcOW{ef1hm(3iZN5qEKhmfzU){0-P z1jJbXvp>@z8Pn2zSy_>}j zofK=>Mh4pxQV*jh$c0?~hkj`+1b<>lgu0_`QZu?p+}o}CqxN$e6`63;3kHRYf_1t( zJd+?u^H}D1YqJ_BoI!+v7^=6LGLA8=8QziFwjNw70LE1ojRMb^K%$36$7$ovH(}&tnb^YhBpt0>! zd%d#}*zNh7?%#)jcYIl){zrRcmGI_L^GIp@MIDLjA86(FMwX*iV^&jip3pJp-hxln zOgBOLyM*1DoDSE}WqmGWns1W5x9-A-<#|^$O^mYpOmu$`<{UejH62j$N(=R9?8I%t z)2P*{W1-MHd?aZG$&A@*No46G-jZ0>tw{j`{fwZ?RXTYd2*K<6{>OQJPDjh5#%C|6 zyVL!PyqQHg@1TTeMyDANg*_!@tcZc6&X;UB;wP$S(n$LDwKUhj1L3$rePP4nA4=T2 zVn0i11j7?uMPs@0e9zYUE_V9SOxsswr7*JH+r8{&>btOySrJ!tm(oVfKNa`yMLwJX zD8&`Ky2Ge!e%1oweB7001r2xP{0tPA-=cV$l$PKOYDKTJptQUPDxvx8pb3BYTxx;$ zBbUS3rl{@cTr1ufcI2V7K02ek)KQpQ^l}#|l|wQcPSC}Qi>uP%X%_9DyzB5T9TDs! zdMrXhU!a(XTN$|vYnFpu)N56wuqvSV?}k?O6m+zV6ogM}GnAV~z@jDvPacSKxs6Mm z8N6NOh=uYJ(AaZlaU)g20RETHj5%-Jq8)UdKNx%2YZJ6v=2SDj&N(*=7Yhf1BL7 zu+-dQljgsPus=`aXZSk8UN|o{Y;hyOdjkbC5SBXI%c39-a9#DnW6iw+rC0oV9sSu{cWbKuPW%3p zgq`*I*%$8}BujZx~kUo8^mpZ*|(e?TGQ-7Fb=T<{miy+vMD+hJ#GhHvs&nh=>ij>C0addmCwM z(+J71gL&I;XJcva+1yuM74)?JJP@%Wce;-U)EWCPIfisSv{>^8O@;VOsKc9nLYI9z zT38vEa`;F$c(E@Q_9!N5_yS2j*Fdt)zF{2I_InQH7IH(n55b<@Q-@sO(osh}GqE;n z&7-cP(GpKpMj%Lg;N)D}3MK8CprZzgLYa`1aM@!6{LBi#ek<>WeIu`*<_4p&4chCl z;GDNL((34a$BjuRL`s#0Q4K!DNbc9nrsQzKhO$=Q988c`(k32L)o_*hP&>Tb;^amq zE_X+L_HRWf!oTlwKl;$JCCOv|c&Peu&ZJ}Op5j&i5|SJ6tsZeCJo(4Et$cn~0DAdL zm>W5ol}Wdwe7Yu{8N!~akbIPo#7O4|l&^;91SyP-Z|CqO*8ct@!ICxkPtrNu&A#bv zzp8d*iBMpUEf;Uq)%pT*`ZzeTE~z}*qH3joFjL&!EPKq245B3WhScsjVR?5v-q(cC zE|(VoR_x(^LqE&I*@d5+8$pd%>qTF<(;mtf2NttOgW1{b#2&#MwcPJ^7KNT5JwC#! z4L2n_;#PT$)Z;q*u#}9(Cl;mmSjES!b2@`m3Qm7dFiRA>71)#2`Y5jcQ}^ zcG}C!x-L)!*;#fp;rT)owqo!cGp#91L3*ZjA+VkR-l z=FA`eW(E2k=Rn)k!K(RtR68(7sYDJQj6=R>soB%^&&d(3$qYlRWn6XyuP?c#b6_1% zpJwm0BnI8p4{OlCA|!oQwe4!RdE7%Eo$-yESA1pHxEwDWCcnQFOOvJHR6)S*%`%%XAT^e<7w zuC3giVN24dUH>@ zPyFZC4h_MBa_xL!_F_58yf;YQ?I+KHhx?o{$3jhM7k#i&NUTSsy-;P1JEuEi5Voo` z2GWINkBDKEUQ<$pEY%%Oh^zI2xDz`_EN2xl9x2ruTaxDSWzhtBrfj~tXG|nkrIz}v zOQSYv9be2nwUA)dJ;bZ6%DpH4Q>f?>hT5slHZ>t&QO`GYR3gyHDi715?hR;}^NX}H zi(9b&n%H%f*7Xh5e^Yw;W-7Y#7O&l4E|IR#-gMJ(2Igjf{(R$N{PchVo)UQ=2~eCV zfBgZM@I=C11f#~IhF>$L~x74cS z6?KU6`BPs^XUa$mv+-ix->crBUH~EwXdqoqV${nu&;l`9!2E8WFoEu%$v=(3skX#d zb95f!jl{<#PyO@PcnizZ!)+8XmksqV8h2XfFOG38ePS&9yxZ)_2M`3CF9a?!PR8cx zD{TUBaWZ4xrZ&yhAI5)<=T-^pLghJHst;)nfj8lwxWB4<)pto(2AULE^O{LlDk+tv zkF!SIRsDK1JN0om=~DS$&8eYaM6;>h2_>#An^e^{15b7k3txIm(zXkEy!dKGjjXGh z&x|}ATi8KGv6^PLk0bh<{B~;9bZ-8goV5l=ucX{ z)0+-ZWc9;zeYs`-CJMfgV)!N5U(eXNvyPkO+gnKPZaaS(9WEjEmc|<8_enCgjU3i@ zLToO*3*(>d#sH*`r^HrN$IS%PyjaT(+=42vsj<%F*9ztl!2kS@<7XtsVoSHo%5!n7 z3hNauikMksq&ZnvO%t53qHZBnF)$~FO(%}}KLfQjKPCvj7XEW*BHBB8zKZ&&ZM<`+ z@ZZV6ujU5Kpn&VYigiD(mhglgY#F)SjzMsI^Q+%wpWE2BhKP!ev8TH%A+OAJLP@9Q zU+5ZDZLQl+AdzLv*5E?A5Bq7#zqDC*Ol=B=$ywjD-o!H1lvT%%{tbk5^o?_V^-5Z& zqbd{ki=Dg_XY(fgcAH47`m#cwk3?tH#n}$1+-)i-BqKVYVzcijw*nA$U%Km^@6f!X)fHD}Vl8+xM@_T?_pSevm>-Z)qDlS4QaboN|UQKy+u`?%`*(RdW> z9=$dC~B8**t zKcfKYoFBo?}UDb;fR$l+GkLNv9pXN z`0_lu|AOeF-6*a8eKGv~Qm#iLxZ9-Dt=Q+xW#AQeM=eaR$m^Ajv2swjz48fk=MQlB z)!J>&%dxwnLEihV;n-~(@BdwdSD#b3{>CQ**K3?l3m06}9xJ{LZ(42CFyxT4B6TcN z9$k(Op8R?ssw5L?%=OPGv@u)x3ei8x_kyqI$km<~^*8Ltk)wQ2J#*S9_BStw)&pN1+8;9Zfpf-P)UNl%M1cxR_07@^%{X8vZ4HTS)-RbQ)oOS+Rx1>2cr%g z9p{3<*<2DUh9RIg9p-I5Mec~y65iNuL-&&zq38_)^0Ysxrutn}$$F2JG$)cO>8rAj zAk|=1TEqkTn#i--P*K8`=@{(#H93}L4rXa;wUU5H6j#h?SOfG%YHWv(&xGdsnn_nu zAJH+uB@q0+Cyk^xyLR)$_LJ1@q5!~$|6)EERwF%^!uBoTWzCtXbU+uoU5jDBc3YZ~ z{%Q)oDmvoCRv9!sD_u&9BtZ?)EzJY9={F#Rhayc%3n}hipZ=?S!=H6>?TQids3+fV zg2(n|&G&@!^~Gb)C+PLEhQBJ4y?>hnnMM$W8}_fod$OJE$A#m3fX%s!zF~mniJLlD zBt8)EU$1}5%*gZ;^gi-3i20u!D2pF%i=(nX!En?bmH&wtR+3>-PzeNE2xy9RviVN$({R!-uuhj2TbKv zSH&jGQ$DTazYw`s{`_1s4Unx&+NKDe6VPv~>iBHOs%ydI!zt;me7?TVr4+rLNCc-W zW`?2S*-xP|6Vlm*a`v*HDg0sQ7!X>VIzD5M7TM`f+-rmj#*qC*+p)()w{$oAAUlTs z-#*pmTy^$f2*abK2|c@suMXrR_*z8H)C{Yv;HwQ@baClck}VR1Cu{teP-J zpFTW<$S6Lf#01XUal6g3^d7u|Wy-KLai5gJe=p z?Ti*IpSpAQv?;Is9fjU-ohoV!&%KyoIb5dM)2h-~_2%I&leN8Isv%Y-MlwS={Fq^7 zPLBIeaySwz+UhR7lg9jSb^ejwD+0@LPq%8OY1{;uY%;l2 zjnYwYQL3IU=1uEXuLnw!;%&Y+?*1|7v=*1D-$5V)3pJ1 zw}UqT|C1M&3lH4(bZxZx3^0_I^olLwy#? z78#(}RSn))FE$h3hx0e-ZCro+B3T}w;%?F|O(^DTjgt$l$C)>@BK&&- z&)8Q`z|T;fjL^Kz30Toy_`Di3c({GJd8&B&;w-0HJ{)#OItwWCC4Poe+t+!&C(Eg~ zs?wz-sX?coqd;A)T#JY!r=a%2Q$`WFhih1to+HQmcZGVKDmlXlWMfljgWLt_VJalV zz8Y2Y$j`XYd*CwXh1m!bgmpo74K*YrEg9(?uXiO`=_8CU4sq=6l_CspqBMyFhx}YV{=KuImrL&905e6 zkF;iuRP8)(sXc&3`mK#9i0lWvf8)%jAzl1qeW+e3AP*L(lzH=wKgX*hDGTVj_-&(J zd#RJjfH8#`Ca7Zm2Nw=-+V=CKpTTwc*UwI72Ju>`W5?{X%sUa>Eysj&D(r4Gi?QCV z5zVv>ndJ4h`1^S|j5fXYruamE$3@^Gm9jvmkaeX^DbVF{Ifc8o`Qd@_+4HmUy}IG& z>74|Ny}~D`XM(mLI72s<3HFaOtI0+<7HGipqa|@KDI0OwpnK&M9<5t%dMRk7@*gX_ znZJ8l!xi1nv{use>KomlnO1kkP>e)7W1}XS{8w?TB(BJfe2LJJmuJ#io)G~)5DUfU zCB5FW#VM(z-zltpsgFSs98Uk2v6;?q+N5gbn)z=p-%!f{bnDiqu&6T*C7?b=AiY8ez#wRYS4&MMy=_j51uLU9%r)w15?O}+GQqmk(UeAmgb z18Q6XdLrZ)D$-vB0@F)G!7-V=Y8LSDV~r1Z8Lk0%pzL6G1ApsU@LGY1MJpLcP#Zn_ z6)dmfkybr!i*Quu+c11H3AgRHIBQxKn(Qn@kqmdt;_Td-iK&5 zCD!^eE}(=3-S*`K=o5>uXRkzpxz#GG4VDd6^jOnR=PL0rp!A-f*aF?Ol6(Zf=h)$~yAm ziUh<*($?PKVZWrjOKP4*=B^nfZU#;(MRw6%h8M+#Rd0k8AoLrjP2n8&1nNmnHgayT zf_GS!RHQ#BcsIKi`zvW#n=XJuMMd->_Du#>H`welu34AO^ne*~=PXaC0nzvjV z-;sJ4mUnAVX0YkfSiME~fFJwE&LS)m0}SlV(n+`?0(EWUPisO}GJR(&Wo-~v*%6{` z8Y|ig^Z_~bHEUugY&uE_FwSA*lgB1t9bVN)moa4ROOlKkrxx0dt0p5G!LNQT{p~T~ zLf7MEAid4|@;lF6Gj^ID-&lukgjxJCZvSq6(?pf`&pXnu2#(#u2d9dh$iwqF6QJfR zqK?vuJtzMdZN*aB(SPj!sWbVI1FbveOic&JN8v&a)^j5|6>EB!`7-^g6vZ$*QP$T=yoIJWZxs z`K3Bklqx5_F@PR9q454ikA>rJV8P4t6||ICn;Mr|R^>MUk3$>_v2X)lvMpYEMaT^X zi}+2AqPmr_eYjMFqiKKBj`aSUiVZPv4GZX>d7U!E3e3?YI}siSewOsj2>r*(9Pr0Q zwnK8jOJV@|27PU%%{C32fliA)zKbWVXi6Z5!_i{QdNby@3Secs0tecr6p;5Pzt+e+ z-y7<_wwDKz_DtLQ+}#gbdYL8AnX@EIw*noJNnw=VgKjh};iNCX<2W2z;Ze$lnXLNk z$%du`eYZN~sOrGg&tlIa%sF(;msh$6adnr@e^nl-1$pE8d8Z|#p(~@>j$hMlO{@U% zUSve(9&GAvkJR4fJp!v3*q976s5UaHQ;8Zim!IcNOxT9FIpRIjDByfEBTcm>TDmX* z5f7PM8&rk?d` z390;bnft9Lk)7t{t^9|I8T7dKjTNQBT8}Yf`5R`hH`wi&Zg;Edr5|Ep!WDS+b#*rI z9LwZ@Gm!h1MnZ|WANS#)QHbyP%GR$Etis%{n|DI9DUmZHrLsg|i9r?kFM;pMcstZ%JS#Of7^TO}Z}OHfNsNt^rhY+wvEj&Hj|)wm zK>S+s`s*C$vk)jv%#ZdYBESy0JDJU;`bB0F9;!N{Emhf;E zHRfKDb3AbM3&Ym4_Lt=)nSPQ32GIXA08y}~ApdlGF4)!8pryjjF9AQ)>E@NHt?>dr z)~KK$`3GchJG&wv9fOzIY#%mu1#!18fBu`_ zbp~qWn51s%$^O@1XmakF!keiUl=AS+#(3Q%n_o~X?hr5Lf`h4j9V%|w1^hM9R&jAZ z>ii#NYMb7fl3?e079fG)us}Hx6V;s zbo<442gH8P3RJG+h=bMu82oK7jy|}P`2!7)f;-JGh3YJ1C@y_k-+8--z8E3a$S-wR zq~1#DNX>~fKMB3JdfB%Zx#E|{y%)l8;P36bd_G+FNwN%*DQilzF_^y7%3WCLl`Phn z!w~4fLSrZXvImp!B}~zcp4fCRTb8IgqHH)0a)XE{;I+mGPF1b|NsSVc1i~byR*j>_ zyqf*9+&c}x2R&pSk=t(I+jNvnZs9zjIC=f5`->57qK>yfkUcm0^X0leT@=nPs@-n~ ztTN6$Ej2N+_NGD{9g)kh^rVTd^oU`xV-K z(YvZ){$h{WzZ~F5_hr_((6BC73|gxkp5B5R4L%E`g8rsz=uv1)bg~n7II~CP2M7=M zf(_SMqSH^d0;wlTS>hLnm#Ja*^;=+2^fn&kut^~k-CXOvchDz6uPo8JVfD5v_y&+07>g1haXCUkEaPiA_v3pg&e9_xR3+%r6 zK~qqrK-PMjddKIhY|LI(gpg1-%ZF@!v3?co@E4b&YDo2Ai^{K+aKZyVa(a>KfK zs)Zn*xQ!cKZU@bT5pt-L%AnMzBH2;g;p(y!ZG$?7a|OW-y1b zeCG`Pq>+%@X>ob9$1lo0basypi)$#uJz=?(D*#F-S?60Q056kmp*P=$1mLI?<|nAyV8KkD<>8TuhHv>C%bprNvJla~;NIeZ5e0lab zk7Pf#z8GPyGq zkPul5?0O-aUbF%66`v2jf&Shse0Ruwzhp^V$-P>+=WNf+FMH@w4y3ESx&rdlYCp(a z#u=eZey7heF1w}I;p&&T_D@PyYM;e~v6X5+tG;*dN{}9|!2W^rG@<^SKB(u&UHNu+ zq}17xx42Gro8HabI{3+28@uV~q6=^v$UZ}FqJyi(&LS99m%jCH+=N&GGl+|xrBhW< z5xWmhn?_`5SSLoh?GBViK0N!4?A7t(h(txRK_9CXJlcII7f#qX^%aM;C++fc(*sbl zQmd>|2!`p0$5P?P-W-vL_Gejz8v|wBe~%iY{da~i_bJ`X0&RBnnsoP8XT5-`{vzjr zCbbgmW2Yd~{q?*j>?R?YQahw`t)-?Rj6e^U2ArVem)fXyGCpun6jEE zF0%`IX{0{*8&qA}@IvVC;^0dHvng?ZHT=l^xJdf@s(h|5 zY&FbCz4!OaXWs4hs$RK*^XLciaTSfcsvf8>R!>sdT&cg;i*m9DbDjdXB`jXpzppSV zV|gy`HucBHc3Y*Ov-N0PaWlYGH~^&bbs4Yv6j?+NkiqBpUx#gE1tr`XprY#8{F<9J zK&N*y7oFkf(rh+M5y6d)hM~DwQ@coJBDItGs1ATUH z%?o6?#($|HWs5qy19bpAS(MIg{h1p8GyZCNw6+`-{0s3#AXEX~oX_mcylJPcx zQ*3>+G@u|2w8KLb*Cn_G!W(x7$GtMX1k`IE=(2WCRhx6mIx>6N*dG>qHVt|y+bHZZ zjwfBvD9tq~1B<-OUcFIT`;tM82IHqRWk+h(lk9%#Cp(%BtjyyQt$$*IHnUZJZQ3%g z=n8tK3uTp?Cf^ig)icJX90H_oQIjjS0ToN4Yy7$=TCg&{=r&UU4)5lz zALe?~lM^sMmwAge=9^SLp)`nEi1T5O^&1E0lm|{u10u6D@`HEjim)p6ZJej~78@|H z=oA@nWMqkuinKHFDAj$Z?NyZa_%|-;l(+{y)arrm)KJ;FO~r22(!YPJ9v*ILjX-aS zp&ZSDQ5W|wv40*N4v7YS-$AdXn%VY7Y7H}ZWer;kZEs{3oav=;-9EaZ$@HzH@GOVt z2k-ClPp6ao2q)VKZZ{(1jpkLiv4bekjbYUJdBZ=b-z~bN@Wzs64ouj~ui)fws!Wen z-;UbjK!p}(+=GlaeVQc zGd&`%b_7aWV))kH*`Pon1QHOto_m%EEjJdH3w!_#EQ^RP3sWVTjlMbn^PZ$2gZ;Lg z_Bh^%W;gD|)^02ZgLjHa^vw2p?F^CiEN-O_qO(AP=M*TZfGuqHvR8C+Z1mm3%9mI` zxW@aWsTA+tv@an2F}l}|_4RO;^oUftUj7q5n&H$b_@9Oq&tszI1h1vb)zXz@L z2a6LPp`a@edCo<+x7|ZC)b@FHc;d)pNhT}P^9DiR_tX(!7bArq^C;$Rw!LIk{GGi* z`|Ng)i*e0Hzb#ph`w|bz3e)o{)WmOJ_9}-WKG>RTKa(WlWJn}0H%>3vpYb;HrxFU9 zZQ3)``ieb-k7qaNZ8Rw&mt5>WD-+#k8c9zqXfi4!Guf|0U+y+oma_-<{C zugJO>M(ELtO`Hh#y5|pRkNX3AGx1yJzZsy55(i6S4V{VktY`M3f}NJ2NLJ&?v9>F5 zgY5}*_Oy{|BTP*{UriN#wZFVzTeA;ZC=E8eJzf?w(BV?66IIES z4TyR*c$L2P^djbcU;9q~saYf0H0fz+&(buXu{%36*@H0rB*1*=MsxTgM}!HqiB3U$&HLpuPn~Hf6@WMP% zfb1f!g>WgD{Iy}6depR}dTPhK`{>(am-c9c%x>WP;?2qwLa`yO=-4y5-A|PEkL8>f zhpeP1n|2GEv=0)PfwBd~+XkROuz%8-SK8h~sky!!xyt1I*~E=xYEE)~!-vkf z@ws?CZQ)0Kf6>V13+r>17IKeC#!!M7Wa0K1$Hwap$Qg^p#IS1rn!vNIiW*~@%O9B#)l92k6APCtCA$0R}#ebGEs_8M2|OOKddo~^OE{h z;eO}qjwkTIqs8nCCB~i<$tc-9j$;w}?4lDC?jKw#xL*7Rw&OK)^e0OH$3$rk1Ker9 z-X~;@jqe^X63C>@y4~_&r0sUxB+1?MY3=`<1m+O1Fe!t@ar=BXZYhQwwgT@_5m}iC zjzgWMY@R*oKnO<~wMOEB_V%|J2XZ}KQLKdm5r7-OJ&g9rJ|-CE3<7%k+^BMW47OBm z*urzme`9v+jC(8?eS4o)m0WEmUXtSNdh84V%wiWP;Cska)kyOL9;yLCO?+3iZ+Syf z+&o?a`}?N(WKx{xg%{jlWl_+<6sEex1hPNeV|SmRZPORfF@`v(4qTP_;AwVn897~c z=pwx89vb@2c{7&YZ8h+tb*f*(Z027RdR8OIdlZ&A@8%CWdS9 z?fk!6aCvf%tJHa8M*fEJBqCQQInEq&pW0;2q?7a3c_Z9&G2maPz0m-ws6#aNtrNV{ z%i$+~JZV?pWhu7?Hok^dgYiHp@UGz9xg~3-RQP%o;@C@Cj!MyKxbe_L2%vLq^*)~B zA>w>#6NSj1Z4#oprH;Jm!|dD@4^i%yIXv0Kw2|@T%WVj0kt;m(^AH7Ymm$=)XRXvT z_&~7))4~(igRyb17+LujniLl~tSZDD3g)ZOW4(d1DBYID_=-1uI>HXVGPJsQvvUXA zo`^fW-xZR&d`q>HQGTNhxEWzazqlL|k*pj!bL1Yv3-PN3+NBI+5gOHN<^R`i_CQ-8IVrQc~k0U-BEJYUN?o zx#Y_44zw0AHN!>E;>&LPL-3WKHDQ4RJ@|A^pQx2)W_p6bPSU$>+@d)Ro;&DYmm1GhTMvNr(e-)W#lYW z%jGv7Y4<-4yJogxVmSeG!t}rT zA@jgI@jG4MP*cIQ;$|apsw;S!h@1ijfl0z!&SUNuo^L)I&R@RUIT-lVbBqyg^D(p6 zHg0X)tje$B==_mi<_HaL`2V{e2eyECNLeGQo~37XO4**FK>S@a?{5)A9q;#Vi*VEm zK(hH?m92q%x%#jdrH}X^r+>uL$Fs^z0{e5{M}$|-E98G+TF7mh=Tt7G;_k~mYti9o z$I5^>*FQ(b99dOH*QIiJix)hyyKgy7wyCW^;^M8x5^aps9h?jC_l>pcF^fdpi>3g- z^S`t$q6%iv3yElaDf)Y`|R@7+EBG!#C$Bgdl{`H<3ynVY^L-9p1I=zEdf zb@xt*&zqbQ5fy3|@$T^531J0}A?w0bg*$9oJ7UPpntvxk(dd0{+Df?Z8L&%ua$K2X z7@ravKPy~zf}fv+%O!> zn9dYc8I$W*Qw747{1?03fN{1PQzXUg58)f-fn%&f)QwY-5RQ&p&l3xG#+*)3GH3|f2tVjmEQ zGuc(poh*$~%5G-I!u-`67h#4FYd!9#6|Ts+9SHv%l{aP9?fQmW5 zm3#?KCjikqV_QZSq08@{zu&&c9al1|B;nd3|1h}t&)DxmGS8V=-Wqf$oN^cN-cKWSQi#lDp=3nY|@1NXUAII!-%01aVe0JCWrDgKL zZlt99;iACjBnIg(e-r|#=N7Z?YT-w|qy)A}VR!LC>3}L9g5B>DLR~30W@QqBy?=Uk zllEP^TXFj7(bMRtnP&AL`{Ww;nRs&rWZS9Q7}Fxi1Qq|g^9b0vC8vr}K1hiYiM(TB z<6}b~$C{K%I1(JYs>au`7x`LhNS(cCZs^SEquWz4seiJ2lQKu~UeX|kW8Lg-KJqUF zsoi@M3`_#91+`VcbcE}AkJXM{_ut?ht_lpvfpo>WS}@Ebd`AbMYWo~H8tE@%XB*e& zBm;l(Q4Q1LYL8pT-f^>ZBu9d?JFn@jIj-V?8Dw0SETALR7GBCC<5(V+>g>vnr&lrn z6Sj1xPk!{8)yTTktxpdHeFyuK6n8IVvB!XL8q8dD(9Gfnl)J+C^=YOBBv5Jhdoif` zZg%n?wWYE>`(@~1&I6|gszy{K__xwZ<>#KhFK0~^TlOgv4Nrpdu)}3jdY|KwuVWvk zn(b<13>SuYXPCBvBUtPYC6vM#RLcBRT(boa9#eDmv8)|Xwx4btseqcI5?mgSKPv~m zS84oN_{>J*cH9{_QQDGj5dMO`-W#r6-ME6DpjF4i$B6XvYVP3^Z5G_TqAh7wrPs#~ zjeNu)2AidN zcW=UXVQ@YhNs7fTbfL8FS|)^N`T@YZ^UJ+K!ySG18A!4M5rQ_Qlv(qsFk-wo@%*rC zV6s|Zbyw2%b6`(x59s^tRnF&% z8hC@!GgQgnL7FYRDu{V}R#oOmHfE|4XBc4=v3aAABY*^BSbcLtR#DOdBwp;n*6 zcbA6w*r~QAT2%AD^ylknb@9W`jT`Wp`Kxn(SA)kR_9V*BAl$_5B8F$~dRW?T@!Uwahj->X*zR-jY?{L4?-4 zIN>9ksGg0~@f`VE#S(Hv1UhaGEdTD+@RA#rF!2QyKq@1TI;Hq_ySK1a;7m$98aA$> z;M;XMC%xO^FdP5K>z9Lea?iWOb`oRjC%#vR+O$D|0Bnm*3963{{PM0cI$rkL)h;nc zrQiekT37qx&(jxxRTUl>P<>!g_z{aMjfFy*1x(u|%bP)||cU zYVN0t4Yw3GY^d;iaq!*sZ<%E$80ow4PgnZ zHkw$K>;k7UXZV8PQ{aD`S1VZn5l(t!GxImil)mUM7L`eDt|8PVYjN>hufekv=n*xK}6LRlna!T}1-e`x8+FK{{AE!<`H| zPj~aKE`&51|6=8=uyYM%L6*CoqfwqEz@P=@@Ph)J7bc`AwD;McaGO$=j<>^ECZ$&z z&qxY9^gYq|v!PEX-7DpRx3EgQDeF(WR2aJ?l@RAPzIB6PZb*4lGJU2k^^@UipiBo=MKdu_=`GY;U)GMtrq0(Mo7bG-T7v20kl%+04a`V5ck1xj|#&urm z=q&-o)KLibrT_d>S$-!$G2ekp0|wzyH*%x*g-4U=PuG9f{Cegloup4%(n}2l2U)tF zKZCU>EP-iayN#>5zVd+?)8Ny<6N;%r`>6gdhFFB^c1JF45+dLoE?x z8pM=-`S+(SRxY6;`8Mh6gh%Le`FguM_ijtW0<`4p8+Lck(bPN9zXf1F&SxLyUmj#d zTxS!(iLaAq);l|`t9hV7qOa48L{mFxdEjRJ_%~K^fRk#dK)WIY1v`?@&bLW61OdQ*pf5LAAf@~ZlrxM;rTTSxLag*!Sgw12>=fq1>d3p?4E zgDd;QA}#G%fmohnVV>>ai*vxP zB#H{f65%?wxZ~ekGxVx*+@8k35qSB=!Iuhxm@CX!)2`=qZv2k)d*)e5l?b^&!66== zYj>o9uE}3)WX5>G^V5Po@a2LT5Kv;Ee`OnDT$M6;k{hCnJ<%2{%XH){xH-u#x#T@( zMk(wrvoV&t-?pH>yvsiZw;H$v*5H=r*I3GC9f?_eou6~D$=x6}IW&M~?~$49EDr?l z+98gOH7-45^a%5}^}-)de_ph6vz=3|GiJjMQo-9iwTxU{)P&aqWo4>Z-j8A(&B(8n zft{Yw<8$3hjt2a#??TgE62?{E2M2ewh1avM6=)ZbKQx_mr9>N5G5;o4yE}X@>3Mke z(yuX^S0PN#?fF75Hh#kaq2}Heh0)e%lK(dX zdDd#H8SpCBLi*^>dBq&lw0F|f7rOQZ^+i~OTdieh&tH!W?61eo3SPyE1$E+9*A?L2 zOqoK)QXl;hnsxjq8LEPvN~mtiM6{02)%BxI(y8%Xw0q*hQx?GPH!4~`7Inn}+UAo< zBlO)^e|dd;XdcY;u;%vZ(+j_(kODo<4bjiR171J6t@>z#;xe!y9s{)>TNB(=4G4~% z+jZ4E3dA#vrAt$AZi?fB!I2w^?$OwFYQgD$4=2@nn%tmtKNg-ezG7)l237B+8b~vK zoR@mTuvnMBh`S05W=X%;+Y4;3r0<;ffMN+>o+$;UHE@dkJgrF`th?#HT0nH769``Y zK)L3+e(-H&S;ZYUAC!}ceKe#s)z?^|>#}%t4(4OTsuQUDyx;rk#d>R>bdC3DsETKZtHEa2b!v;aV7Mj*1ML?8*jW z4IDaD;-nkox}HbW-M+nD#Ai3>gJqfVN0p(sTEe|1b%Kbpyh``{`7kNd7}^PZi|u9>Z30OP+8Wb;S1ln z>`Dnvl6GK8_@LRwG$nFM*GNNiAR9ErN(3-ljLD=CB1O=U=1tjL@}1S>WqXAYFulj= zho2jC@U7CP6#SZ%9*^d-os5nti3`h^hMXtR5B?QSRd%ztbq@21EBBUXzmx$e2D{#oOR0~6yqY9?=B)E%62Rf?;r?~E`~I&M zzMh{{?boxH_RV>U(rU4<_Qyx1Yit6*l1D8(_gDzwC5W$j`Xq(x?I9$u+2O3cI=ZHYjns~6Q^rSk@;U4zR&gdH)^~j zo1BCli#^SGPag*L3nv{LnE^AUy3p7eLp=Xo&5T1Uisq$(o~JI;X5BAxOvM9-{#Xo9 z#fdV(a)TZ49hlV7h~%oz3(oYiKBX-wHx$-R13)d@!l@UL=TjSi3!mG^tjrD&%(C|dI;5#4{RH+3VWJ7nPZHRJuQm7xecC^h5KiCU$deok$Y++)sI7PB6IuxY z;zJ)F1TPG`%-esI1uk3X2n9Jz^&Gu!c9HbLLyenGm!nIjD1WZc7KOW@$2-5uhNL2< zn8Uii@9EjtC=1`%4jmNN(0VgSwHVL;j54HWX z;Iwv{zH4xv&w0@rBNH9*gi?D73@F~ePgdHn#e9zz7p&w0jQ_j>uGn{ZteQvQZM0n? znsg&qv>oKIB*n678K}><##xtXjFsH&#Tv>IgN=?zhn#9Y49v*AosPJcWzWsica>_z zTjVD^=)&or%2T(+p|PMg8grS+!v{uFuN~kVyGXKlg7ZE7cjh(<@1P4ak7hhr+hJ$R zub!fQz=uBqo}tZ0-z+OlmgrcVdsr}=jS9LhJ5md}a8hM9O z&qO6bObu`R@W~gA=lgt4`R&lF3vT%6la-ho+o~HIlBe9GsPZ(frfdbxNV|JfU{F77 zP#8lvA2`ObPf*F_#Y6ho>Hjgr)>@d%S+n7u|ShZv^;2o)ufP<6-ZJ0HM>V=$7FxM9r7otR~w;QPWCON434H;c7dRPMtaz z);ZrxHSyC&oxrog%y+~f)3f3U(4MP3BoU)p0}DsoP}&PQ58mkye}k-VVKpde_*Txu zjkpeav{cD_W2I5s-yt{#kp1CPx2ll-_!1TjzPm5Lz}=R$2sS>mU?fgrs)ubO^}#r= zs>*kJdY+wCZH$u$yw{Z8H;dP0WjR;*-`IZH{X`M(T25-F#=u9{jaIp%_B*4nTlj@_ z+snyQQ5eJFc4`aUp~E8+D0}F}M*e|szrEJ|5q{-R3V%I;NyfH$_@?J$FJi7J(2DQ^ zWbuaQiMqnm2dhWb+3thfy6@N)V(e!QYi-|FN|rhM&11F3%&U5J!`oERuY(J8J%1Br zxeU^XwS-XVRwXi?*Cb7e9rNpOy(|Uy-mm4$f1gELbHxJxS^K@+)onM^MHLgXOX-V{ zlHSvF;I>Bvf|L#^aQPLjwWAtf-JpECnA@c=9Fu$DXOH>8U$yL&{i{tk$HJ41?dHai zCz<&Q7|W_uW_NWv$8CR+uq3SE+3Hx;@sD0g7JQ-oM=H$&-Y9#W)NGGh@vV2Y*U+6w zBVu!$f`H17wx0aL?>e@BeOeei{|=ry+sVvOvW6`h+#y!(9cgo?w`u}>g465j8lSX; zS0y*hEi7zO1fAz9^q%7yzsuX^Qi}#jX@n0NPn_4iy|=a%u%*~pm36+{;DCK5ym#^7 zx9C>rl?zais`>*3Tll^a&%I+&AAO<2(4v@G%L8Rr;>wfod?u6|gPRVR;%$+0WB&1( zaerVxE7UX2;?tOp&5j1Z>Eh?PI zPM*UlO`K`FaoA$dFE7}N&QkZYsn%j*%jop`J?eQv+X_#zn^Mu6Am&b(N-US=8mcj{ zaW-2pmyAG~79BqGC`xZxd$2)U>3?GFDvjW_%zCrIEwc1lB(xb=sSeOXsiFpKx#*nxW*-aoKqkdndaYwLOfizM+qeJ$zR>9ll=+W1vt=d-XbH{^osww z?pN@fj)5ERAn=Op)CQqi1E#bNhZ@|!5_;W~bjj7u?Bn*gR;SEt%H!QaBon!s-b3|d zVZA?%uI?GVJdo(GTz@wA*Hr)hYm^;mNXg~1w7NAW{}?h)(tb$+ZNYZk?dLXHKUxU8 zcjFN08ut#Fy0tJk_Bb0P03Y?_(?UOHU6x9+5Jbrh1FaO1nZ*mTS8zbI@jLd(z}q5< z#3%VzCgsGGiDIVSyTl$;m70IYD$lXPgtaeC6Y4Kq8*jVca07d&#vT3wjbh$w%(vQa z6*%MN%BOBXF8&6XNEeWJFzxU??q}%x$!?y9>oi~DW%tG5eTlJef9+Z7lL`qv=$p|{ zQN^o3AWorA1&Q6+kHuIvB2Av(dIuA0gPgsS!q$z)UKY`q8WU8^h#XQnc%?0E)- z-gQQoq${w~`ybbT4+=E;;7_{`zt}P#VAstN4@wqrH?`4vfM57kpqO3NeOC8&mFEuo z+&^@RHVpF(@GFdlAUWLgE{0bi=(;@E>?)k{y;msuuP~kb7SyTI8De#u0CXRJU zj#O3u78yB}+K$LB6dtFWi787#W3|_t42CMoMPSo0XQj%@lI!H4$gBx4{U*3a-`SX7 zd#lI(DgGE56k_&DF?7Q6W+U4cvI;fyEr&mN<`%@lcsl>A=V36n6e#+}SD>Tzngf>M z#2Tb9kT-!r^g!4)V1YHPJc#?z^6oFZ_g7aromJEiNfW%&^#4p*Q|2LU=J0tX zZfLumO`yVj!wNCm;c{M`?cV9%4{7>nuaKc+YpJXd6Wdqj{aqQmr??_3@g2R`#KxNR zv*a5#TAgluEYkAM&(9WyfVoRS%QI$nITw4-R@CwH#drLFw(3%%QM(nIg~mJkjAVPP3ox6v9jQ zmRJ+uFF2Oy3O1t6-7G;|8u_TQXGQ)MlXu?!n2vGzv$=H7op|ce?F39!rx*Ost`e@Q z$hoiE&U`RYqwtnCo6ok?tMBTDldR_Z!ZY*O?^cqTXxGi_C=auy*EC$u_?_E16jEBA zmrloc`Zf3PPIn4CtqypciQadjw7C7QlVA zq44%LQ%N?>3Y2$CFEu*8zrLvT0@WHD1pY+^esIzC$lI?_#Q`Tdf}0Inuy{P2+=IvX zD40*nT-Z+!5bw=`yJe0D0f1RM`eL z4S))_tA8y&4~ws#G_Gx$f_{9?b;;ruyT~4MO*q1Bf+lr@s66k+8PU8G*EOWJ(~9h5 zNet6W(K$O|Qnx|V;_6$>5$DX;?hcD-z|N>mxZnYQu5mq;G{&(9wI~tt6@z@nurRua zU?SUDzYsABe8UV-ORmxcDePIzRk&e+qA!0~z*grm#V6koyEy~=C$#ISM9?a)`dmn3 z7jslOW2t4&!c35hSnXuF_qDN)sJrpAr{o0R*A5w9I~G!R;63`UER+BuYvc@Ja0Er(@ z1PFGXN*g)koXb;Et*FWX^f&p0jB}OXm77ab(x*b=1;Otmx+qQ12I-LRLrYr+$Yf~O zk+~*wU0C!R7s0uuy}A+R1^9GzHj78|9->L#$#CB^Yfr|{DZe?E?qcb`Ep0s+*w4)$ zoC?m){kcBaxVg^9f>wlqNXU(@c_Mf0`QMivo~eyZBkfO#j`xxPJi4>xIZ4-E&J*$T zh%kP4OJp7{;<2=-rFGFIJ17(yYJ`40K!V8VmK?Y>py5-G|5rzzwl9|Wbgar*i~bszzfxEaYi)fFw{Y(G-ulOix$+?AKdwOET@jey>dTGthb)dc zxmmFv*HdL<_7Y@q`DlUNlvv0T`0gajaHpF1TVWMbv>0$lmLVrAe1$%{sev;^UxyHM zqe1}he14Z};jCSdW_T))qa>xnDklCWl4ni>%Hzqb@9nJU$>wU|?#PSLOA>{3Ymt4Dz|){; z#Iz~x(L;G%>ixOvFfMVu$D*=+_9rHOQ+%DMB#4r0lUW5c@PR1)90P^iSwu8)Yte|ut86qpK&bRFkDT7$E0Vc*DrBwmM#~hn&fC8LxrBb;QJ8zJyj08SA(Ig>{0qW% zrk|$k`5+5;crpeKYQ*@)GC|+MM&lkz#Ufo8V^EHAl`z*w{ej|`r)Qx$@gMFU78~zp z)!59@``hj*7CO$(Eg|U?(A=1bGup0pE=dEK9)FQ>OMqc<(OWOO3vX7_P{sBMZZUqt zO(m8qaVqyRDuZM9rR21N?H}OH*Jkw77_9!#us^cP3ch+pA>kGk-mbhw;maH9Z4E5# z3Uaz}Dc}hwHUY8yyUnS%jHxHpPZzN*v3a^M%O4+>AG}jKEixRCDt-ektn&8s$~w8H zPSNJ=q?>}=zzg#)E$4?rjvfA=ZkycW{fi>_$`clp(q0^VE zL;b#!B+_;2MOcn>YF9=UW9?>$r9z_o%hjpY!AgB*4aHwRuBi$!?gqWDzoaqRL$GH` ztE(m5*crFWMX#d}-wu4dOv?=eJApZ)hdKoZp9X)0ur3Ed(*bG+xJ4l)%IXC_SoJ!v zU3d^u>l#BNr^c=3EeAi`DBbWlMYl6kJpXxe5-s=^cbXW;k>xVcmg8?)ZG)1+Xuuyn z&wJ&iRzn+W(&E|iMZX#_yzuejrx{(4i>5|`6_d-U=tx?Zrf_CGG0~T8Hry#?)lsg1 zGWm~bfkUzb!eGaijXYw<3-d}d(_s1-?Clk|$_}ffjk>OpfZ;!p{W)eI;xc2a3l8!$ z9QGyJ;46y)4x}wpqLLe(-hOWhOC0FMRG@8;8%QotE%4{1KPaE0OfW9lG9uBDR1)i~ z9ZNE2^tK;N31FkV4f?l?!%(?#U|uJVILXpo9ts3-&FQ8DN4P86XNP))@MSSBt~B?c zVfHe9%Dz)lKAu~=)qi6*M5X3cIl|&jYTtJ(`0+1B;!;hxV!1hP!7aXi$|DGKz5E_+z#MtCx)5a52SngW?_ZOJYs}U{7VP;0EMcfqtIK z2x*K^3>IT7iCJr}UAP%Tfne@IOQ_2AW!bdwS2xO}k5sSi5$f4f|2QJrq1F=LF2Q zK?-l|e?AY`zHbIBV5RCfAB^UmwEksx(A@QAFOt7XrkdT)CJkeoE?5F~8mXTg5g97f zc#GPa!Jji;PTAXkx*#(KCfl)%kl7m|^ZCCEeQ(9~zNKC4T~XZF4v$Ka0&PXh>E6N0bmcXY4cmQ`NlTKK*C!+rJJ{kvL=uwwIDlT+ne5Q6R2 zyueY`{6xNkqLeiGqkIr+>RYx-i@WQm+CI^nvZpPP164Ke2G=_lYy=_?&^k{IbJm<` zqfks8vI5<4-?3}YeBbASmps=kZF=XA?_2${TF3YFcIgecNTmXVpIjymN446CuLg$* zh^9|2`z=RE?%jS1XKnP8jhkE7KE@{vQK*4&7PNt<0tj@ zfl6%KLH>m;+}?OuQgDM}>Yx$4-im11bTN7Fc+GV*(jrz#zTG^IRrn`s!+6NAoiFT! zGCJxVVF$PxnjbJO^b8n2`~MYd|7+Ql6{)~=d)&lS@G~EBOrC6rkY3z)wq#O1&gM6A zy7el80Mi%$gZicsvieMF@N6m#-VeRP_fVa9ue4OHdteS+D! zye^YE8y1`B)NrJ7q`W6J>6m^MQEHEE@%C?0e?Hp=9CIbZ)pbAI!lw#;BT76h!YS~W zUhPg~-Q+qmOqINW?zBWkE~?5OPg{@Jo#%8?^bI=%ruW-JL`6-Vx@&Y!%g-j#j!@mF zeDTYoKZ^cC7L{>h{)$hswJR{BD6AQFfQnp;VEuWHVkW~u+1Pu=$yvzE{**YjGk)tO znEoFiE!o#&IrDgN3&E_rh>KN5zL9uw{=~!=+0(GTMqXq|SmbCz3{Z0=J6)uWhWhuN zL?}HK^41W3%2CY90Lu2ak}nu4@F*s})@`+^#&1Hs$7@f5f`t&T$q(I)@$DZ$$7@_C zWwt)8djUw@vE{5cmLiG%3ZAWYSKZmBxDDk&0w+}fz zb|*)t6T=(1SA@~Mc>{*O!IB%Z^pD#$IOKed)14!*JfXFl(_IRy-O4v*C_}CAy9Gd~ zmfwL(wu^e-moGPTqd{w+yZ=7uGo|aw2~)G9W*?;(Umh*uT@2^jZ%)z9cKJp+mX}+o z)QY~C(nkg96;dlmzu00kX`U>2&UOsnDWJQu{JQ*K^sa)58m(FVXpyaf`(tYZ=YrwI zr`-v`(MnLOU)>1yVN0Gxx(MSNmK@-bH|@!OmVzPsUI^4{=f#8NMRXj)WV=vYm}c(` z_bnE#Fo_+;!_2}Rq?B1_u(V;HZv0iJmcURwY>^+kU|h(pu-`Qzo&G1-!3UJbabv<^ zjseH_raK%7yVs_(2+G`P&6f1rXGJk3vO^sMM7yY-M5N?I0w`0i-}>5)mI82JgR*1J zRVK1UZTTu-RJ&V9K5t&Q<8epxej<=%n2|-LsW5G=WOrLli*%(XPMU9wTwD0JOT=m;m=nNV^#?_7_n22H}`XW680&n*1b0B z6Z4~oulWmX)L*11KTNKR`F;$bKani3#4Ut72sK1FKvLvEV)lcX-W&aC(*Aa_yV`#% zruJjbU>>=3DSXhOT55s%PK9#T$waltn3fxF+hi?z|3n^%F72@+K#%NY;%+_(y_JZ) z{_4C!)p5}^gioE$?7n5aW<`^H)Q4EpZI%+Fy(J4w=oVjlM|XStv+mzVP_dJ?1UKbv5v!9|(3 z9!66O3hIPT#0|aTrKX&{qHx5{-M*u{WlaF=^r(3)sy|m^l*$8im|SnpNxWr zx2!^&EWmr}+*mj(y>8uRIK;gpIUN5R)L8tDb3C`A`724G2HkeWqROK}So*o0TdgSy z$LuT{tQ^p49t%*<)NaJB1O+5c_qtSDo&5;cuEb1)3fTyd??cpUZGT5!VSNSt`rab& zIbF7kJy!jMvo00M!u9Xl4~N~Z#LdCxs*qUfy@$^fS}$*n>oiRrKe4uY1-`Y9YN?;R zPUxDdNtmhH#M_i*s8}BsXZe&>Wc`lmV=!>!T)aVDx(Tr9<{glAczFw_mdA9d{~I|4 z9%Hs4Ov{%!MZ6slZAx2*-y3kN2Y2p>=X?-DF}9K?k>MMl&9^oc|2lOJAD*==8y(zl zU)l#QbVDZcBM>)39cR4Lhj3`$f)+u!(%qTM>6BN${8#g7a2rsi1V=;|ZkDFLW;t?h z5%vA-7C5WfN4fg_M29l#bxw; z{yR!|b*WXc<$3|?{r)XX#)JjPK|#ZMfw{96m$1~OxOP)F@_aCO;9qR|yY>*W-nonY zo&EVM0jLfLp(;a`v<#dw*XD?Y=$9ayg6t3&{ zdU8M5U+oMyP`mypTRdXS)Z1PkRyT_3k)Z~i??9@%AEOfsk6lP6RUS)o3-<)V?IO#Yxj;*)90%R;_&KEUA7 zcPmi;MQhE64H4)LTuA;(4h#H&%D#`lER4oYtn9GhOegA2UbRIBdOc0H$6p=;J#K53 zF;4BB@=dh8^I&+;bMLFx9OxUh?SCRcr??O?A`% zcJ?e%RnBBZT%}RBH~O8!E$aos>)NDc%b%`M-&4G`1+b;*_xYuR>YtmxpLJ+FSglMg zsjPA7?eeUQkf7xC;^60(nCI^a%|DIWj$VwX5ql>R-$_~nEt|HmD31`5fPV4Un-^tx z;=8LN->I(&j-PGSF_E+m4#sG@g0N#tOd$yFwUcPmJj;$uPn1X2abB^Y)Hb=TZtZ8# ztt3^@j@?_-)510Fb?OtL4+KX6fiDxStyK+?c_~N-{Rm5XzbqEo(*O1kc{8qFzn2+I z;h#9;cRN_JVOPz`*NZ-df&!L<{Su!&#m^N>yHOyOsm|xt=@J})B!VhXoo(_N#sM$h^0+p@ zN^10fLliRBRUi2%7xZBb4`!Oa0nIa#BpF8nR;J2Q(!ak)JyPF9V24+}y! zWDgm9;eFJ62N;0i%RVcYw{@q(<0iCiTz%|^z{S$^5x6?xepN6VZW)htV+=-J+hMX~ z$Z^K&KGc-aaP{PwOB;GP^u;jYB$V&8VH&3NxMFG5Pp)+SrEbj+ zR0)vgvAiMfHpei3K@p5RLktl>B~k>HLv!f{xH@3wFa0hO$_NjXs#_z-D@iz zW6I`rzx6m_@wzTq!X#!)?X|pO{+xCkL82($XGO7AEo^|h9^8OW^ z$VeL`(Q0)AxY|o14=xg?1s=h1epMuH7F^o;;+w>ZZeIG6FlqdccU7(iA%h(Q)Vm?Q z$%Bg7f5`Qgm4uTKyC)#=;Fv>56wuT|Q=2yx2j*s%LN?x~g|GJeg#Yr z*hP~L-M$j2&Gj=J&}>K=BU!Ge3o7VNZ%wg+s=NPO&9-0mJhGDcx4*WHi^Sa+(uLOs z831+YpQ=*i47@b0hyz``TV!P4W^&DPA}@9Qczddw<*w}rX~hFsgncI;m=)?4k0tVXifWc44}_oX%W&5Cv2$hWNxa?FkC>H3_bXBJ2hE5bPxQwjE7IN|DN*BFRzWQe>(Hl<%UVQ1=T%R?I(kV z&P?o&v7n2S_(h$7E}lpC(o=WbfL~80Sue`w-zZ8hz{n0I5bX3WHPYOCa)>)M@HWs+ zljqI;_+qwYqWY5*>qb_S^xDELkT5u`p=Ha58{$?aSQl!!;JDULw~;MN*Bkf3Cexl~ z|J-DhxQL(1QOsz5=qn;`u#fz@C3he=YkcI_f4aD1Pqy@o-@l=tU^NH>tTNphvR;_y z&wD2SJ#6>|Q7Rb5KCqh>IKUh=78$+ zf2$+H#PvOGzedAvt+y2(7@56fDF}|LTu8Sq^jQ>2^T4}Ea6kk1KwgnkU%5Zgv=B*T zEEC%soCYN!#|Pxy3W;w6O2KOkMX0}_(mQY48~j_O^ca|YQ1_IN+1}E{Q0c5ni}Jzm zPt=$=Uz>DlLpNZ~^yOQOb)S1vw+uN;K_=#^;!s1{!I5wU@yKo8K{>;K_152aVZ#44 zHh-k$^%E7(qHThcC# z4wP@u%ENlEAXuz-S561h8<&b)jGVo>;8z7B5dvuaxmTwLpXTZJ9)EwQsZ217Izg__ znYu2uexW}&&KWQf&})9Yc`cCNk~v!mO`tYt-p;{>`-xe*G0H0mleUHfu2_r_?fC0D z-7+a&+d?ftxf||>X9Il<*ZA@*f>7@n>Q+CKVfnsRrKLp`2F+MZ(Zpc$yOg9JT_=0Q z=b&c_R2xTxcNO!US0GEKcc>NgWhbE6A^hr~uUKvWW1!Bvz@Y;ocW95~tqV0_jx}Lj zTKy}d+am7@WqICl)tWlqhi{+9HfYDd1J(lwtJI}`}-hmcUyLRlO)wMmQ zetjlNFL~WP9&>z~&eyWt*Pc8cr&jFr-IIY}*Qb?7xKYO#U8ruM2zl_Q`g8vo<1N9| zNf#}w&~CVf_E7uJYYohz7%>Ullw!l9O=P!v@N__D>4Mhp-5@6$*YNe=n`E<&hF|Lf zyFfPvoC4oD?>!9^8(i;Y~I zbqHRb3u~gnVHH=HZ!2uS*vuWn{T7)h?FkQ6NMUIgFcou)uL0ei0s5BK!4tCD&qZ%d zWu!C&8^JeBpV75C+c2x_-&RjDr_zmY0){o+So_DPspsHw2HM!5UHZ_Ppk@7m8IvOm z{`|*KtmA1fZVh>a-t?|l-3gLXtKp8$G`am|>Qc_<+b8$?^3plI$}&tcY5`8D`&xC7 zSj9nysWSU_qxR}Qr3G8a*Ee?7SLJch9A%|zA5ugtJC+_nuCNRTmi3GJyj$ix1fpWr zjP{2zxH`kB=&d)QeJ1u)3Qe|~sxb7dJ5*E+Co{__8i$B4n;Lh^qW$MUB9pRF>Gk-j zVJSMjKL!~+A>~naM60Z%nbKa7e-t!T#WWqAeM`^_x3_PsP{!PQx5oLY!pN94nbb79@OU`NuhF<7jt|<0fc%ZSqF611#S_Q(ym?g zmn0sy7h!v>$EM5GV79?OV_#a1^)&V$Y5wowHAUV-eLoQ^(^s|u5`LA5Glh`_Hbxr)3^;gTPCGbAW{}-pl_F{Q|TB;U# z$5ajwMGAZmjPAfyMlTmGw?EHb0q=)boGLJmmha_9qy+VS2ck>uAg z`KuFGW$7v1AcjlFIT=0L9t z>TBS|4N)2?TEV{AD0xMEdf*?w6yU>_!0k+EPu60;nfofdu*p3S`Z<+MhvAAe-=P-& zvN+2{_ctU+zsRKs8bjlaAqhshQ%DCXyNyyOJ0f4Pp=#h6^yVmN=86Rg8>a@ahIywL zKLTFC4yEJ%bL1F`%TYrQ%dO(eg|e~BJG9-#NjYx4rK$y$|8d=FCWiAZz>3uH`UNMt z*Ka+C`CFc;e^E1YOPAn6w~X?IWt#4f$gvFovY z1+-q&Aw&)~xLjw1y7NUEPrbbPMMh=tU=)Bq51<#q(R+8@>C7pb`I&ble2vchAX3|C zkiLMd&4QN!uKUR~VIHolEko11?$7rw`owI+OBxmTnFkwv(s}s+l9_+&?7u?WE&kT9 zRKp!sW8Vb0kTeD#Zi4h!O~^J#LfH0@{bpnrKI6-zuhmjMfS6^(<30q+Y0}m(rvmNX zgKWDzvNOmUe^jR|MX7_J8yyLvKj2j9_Md->Rgn}7@;}i&oN!*fNNRJelD*=P?cryw zJx?8=EJjgH?|z~MJZ!(GB33lgvI4dWncJeMj2wN^@FLY~>hiXm_%XRUTKHGR6F-J~ zlsTKx%v3&is^^j0uTSP0Fo?C71*Eud*E6&EXJw`|!}<*G8ucY@1QQwN_4TgMjfU(U z!BYpCh*w(!0d1B6I@Z{&1YFD1Kv?ocQW3NoA$s|fp2xe5bB)6l_rKIb?Hb%x#p3Rg z=$g(abP8|tcD3<#>rF_1NU)(>dHpwNjri_2MmNrq2by@hKNSu1*zmDBAUr40m9hCh zdSo1C;fK7M16Nr=de4SZWpRg&A{*18{~{y#x%v^6G@f31@vU4~ld?6^l<{1H#oo(% zny)!cx8A*OE9=2A6^d|7H6^LADdqQ-mDgkU&)L5`*bw;rIMyR5$m*}*bnW>x^LFZz zi{^YV6DMLx7t1QWGu|!$tm7?TK~$}}+J;4NWoPXq8~b#R%TtYzgnY!%M`8Tp#8XVO zcjb3K;{N+au<$_0xw z29Gdflt)?8g7mm<-f}P(j<>j9_Xsg!zj2KC2j^=jKeu&Sf`WWQSdVY;fwZlPifase>B_KTf^t~C6txbz) zQD}N2x5YwrG~jPNbqvK_^G#FUCOi@7mb*)5-^Abd<*K~gHHHs-QE<9V>@zp#6sepn)R#s|l?aHIDIczVicb6)6l+{zAG&?0-BXTE#dZ$e1k z=zB@zT%=ZGlt8GEPu4T9B8CU2IAuQc3kBx-av2ooU;(e*ccJodk<(8SNb0Bk@<=(3 z>|cbR^fRzk@`yApNTIvi|3S=MAnhJr?Q%2UfzU13Ud63A;b^o}3Fyls)C?g;@^hq_)%A zuerxZ)>_I;t`EpsZdVO~`OkgC4x;UYxGhtv6>P3&2w-fyMj?sk*wTg&=QPOPT)L^%cEO}!39L!^ z=@=SE^b^qu#Wbe;H+KGcXl%0XPlx@j_wIFV>P&IwOdlMjw{mde6gdfS0J1@m9XVvC zAb<@P;yk`5gGdb7gH{Z5TdHO0lhitAK2ZEvg#fyrrx?4KblxZgcLgGTH}-GbX-3tk;A z$U_uVJJ=B#%8AsYPX$iDz1(NCU{P{3vS1*MD;QHXILrkFIWGF zA>r3hBBRa*NN!2Wc~AtatAwM3}E#AaZXEpyR6@!~|XeWws7e z3T|TMaXaiRyOEVgKI=U&z<3dr+j8Ab712uJjFk*{b$ltd5%z3@8b0&R!H}C2f57+! zr`FtWf7smYv3gidd@cA{2T2nf{Vyr6FYSxOB?zrOG$ArrFHd0J=Q$7y zB1dC&BT|2+c}I-`i(+T>BZ5+6nrrfVl%pFEh{0EU>%ZccV=1z}Qpual?IgQq*;^;e z*5<4^{u3_0{D9+OHzarklNrc~xFt-Ql>aa~#f3UizU)GAJ~FCK?M8QX+%dQ@2onJ3CS+3FPADUaK0ZP%ygr#W{@6y#JgT8J|f^)1(x<6;O zJMi+eix_09Q;e-5%ud=h$B%TDpmVAW`^|lr&poNbqcj}n)jFf(Co4bXB-!Glp>f}p zf^^!AyW`PoH@QiCjgqP=J?U^y>iQjDHW1CH(m5q*c~^~vU0}u7i5%0CeodWuk6x(fNMb5V2r`<<2$hBOM ze=!i=y!YUdL*O6`rUreJw#Zq0Ib-X!q#jAluS!5D?r;=*p1-k8n{(hat2}7yyn_%y$MV6xtsr)PKo>kXr1}^ zGXrXst#`LV?jxG>=@|ECBMSO%!z6^ZwF<7wc;*`)3FVUW37WksDiH}8KFtLyiS{r& z>6lXPfG&gWU7NpM6%bw-s`VWPG| zytjnC_CxFigDl1HR0AS#t$vRg`1k^{GoF3B`Y02*&7#+W32hrX0TnHCOY>y)boVu} zjL2=ySl{j*yMUCr&i?fK?B7zrtg|Y&{PE+W_ZEB}IYr9-j|Fgeqsnq)Y8K4fl;L=z z#8?GG2pA(d*`EftPZDfUV&Mn=%i1^D?=@LuTP-X`aANJ~=gYCYtgknLz?nAhZ16lE zoz@X^>wgvGKkmBgx$B&Zox*IO>cZDqe;4U(6Mds~zO|yv^)y>$akYpST41G4T95%5 z+F>XUl58<0MD>#aX>JK|5{-)Yi{~ zO>UH6yvL($ajo{DB}V{n`SwodHA9xv9D^X6-1?S#+1|21H(jHBd~2SA8MtO+&be5> zDQA;%!+1cTDVxK3s>bP2reEG<=qzw){IUDllxilT;x-|$ zvWzk6d)&!4S2s&o_U!1Jz6DNRj!ip+8`z@6mW0K&UvM@^Rss$!t7x|kqwRCLacu6G zm^bJ=jg_&~0Ohn-ngH3refU;rcUWRS!NY0w=jY{-agkf&Ut2~%t@$=TmB@{W))8E? zbaQE14%~5{WxW;HvpvgsGR}jm`SdFwA5?tYI0`5{d%XV=D~x>VQ>Jq(16Q z#dX3xAp1<)bbHEQ{f^5`|2;c&2|Pmud-+sb9(HG`20;8muCdNt^xyPXlDDvOQK5j- z*Mdm!TP&xwWl3FSb#YlTTaQR$r=8sAD0js9r5TpS{Ar7i7mMDX;K<}wfXFM=5zSGK zH?X4RKzLvr&QTR|W*e2?NFBgeurONJ$^{=w2`J&27Osp!)_v%;v(|{&Sc4uHENU`mfKi1KV9vO|zY7y+2hpgW>|l z*bS&REY8oN#CBBVG~P>z8akEAC$KRJzPI=LA5m2z>N1zu{IWfEhk7JXEZVlg%e}L= zS!DbRusiRsbHsdZaAbb_uRE1c_-_D@_mAaSSrY1|iXDUbf(7fe6*^-=;(Q#DO{Ec& ziixAcK*q%Z541g>)AFA~gI{If+eDffpGRb8;Ie9CRR>$j0@3m$^54Nl{OPNGn^*fs z=W*VcSaYMlcQoG=RYhi8W)_)$F%)&V1NB7*d}Vu> z{N|-n*j}%As|wQsFIyyH#k1gcnE;k3D&oNzV{J+4i=Rx+5j8C4xvY?bx8WsI>RtC^ z_Ej5KLyIM(k+_gGt=eWS(FY8@nhLI4(*MP2Jvn_j*F9U71p7~R_nuFxoNKR4H+OE! z(SETzto90*b*&cqO6wZ}&_$M#dwf_jEDB@#M_9sNyWqFrZ_V6~PN`IM9~S;=y4tz& za}KU}I(fa;;Kz(Mh1z24skkxq&{!q(<<0{Uu0b|-x=1Nufdbzzo%K%H08>SPoN&a2 z2z~Xue#J+>>-IrD0hpR%o?_0`clBbKa_|>$8->i~iY?)@l{QUzK;I$q$i1)jeKdq0+H{c2+2r)$#K;3XkC^bBSM@0_bgek8Bg#y_ps~Ko5UT(fw;YDB>D! zy)f!FMu`szbw2}!rQVf3zURJ4c?lCDKKo>pav^NWAE~6rD7^?=AXs855ZJK22CdEc zDfgeO$(`zyKB-D6eCoo-jvSK%3{z#s9P9B<_N(=Y5}&Gn@}bwzo$hSGWei^*_4 z^g9*W#Ap+KuWkW{CnKeDgpNY|{zLYozUaKZ9OoklasFTaIlP%1uu9*!g^7_n%GyfJ zS=-#&6OV0Qg(Z>RP3OB!h_SI+bykMh!bcWqzuYPC1j*1vYNY?uedWt)GF#H`A;iJo zTM8`)GsOA&Y__YB3|chbF|ip%;rJt-yTdHG z2GJ_3WfWX7)J?E2UPKkICM}XtiV1ePyg39wR({Et0&bmT$2zp4* zoi98Xi)VNwQ=E3$NP(y7@(`g|wKHB`lE=Y}xj}H<#Bw+hYftCsDEkXhKHwks?O+UF zTTz}*IG8^e%X^_;uG0Rm^G}v@H11G)k^xYFU@tlP_0ucKtEij zb#=|z;d)WUTV(X#<<}0-Q@D17A~P6rQs<+n4JA_@xDE1M7x;%d19UEtrO?`(iKE#T^;rulwxC zY;1C`$Lb?*1Fs9N980EUI#qK$n=CAk8W4&K+n^Z>;u~FkAhbR+(9-f7^@Sur3@YK> z6^P%_~FqJR<+z|~7X^sS4 z=rzF450w`Bp9^Hbs(UJ%dk=6$jV#n9to<$-`CM&N5f#&FTzgHgPE8?}b@RJbze_Vl zW^-%4{?z9u-)D?P*Qlim)_u!Aw1T(`B1wguT*j>K>MXfe{TT5lsr*w_o!8w!xHG9U zPr_ISG7`FKzuVoY%tsI-C;(D<_foY_j?O!sf(t}gTJKlDANqQT@5_SDKn!a|iFXLy zdFZEz5#Hy=D;@b6RsKtdvk-xvvk7~9AaY0WE#o~xX{vr}w*s$onhDIYv-{fAN4=RK znZ8r>8)IF<>Fet1HfP@9RIr7;yK%}sL%{6p-z=MqKZg}h;80sjXJFw%4LFB>2s(4M zoo7cUc8f@C`B!-C_|6-3dRmh4^2MlZ&Ur~(*ZI!~WDp_QZZYWCf8IClmhdQ?K^7b( zyQY$Dy_el)QlwA z4I$UETUtl5>KE~_*aOx^xwZbs)tRu-x~QUnEt74>joskxmt0W~8jQ&=pGf`bTkO{~ zFm&X=om~gaAG7f>x8S#sXSjA6dEYfE4Lfu^E_(2csh7E~oF|x>>y=2e1a9eZ7bqcuqQO)_EQGRPdFs6qZEHCGCH+I2g zbfc{d{I31ycK2JPw1$-=^Bn@YQcVxRUcwyX5VtQVj6e~K~g+U@sp zoN7CIPWsZV73_I;npZx-Q5IPnD8caF!vmV0lM2w$4*Q}oG0yrMe2Xk{+$kWIJVsm| z(>Aa$Xf|}Qb~~gBFd0dHcqrny;QAT@cyN}YtyGVxz!!owrT^e~yX5m-{d7v=!B61? ztv>dhQTQY5(rYI^_Y4qp;i|%{EMMa6$O}ms#AA=)rq@PJ_IOw0c-7-SX`_MP$AuwQ zE~E1d7&fCWgJz0m@iom`$L+&?k*Rv9j-q3HsXXp{E4FYP8{mmEnYc4e+W7(ujEm^q zfLI>h9yC}mS0#Uye>@kv5W3UC`WXYKY*bC3Ox|koPPH(q_2Js4ld$rY-lq25u3gt7 zCvX~bDjmd?X~t@XJOb8j^kE={td|rWyvipRwM0$FGxu?kVCrkm`f%sC+^d00b9opk zJs5k|(V3SO7VNfAi(2HCj{&Gw0*D!Guc|j?cA1^`|Mr4_{`N&&H5d!)VW(1h5TkQ= zV$WZ>jkxRL({#WdF6OH6Vx12bc>B&c}IDUl-j0-m9Z7VIQfMbm&g$e^S(-Ubn^%iHZckkcb}~SF6OybtKdtuG;Fg6a5vyEZ#kdw5 z-500>(!bQxCQse-4XhZG`!C!m;`>ocz+*XXFNIw@IXAhOX79!Qv6XAG_Gob4`H|jE zeWCa398P$$=J8BfEl~Y3J@RS5%WjX7q0xF_QI4qdZd>PrBe}9mIH^$BssGXYlA7B?sDRQu^ zCVv3J_;%9BU65osyEDOSHDc${UgluyRN<_l^Gb?d^Q=hOqt)A?ZV%2a*ZAjQ+(y!qn^u)|qm3F)6bm2kqjP$YHSZ$>h|~=C zN)yNIoD8-FcttD`#{Ak>4VZ~w^&P)Re<;49BGVEB&`7JLAfXR-nc%qi{M*nkp}YEG zwMFiHx|W)AIdrgMPU=!lLl)j0sn)2ArCv>n`6;)vdTq{~hM9_@^JcmG`yUxICEn)8 zkXIx3!i6oc2ivgD|^vGh3KsS_$=j%09ifbOGmpdPOC~Jo?K=XD~ zvutsHr|n&nDF3JoEk420i$+DT65GSrM05*qW^wH}BA)48(e#LGEk#IecM=?kAB-G6 zR-{dE$eH81{`bC!B~I@JgN28IYV?WyvkGn7n=NOh+kv7&5JxKSNzHuXw??NXNM`ff z#zc-~Fvar;>D{=vJq*&tN!?-M|7klO)6R})Z!L-1SfkE`$lifN=RmT*)|zjU{J_8y zmcQ6D=K<>TaNVHn`9| z7n&(z<*UimAgJoEUf5%xHgxm?kjpzISq_=>hYS%pWBDqOGOK4Y0Qy2$^nC+UTWVtD z#H)+_LaxnEkrVzb=?M)sB*El`}bVRcCW+@GDD*3uJ3+xaPK@8`{`)n->EpuoFoi;CUs}t;k>FhlI+h)YXr`v+I-Jtbu+`O{R)L&losa z+(xc0GS8&zAOin(cP+7r%u4`;xvaZK{Sx7$n9r;sDoLY^`Uoj}>GEV4Lu-=d#(bPV zU4_4x)(8<`U)!dR0#hv~)A3p6o|bHI`(rydz#3?M7^A0%5q)zzF(<@=AdG5{1`hV- zpVhiKS`3Y=tbHAxGt|aSX}=}iMpds&)o+=!tODc!{Z9fedGaMmhjHk=aZ`_gkoT9& zE7;RNRd>uR^iQ*oq2p6U0Fg=#bY|w1664IaII!s>i3Q?9^PIe$-wn!yddzf(MvQ`? zXPgb*p$b%edZ8KR*!-fpX7|H#`v|?~jtV5F20e+hU93e8I->CKMhatWDyTrDQ{+ZFwkOh2yT=D4OY{T*=QngGRnU8gt9v z;Z+W=_NT-(<@NSUGz?YyU%r#S?5jwdSI#{8kBD)XJ5#5$dphFl<23Dc&#uTkmwbRX znYDOzQSYt6xdGYui!$Sv(YBh=ssXNl7eLJ7It2%Xbl6*K-Bo0eh~VT>D2*3TsKU-4 znxp9O2WDuB5cyeXtK=abzTI|jxcNFR)l!@Nv6+!Mqt`+fQe$_T#m!=h#tSA@@FCG@ zoZo3P`igUDLu`7AN>PjaI3)Ul!_TP3y!o%03J_uR0P}Q!eU{jhEnP6u#Ol@v?=6*) z+eb&r#d_3^?|a>9q&F6i&_M(|}aX*K*@t{USTv85E`L8#Sv`o0X{SUdmMTDJ7D z=l#C{A&+Y82Jw4a@W1{m=G^jR+1w2qU*mX~xiaBOeOp!k{7DrBPo9&e?WKuS?Z%rZfpD$m>B14#yi$ zUH=8sY|Q>NL{3+ZFctuZyUf=tmP{{>4kOwRI2Aq4G0Q!~;I-(svnaOW*ZxY29dE)& zH>N0?)YK_Ke|!kLNHA#BuBzPNEwy<&uI(o$wA<29o!BRjjYZtUFjoXTy#)_`;`fsg zZeAz#_!miKL$Kd3KUR>grSee%)>g#!ATDdYaEI8;>ykFs^9Rs2SNa)7MdZfSyt#M+)XiKqzmL`k?|VP2 z=5_Ljhf|pUp~S(Ss@Fwpy?#vJ*_#Y|G=i$UL(yrhB5r*UYS!JGcw>G$^ZFco@COs^BQVR3ZMVwkFzCITge|F3BjJX{(AH!K+gA9r-gj}(JZxUV zCB@};Q|(FIPceNAD@VCTM|3)h*SZ(E+x7i!=v@nKEmgf8XIO{sxs2${vC=WMo*>e0 zjTK3{5PTXbhR1jhbc4j|HQG39ZZNZbsV#N{a6h_iEaC^_i|UpMSt_&%#kCnj<+sPL zgfFGD;B95b-v#ZWBpcaxsrPKYq>qqS#&8}jGUz)Li z?Ik+EH6D60JWv1ibj;n%6Z2}Rnb%Z^!-NiwQwW(4n z|4(y%a`^e{xjMWT-}}I&SjZOQnqMQFo{#=+|9!`x9+rZKfi%i>8Qu%n$Co zV>>f8)8cmZbln8^>$>sVk@~Mk;nt;`XSwW_mSVSMV9d`g;px0JcfA@2R~LW___#BJ zXDF@3hhhQI4X5cX`X_c`i=GSx?Hn$rC6qyD&JKmEXWnj!T(r}SZDgkhJOXtknFD^F zQzs2}mHR@;>yViA z7=#BOjnyEEN0M=KO%vqF!vNroSJ}N7^emfZZFm+~yn=F-Sp48lV|epsh6KJR@ORwdwrdD1dW>OUndXz6YA~ zr|j1Qq+-9&^!y`3_jNQ!Op&d}l|&=!F23ADR?}cnOXvZa+R4p0`|({o8$I7o?9Fb8v7-+#)DS5qJ(3rO)375%Gv=B zNJD>KLYY_{j4uIX+ylk2_@M1n`PVmY5*ng^=RJ}Lr*(MDBWCNZ!n8ZM80R_l{;xpu z1DWpRX^TeA2DlG1WrTO6fxfw89C_LQXPz2&cZ#%~RQ1!}8AJWQ;w*;ROY*&%L`gwm zQQX8=^Z8b0H;x{ytLuim;jrVAe~>nm*&I|I_tATF_yL0@5RxpAI??k)Mg#G^5wgBb z-MthzWYYP0woCU|Xk*-RR<_ZD0V3}C<0OTly?v~aZw(rPSwA1<%mM=pOg}O0pblV4 zRaUn#ZZk&;nv)h$kmuq0@yK~stc2LST@+1w#uMwjQJHO3$cAS z=^jjNKYk6^*^HvZSslA}glPaX=Jk+X6eUR6)~Zy-3ecKL;V%Eeq9WmiEy1;f9RCu( zUCKb75o;TW#c@cp~;+rJXOHQ(D zo34y_TU&o_$IAE3hwWx)dHTMB&pYl63<6ucN)M)cwy~Qc-tRfUW@iJOs2-m2ua;{J zh~H>4z?mm6wkGx*A;Z#ve;{VKWvjb1R<0MpA!DidSppt6%e??uyDfq{uSQ&JVln%c z0B!Xx9{>NY_xY+c7q`Hc>UdRdIg@!7zy5?w+=2y>>)#uBqx(J?xq9y||1GY;9GXh& zOOtaMa=->V`vQVKZl=YL#l?b9G&E2Eod@38kKs<|7I?@fDQf$SLrQw#?&>hG%|XuW z4);9Eja}(xO35*3&3Jk6rVG6^ibJdbi&=7$6TC;{U9(eOb91P_r(C6&o%5SRkc$mM zKY2)O4*yB$AfU-p0H1kQ!^OaK7$_c6Ut(hiW)I&HtH!{X%V86(a}20*=)b=8CJsu%ry9`alN=UIQ>68RbY&+*BL z!okbzzw+)eT*)o37cV(Xx-82JX6)ni;{ak1%;vn3dbFJHK>2$Dt*RZ1*O<3B&bx~z zZQ(;po77z9|8GMoA{zK#Znkdge@#C}!q8UL;{Qy_{K>|Of?duD)F_2qgXVy;yfv!u@U~5Ake-FVvG~I+W_4_lAR_ziWIV)JUd3OFxxKZ2 zsf<-@=ALpS4;8loGn@gxah%d26>ji8eVXD~GXBWRU52N?SE-5)<7Ea4vhT8Mu6pei zVdbihyFclqy42P1cZhlM9YbNc=9bWz7Rbe^(@2+SSpgKEvQ1?crx;X)H(&^fMhWR? zkI-B?U@7BSwRtCZfIw=9tKl(ksXkpc@?~3KoJ;mPbZ1!1Uvr#gu zd(oG*+)GI(Ges&_cas<&wT3ZUDo(EM_>weCQwO<7@fNTAg?RFEc>dEhV|zW|H8;$t zn8J~EITnyJ|5%|)nuyUs=po0=q`asRdWv(>u{`zYKw~;P}hk;?OY=I{-W5KW2@>pr+)Q!)!1caMnmPWi&>s z+Tzpcyw}uWY_3x~F_d}K&n@(&u183VeOw55MM-#eSz_o|SJC`BqLX+%H9exF)W{Sa zoa==Mh;{IEaHvsLBDfU8XDnx&yJNuugj-qfE->i%vJOXVHVnxSYQBT7xmk19bY-G| zvUV+!=ZZ#$q@^~26gu zXx1*r-vDoP+8|1KjNaq_{xA`bbjVlU;i1Ea%AYjf&a-o*Ws3Tp#2eP@-v!$&fC8yI#414l=U5 zs`4~gmBI4~uWH9Hg;on3p>-xd4vJKI=Dc~2x^C^%W+kz|8`eU*EgSYp_P7ky8pBQS zEk5GnB{t45GKT0RqbKO3jVQl=k$kz-)BT-74~GI%G?I08(hXBTiO?xR z-*zWfmEe9+db?hyg}CE^ZW+u?z&;V*=qa$A+Qq;3v2bp5sr%8e=WA&K-DH=b;T?Dp6?-yG zm{Mi)BO=`*k7^*-CjDbXKOl}rl}m#N1e>-1K1`^%(t6uFNN9q;Exib|T0i-8G^nF3 zlUsu`jy|{sQ{+?e8pvZGkA7!D1MU@xLCm)t9CC?_*-*CbwAach{kW{Wu7CG_91iEN zp9MnZ?EacT;D3+(Cfb~RV5-T&&{zCgRiNwvKjt1E^KG{s>#jb?h~b@&>Cu;Ips@)I z(6Lpngf<*Gi#G+CZ~8o7SZ{Q@!S_$eH$)x>%;D7ry_H170mG}7G5Tg3k6soie$Zsj zNWL^FvBy9-v`t5q+88WNSKzzGQ$*#HkbdPyz=V1mw#Yn_F@z;t_B<<#Tk8CWIm>dU zkk?T>7rb-T9d5RWqs^(mpeHNq+Bk0m7M{1-W3siMdH}!O$Fwly_oNN-$1G?)v4Cm z6AJA4lhmgRrf<~VQM&L0K8sL%b}J25#ix*29i&Dno9wsRZ&sMothFS*f1q3&gZ<-U zhtV>s`2dfMdcHl2v>A<6SyGM#u0CYB)7C-C%VtuTcrPEUvha_PqAAqS^%m;Vr5{XP ze7bj!GJ==oEhv0OU3O1VC{HCsMyFeudj%@T-wvr+NIN6 zQ5Bm6jUKnf?n^#Vt2fcTtP!)L=nuolK+h;JV4(%2RvjV zy+_X*ncPBb-YLAM$K4@#mu6A<_5)TTQfqebWtlf>i|cle_nY0hV-5`1VpdNPGoA#0 z{JYk{21yDaw6YeCIxFvQ#w#ms!W zGQE)l`h8Kc_SPYC0A{zSTRXq0(Lu(X#@4a&pgH4&W~VXhD^~55=+FCh+krOZUkuC@ z=}0+WhCt44ls?!*Y;uR3&u%I22&3GD`5F^TlD)f=_SNF7pAvh1OW7C!M~T|}Go;@b z$s@vHe=6MulH*}W@J`whk(S^!70VqrwR>{upWx89>3~0a8I{)G7h;qHkuDa;+5b?6 zFRWnD@S8Q_+LX(6aA@}u#XeKX?KmIV)Ke&22Evt}NEuzDtp2KE|Kw0>n<2Jj4znF% zPrVsBdPhnb%f4)d5I+ER_#pQRP_~SfFWC5phP6IB4(#y2!eTuVm!DfMTJpA#w`dLr zlR_5?2n}_tON?qKZ8{7bi;)~drkMzOsIo0L?%Bx#hd=j_pRJf-L|7i?2mAtF>m$??zb6;U2^if%;6hxq2l$xhFRiJ9S?v z3P@r(Rp9MuzEt2@`*Wz|uYK94#>tmH?&{}d?f60{$oF8mq?&Wp?z?u=L-!Mi<@Y`x z89%$l-(3@gLx*%hLG^}ART=tL)lG`=yRyI8cJ95zQqn5s)>7%-LdQdy6xr_~9U>iI z)4<0Aa$kn~0l_k5o-0la93}vZlN9n(OxPfjWh5U}s~kVvUzM>R4VfhN*K}#jY7buh zm^EHo6kPSM`<2XoaOz*d2O0Zk_7d6Gt}ZSpTvT2sJzX}qp1oV2(P4Hak=csh{YJkd zbU0D}O))mr*ZWnuN_O&1m9+v|;Tetl6oP})U53Z}PXNqj)?kqNo{iL?(|rF#0TKAJ z;bgV%C_J6)~bqSKRY1we|OX1V!Y>JZjO4 z)Q~oH8|XAKJrweX=1C*SH)2;_x`s&xJchLD+~02F$o|cAZL@e^nzd^E*0$At%iHNE zBxL9JE~(EdYQM$6a{$fRyd(p2eP(ld4f`vqCk6P-JK2ywJVQreELri}k4v2hw37lD zyX`k2K5#6$TLGwx(F2%f`y83U9*>I7MJ)M%!Pj5cEUiA;*n7?@XUNQYGv}~@HRoCQ zYUIm5EH>xmrwB{)pcwA!7(XSmEPdzs^5K9kp{%R~yUErpQ!$@9JmmRD;+~+D_Cp)y zT7YYW(m>f< z_4nPwSrtd^-;EVrkkMB%N;+f-P3&*GCYu5+PA^P4NetMee^#h)vtH4EHqeajY7hWb#~hCCUK8xf+z~W3@P_sk zM>7*}lZAi!9iQUi=bwEIhXX7y7{Ut%q@02>r2Z_W&SuA zx2y87O;;Gx7Ar^Bxyhl4pM)Yx>+f= z_<)@(j=#Q>=~-#Lseo1r#(1t z)3hyWW!nGka{NW*vGBcQxz`Y2PuH%XRKF{G+D)u|sx6qk`_b4pq8)l1C8orlEh%e; z)>C%ftT3Y0P++MS5cUEVFtxeEj^*;GDGhyUcf<5qjMi$P7AVRo^@r>8pt{V0k65+u z)@`K;o~&)N+U?rMuoooqI>m_(sY`R&OQVx@CEL8|pfxole4W8Cc zi>_RK2^Vt|Kcgy82?=4iW2(37mIj>_Ovn2#^deQvv6GK-@g^qz%G6l&Ntg&cM@E8Z_23U*=V{a3#O}HkaWQg@j{&Yr*!m z@{=)mgoSpU-nT5)Q$bbV#&_NvDFHT}MszTrVW!`AjCW%X%XtYSN1JvJ=mI2hKlLhc z=%pUBecdkpnjI?})oH2Uu{St2ZN==fN0*q>A;)vPR{@q;u2zV!yMaV!1H*{1()y@? zY~rY4SiUodUw-nNrK=!+)6}tR6~_wsKO;?4)?%d3HG*<{ucbKyS;hEE$bXe_vnr>v z1=55unCkhWMO(&WVuzFwQeAL^Hz|6JBvV!$xu8pd);x+>nKU=8y~Ms)6^IsS7o8ED zyQyAk54^{G7IU06fU6CbwTE_4seHQJq12=+?Qc9yMh$<9_5P~f`za?Pe`w}K3n}=I z5XqGqOU@lm@Yb;*mG#tS#&%QXgKa0v)#Cm^=U(5W^5}{u*=2SYa2YP?b{$`{_$g3( zoM))UMGA;~StWVudGh1((_p&r3})!O>F0aGe}NtmxwGZe8`{Vp44CKB$`dHGQ5D(jG;$GtfjiEW|Ki|8Mjj-+< zA=QxG03MzlZO~LtC8dOFuWVtpqShr98zgy693Ln}n49>l%3$A?v6c;jPZq3%wAB9K z0j9D-0t9AX>S+WV_KU4ISUlTxFJ}?^R}$En9>;@h#0*3w_AVB-avBx42n)e;dp5;y z`dVmPdp-RwHe@KK1i9(i%DETJY=QTTsC%?$p)KRN)bbYiA;RlRmv{Sc+=CBdi=~KH zsIP=N>B7{Yxs^G_GFi>x=U3*Ua4$L(SRDUadJr%osN;Z~7@3o6JPXfPzZ#RY7M*`) z?pgk$lYwY;&;+~S2@eItqL<7ew*B=!7TTY-%=k4CqSl0I+F(>p^ngA7(67VdR>9>dYf7`njjHP@)WcX1S zebAj#(#x&{ed`gJBTPMHx$x!N#T>1rkZuJhSDn27)_gwY8PP%>KSP+@$UCO|LE8pv zem|b5qfB5EydI@SfBgE^szJd5v%hlMJH_m{0E_!f4N7Z;s9D^%wH0 z%)*$XuZ|yziEz4H?h`2Dpg#&b^3CrF)*bD&OK;e@xWW4%&mhHQqb<+un`e{gW5d3N z_31j4!dr6Q_|(|G^zN4hhP^?UAies50gT+W)~T4_ zYSE_LfL7Y-M-cFD+Q6J;9)NrW8vdO6&sUZbx{&NRQxP&9OS3xc*Vu-(TVJ5oIYHN-)t&Zrku8iR-!wkCyJJPrvMXuy$pl zO<|xUeuUgpS~AChIo6rjddo}-46m7?p~K;mi?I)r*Ch2pd1%;MAY~wP;peY8SssuR zm0S-ewuvmZbcg(1KXSuKD=Xw-&j+KZU8l)ip+V|G4Mlj3JNERj6XMnhqLx-;qeq-_;Xgx` zg5urASq#$V;THqFPI82d`W&5QPt}9JPl_eE9c}|~{fmCoQm^N2Uzhal=pb`giZ&f7 z_1g(xpfMBd8W1hIJrlgVFBaTn)%edIW>K^|&qq30=4gxg0!{Ev5krQ&tnE0RnROq);uEp>#arjC96ludlEE; z&aXw6q62}Q2R;Svq`uF7-CE-#`N7p2Gakm2{S!(oT4`_c?M|0MlJ1vpyYFag7J>C! z-CBsViSN7belE>+C0UPxxvhZeunCzb?EeNZvMER39~icz~Li5=92Uc(aIJ zWDzSD&I_6JnK($U^{KOrWXo}=k@UKED&&*2LL2P1Y01Gv$|=r1Qzs49=PMXs_|sA@ z$#hBTL933R_i3zL#Oyn=Ycnejyux(L%!F0szoq4&Zmj>rQ7Qqd$BUn$IWCgnZ$xsk zBUfl15a6u zNS!kc`iq@U=xtQoH~o)-MYRh}n8(iZ56l-Y#Od+0p;#BiftO_AArmi_snDIzA++o_ zZshH-Ob;srE^z~%?1wK{qERe*`U@BQdgES0AL%IK(8F~-$U-!pAt+k(y&Sf=tJ0dQ zAk+JEH{Up`_wVRqumd`~>&Rp^O#NkCO<_BGnu_*^2+(Dd_56r{rmW+>Znc8Ai9+j8 zCgA4Iz_5gWbQxFrg_>G((MEPSU$f}WlVZSkXyid{!yJHJa638d>cie}KTn0khy3qs(Q=r!TNxXZ2g(t@pEv(if;6li*QE8;( zKXaPmQ}W|V9PWp}F6A|nxKfxaE*n&bUO}xtoU$lvG7Q#Je_WkT(u&Fk+vqRsD(oPu z51w9VRR(rg+$PWhRZMMr|445*c#B9xBV)_K*wn~A1oWC<=_aGdJE9Pzjdc4+rGBf6 zS6*e>SJid%SiC{A^t$d2J-Q}dlOj`HG{9_8In!0QzlOmVQG5x{Hw_;R@A2>5$Cm3+qVKPgQKm1k9o z{+S!QJ%PS5Jz~5a8JpESq8&Y`B6`jWu4?q(8bMZfZTfu~Qz>=XD8-ER`HAtobLunA z{S@0geo4ana5V(?nlSfn(IbHHO9}_Y)E=#LE$scPskxCEEP9z4>agTSt6&TSGDYeD zRm=m$T?~&%MVC%^8Hh99^ZPKIfM>=6c>q;2~ z=IS`$)!DOSB}In!o70DXy{t8o?ncT8CLl|opr9P@uJAhfC(SwQDZP(Mi-5Le<#H35 zvRgZ(s*<|JgyFBLi>*eN{HCxm0WwL3kmtw8J$vLU8cT|;4@V7+zO0oB_Oje-LA$0Gs0IlpJ(C?iT6 zZQq_ChGhxAY-ftimOibkaRZi*bvCcraS8@j?-zo*q0liZ&ZFxAcfmj*Q z9F|zqu8C5SZu7sKSHUBnk(mGY)p`(9$r|TF#H^9HHgELlUb?tW$?=C=k5fDi`jhCy z(T{U)KG4f6t7Dd^o)VyjIf2 ztl)8eXHk1kG*pJ)Pn=hGb5(9;|Jifu*wV=Y@fY3KzMg|S->~|^>wL^sk8gIUTCy)n z46x~Pm8pDL*V@t)(9w$lUwgzp0U7@myi`_PYjumUUbpT1$60B=(2{Q+;`c&gFqwl7A9|dr zFt4bv&6a7_9FQSXO006L=&RCe^HNY^l)*a=v;(dV(j3cNvQtH-sQT<(CO^tBZ_rSc z-dW9gmz!VXrPwgM=V2BLx06&VFYNvKT{rvH}~Ps2QO zf7na1H_I?vBUxN^#cn5h1c(_41a@07a|nw?fR_3d=a^Y?PFs3ucdqZ(Y$C*W;K|}N z035zMe^Klit3dpwjb|Y7Yu{KFc^OG+iX=(9kv7xqfJf8T#edb0S zn4~oQ&p$D=f#puGnK0{6)@SkPnH?8S8j|`G*6RM(Nhn-K%2avTc)J})8r+ESSqT)~ zfmp_P5I;3p#=VOoI=w%QnI3@iaxnpZlk4Y4iJ@0kHio=T4LbT&uG>U@5wH2hAFu2J z^^?rLAsT#mdVhZuT6%~}?|5OMGWnUKq}KaIw+z3`{x_-FEm_F771D=`goT8~d&#w7 zlpUx2>u2+&+@~5g1+&L@E05g;B+fb+}fCYu+9PSsqJ2A>8WW~}b_NSHmg`2)=e6M2$5e2tl>#p|>1L@DBD zPPF}jCRu4AB0X2M3urNb@eYv)p}5Co-3%Eu4X zX0mMjaW(8@XWJCY6!^DP9v#tLnI9^X%$J z72wtH=a4=@qK#BSD(KHT#8;6YYVc>PwPC!Eu<7+&UVm$MMcx}|>$l!_NOZF68^T0} zo>5hf@h~kK5CTRQJEGE7!@wu8x%lz1Y%@l6s|M;4jSz+$a6|nlZ~eu)n^B^91EqZ^ zOQ}4{yULdUa9v~#$9?={9h;rrr$o%DBgm$w8}Y$+J9C0WPeun!xn?fmwT$o9)=(r1r* zB|~FFKi=lA(cp(`&0;BSd{l+_Hjh+YU%0fpM6lVWpR7&uR)Z*EhmEZ|X1%?!&Psm= z+ScRnEB)@aU+<^ch8qI^slF9?Wuyu6pQN}UfW8IAVfT4)S&vuxADB;nd2aH1xMvF> z0<(b~py>SiuPO)0c}TRD7_GZKI@2(vV0Y_m`U{oXv3T{rphl1zkO{EzZ7?DYAarxG^``$aH9^ z3->M{)5ev(S?utQI6`b_>=^S}Dd294Zv#X0$EO@KGSIbLnedEk_6-WRNA|sQME4+E z`C&EMh^G zi|URX;oXyyv;64@l!j>L(Wq>9&-@W9xbpC=b%!lGNJ z`L$>Dn<-xQ24p~j0b{r9S?+>bw)2O$xiZAW+PQVuXT|qiG<2Ll(mPF&%uLQ6OOvl( zUrn5i3H1|HO9-VyQ0~_|5x0S6;D6S#CBuCSp?5~%rhm4s`b{o-#!*Dn6zo5v0rx=@ z8mK~?(5b(%e215c-O16)9pJ!a2`}0%VMHmc3?ymSEMyH5R)XT_Z=Y8TV_5TK)kC8of{KVC8#-}Cm0c&`*cLU;`_-B z<+K~{eRD*650|v~i=B;H(+5ipwI)AuR;+`Il0$9oLCB$4@+)@)aOWQ>=W_6&LDHev z%n~}6URTn4o;bO2jIk~i)#*d4VL^+h?@wpVwi4y&!N(@J?e~Ymp!d<;uHs*==v)WF z#-tLilMdcVh1f`xb};!_BCLTwr~F9;ELXdqFlElaUpVe$?vvN0?ee{g72J+>3TGzs zUZ@#p`Py=w8mQa?41-E+N#}rU)cRi>onA>a&u383W^*azVf(#59&941CtGA27xN184)y2s zzyhf44a_!Se?^bXjk|0W)zbv;AEw5Yg|9uc(ViuRQI-K(Z7-4!Gdz5t0ZE@%KP&l! zuR6Oigd!m8ydJA3Xx##m8ffZlxT&uB9BH)2iNg`%_!qKX)=t$2*vQm|HJG67NJ{z3 z(h9+ofyLi_*eii4;(PI_a{m)#Rv3`}Ie>vHmUgCJH$<3sdVlpn&4!qr_VTGmOAb`+398PXM;hL_+Rn020MfziA+IpjD}I4XTd(T zH6Us=XlDKuQNV(u?=~y)X<9oL<^>~Y$OZe3R5UEYe*>TT%pQZ?GAAE|&jVgoru7MIQI63J2YK*$uHtI{!*K?hEb|jqU6>$js zoRvg~a?(y=OFAMwqpK~y)nPomq_yk8(HFTIk^WB~x4AsK8fFQD$$7OIr|{&}LPG@L z^cI=Dm?b=RbTQ5`*zFF2<>+rXX1=r{pO+!pWv<@^Mm*rG!V?xy0mWbQ1@;*(mB>xLgOp#9zl2E?(n0>?JIgowqq2DG5Q{H-}0=Xw}i_q7)^@ zVuyrRX>5Ft=5_uVHMR7HTSt^CJ9Pl?xOC76=Sre7HnS@MyN=FOKH8jZn-z(fjLF>} z4flrOmC?NmiUTSl*KM+US>z}@iImeK6x|UFeT>B3$#e30)XmZrx1<6HV7hE$;tdr2 zFH9+J?!tK2dkO~$_G1h+WqRCl2%`0U;W(lzCA3b%QHk5VT)T}eO_+xZ> z5kGqwY>Y5#c=EaDN66+658!=(5;zCUY%A%u=i%h}PHxHLYHxTvvMI6{*?YnjjaEK3 zw`<^Q3WI9=#$UyoBTNGXCWsHkq5lf5fOETz;}^kyrN2@m_X7+nkS6gs+O`febduqu z@}@c=@$6$KSx+2YSd!(0+c@Y@`D8DNzi0G9t}D?pf=E+nJoKX(7>(XMWv$Gf|AIC?%5>qq29XzrSHID%1A^Fh1;) z3dO}=Acnpji{T{W^51lGz=tumvpPXzZ3@XR!C&bY_Iy6lHJRreUrfruC-xAQoobA^ zcj&dMR6@p>J%LZ*?n9B&jB|>4-8IZ!R~4=g+P;a|{4jAO`Mq^*&D-81BbWcw^S?vV zu#bqq?6UW*knkw`Kdhv2@G;XZ;J>~>o|P1l5*>$eL(Q7tAcnJ)l=g$55OaM=$TRXrt5y!ZXvzO&na;S*udhQ=e8lJ@yi^nlZqkFvkUdTa z?dG-Id=6&1ofg3JzPl=eL#NVGpb|Jr#Y&&T!xW~hmz7PEp98cIF1K&I`;^md!oKem z_3yK6aR2`HpR2N(N6Td?gw+PUgXby6+FGQ%Mtz`mXm|YLRIPf*(eCv9 z^lDj}HWpX$u*=*@@{00Yi$W4vJ&{&&?OU1!d--|*x-O$a+^NE%h@!G5CL96$eZiy^ zE&i$binwy0t#Mw*+AYh_XXJIiU`kAZ;d z9|uqllQ(wFWy35_9x0ZiH@aWQR^L<3bQgn}{C9F`E;f`&xVm$&X|VOAb7U$z(wQ84 zquwzeb6nuH_mHxp`rv2?{(&6Qo%fExyXGuCGNpE8xz}7i4>q8r)uV5s?Jzr|wPAe% zp-2XsectA+&vqSno2=DN(n&KaHpe*8L;~6mJM;j@(;tyusYdywlpaOSY}jKaTu(7a zgLv2I^KPS5?)NK*GAHY?TUiiFN6)O8+^t%T5y84kWMHP^p8CqQ%4$0R!l|f_qPAKo#&+GR?rKp&5;5fqiC zrf<3<&Z*V$&2N<-CH=}9S^mj1mT26I6QuGQrpld7hZ`Sdn-7uY&UOT;|3j|$dbR?w zWnv~j@)H!d_!v+B5{!V>Gb8gNw~x+;U&V;#x7@)ByBBQg#cA7gg`b*y%qu#p7GHS% zKM_pe>EvMkx4euu4^(C50*Cki*|9g&7OTBabXpzZh>TA1Ui6kTdH3Y1*H)GksHq8 zx#@uOPW7cJ6)X_ig_^00J~|eOp}e-4x05Z0ysbyZq=jhsDB6vW1X%mI_w!d zd)No77KY)242gW^>B_9c1B;4ArhUTDUkLZ91$O|f3+OVl+^15Y8+e$_jb6RQ(Pypv zK(Kpc8_FpIpF3>3(^4}s%b28i3nL!cIEAVQdqk%+n^T*(68on|7S&ynq~y|Q$)7Ur zn<6()-{kWl^}gz%=DJlLv=mpIn_V{-$ zoFCj&+H{Y|t<6?*Y3hmkIT*^5F5V{I*>$b6ps$UamYfV4RaX0`i_p0;pEvZ2-en%h zL@0T%F$BJlM-{)$X{#S`s$FgHqd8iy4!|V@Ax&3wf@a3fxbYLy!r=WxoMA1w6eMft z6jpbeeuFP;?Ad5t;8}a0Wi%8bo15+(bsu5l&fef`y|%&98WSq5=Lo^ww3b?_PkWTO z)0XrXHl6(_N6d15CtS2A(0lMusyiREh}28ci8a~|7u;jxlY_afDHQQiwf!9c(aP39 zr&>A@w>*7AIxzF=&9~8qARW}if7sQ7HMO4JjZ^RfJVc*>3F6*?#`1n?=v9mji!G{g zkDRXhPYXoWvY@)UNI~}A20LFJG662CizWglJ$>r^mq@+sQOu zkw!d1ZN_b)PB!?`#iH-42u1l_daIa^!Odxm&avbipi z-~SeW7%9gJM%yGx0lo&*Z{gn0924$)sO+3T|Bt1!{%f**|Nm_wQn#WYxmyvC?k*El z1Vp4`Al=PI?NU;tM5Ie3l^Qv6Bcx-5bZm69!GI0M*q8U`@%;y`U(UyM9LIScuh;8o z2o?KnEC6-**uBIN4xO_4i+m$qdv6eJcT@RFXQZBrIw(1$M3mQphaf>&FnS;_Tj;S(pm}yH6$KB|S0n^aDoR*IJd7S3(d4YH8wPnKRvrH;#XIa&FFgOl& z_SXqfdCS%c_%nUg#zqeJ1yhKsnTiPWtIt zB~AD8+=XrM^}8!l*TlZZteq>F|9`tVV3yyMo#ECx5AKlux9jQ`daKid{`tE9UzWoi zI={OOyp-ndoPJaG<8iYcIccYEBM%x*4cRE1OvRQv1WL zOsd^(C%q9*V|%bfS$_>ozxT&|7d{BolC><)$7{$>OGv&Mdm3I)6Q{2SNCBeC#-0PL zCXiQqz5mGhzmm=KS&922X#&}_oC=}f%a=5(`WHcErY+#slMwzpB92)FzpM4x-#x0x zDCOws`+|CU+bVZ?I$LN%alZPPU3k#$=jdL_w?wg=5}&X!AwhG)_Dj}J?SsMqLRrhp zAwylTn_!0>GFF8Wd*%%e5Cci=)iDZv-MrWMrAJ0FXn(@Nj_lD-)2)-5GSraH*VDc6SJO3Jz zQp3V38d`J#Nch|8o6H`R?D0asq*7c(Y%948{N$*1jJb@~BUyynltejrM;Ph!lPML~ zJj<7Msn&1sW2gm|lVeQu;tz+`Du#a$&7CYpjtcP1W&DthV55zLCvRv=scUttEo#fE z?mL6_jJZVDxpm#kz})KKUu~8nr(4fX>xNdNHz}MgFl?lZswRNBj;aXGdmB!2Bip48 zlU118s@j+F*K$5N+DL8Q0ePnqveZdVbisIbqBkMj3y>uGqqzQyn))t zSGc0SS&J;9qFD&bY}sd3x5qQS&tw3L43u*uaQ|^CX+xQfBWpW z|6Mhe?h@D7XFRjKw44kkGC2nah37lGmnz=2XdOK)LR@qq2j(SP;*|XyRUIu06NG_HqN*U`0H8FI0cN{nypKeB?CtVne(U^R;mai(9J!n z7?H53wS2ZHVSVMwQ><;_z6JADsH0Mg=x}p1;ZBYHfcinxam;NR(m{RHg_R*eIm3BLgW2Z zV6V4@>w5N379n07!S8u{>9oc46FeV+>W@+<%;zpteRXQ}Oyy*)oW)BzcLc^z|DdvR z^|W`h)1tY=PFtnUj&1fLDQbiG!$=+bSz*6|_5Izi{X$me$2H;PVsj$ki7WM+OWATP z$k0iCZjnPn;OYhd*iNXIR|w^yE5OCUx)F(~RtWpW(~UTc@fR*PHZC7EN} zL1!K8Z!75Gvm=iuzMdyv$bDylXC%WSPdtU9&m<6}m#Fjj{+1#6(`Ca)Dj8~;HITMJ zf5MRi;1->|2coIC3n-^-(sOL+m}G>W9u1OyWUUYqOAU-#-450)R!p-YSqneU2iVMl zBX$sw!%=gO$j&sYK!-q+6c!d|GegZy0MlL!XaxUWQBlq~@b-VRYo#+~JKeRsLYuv( zVS`niUnTU;h;3DvJFJJxvERV>MDjZ^0dLU0Syk!Z<)?lDe7}hQm{Gdhly9kK>{P{< zPk!i3!mYJ0nSan!UStTw5t3?ib20>{UoP@?kA*#o%8?rn<%1uqAh+=OMD{;j}u z@6z$jblZJKpAbpeC~_1d;zV+yt)hQDNf)JaFq=@DVb!z}KJyeWQvGF&28(Gj%;vt) zFDSYbQ*dD zpo!_!Wks(1PnGb=kCQ2!zvh(O#7rmue6Z7ML44Yy^W4r509U%J*dFUN?#(rO5MzVf zF801^e$RoQ6@QdmoX0$lSXDTF-l^k|d6?A3@Z+a^1J&u9lt-hTSKO zL_V(+k#lu3nW~V1ph~&P&O$=N{DNPA`SEa9s&*3S2IJ&Rgv<2`g7eNZ|Zz`kt6a7IouO5 zj~cD5q5dyl1!TInA63d-45RTk!7u6gOSL-)b~wxH!V+QK;O_1V3VXCF@Qqq?hw(rK zQBsDf)7)0#t7|0~XYJTiM!R6U^_2I1t(rMeH%!w|PQ#B^jQ=k+-eA54`l$y@`HSi} zUtrms@kY;TM7L-!dum%}YN&g~X?z%dsWEkaihz)4H zqbH&h=I22`gP_~3fcT2lbOJBP_{MU~-H##@H$->R3Ai)wWv`BU&xY9t<}}ZjOHJQn z{xdH=4(sfpbw~ntSNfkAJ**J6mWXFD7?(cIO1bsF3pz2}ytnBH|F#vb|;gqp5UEg;^}d}oB*s7{r7`=j|R!s6UCObypT zyHLVc8q%R^mkIkPVI#CO;XZGYR#CCK)GVYBnqT*-ZjX-Cmvok6Zw4eZlO)QioJx2 z=7lD_%`-mMxT;`-KP?S)N-w6iB`t8s8{IY*VA}y?2Ac6}2sUQo(&CL~>VB{|PA~mZ zVsf458oJJ2yzQ`>5gLpmu9C~gFrE|!StODX%mQHQov#iUt2HoEFz_R-6?Xpw_>HMf zW*ti-zpY+teY}-st!tjc`4u(x!Xs!l%`sH4725dQ{V6IK6H{0db;s?2{2+5VEq-7B z6F7RVqBMeQ?B;rL`znvKdgfykz$OF7LfIg*l^COegrDxAGL~uBGD*!}7Tk$Qf5tOc zpmCzdjpXK^T+LnT>ECMr`MaF6fUA-U@tw@#Okv#4AFyz}*_1=^bH6dvxkK#I);!JP zIA!$^F#G8*WPC|9#?f9Rui?LHDV>*N1lSScO3C7@4}F6lJk*07j?|$ULkm~NUs6x! z9i1-7a9=;74Vl_1XSA;?IZ*9H-8sIZfNIp_z&rzug}3Eu+q$fyPgAS2a5rDpM*`oO zVRU;6+4Xag3A%V$kY>RM^qrDeKYrw!#rf&f{8C#7kEzEB>8zbv8B!HY3ty^Z9ng5Rg_q zB))(eCR5a~Fy2|0O;nyWrSgdEKtNy&wQ`Os%|7%}C7=4ZR1N`Ry!}DyurGp4<-F)c zC@OU-->XFB9_6IAV=d^1YZ|^;MKGkfX7naE2N2$Vm>yG_b9lC+dDBoP?a3@C>$Ok> zJZ*m{6zzQuUi1;4im5Sc{c;Qb^Zh3{?@p!n;rmm-mQ=kT<%VB8Ty@Ml=c$kvWpxX_ zb2MFQrKcJlRq`5X5Dp*eYCR2w&wq@cRXZPNJW<-gxh9kgA(Ts%iN=ds+|ko3)sqoj zfcTF>2EB&C4>3B=xAdvwaZ4Bbc1qTT*7BlN#d9E(J=RLG#&+I9=dKs|WyTMWH*^-bApdEM+`xzi|7y57-ytQ|)5-mWc?%Topa zk*Sqd2I=7PJC3rE{ap%-T)yYn2^4S|3q+0_ERBlWt9S-5ks8iB-kG`2k_c*s$ARd( z9#)6!0l?t=qW}!z$7aW*_r8R{2wjGUnw|4FsTFL>|JubD$V!QcGPC5@js70tZki%z~ZyBK-Cm_ zODV60yVm-a`&;^8221NFh_>ZL6d@$2k+9DI)jY|pPrU%pta2ap~>3)a-GQK8>~1DKN)jk9%oATl6*(7pOyw1?`yEvq8AG zZV$~(l>J{N%b()FX@>~$sWbMZ=IeuITrR#S9-i}IobW0XpZTRJlXz{x(CzNp1X?ah zn*kk~RS*RJ+b%ulg}f21z&2N#%Pl&U(QMiB=zxfgcD-^&?s|+w!1<_j>*`R%*Wv2^ zP~$g2JxDDz>|o}#BIB6nZ%+&l;)hFnpL`HrTMPM-%vcZ9kj+wy<%bNL44x|qlblUY z1nRM2gUhmlV%{M2p4aeuu5C-fE`m(iiOHOyKy6>oc}R)DH5!Eu?=Y77^W1|fhtaf~Juy3<`2CQnh}#y2oq^X20756a=>@!Gpsnf{ zmdy)?x&w5a_w(7U{|l$&r0AW{$|YNH)m)GBuXTULtnBOJJ@pIbrxVD1aAW9wbGiDu z#+11ovRXP?!c?&GC*xX8QNI5=>I{0g$RH`a1~s01ph#urbH_9?`{|IpV#{-m_BfuR z7k$YfN-jw#srIG@Q|HM9Vd{u&LRr%JT*S!A1=x|Psyf%YG-4%O=(DwQZw8z&`1^r= z{U(-`=_9!Q%5B!!|UlYTajMcY4FDBAPJt*8j%BisH_} zjfMT`yG>lCkNQ94r`8I4b?-O7aII>lXvKKOA9C~(lB+FFZWIQ1lI^|DkQ@W!n_XGLp?g`45(9@bji7Of&DEyt5GpG~5;oDKoy(Zj1>n_;m zSa2ZIX0Bm&Z}Sz>f~0QAf|kurZx6*r0``Iy#jTjKY*BW}Xax0Vg)JhoUDs3Zn^c0u zY<}r9kCipsZk`|h`&?YT1pKWov6U7-qfS=%;*o;+-J{?!$n&Wq(K03ZLz9tN&gly! zCauuWHRo`h(8$9Yfx$41116>4AGfz5WTy zslbcJiMFB!-*YCkYP)sMnI`2XT_Pso?Ppt_YFQMxJ<)GUnB24if?|&nqFwFx_gKq) z5g@0UP}T^0E=YQ36Uq&gY6;XcF_QKMAPg3>TXhr6suE55?i^es|W+Dq_!uR5wl^TxOvo-Os&35SS+_U8*kRVy>s#9&{n!rm5gE5p=o& z@i}SM2@}ig<%H5}vq|r`NjB>)dYwp_UuiPr|LQ@jws znrC++59X?WuXo5pVaA?8|LsL?)?lwUFSwk*UF!i-hJn36>ooTTN6xZ?nuXR#&C1X4)}=D7>O4YN4*byxq4d{i!q>{-DVi*p_Em_UQ}~8I+>` zzr^BbRF20~+FIH!E0xNC;`vXDP>+iURbzcc7y3{Oq)+kCs!-RCUcPNTc-+<4yQ;E_VXX37a~ zXIf0wpAX7isU&EdJu5K)ojvej&gBi@ryJ1Z(y|w4Xe;5}Y1=(^JXa^bPOS&lrny#* z5#LHuoaNFU;Mz*MM>&UHJ;R7@n+<$$u*)6W0f>l;8?sdjaxbb6-1DJpciK&xkVW*3 z;UqcUik7%wg)R+?iMY*7RnVN$Wu6mnCGqXgHcbsA|1A)lr+ZtpQ%MTi5d<{{>%mlCh=UzlQ2 zcx)CDxhRcj_sC%FEXmU=Ou%X7Nr_remxOYfa=rB?b0Bo|_=$0leDdnV%rzct#@@3R zq(xu1kR}{YaLVFIe{UuZ($-`oIC@!JNnCyA`$T9!@zm?J0o+HhmTt>`Hwz(q&CoLjP>f30nUD0A8{?(#sXJ0 zRkf9+Z`mkQp?}3)^$1o@|o8PVX_9w25XIFaS ze~F4;s3(Qr16da~AbBI3U4#Mfq*U?UEI%i_ zeSTfmOlBE-leE;YHQSRpsVTlrHurehto?!I7+6K;w{=(!H5)*+e|A_OL^5lFT1o0@mLS9{a568b!K-9jz z@wJJ7%9VUKvLDhAN%e5YlZebp?yflWG*1d?} z4dI-#{5nCGqn|jKeL23l$vRHs-#wza%p`w@K!QLmPssGZBshfM5wJf4#Y;xIg6tUo zW8JK#VWhK?N^_Eu*&u24QO4ccFXf0t7b}MwKirvQ>^!L~L%vw0B))xZymw1>EYSi8 z{NAX$J7>*B99$r_*zFK`M?`6 z6Y5MD;Cm;dS1GwEw$I*X5E8Bg?}_%-ey^%P?3Bpnp8#t8LQr2y5D85vw~(Z@^6E``1JeSl>nY_@cPgSHEv)}*M>J$mvgAW&lm`%1QYYjNL_ z0eZSR5gn>snMT!^%IWsrr%;#GUWc)~dz8TY?%iugkn{6zuM28ky>KiTEf>!1Nw0a? z^iVJ=UpVQTdDU~lgwoz)sL>LnNiCZjd;p_}=5zy-{R&d{X;St>1J-Mqw}3{bGyC?u zRWB324q5aZw^OT5tpxET5o70_mf>;e!}tQ&}VCQ z=MjjDlB8bv=okU3DZ$YlZDB37T*hcLP((O648`HFzYS-YS%yzc^zI+9ER>8xUGER1 z5t(FF{oliG&F!2{zq+|L2Y^N!)oT9X9B?SBA9@R%*>u|&lRDc>*-h}9z7HfJRz;4O zZ;yhkLtJ(W|CN>U)f{_y zdoaddolQH_@J=qxtT&&yrPQ~Ckzc1iszY_M3Rl;Qo6#0;D5kwX`+?j?RKBtx|0^WD z{a;BPi&GoL*CO!E-#2U_p2|~(C(bE{N~*xsc6E*pSF+9;E;K%%^cej52=d}Ala5nC z>`5@&n|^gvXweSGaa?J=ciGVU9X0FKIBw>tIlK1GH_)Rd_uDJ4?V?8Ct?1y^|M;$) zt=07PHzGXBxy6n)~^uWsi3#8`N-X$yk#s@tjcAemhQ0 zvX-=kwrXHGkrt{S-`jV&0E`n}I;0;Okp75o3al@xEW7!<1?tTY#?#Sw@KGe+9o2kG zVDfK& zEbWOMCZ|;5;8I*g>+e~mjWcdB=+=L8Qbr&8w10~&zDRR~Z=mPEbsi)$bc*SNw`$?@ zqAMp$izfcJfZ)Z;iL4i6aF3m;%3n$|ovI6Bv#;W1Cg9e$*mOk28Qoo;NxWC6`qQ(l zA<6AmT>$?w;=_)Fh)8f*j-tuCXcj-oU0)CzeYZlnP1N1p3i4#jEXy@xTk z6OSTNGNfPP#&>Lj02V}6c;0r-(6^ki-uyYcYI7`2x=!bH^sbEwH-muE3xeJ%oU3qP z+eXwla0>LP<(**T^+BACTVZT{;6KQVnY)?;R^eh^o3Yj*$sm1t1I$wQefk=pWQ3UU zeZmhgdkZ>6)Ec;>E^|C`BR5=vNv}JR`Q@+yv=8OuJC$_wrNT)DVfuA|U| z$R=j`267}XutHM1e91;6^U4lvF#c=LH5gC;k3T%pBQN?`5khWHN!i&>T!L;kl_+gt zBiOy2X-H?Q`kkXMOH_bbTrSL!Ml1!nbVH-m#BJgWNw#0dLgn=~(RY_q_4Xn&@+ebY zdz*Z>#`H_u<(fAj&Y%DKH2u4uhbZ%sf3aVz750g&Rop}^jn1-qsG_e}CnUN~0>Df9OCS+K-SXL}Db49TcirzTFcJyM7WQr6sN zyUx(Ka_wTJ>gpXiKdFC~&O{@N5>cYTDUg&tgDm{3!zSrOzrhW@KrwAT=!$;i<86p2 zeegPcybxpahUPZa{MZF^1Cm9j4-g|E#qAq~cS?A9 zEJ8mzdhZ_s{l3_n+-?qMHRtpA%mkbhUo~ ze|UD8NsBlU8zF*jAx&QrlG#`z!xgD;dNr?)RnVbexgBZZx3%ScosMo6aBat(sop;rWXRSEO0~6F?qA3jV&}FSs zUX0;9J76lC30bqaZes%WolJvka~oBit?inbphn52yDyCj47~4@bM2Krn|{&hlbeP#|FaMGb}IrhYi9UHG2^ zA?chxM8j;M_2;&jTp5Dg#h$uJ914%d3$ShRYy>Qv zu49E%NZw8D*6i-@i`~ua7%+h~Pcyp2SSQZ!_`KZf2ZZ`OuTvhbQ%QMwuufh+KS{9k zHS^zx;s*W>4>3_SEKIxqT1=V7?YFEBQ@2oGv!+wJ6T(muM1lu=Vh z>ff!-57!g$SJtl}x8T#qug;_38inSpvE;-gv?gm?CN*O*t7}=vWbsbfd$mS1c8zyR z#_(eo(Bjwshpq%0_wD!t`?@CMp4nX{>XJgxr>@=xeZ)|A+xE?Kw*qphb$hkJ-B$nj zopHWa9lyOs3x-y1Lh*9+detcCh&KVf$~a7 z2xZ9S-gDyaNK@I_YwR>E6h(I=ga(_pSRVqM9hBX!DrNby<&WYjMf*_qZ1VN&TH-oG zz+R$)uQNFq+C30{`_RmB-~b-TiVeHvTCf8iSOG60)7(cEm=wZy`*sW--Uy6TwE>&;1*DkzPvuT?MFvCRQ% zY7@>>=_K?EHpe9636a0^oPQ1!7rv-ePuaZU;58X|WhwiZMHWvIn2eBc# z->Rs5_o~0HS+VfrG<7DZ|LjR8e(hF4I@4m?F24r->nBRn!uS5Y4$L-r*K!Fr?J@w5 z28?M~R1by=+L-D}n8`KgzWmmckMtKWsl|!TQLknP)wb+!s5M7!8`jT_x>Q8tbXb)T~NRUJX& zH~7o9txUg}8#XgMQR`&O86)(b%0Os}e9wt30xn(~e-8aYifO{P^ugZp(_6I~7YwsR zP2y{)l2%Mo+-abQFe(H%;P8aLw^HZl@x?D{>a{Eo@fQu6OgPC)Zr^&wn|^gfwpoU> z#?daviQ1ZKeI~m@DwwR;^_aaqlSapc{%?q^kfi zF5Qs9v zH9s80w4-o;`{*suvfy8f_%uVqMs%E#C()IsJ zJ6O$Tfz?gCY@RVd4zwU7e~yCB^%rJ=uw|>c#;^YlsrRu^KE?JARwXS;5fQAz{>qB3 z3^_NI-G`zMl<+cn_q7v$fdqoSnOvdKQh+<$)Sbx_om11VguG~j#(_%8xS|;)MPRa1RRk~j13BeB!Z&NI8 z4V75Eli379?HJCVLQOL(x0L&E+ZwXqMf2_cI&>tRtgGJ3a0S9zyR_?bPZ#4_OZ>(|bgoL@wLmE$C@tupjHwJbf18Z}$F@xuCB1ivlul@-Ar zuFV6-8K%E5vl|zG!_l(mGmvPQTx)~wO(?QMC?tI-p?ZD2)m9F=-7E(J&JjJ^h*$-i)& zku@~hS}eoo;@it-d>}@lEHzL47x34&Gb3x`rq%-6Ch1zl%zsd8x!=2}yxC=gT=6mg zqM6>68L`a&nUP_~Fz1U3IN2hs1hg)a>$!nQ?GiDx?C_SFUu!pyrGrGat{JBtEqT~j zX*xKd2)NyVEG!3nIiX^51q*y^`FV_3t`|t#sjm>&w}~`F%>L(WpWpS zk9$JiyW!&=K9+A;gNrIs zwHEfI>`8i%$4!tN0=&>*`$PflHQT*h7);FnF#YD-jW1&@3_4Qlq2Z-WM%mw_J9h=) zV5Niaqju>4DdBmOGCDQKyC*PO*++HGQlWYe#Z?9eR&bPLH=~6>hP#{v;W}4O-i2<9J?41u{R?yn3ksQgay#V zf;V1nAWP@Iolo)9zPxPp@mb-%G-`ctQfdpk(_GRc$cE_M}VXx7s`YKcS8 z^26`7@b=F1wYwe;!L>eOXW#9KSE6CQZDkyPGn9020ZsEn+$P$`R;pYxSyf&e6Jt)C zzW`tiUgek>Lc;NwBR|KPmS^R`R&%bC4`rO2+WD?Sv|lz>rs0>TBShioU2c*6YL~7? zKA>ukJ{UYc-MIBlDZ{t{6CBFijC?~Hpw*G>2;54apd}^P|H?aTKsFc0HsYhk(Irin z%@v2L(|Q!vB?Zo-QsNCU2Op#or$0>dTix~j^?=4*)>_`PuT4+f#Po26&ZW>+-~T`V zpF^)O0;(=uE0q36uQ6*|M3L&C>4BxR3_vX>BEzp(V7zTG(oFRotb^T9%pBKkXCbGb z^i|~8oYC!*)@%NzoIOKBNmS#pB88Y0NdtjFhUAQ%jqr_*f$9f3r#dGlJ?iddu<-_& zsrl`p2uW}OLoTz_7%_1KS|SVaOJ-LbzEAN0hV#(z%$l^MQ;Qnc>2BM@_^-2Y?@RB-i0 z11AXlvVAm20V39KN(;p6v0E?$9)Ysog-6la-9Ra zlyf%+Or?4geq|`~Hk)^?glzbrky#2J^#U^^W>E%jNF6Nhzi0f$7>^5j^uM5_$YO;V zlZxqq&;C+RHz{W)z$J6FhnOGPUD?9=A6=D^ZfBRa%P9JM&j{g}n4NM;@}TlkgV0lg z2UlsFoJDG%orAxcXFApT>{l%_CRYXW0y?5>lj+M~wXi{uJXC4I_|Cg*5?$8z^QXrg z7pkA-t#oC7DpHH$?7jl75A;!IQhwv^%`w`d`djg*!J5-t7UscVkpMoH}6IFn1^ zkyF3W>CoBt{^W-!A6f72;7FOlXAo7O9TrP3OE_D-t#RsR9@z2ihbjC=l&$Wy9b;!T zNu|U=>FrEc!gQU4pX?%J#wz+pK1wB9bf)oG*wva(m?_)%PtE|mmb6*eNO_0#&Ra&vmtOv zc5Sh_E?JR3=b>OsT$o5sJ-23v&_Wy)|BpqL@o3QNTN$s;hr|LvjHS01R{y~?aC8H# zs&xhUK24(~dBTYws;>|V8Zb#+OdgD_ZIPt6@~VM?pMZ_Y6;vrW_lEn>T72;8 z8~{C?{AT&L<9#%Awa8<*TE$!It=ot!%3POnJg7x?B99)_=uSZa(mCYrt%(`Wp)_zBdWoiR9Z8SlC;hAAA$2P03A(J`3 z(ls$0jBn^p@JpMNJ$2ly2wm(07H>iyfElCtH`&HEQR1rl=?tDl1mS@)&q^UCQ&Z-P|9rC<%`zf>nzODW4#AEAALVxhfOLX_Qnk~pn)4PZoirKklb#-g5S3- zcjJxty+jYQ=Y4*Ck%pZik-mqN#fk4c_SkX>#bd=I;V#_LpU151IU|Zl_-d2@&U{h9 z!2e?H(?3GnL7F?)Sa=&pH|NW+*-;L*3_*|8maB;_$t}oxijyEO< z^XUrN1u~Xqe1&TN3j>cSG=5!R6%XY1wYeJYneZq;|0z0&5YM;9XfI(`^Ho}Tw(7yd z+kPb@NE62RsQ6&Wy|qKrLuBhhuv8LOtZdI7co#JGoB;0l3eGub7Bm9LA>)x|q&>Te z4JT4u$5C?!zNWOa_Wi`*;nP((vTD20N&f7`{IEqY#Evd3*MFPuexVD zyQg^#e~hJ*P=LE8pGZpD2kSx|ejoBxJ&Am=ryzg-p^czIseI}5Rc_;xM~BR%hF0uH zrV*W`wJq%5b*MUFt{f-VEnWkuZ303|al#=L4_kisg=1Xlhe4OohEggz$eeml%>!u7 zvtx{`wo;H>5O4q^HJp@(xsbYKG{_9gj^}V(y3H?ewU;k8p;fzVA-!5-pJp(zDODif=FZ$gsX?4Wj6xgAfo?%_C(#9^c_#)O~P9)urd1L zdCYUF4(nwLe>`2iR7=!tysgoggP;Jrkb?ENN{;2(REK>%P%%YzA#s^0@|xG=>gY-J z%HzLj!lXMETESozg%l*kr(c9{8k zwde5Oi$X}O@vzwGHZ?j_K_+7V$acX-D}+{hyDIK*ew)1)SvgYui;5p!FiT4u?HVY! z#%{?&TU~>xm`z1*qE)}$-DTne$c18OQNWYbzh4lp^w!Q^Q8P&$S98=${>rW`#_~Xl zv*z^7lpAi!3Qsn^=-$kD5%D((;u^EL_^*ayT!&WP<+>JkGIgfyuUq!LlA5{;Yg~l0 z6wM1TdAMt*0eb3xeQsF(SpQtv3ggfdIQN7po(cVhYHL2>@J79N7p&DB3h3!{rAMn1ZYVOjVT$J~8}nn+-cNgH z4GB?O(Ag!xW(k$)e*eYOLajtNpwIktgXD_zzX(%xo&~5HZC-KR@poa))_&@>q_=@n zPe4`4c}Os7;T7d*Z#v6LPjDuc*f}lMd#z4$OIyEAB9xC*qDNMo^!5xM&{+{f?#Umm z-!{(alr>m{YChaBXlIXPP2)Tt@4BZFb^OzV%=#qjuDBMR#w@r7?Gy!+xsh>XMMYS_ z!oI$Y>zk0tPdY1!V^vpvJI$u9Y@YE5Ah)V{PffQ+&a-2Xk9UI;O25K^XB^e9Z9HkS zm4--H~pEKfQ+SquOC zqCR#~==+FpfM1g>3>*aF-YbIQ)!DP4H^KA1n_ZwS!z!gonYIU!<3otnTe{CM!fuY% z&%61G>e{Pn2MuVj#s$^BJvF5#*3dD{vTVDp?rcYai}RQG@L(PBwIJ|~MvSww^`2u% zolG0ysab|x+gP3-IM)Lar4g|ZY0a9JWuuD>)7@WUalVqV zCWoVGY4*r5xC>}n>XY?SG;sL}&HEkwA`jLI4x!gQfqND_8oTqLQQFB03E4stk1%@| ziL$H2eQ8jM|Fti19EA*C`NR*$Q7FutBvoX3t>g7mH=yCw2O@iMOVsZE%+1I#q^XF z+f)jcjXzz@GG+NbmQw`bCNme{=Cv=V-6r&xD$+Kc8DzCu{75Q$yrOG@bK+zOcc7aY z#@17(oM)ik*LERcQrIr;=|{^OZ~8OPu+RWtSU~nci2^8k=BN%WnQk7qggGv-C2t}6 zf4pb$E^ny$!YLp)FU_Xd@vRFY(;rZ!FBVrSbT~jZTf0tCnX|J!xt{ zzz0~Le32uCb8QO)G5$0`qx46OjAhT5`a~>=l@Z3pW$q_Z2-rgwo2``R?R$p6t$~15nZTS zRjoaWqV|j(cTu#ps%no^)!w5vF=~rYdq%9-iJ6d)*ZcYYa39D0AvuogI?vx9=*_>K zeQ|*E<|aNq9?kf@DliAez9MevZ6YvA&4eLsh0<65R?}wZ*>T%bJByON*M=7e$|~cz6)t^Ur<$bVv=l&+^)qnkeHPARwrF5E_XNOuE*M;5kJ*Z zrx}Tzt|N0_>7;)5e8uqAN*md|;Z2cjnAq3dpC5_RUG}J3c_-b?+XnZvD;%S_$GjJY zkEn@%9v_ZK;ny`*vUScs04Jmp0c#%c6OHX8dh*`klnrOYV*BAaKN0z#rRQ~G@F4Q( zXMCh&eDwDvXFzuc!R(%94S_ubpY4W!TByYEB@&A~g7!(_qSnL5Eaj$q>>;$n`by49 z%!c1gAkDY!n-1M1!lLf{QmI6}m9mjAc#_gJH_+*v;_&k#Zo0P&h@5}|{@Q&uQfk-p zRoL_%m zs98=6!qU0(&sFyhtCX7Eo|Nj;+|+oU7>5koOR;X-}KbgKwiPMttP53=TXWB3X#3DgwMG7-e)0bUqYiV11v4F;Ln#A(c%mdA zdJorr>sGT$f7ew=aN$Rz;p4fK7w2y(btg)t8dT?7HmQHZ-|4GRAV@-L?z{P>7IXa5hyri_H`^QJiCfo78C{^^oavWmKmD%FJV@ zb&%h(Lj$5`Vtj>O_E}~CtrisE5sU+>7bZ^I{gWSL)GF_D(;VR}HB zR3kOv2$tlj#V~(=Dg~6l3)yEdGmXmB6?z)K*Zf1c!PKXQ89~@jR%ceNu+Gi8)(EO6AF@DV~Udk4S|BlvYwb#Ld3#$Q4;0db>4qpa9w&RUm31z6-x z{8ndOD<6FYq7Jf)*x?rHv5^^A@rmquNU)NHvutOr#&;6ZH5_+Th z8$$Ovr~iF$cZ61A{g#R-onI_a5xmbGqW^nWF`z>2q{(yn61huU5TmYn79}Ur^|;y- zq~5{d@W;U|9Oloe^2fR!e%O-TnP9-7&COW4@cpqA`}YT}}kfOW*rj8fbQP2~{-JwX;OeZf|!``4f}%(_CTrreb9M>BNlia}4+n zw9D;3^IWGOF`kQjKGr-c(Xr2v0ia18`T?-U&J%nfq{qve=-#hqNr*ipVL(VHn6A2M^WcT)eG9^@PZ!(at zh>zdpW^g1qa_&T7tp&Oq!i80ELP8G3@eWcNt!R*8sPrryBC5TcWj*+w_j*8-;^9Ci z<6WJ*D2$zCx}75hJ?S=D!i`S3IQG;g*>fIARv=S{G~*v22#^y0ciKpxKWpdVKYR?p zWxke*^FS{>!`wv+bkZ%+pSX&wS`4Tw9b77Wui zh7eA`!TKhGt4H?9dT*al@JA}6_N!|0@?)oeOyF$mF}-i~l%etR?@axZ<8b+QpLr`? zM&UZEM1#ic<*|{FpH^rgD?2fvv`#&Ai0@sL!2_jr2KrCqH5ZhN8%?9_9lF6@;D&H7>x-ON{+Y(+IH1w!bW&2D&s*B{ZDL7ZYGwqD z7Xn-@<_ngN)X|MXs!C7>^91BJf-&xBIym*LKJzYFUEkwte-!l=Xl@WtpXdYxk-*rm zi$kr`?>>!b89Xm-nw){e8^& zUybMG{+8U|W2ecz)QB;RzA!uZl8>a9_U(|~=nizEXy}=$b*B6$@+PvKPAG8r^ZU!g zE6WRI>e16o1^0Dd;@gi$$ zt%PO25D&Lo@aU6YzOGl(@}ZOANz1${eIbeJE@C8WTPbLuGCEdyz7>%e!wjhD=1hB z&{0m1GVYN^(WSRWOg|jZj_B;!`Z7-iR0fbSlj;C?dP83 zpPlhj@i{&idI-{mDnP=_e{l!GW_~W7=DyEN`8s|QQMx1_ej;xMxWqdXU0tRvP-)w(VpQ+DZQj&~KkHhfrw z$%}nkb=dUXT$D|EuE;fKjD&rTMM4OUVkQH*OfR@JH@J%_P|6YSueKDqR{a}cQt`^q=L!3un?zlr4w)uK5K;BoKGsph30Q?D1dP&8oO zP6GWQLs5&YyJX6{4n4q#dTjrO)bO1)AKK_N8Ss(lZw`zt9HG%M@E3km2%Fh8wtv`r zW2yl5cf}FhII=Pk^4ON0{|&+7^KjIz!9iM4Ww#Jg&!>&bf8cuQ2e@%JGWSsUb@#;K z^$6yNP6hZ+00EK7nzGzR{5!%!hfc+TmKlSDoqG2>nCL&2+_pZE%+LrIZaFViM&{nW za71!(RqPQ%aG@?{o&qsIoFvJxz9u;siP$8Z|?HdBb3Vzj5iUFFO(v*_6HouQ?c z9Ov0WRf&f585`Ou<%z&o6x}W+Q*6k~Gii;c>`(C768kGgF>`gv<$8$Yz-5)C(<)oG zjX-7K)qedE4Y9$jNz|g^=`_o-QASm&S|mB#vE|>#^#4}0!w~sD=wb`5M%!41gzm1q zNwPP9@rpCwwCcA}I9zY{8=vA#?W%Z+Gm-eQ-;t;jwSqxeBLx|PF$H0R$Two^zp6$R zRhkx|I<3upJS!9M5;_jayyKK>Fgv4MNZ2yK%+(nSMeFr;-lfywj#)ah?;lu_6;nsy zhc@ym_0`nBrCyJlDv81fjw2A&lF=qnXC}=}NiL0;kQX%Mz2#c|ce$R<(LH81!4vaH zvGC}o|EzZBM*J$?DXes06o^hkf2in~Q@9Nt*z%XVvo|5XhdkQa4)eR*YVqZg+-w4% zc-JQsQ{Vb0+->rn$2Qj+u-IW95n!7|Cu_~)Z#k}_sI63#Y0Q|m1u4lb6M`;Hu?wQ(yoexsX;so)(C*KazHFO$WZzDz2H(n0xEhUtZ*xrLZ z%qF%Ws$zA}QM0D(`T~@RLFCcTtAMxMOHv1HMId_-id8^+d|#fQQEu@lpzXN|fun!H z9;05M{dSKbwv;+xi5!O(=^O$Vl4wU zM43G?G_zj4BA+UkqpPk+mMt@I#5PxP)oNe(tIr4K)*A+vHxRSIP3Ql*0K}?%C=*zC zYnxhQ+QqnV@V^F4g%|rbcBHZ)Ja$sFazf7i>go|(3K+_1`P$8%I7Ya=By0SG&O!21jn0ZZN+5V zP>Q3<+2saYdfb7*HqD62$kl!ycCt1GD=t#;G3s|`xu(nd`4YETUwk<->zH?asDg&X z3}5>FA_5sK^FsW7n9wAWkConi=3BuN(iCF39PjfmL)h)aGY7vfjtZgDv6jaCF1x5z z9d4p8cCi<=_`0;2K`@6gG0QbO5sT1O7(P*+-a&BdHgLyd-RtHbV-GXEn=0Pl7HtFr z-C6f6n&{G1xhc(Y9qkR^Z8+#bxT-1}I9Yw=W)!i;3X|SzKw~$0cpR@~au`{i`UZ^k z8##P2>}}HU<9&soO2v^p$Aa|J8`!8Qv&Rq@k)CF}EE%%X@cK$@$%}_{y|gu{MI{VS zdW>J4DiE?0di>=omZQVDR*h#1Lz`3bCVKO9$9v*vKL zD!Q;kyp649SpDwZQ13J&@*~DBd?IBgWEr>T5Gf8_H~0fl8i9q>r|JusYmX}ve^!9k zdWF81T_i5j|IK=@a|*Lj*pf%x$h1nX-Z~<`0rpbg4LK2g3gL8(*pe1G^mBF=5;=HI zgG-3}zMw@^z3W&?&e=4-bG5lT>-jQUtk7#K1JSi<2@gzEK)?~%uaq)2kFK=ezs6XM zMue9ay0CRMsQ#Q6y~b|hkb0z5>IaJn>Gj&q)7Klj2;%dLDDVq$Pk!AgGWwo7q*+>>`Z&hEuDERS-liI7|e7dZYl4s>-51|TF; z{m2t)ebU%D^`|j;mp@i0p4h5?5xP^A0+c-ID)}s}72m?V=;Lnj>MzLb7&1+scHnzP z?{%Zl_zEt;>KeFhHd1<)p2Il*jbtQ%C{%D${wHO6{xhfUVT@t)3}2YycHCQvE+eUp zHzI|4S}Xh3c2)|ivI2rK#o5C{#SuPkW0CQH!{4MzBiO}!&okNs{O>tjQDXOgpZoo* zd}iuH2R%0M>!P;7l!JPskMgu`pO6+HDpVG6(v6wi*x$b{GE~O>)OTj;C6Nr2NOPHC zXg)8W`eDpR3%Ro^QFXhW%ov7?c=)UPaM+@9jC^+hVUU z^@-Qk2Um>C_Op*6v0Dz=-+&XoR9r^=E5Tg~>i7C{qRu!v2SnmE8z#N=fOT19r{E)t z+quziP1&6|TAo>|R)5=yV*jKbh?W4xileY*;##6&^<$YV ztI|iQ$SI*+EH2tZ&-ObBv-X!Vo8#rKeDr*zNu{Dt(ru@8k}!tpy~Q!W+;tfZ;}DOM zRIK9!MHG<5jO!W7$&10OcUp!BDI^HBURc?LQI-mPZ|0|Uq!-w_~cNN z>utLUzi+f@$C$XEe^xlQ`0tl_F~RmJ!w&km#=Cf1;d!45JpOuMNbP;htTxdkZ`ukJ z*!I1U^VzmqtMtI9lU%H=*6LHg%Reo(f5DK~aI6eZD*zBHqGduzHE+8(MNq;PiEp`7 zIgp<}MQx**G@15{rgY>wvQivdPMu@5s3y=q*1L@yg9Gn7^}9{KG813nT0regrpsTK z*ixvHU@d3#3|f42EZs^*iTh*3Sa7QNedp81eoIz7Q_4b57>jhf+`Ob%k zUk&q51EM{U6LF%tIV zPH1%i6&IOg2?2@RXofht#O9D%7wdj+_0t)OiLFdFHectv4fc5vj3AntjfLM{f}e`W z4n)9QnRjKVcE2B5y0kB!OY5P#6!lGHT49{!fTG%y6v-Y;=7U22TW`;-l(R@=9TD}Xmy(=a*c7K&IUifxx))g8h=az$ySr?yTcH7&gh%gY24lsrU+R1`lZ8jeZ z`9~hJrfH`pvnW!N92GOn!*NV}7ppgikY+!}dK7{T&VVh`_jiJSt-U>g5c{;w&($6{ z1DRGRKL1$q0b=+$a6}F_ZMH7bMUp>|8gS32k8FfmY|cuiA~9n5PesQ1*)Lp|?{NMj zy2p%MxH6dGR41bHNO``c##5B+Mf$t*ROIXKftQIR@jIGh6%qb8nQl5I0D9+z5|2cgXXpnV_ z=FB`e+gyyi{|f~vsA6UR8^Bw&c55r%ucYNxaL)IDeR@8A#i5RyZsd=lNEY^$8OZx| zK9_pP5C5y>8LmTh+)5tJPIZU$3a9xNpXG*5<8DkL9g?Z%I2Be$ehXh+0f+4E zEZBo6ZT}t{DxSZ&vKWOT{i`&X3h-iz%u*ec#()b``nhw^zB9D<`;!S9lcBU8*{U&& zo^VucE9Q7uRK2iMBSWdJp))G-cGkZ;=X>mHlL zr=7Hc{;Alpl>gLQi<@uQ3h^RXWs2g!AM@d{+sb|(mKInH#{1Wyh|M>DV3cmvb#=mN zf3P7XZR|Ct#35|}dJ5WDMu2!Z;sUy3gIs-{^|&`Na~I|N^6JvIIL`kwXEBvAMTM^0 zZ!yp#Ko7GDHge6MK%D8e-X`f7H1RBz#)GQ+)Q>tDTc9ID>R(U+s*Jv7Ua0gF_+(wl zHov*|rAw!-&==(9dkYNsjw}mSuP5TBuIrcoa-QOl>j<|Li+>pApl5j5LO#vl7&*S? zD{-3nBxEIb*PWEv?a^ix&f7a(aPcwdqp66gbp|uCyk?m+U^&t)2cgkxUNU%riRCaf zrf+*Ir5X}**`Xj+$&_ocB`cL&dY#I;K;tBzWy8G?<{e7&3)>^fGX@GBT>=}5YUI-^ z4!pprzbtvLQpM^zPr-XAmOj|5wYP+){F~*2tpo0(=AOswR>J3sTq`|o-3=b|wTgDH zEp4ym%6n+_T+;Z{au#6G*hMVe*tZLYpvKKVL5QwnloK%D`lLbHzR`#!)6O2h$3h-= z>(1H6d7^)iW<@}j9HX^EGO^v?>2UIc;RdRo#rqIVp>#rH;&bA`19|cHzXKY@Ivz1Nl7dB%NrosYSigJ1*{dHeh}gWf9qHyqNWOv zL#U6ZAfQ_bk&9&=Xp^SNt4Xb=&!29KI9+v1>+75dkDhADKPmDz(P9npeDp(_mWjQ| z-3O(?< z?Kc(AeC=$58%&oaPWAh3PYdu6WJ}qq>QNJvDY`MI5w*n*4*B_&v}>NJ_s#L4{F1l> zP#XL6&;xyHJs-X86B6rKH+9};<5R)NrPG#tIn#TCTYUHhZDrKK&stv|1?7z6#4}|y0lKr>oH-iZ0uAyRBhrFit|~nea%NhS zCy)ZE?Og(OPucA&d_1^OKG@bw(6K!3>oSMLuHdR2FDCF{nyaMi8R|!jjx_gAtUJ+ohq&5TD zdZU%`15VsJsfOMlFJq7UWASqxHF5M~-r0B|gvzM<5M!J)h_(ck11yf}f*I4*tWVLM zcU_3%f4HO7JEoWsTf|Qxzr5d&*GKX1EHKaXj<|*LBehdLH2clwi$6i&owT*m?(qcM z8%|oJO5+{||J2cbL3RFz0DzB0ib8O)_7ufm57`$3NV;P=^057s!5yRLVFK}1Ck5xg zMcV9gSjZo5BPW?W(80;p3jc=24!ar?KRU4~T_`3b?C^}12j}MViv7HEIv4(@pA-0a zr0vO9-|a>x=-o!&6<`y${Hcp+*aBCMX)%`b{K~#7d9)-s_Vhgg02ykU>7V_S^gm+G z$pV^6EuNp|_NrLF$L8v}-R5RS$C;G;rrtGwsdX5}kQrbLZIqe~NDVCBqVj*X@cZf1 z+01hjmrb$S!{aBBS=Ao1i5y16k#c9jQd4z|RnnC1?gtftUf2Ja*{re_KKO>TD_5qq zkk-jXY$`+k+azVvrWT^H_0k*FDSf9!q6XSvo78nUmnnA{pEe1e*|NG{sZeFiGa13e%T(c zP*bn5PA`ACN#CQfu8Zi;{ZjS^yo5uShx@e)(Sm_uX{p3J^>${Moer8hMRhmqXx8{YCP-qNyKH;Brb zm7LdTI%l}odm*Mopptk{%PKG^cNs1%>}iOE)JDn!NEMvqtMKhdBc?QT?xViqaZ$Ex zwen&)*cO&atC(UtsZ4_1265|GFTA)58l&R0C=w_ky6+czAYkiRO(1kntQ^*mu z9_}o(%_7RdwDhfX=EIkBWP#&UKp^9mNXf3E%gN6ru%xaWleRM_1_1gUCL+{3G zLzj}{QcCLr=`GuJ*-JEFy?gsf&`{u1S7-#t(iAZm(<5znBDrL;C@4A+JAr z!*n31JwY}?9n7z;51puD)7ON*yNO{+K`S!Nm2A#;MWN511N2~Hl z#TKfN9pCaJ{=a8zt`7mJ*cG{2UF|TIl+EU?u4Vaqn#+9t7{n3?GOe+rTZQ1cN zCzcMEkbJU2%-xr<+|W_3D*P8*Zq=}Np0bB3OFFyIQB@(bF*%2P zU836)d^frntK;weeBYAb6Yh5d*ulKir`$YY$YAG9Y(l|zu;EoULVq;&xqI;PutYm_IF|MixS9kn;(xtzPG6fu}jO_KtV1~TU-XL zuBv8MdGVf8j>{$FHLsP=oGz?WO$=_NDPMjjgLA|f#rxVe^|5ahAKR-|&qWi0jkJoc zB(It0@KEZiezo8SIhD;$KtcF)p3n_Zj(~r?&C48CO|{o;^?SRqt{VekG#rF-wA8Xiz@w zvd8EFtvsspH?y89Yq*iKc)4~|L~-OWH?8F1xL&{~uRYaTQDZ6~WZ`}>WHcUWF6M6i zap_?d^M7+o;8@L+>u&>+(h#Wj%*(lrSd`C2$j5D#kjDL2Ca2OBX=gQ@$h0Ye<|4R+ z@ar#8U4W9tZ$b&Tn?(*E?%*f{n?-P1x%t>uPP#Jz{ozaw)5>yU{sg^xC{(lhaRz}7 zV2)`n$T<(a?_vj>{>&)dKZ~4ZXwb^N>n)ji9#H?suEF)F>2N$gd*)`H{qie0>GQdU zlWUb*CFLY7%%jC#)Q)vJQT$lYMLnajZs{g?kKC-gX6IsWd)ohW zb@hn%Gy-40Sqv`%0bc7R8NY-xa_sK%I<{EzCdt!e2blpsBFw9$8r|4<_9i%ASo-d+ z_g||VQDX!hBpg1@6-%y3Q`xLZitC(Z65SI`tx8i&j2usl;CX?t{NRw8j^ZJKpb>$s zy<^HaqD0!f-R%>Xb%PG(B6@onj$WasmKt)0iZw3|vu6;8am+E?1}_+sks}8J5E&*d zx|!rFSS$c;(9$)m3X~rVMT)7ex^B``a5j1l@lC&J%pOzer*z%ca9c_$Vhjp%qx z{6Dv>1R33oH48wM1<+|J|0h6PE}oVbz^8(osmezh?DA3mIpNcYOAPhwq6oWDZ&ddn z5UPB}C){_&ulEmGKyKaae(8{mGBf0l{j+b$SYYv&=c)GRhU@r@(>Vw_j388%>uQa| zEO6ChCeqV@Z%fk%`pNlFiWt3HhEFPTJ^{j_y-ubuPg!KkUWQf*mB+pB)St)6Tc_Wv z@s!Z!K0L3za&|c{6-G}#5>+PGy5)d(C#^-win79wo)~M-UQJxpb5UQ$R>vJuw{HIj z0Pm#rWMbrB62%(X;%KaK*Whi5$9~uz;f@)zI;Mlj2zwXe`lTLcYNjZ@<6W;*}CfwHDtbL7ZVjI;F%QSVlhrs(sWV{H9j640grdbTy3 z{>f9Lj2s+jwJ{ydT(D&g6nN(-;L=k?6FvlDfFfu%&(;YIQ|qoN}O~R?0AsSB$_Ck1pU)NV>DyimzH*t{c8j+?h+Ri^j*k&^2n?UF&@Q89^Cy%cij~ z9_P$*;r8o5f~B?LT5>{=Wiy|za?opk_Lhs@&%4`8fS-GLx$YB~m6_bm)rI)?q9v)^ z?cQ#V?zyBS4Xvnkwxu)tMd<1a?}iEYcNyzn+H6l@XC@Rbb3H!Mf(m{Oogjpd_)s>x z?X!LOFhX4MN{FMXW=adfI>TMKTn~-{cr*^#y&{#Hco|au};G>8pRj0m#v~YK8w?#;9k-2)t_t0HxKbg zBX0j%SyyqlT(u$M^8cLssD4L$GK6$N8yA7*4{^5nB4#-(i%Q-0yp2agS^fpGF80NQ z#Sh}I zDX%fi`52)M#bOQf z?m5@3k^?RRxPpy48_oH$U9Bk38G&`ak~blWz-#N_bIu(RSg#kI1>Di*0a5KgE{35~ zChAj8EtZbXKzawhiz^v?o-cpw;tJ%OXiE6Nv1{c=X%@A>n_cMM4P=sm4t12YDe&yQz}Bm>sOc$ z$^BZVyDwKxp-h&GfgTU@&?9dh0T$n8A3sr*lys%TwE5@sa$UrG(|TccPWkJSQK&Cb zyRY+4M3iT?Z5gzFbVa%DeQZ zAp^&_v~%)Cv!8Gc-?;=V`C5g=h|>l`MKQR}n6EtHwr1%^Xx1x<5$`$|xVr_t7-_im zs3wa}`7P4ONL`;8ecB8BX-8lo-;%>s*X(8PFVD9;i1=J^9-GVs;8w0STahhuMsV{B z6Z0(Pcys_?$CxtWO`Ce!bCn)&(pUzst+uB)_%u(6-u7p6`teCoK4sWl_Q8MER&7TE5TJ@VSTE=r_P5-hH%vcVCZEZQmz(aDk z<2*(`O1^qmAJfBR=RW}dyo*{|6V}qY?MbOqF{w-KgwF#F2LzemwW)^~EZ$|Jd}j@> zLvvl#-cfKe?Z%IS>SGt7{hAFWB=f63bO(O6(j{iY zZp@+41gCXZsGaoX0by^#n1-<-6Ex=-7diZ2eLmn=HsGnQTs?c&hjG!g;8h*B8>;-% zjmUV=H1XvvOU3Q^v|D-1C`|o}{OkBr>B{89PB$OgN z`&R)k8dc*5t@niv@68$vPCW!2lx);oeV_w>Ztt4F%A`1o4RvMPRk)2j;Bd&4fLeEt zpd0G$K**;-Oyz9Lxb4@M3T)*AHlLlWDIYPvOvt}`6E`>UV*bxB*lO%eL570X^SSDB zhcCCIZ0R$lovJAv_VX3^b&z9}W13|ayBv@!W8n}iWWLhT_HJ~*eovBOGo!Z6Ro@o_ znvC53aQZpv@(azXkbuUT2aAcpE(4dA@?zt^M_-Zl`D#3LD-moG=D~auaTj+Vz6p(A zzZ>h#d{ccf96AgF$<$Yf8Ng?))}vVJq8v55mh%>R!YVbw)p8i?nESs}utjKTWC61! z)X{A8#xbFahcDWb`Lj;?+QWOl6a$aW_S7;EqMdWuJBl|ylf~2J4c~D4maZ*^6#MU!Kj6*+vdK^%7U@|rDD+*DEHLn7#F%$!(R zevV_$fzvN%AtLVGq1R|I{cuwW1)v@M4%Y&jne;35`1rHo+-0*Ury!t2irp0lK4F74 z-d}rv9xo`D%VJ@+u1G+K)G0~oOI2E#w+$WA^}Y=W&3YqSd+{6F{X-UyHkgg#USd45 zrk;P`O0iQKp08Cv&$VmCBU_7@tXhlknQ`06?kE$|+u>l9=cE;;D}%C7Kmjprh11R; z0f&)Z;3svO%Bz`^FE%Yu#x3=iB3Pt(FzDju z`Vjij_CuOY&`5-M`T}!zmkiHp#GACyJUz!&+d(To%m2!bqh+E&?VY6IO|EuG0E%z^ zgAq1hFN-P~F@DN=HHr)fr;9O?$}(7k*)G&5-7o?~hCa9|b2feL%t71J>Zb3R`#Yau5qP%AV6`LUke?Cd>LYC(Z~ z%!Qrr<7qz{0GZ6u5I5k!gz%%5dj(CCV4tq9_?kE<@cQaY$ZlHnee!a?_}{9AxJgwj zrza9_Uuk#$Kt0oUTpQ!m+u}m7gS?ElBGA(?`DsqF{ zv=1yr$}@uZY-Q%Hf3HXj6?R3OJ~RR^kybKsLb)!$Q;#5kX*fB-bN>36%N@%H^*i&` zKP`U-1WxU*H=CZ+u{a{%ZdZV#E3KY@r(6>V$)ojo!;TltafJ5D9La}?zPUV^P-TpF z$-OE1&Z}pG%fj$$gjgTA7aGfVm&cpX$24!SeV?`au2_|{|CyJ0kfL+t`wJ3;a1w4d z8NdhZMsI`mm8N*y+)%Z!EAHk#+Y@)E^@21vMUib#|GbT-kkou`Db-rK;y)tlLV@|O_BIH3sQxU@jtK#@1{S;DT_{szt z^9?o%@>^DdZTEhnVZ&R-&Lk#zEKrmJNj57o%c;aHi8ITA6;&q;ycIi+>WUdI z(?gOA;${a+f}xLRBuDGOm+?ybuK7Cl)%4fjPOX$;&wYcq@q5ElVUTGrQj4{wXt!B#(FM=))0WrfILvKBJ3=$~MvH0#X^W!`7 z;QN;M{-1n({!?`0-bK4*4J=)|gZd)H@3(#=suh(u8P`G?IA`egSRR@KJJo4I6*4~0 zJ2e8T$BHxuM@A}-x#xbP_5c_6#;D`u4DOS;lUKW%9~)CE1J=Rnux-1c{0sNE;RA!K z@zXJgKAh&bRsQ@Zs85WI^lt&i>~eg9Nw%wSf{UP&{Yl^!N;@UfD(SdVQapzW7^C;t z&wHYOU|{II^Kg2ji&ORsD8f2LY$yPIXVFC!{O&$@TJuHJ-x_vvcL0As4EcxFP)(`B zG^_1EdZ|i)e<8l>+TfRO-OI(Do0PVl_vSh7QB{94zq%BJkPNF|6CXAbn%o!6n6HhM zodn&5(rr?~TL~Y}T!%>o%+m~WkL;);r0Xq+75^;|Do`kX{)k*@OxeQ9;w!R)fD=~) zVP=ST?5_N#(u3Xp7l5c_!@HTl>(z!4q&^{nM^*vttED%Kj%y3`X9wxumn&MBvfn_8 zqg}*D8sHof=<~VsWpp#K@(o2WLq9{4Xrh{OPa17X+#3lX^?kve+r_ZhZ{S*KKx1+U zg=>?C+*0Qdiz&n2cu(dYSi`8n`jz8w#{zP)rH%Av{w0uF1g|ny=#jrcSST?pQ5!v# zj};8Ik^T#G;RL~vyaP7t=RMHCzIf1>)~G)EwQPx#go9}EApO!jtb=>-zIGVsBh zfcwn~(!{%=IL#{#Q z;dLN3mmH$b=bj8p44J$7@jKH+iUP<%=(42I4V-U$8PDOqe*sFH2%20bw?cH5cy@6< z7mlIg_}txul_JCgmW!8UMn0of(=TV?DO|Ee87ic+#HSK*j`dZPp0gnSBFfTG;_`wY z@0@uR^4UZ|1$>g3=cmW@iz@H;H!M;N(LveeSI`+ONR9K0XDJBF;ydy!vU90VF&xhX zfdC2h)8&(L`d{10-J9d8h~Z<4`j3P^=Ec6a<~<%JcusEQg;Pq{-Vi&ng3LlsJ(0HKoI0b*AA6J( zZ|S!j>X7V?Z@7x+Z*kX&Yu=s-PQL&F1-{Q$JX!@J>k}w6Pu=Ah!cdl(UT<$50EZ2A z_z^|exx-K(6oA2X$<;@msiM4+) zl}mF7nNhe#wD_FF6|~rnLKV}ws!qLf*@$bmr$QI;v1E+- zEvVgPRc}|dage$6= zl!uN7<-FKfdxgBLAbOa~KsL%KXQ~5V0t1G}n&YmC_T*xO56bz>JpR3IJ-0R`nS@3g zC0}eS{GXOlBxp{bqy%BSxZ*ttdF_RUUR$x*h)#5IBz69IeBcwvvM2EH+X3cgv;Wvc zlFND;+um)Uu)-U;n$X_Z_JH_0S`*jss7@X<-*6X$h27sPN*XoHH9U6RR;HMIr@d57 zZ!JCoiF9FqzDE6p3d+9e#D^-*mTi$SGLVJBgy|O)$zg>wTP;j^0aOBM8NUB@w7~pe z$vv<`Z*p15JOvgSH#LBFnsI9IuvBL;5%uk;iU-&?Qc8TvNA|hx_*mR}1^5y(Va66=ysV^2Ki2uX1ql(!@Sw;9Ti%T&SeOgC4pcp9u6qM} zbnX>yw6$D6IUS-;{Cam>GWpEas)2XcF3d{gI3tQa8m8NEST5gI5YmCRN4;b3L90pd z1DS>B+bPNl2$q#o@`s$sl?^cD#LWCEw%_RSrQEUIGCG(nH}ni~I4M4C!Z$fgXOa2k z1a34@rh47dPaCHvH``%L5Ot{+ZdknN`m@7v*;r9x6%9!#wNNlxU}2#IY?eVZZG~<1`D8>~{^36f^Ai zxVP>~*H$EWe_s@g+soPRyS@N7syXkxO%Qj9%r|-0b;vTF640?NjXmG^b#kx+oSmvZ zz&74HQ3;vu9tk&_89LvRAKUOBli{G7d!YN^lMBlQs26k^(m&SB_hrS3lJm68c&Lb_ zf@#dO^ow40HQe1nD%0-~lw!dgaoN=sE$X%m@#c;;>Ah2HINDTPl?+6enhdqgs@$!O zEAer5LiLu3t>@a!4^k7a2c4J#z%PO7XS4a&PlQ`{D)}I*;L?am&$ac447r2TFC?CK zeP=TgOiE(vE_a+ybYQTuWv9^aw#vOwP7-K?LgM*&`OfB}DzylXp#Z&4>#bOQ3lFNc z@$a)9%M=y7#K!6hZ-iCdFT6k|J~P~xvsO%K0DUB*Zt9^8L)Yo0YW^< z|7sEDYJ34+a9NjU26~6G4@PX^dHQWGxv^jCA7ws_(;DjVcz!_PHJ^~;B$j0Ad@zIi z=c`g%)ymVF47TByJ(6JJ&wB~%>Rw|Fg+r40%3-|C77QrI`7dhc=awU5Y=^W>N~Z^f zs5kw?QbMVjgKxJdw(*Sg`BQnVTS|~&_}QKWMk4IE;P>0aC?GKnavh{#ijYp)9udeF z+ZRi1i(Ad0F}+gU#8N}Ubj=W3Pna2#IayiN4`eV>Rtn|4Z*7jYk76S`r0Fb`1H|Jp zJMGFYRI`$RtMD1T?S!b*0(BN#5qlbx%P;t@;VK3vim4Fq^2vP`mnkSpkYY~{q`yMd z7yrt@OEUmKbVPx9je=GzHccAdp~F z5Q#G8)8^jqDaZlPFJklS!=KdPesOy~f?}l+`OpgI!dLgaH4$HH>+GZB-_QIfqf2=DlwfQ?OGn)s`Tgol~aJ8g> z{7tRjzn!HSWC3ddopds72@52I?vzB>E9*vH1^6g1g+As#72I2$jqgyF~)h4r2z<9lpGwU$t36 zT2H#GS*P~0ouRTQrfUg}g8lNr7}c|gWC>7bul83)PLF7?)iMW|8qPu95M627omY)f zcY^fKpKMgttUpY>;y+15^ZTqgucfsZtmJnKXC17$#W;B}hd7Fj=M!%)cUL=sEoyE< z?`~ZVrELQOGQlFZx`=Xf?^wn(om#f^t7!K{Bn##exAARDPyE=oA^F$3j90Pe_YO~l z-%i^!6OJQ1(@qBJ-rH?P0W=Gm8Qlxy$+e_;-iQ&}oBjym=d9wDxyt*=OY3R=rvEU; z_fFyEd2ik&wq;XSyIj{duqI<^c}CJ@&2Nc&-|>6RV&6rzLxb?bLJUHtt+(P~X_#VX zyAQopr$p^X!Vi1RUX$h*sG04ElRuy(_tqNx6{oSo(l5Nw*81WlU>+S~H`O|rUD*tE zau;&-j!duAg62_lQIjnF?~Q{w12%41No(?K+;4z$4{7Jxo_}*?Nt`)tN?B^SU&TuF z>AfWnK3_Oaj+jH`yXF*PF__-0>`9ix;luW@*liV~5rqe2>SvE6J!HBkmlM?8gZrA7 z`yIE#p9G`kgp>nSd)JXa!UZ7EiZ6;YwC*WlF!(x21mEa%)1N9Cy(MyWRpN@KC^z{NNPXEpG`w+Re4WuG7OT z1?(~x$_i7sYWN0OF!?{r46<>i`!Dzc3>tPP%+GF#CB5xPf;HxMKqY|pCr9DTPPFI; zEM$u!4dq>0cATcf z0T$6RELI_Ofyea5sS=n#n4)L}Inn2>UxQ=U0H>{Sa@2?vo(I^v_uYh3ex!c_*`lKl=tqNnzZa zE{YxS&$O?D5Yy1CF*W)3gVVo+jff}sC)2fFoKTCNbvSac*{-F!mjG-rTvify#C>H? zhx6Vp2W*bbR(v{f1J!M85*)`}54;o|52VLG<2l_uLa`f(U#r4gWRA6_r~1Rd$H`+6 z&Llw6qSts`fbUH6YtgafKFI5x1V?!V^m8Tnc4X;B=alMZIQLenC9}tx{y07C^6#{) z+u8lYk-ay^38y4`IB>Nx(k)7{;WBW~wlz27IZDnJ{E9Dk#irQ~COzi90c-wWhf9*m zWp>Z1=QqUIqq_4!)kVeVvqyj_=#ZykP0q0b_Th@y_4jR8CM*P7Tz<(zYgbLN5AZ*B zYqU*^NM^~FYcAr`41V6>MW)(g+zmZV`rK|ERldGz+&Ttm_8jaaIG1e@L5ipDShs(4vo|Bl;;kaVa)&^Hy*UJG$p5|=Fx}V26;RrWX#Zoo})CT&Xm~Ef7ADJ zX-}5vZTRkyG&@ZsRYJZ|i*$;4VAaeX6|O6Fpf3ggp0;b%U{PB_E9;|R%4*|XJoQ3R zD_7070^l9aUt{YqvwklGG@h9HZMj;|)Z~u*Hw|pVy-*$GoK}rMY6&_nU-U}z@D5IS zbFV2&;c7TBWO$n+>82oSLksl=WEi9J_fmy}qHlOUSJ{I$CP$a?F+GfBdI(Yc)zc3$ zBrw~PR%wT=W0?0(u9jjY{!NETJ3W_&iF&|PfLv(Tm-U*!3ALxffnb>XXFXwS4cUXc zm9etT{|>x;k@erCRU{U;SXQPBeo*h*Yf!o77kyFOM>}&HpV{&OH{oE{R=p?^rqq$# zSlMtdXm76RNDZ;g&A4vAqYGp18O=f^F@8>K>M#*>R}ppJ6i8a(z|zUq=2_cH2=Ivn z0ZIwDA9I0Foo}RCUMXQq$!|(NpV2W9v2n%ldQH=B?AF*>j``k3_w z<4f(*t1&4r!B-JUGivo-0q089SszH2mpLyQxl2fq`^LXA-QSG7a33xQ$egB78MP3=Q5=%P zk&IeNBcGMeKV{Q39p(g5GF)C_BxAln{ijrN!%-;<9M1VS;TUCpa3%cz)|u-b@^&-V z;n|OMP|&P#hscD~vNzh{3o}1#DW+NP%N$y6u%e;fEi2G=-}ghCq-p-m;yx_>wLPsRMuR+wI{F|P*biVr%nle{ z^8F6rAN=1~pd~;^l2YP$byK=o9V^A26f#(hSs9V-JGBO+jivAjvQ`(P$UR=7mg!?W z58||EHtT*J;U~hisrq1Hx$=ABYTxqHVQliDPe&J=L%?@deDlh?>z{Q{K^p&Py}Qva zyB@2x8X#RK6zJ1%qh0*O+-jfh5;&0TmbzQ_XVqOaG3o2qY-$nFll8BfHhl4kKlQ`a z#px3pq9%aMH6_U+usL~BtQFh_$%e_j6M>mCR!K3fmDYNWl|dcVJ5tu2y*uNq__zYb zmC06z7BLzhLcf*STVFFE2=;Fr!*3OJOa#(h%#U=}6aeWDJ@1dcg?!W#diEVV<4P>0 zk2&b<$WS{k)T>@)HR>IB+iB#K@FN&Ro34n;pa3{?^R`|dI4IQ;YFU*bo1&5HjQs*V9z{ z+TUgMNtWK@#ocBWL?vPlvOs$!sZC+m@<5 z<4uMgiMYxrsD-8rWE3;FcPRZX$ua(6WdUZ>VG5DeC|%sF zhFcE9d?*eL=X+>{IPj*j5pDRJsn`yX$^a#qz2KqI_Hxzr($ZfETwak_nxd6T_t75I z*JO8|I=jGznvNc$wak79R>)na!6M4~5rjA&t}iAEr=Sg0F|)jUvq2fe4PU+2 z3ZDNAzv{bpxjmy@jNiMFeu=y}<{pnwj&k?wy2AZ+B}sT?!YnyjRZ3QFQv_+K15^4k z%?4L3&+QD^>g=Fu@~g;+b{Fqy6o{>WC(rv+9@QN>6)Evb25j5C(C|E#hr-h%aa8RG*l&gciG>=CSb-`L2Rxo z8CpWyycg}eBjFsd+GWABzc1)!XOTY8h zGGas-HsE7|pFSvrW*QQ;Pj);epPG+*t zggz5i-bO=yqop-2T&(WM1&=J3bagd|DMcg4KdTEwEwJ{Y6x3=5;pICGRDiqvu9VcU z%1+1ipq&O<%OS?!2^yRN2X(1=;gR#{(%a47ezM3ptPuVCi=4qcb>+@LtcoYoZhE~K zLATR)NC8N(iR~i7`bX(?#_QvET_Jk`vReB%nf2Yy!4hj zE`JUVjjv*=7o&R2c)twjS_BrI`bC}AtQL>)2TNo5%lF4|*(cTv zdpU}jBnP5Lh)vhHzd<`ydkk;ZkB!vOYI_dC`AQP)Jq}mM?&=6ZdYkYo3eBH$PP%g_ z@bx@mIUU7La)O+cuJYa44OSjG4GNzaklr4+_UXo1D~i7%L{x*paTW>+Se;V&ywD$+ z2tbF5FNv0?YC3@)Y`%UYr#>N2nrBC+P5L~Kx%~NPJZnwS8?=W-dL%pH-OkG({iDU7^>o0{$E?d( z3a_a0h=NCoZECjy7X{y$9eGPxq;Kxt8=0iU^d5|@*3)Te)Dn7BM4fWAgG{FCGm*Av ztv#`Nx=&4p)8`QDFnAXw|hJkvgk zhMvCq(cHmSR(+LaDNRUJ_%@)iLkhOqJl*YVEeJ{7BRhrPm+?5oo^pjESnG=9o%2v- z?XRRO56rll=W@2~=%@MbKcm=D5@u7|NL8{VDdU93-#+vX)!ZI0XFpoVe0kmq;y^(I z6h~Y1deW|&Jn%SagbygXa9~yix)hvy1qgTH)9sk3fKjx!! zUVoBmbFsnUg@=XMy%vVOl(Nvu*2X)h&TgF2hX%qe!htKl)KC66734Ut;TiboKw{A` zdp2wO(-Uv;jdY~zF}Zo;3is9=xiX&THNCVsA|C-3({uHtMZ{br!(DKb;_nOEs-jPm zSA8lwd*iHCh1TMJ0U5G#`>u=QEsG2s8W*vH4Z_^|-8S*>_HRUas^qK(GJRo@`xgV5871wu8SXoR` zZMVEd6&Jzfek;v8vp71lFO7Qf&}AgQ>swisn&io5O36fF@4tA7gPMZYzX10masPq;p5Jxf{_H=VzH-MrQI zC-eLS_d+qifqvz=VOT~nZRJPTXl*Dl!TUTR(^C!F^HCiry1s60uOeEXI5Xj*BAC=o z-)>S};GeZUbzRiU>vwATCU$AcHfg< z97raNcd_l$bfvVEXdejfeX1qC@3HJ3DbWWUkIIeuX^`JOIj`64yjFqsHY=MtsnVlN zb5Lf$I`dqNp>ysNrGZ=~G$Le1Tjgh$kIAIs-y6R3tlxtFV%fk!edx+se;0N(Tsw+) zG*jd*kz>uDKsTBRXINu99qMQGK^;hH_iR zbuZ>Ty~_E!zn@i@@Salu3Ol`@EYMlgTyO^XXYJT$5{!3o1J5 z$EhrNu2}>6m;q?rPsybJ)>~(M=)K^*x#^qd({518?e>LR`64>hN&R6XvjW$^&UqxR|#P1mjd<|)8@T{~)*+xSVS0dR0gmx|>lgP6F9pk2I){0zcy=CE69DKO# z>vTa36P6Pdtd**lU|e}UEaL9_0q)K&j-}EWDLsyAfLbSCQM!VC9<(!V7fbQ92W

    ~pxCk-CAT4~N(Vr0x{p4fTQgj+%}@LTEFGVeyLBE1 zFG@@7en^3n7Fni+cIIOaW@ab#<=wW8cK5ml7`CIdOIn1pGp~-mO#Zos>LFj=%0Wg9 z_Y<32iIPkAe< z{Khx|xZtGkz1w*F>OnYA1FIeCp=YVfRFq-+>DYn&vOC5iBTTEQ^KZaO;+rGk+|K5O z0p!ZJL_hSq;}gk`B6^AcJt!OKM}-{nQv}`iuc1a7{my+x2+&L)^lkpU%KVd-{!~1n zAHkfAX_`r&u!WAJOP z*|)%9cwha0a<++s?(z_)snD3&IDUtxnK4bS&Q%Ac>(2 zWEQN~k4hJ!gBjdzGr42@b8+OIv}@C`V7QY9`@jy3ijn~E=8~0pQRT=P#v#qfJHV-T ztcNA`vU>cFI)zQ^{=sFqZp5>Ckg^aStl9F6JfTVik(pThh#Yer{~Otpl+T^>@4dMc zQUwJ2_tdQsQUw6KWHVZwbV<uBm6Xx5HSyWA{d5mPR= zc00Ji2hglq=OH3a=U76aXRi+4ZF$<KrJ6qdHNho;v zdV>9(bg-ispRfrJus61|yaxGSykw0g`iSkY=dI7{6{$hF(EtW5vrT;Oe+G*@7in0d zX4D(o38%&Q^Ipnh&N7XmdwtyTSzGAt9U%}f@iek4{`~ALvQ6bG2z4v35I3-Q>!G5# zxG1OcvmLWi#HUl@c}0Yr5l90~VVdV8=0D)DKeJwu>CQM{Z7X*7*|jSDlaxQ`Mb$8K zok6wDdx?rJJA5>C68rh^h=t|S5}im+rlU43WzqMmVoI3t``kRWIuZRzUr(G?2lfI1 zL{qQ2=U-buE|^ms`~nlL4;9?@|2v-)XiGCSahD2_$370(jN@TQszuNrmS=nRaa9|} zyu#OIw4I$k-c)Ey>0IvFI$YLmT4(7C;O+1JB;;-^gYXO#QDJ}B{r1j|yI{w)&|g#% z*$DVgCxe%WNvRi~Mb_=ugLxKyDpLvoLC+{_Gw%F(06p8xXM`?wLy!aFTqjJdrysJt zFsyYvvvhhXQKdk*c{RI1b#K?OigSH0ztcc6=k=|nY5YH<+ z1xxjSM-W$=VXqfCe4j&b%bR^5a0Yv%Yd;4a^@oWcELS&5_HR0W?lX?E(di9l4n}LF zt2CIVcKGwzEw%0dgV(tubYHIn7;!K|tcd7{wjug8xH-P<{Tf?_r&XEC5{ifMQG{aRC;X6M8I&xvS39dTlVeU)1Uh*orY4SJhWHRa<(t7=4Z;#1s zFY6N+yt2kV=a zh+LWf#~ssmPtNkJ;yO*Br5PeogAFy4cspG~F_K=}Jm~X|TGViWK0&uFC-F zzqt-`s(kN@5CP1qvv|9`sibu2_1;RD>}=Nz^cfaQVjXlHB#I5UHIqJiD$hBTJpC&l zy1U7Q%YVHbFjN2Hqyn5EcA;YOwoSL6|E9D=3%;rCU&RH)Se0n7^!cmFw<;=DLH-5~ zjaEoB^duoPjpoU^ALq{mrKckULSH?LLADZ-Fl02}r+k1qfMejDv~?P&EZSum_tQ)B z%UU@2wRD>_fdUqcg^CyyJWWc zim)Gsd(=FgiP&H_*k`pUT)1cvcz;-PfzwQ8%`!MqG~1kWpYvb3lI+QsYi{q7cC}IX znsD1OPYwX%*xr|};5Cz{D)#!iTYtHe%e-UrR`U%IP2!wye)cmKMEC&R0E&fN-(SLJ z*m^nl*9?Z&uTkUhuLH3J+I?Lb#d9mw4qK3_fM)~op`BEAquE@&_vU>+m$*81HOpJ~ z-P`HKj)P?ptbBC;fj)FJ3XbT1RPu0oLfz+@mJ6t;F`L*OH*p;mv6(VYl0L2C)qn5X zB3tNc9X!_R7nES%N>RWHEL;=S6#W*cjtrK6iX6CyhQ9e&O--H8H9{lI3>I&xb_-pw zXj|^#FfE$@;u3OA1cL~#qS}=I9!P`i8K?iaJw-e+h;bU|y=LAbbo*+bcm3yn*l<$8 zJTUY{Hlz4w31Pf5%rWSRRRd(0^Q^hi-eh6DF8J%^o8Sl=82DH0ku@(xd}`+|$|ZrU0ZnDMkc?o8IB zm0`a+x0!+b8}PUoKjDiru^U{X01!#mz)lk%?W-8FiX@xGj&J2g%rSWK1)S9j{b!YV zZ}zRkcyrRZuyF7DrbdiD2Z%T6%Us-%gI|hu^Z>e;dnubv#?8!n?h($0OV4He3@hrS zc!MoH+fkq|mc7mGDJL2G0s1%Gi7%fB>$(Gj4AU<;S>h{1DrdmH$AvvI#T^7d8=)ZC zyWh*-`DX{e*+2unw-)`!*-p0Eb@}wYN)WzyVPl9WU2xf!oV2)T0Bv?`d&UltV9t9* zz@Pk%G=otVCUs~zP!q`(PsOZb=`SXKJ1^?ndxTb9pb_=BhQd9z+(u1alN zF?iK|$#0|b(eS}R?#UOoW+4^8m_zv4ifGS~HF=#y^@|JK+fh@bf^i%&&~~w#oI$0`TSFU*{Uu7=wB!A`lfa2`#RJf5LNodMBz)(7 zcXLj#0%FC|uYVFMGM5Ld&mL#Xu2XecDe^eBNXH)?06C^zEoggK*iK*Q7qv zwAgwvS-j_FtNeuV<;&vUC;%K*jLdwus&F;*4@bb>WF*@Os9H`nVI9G$^=knYxj<3x&I~pgF!63ojRkkrw*um*}^1>bF@$X4d?fzcx`o1i@A{t7iKS6702~t?x&j z_mimvyU7_#UBrRTWDiCV62f1?F7w1=-a$h6J=}MGX8E%{%kg~f#JiNNxP;1dq5^oB zJlJ?zOk6tfGlQq{pz}vi+w4PW)tPr+!c3p=I(<0`y)*d0kaOa`Li$*ab4N+rHK^G) z-hkW6o$ggA4YS!CC5dZk$L%Nx;}!VQ);Hxu(JDzkeQfCtr^A4#C2pz0&}%FenmEfc z9!!}%1XS>JEv4@oQ?>~qzW%~-I;sw3wd_bpteUn01=MH@LzV&l@r8vf=+JUsXT~3| zi3Zs3{=BX&8V+4?`ou*rkn1!hUAk;LEY( z{ErnfB}i73lcH~59*vEU1QD!R8Z*vLUHyXCE>T{wUacI04ags0o*W~6%U9S38O&!> zWUa{=LunbL;3j^0_+L}+;=l^YiTWMt1_>_B?fH)Vv4LEY3hMg<|0V&-?a};ys?8aR zyG#}7%Svv{Zuc9u@cgp%PxrI0w+8@7hPts6FT5Pu(H6cRF>`bM;goUL6I%}(qnWL& zKencA4Eukn;f=c)G1L$#F>$4TrGH&1q_WtAxF!u+XPg7vXCA|KzP}^UZoFG@f8s(~ zMP#e)K1rvPX-<4ra+*hmUA_uRWSeMuEK8Wlk|J;}j#>>|6x=)+D7VzWpz45lSU>CB z2?vuue{8

    {&St9mMFd!EI0z2poF1YOpO$zlS})w~}lFleJEzJ`!*CYQi<*g?Jkn zr#0jK9Fack39^btcETIdhi4kJHH`mVSvYd(lA^w3^K+hO2=cV;e}A@EGTa#NZHv#l zBlDpWo~U>7k=}7L-(Y~a>GDDl;~n#H@KMlqEF4`ujR{5H3zy0F%KQB~#gI61wsw}) z%jxv!`e89#&WeK06M!M^lT%2(b4xc&jR$UbL^|^E`Uibetk1F$P8i5dzm*u%Fphji zxb3^$@jNVYJ7%kK`s(*9ix+8QCp)HTv;`Xq=Kqmcb&`TLd#M8B0#*8naY9axaR&HK zZ07(4R)|fi9CB~ebcp+5;@MHk9pTS~=L3E>yX?fWm)do?i~%~1K&49jpp!J?Mc~XL z|4Hu7=|?wN%OC3tewf}gU28t=#nGO$!958CM(p^Ax2PF7sm2!2k@VmEdn;lhWj;kW zLP6h}1+n^ZPPo2n%9`h;Wd4Rh$14yIW;D>|`^aMcPV2}4|5f>fuX@z_6a(HVDTYSP zcV&kwtZgKC8z`_dG+aR(B*O^`b$2zoc@$_0JAWuD5ImqvksyJh=GBM^?d|QeK0D7Y zcdX6;$zl4@d-y`{9L)mrcSR-3AgrwguO$N>Pi*PU=p}2ZsEZ$Uu*rW?oK=Cy*i6cu z(o}iIa9R}*BhQJdtl8dPZNIg#uAAxaXdr#qkn0qHQ4m5oeS8rah9#LfPWc{DWw%J# ztI483<5~6B`Elvb7u?T`z)C$8(XXW$H<~xnZbOjg(Q|iImPXlXL{cp=^fN+Y2=jfO{v_SMIRIR*MiI zJ0QJL$J6fZyOXEuWoSLq$51oXbgONC5@_f#Ho-r>EU~vn`v-Sjl%z4O-0xxH5sA+E zAT+APz9(Pw7H=ebEinM1m|JD|E22NvfLJxmSvwmQ!3lYAc};Jkj7?`@Vsy;7-Rbk1 zEbk`A+(hPHyXyJD;%L#|^TZTl)&031M_M-xF3c{gWf`2EibotMAWG7ODe4?0ko5*1Muns+x`sF&c^5QjW^9N z`O_n?rcoHW#+pq3Bds}aqkJ~|n-fj7q%PMY{J){ZPwrvk7jPa2+L!>2MdEd7XU|};p&{R!^b9jW~D9l@tz zA)Yr;9k9X|S<6lP_ZYbWcjoL&V~F|5zoYSDCotM_;ar*1`+^o0B6#X!3|F`E&6QiA z?fkxXGw&t#k89?2&#-fX1A>b*-UR@y{isk zbn$531WyHe5s&w7AWR%FxcKXq`QrAPUtY3Dd<+@?+S)y>Fgp!6UDU8r5FID<48zPI z(}Wu$ue%B%IsKrr%ZQEOEr7~R&1W_Pi=Ix0OO{6pr zQIi4hbXH~-HXrX@=c142+4D4B<_vUe$%QWGct4E`?UM3}e=oX)=+VAU!>gCk5{3In zL|am95UnIl|LgC&6bXbEK~YG0yog4P_A|J12kDmxP&l%^cSYwnbS4#?dSAi>Ec-ym zzrAnsFf1_sGjG1O{`o8stuPtxy`{icnBRk`B&^tJQU$I0e$p-wQ)W!f*i}Dr&-?r8 zyMotOuaw6qm7%)Aoori(wA+5xZTZe^q?HUb+H&{_b{BFLyfGeFaHk%5WNA^V)Xv7x zEK6YmNXW7t-6^Na)8QXK%-u;F2cI$u(IhYMe|r4$n8b~I>O{uf6AA)W`c09~**EiH zMLJ>U-L)6_fS;|I#aSKAYcCFgQzdIty@Tk=|DZ9@_qx%K8dS%{1#5oky6{+QK7L}F zMIW(%yNNw4gp#1J48{1FbocbdUlF)4Tp}j`?Y{fEIDqLp+}o8K5_~zElHj+R+jvp+ z@91rg@nR^{VsULfX;7hS(RU&BBu8my35`I(nF)nZ7u%&b$8^VGo89t5^1i{QauCM} zt!&?A(wgS~iScq3JCF%aSp>7Q6My~6$U#xJn%n?$24ZjZL*-*z*XSEaVV(}Qz+z3~ zMf_FGJN>O(>Z4A7j#f8XP>i7pD)>{Az@bc)MphLCySg{?-4jRj>T=+EI61Cw4TI3? zxE9B)r_dsPwBtqrlsz4rJ%D)VY*|?XL zHvdbD7g`wMFKPG#Rq$8BbGmQ=V4wxvR^UlAc=p_SIC1Pg`*WSNi&{#zUUN!Usx8zQ}O9uX$N}8GS&XzhXi)DM=9p z{e^;~1C$LdjHh-qR1$L)lD4aA1voNeluaF{9=BjyNo3U>{!!r2$G_6(jN?({|H{qD zf;~Esro5{8%%sZRh8ITN7O&Xt_NSICDQ+xhw(z@BIPDWHL8R*DMG^HaMa~ME1or&@ zLSwDGH@Fc zo>gm1K~(%T_M#j=Gtx_V$k!u3@#yM?n zV+R9=M{@*lJBORYxd2lnLcUZzIz|mUPv2^}Jrbay`ql_w>+lV<>!^*H=?~~1?pAW% z`>+#1_7|Y35ENLR9H$ma@-x2X^`a%mdU4OCbDJ zdj1MWEf~m?y3~NRqD;$~rxeJ^$A;7Y@RM%|o=P3SN*_r;_);Nqg<~93>anc=8+XJ0 z4O+}1X5aTXG7BiAW`u@k|x_7^WqYRyT=Cx-YZO!^m{-L zP0=F)!(81;!mt{BVv*|nRF3_K+Pz$|P#CZx3xzoVv+gr*p3!%*)_&0wbc?-(UbE3q z{NH1?z3F?99RFKmgbMWvI@H`yV3S~rZsO6XBmOzbM6b8}1*v~aUxB4vb!|1vB1nAwUzeGwg>@3A zT_6W&juDdte&(K1X+&Mb&h#Uh8^EXWs1^P9`sM4i*U#=6ls>IZDSDbBR9NBeZ1~f` z#qidW0qo%QmCeQxWDklXC<8E+yrfJC38(R#7N<;!nJ@En~&d!1x`ZA1d9TnO`AZ;{3MD3TFtH?jmWS*gDXKmBUS&7~bl)2HE!Sy}K42cOyBN7x(=(5Iz32ht%O%z?BPo0w5TC(qmz3hU3YS1!@J%YXKj1>;!kiMT+Dl;!T9bO^U z$({|kxGGLxWP#phy9>1%u=wZUig5@>SW4==aO#_*E;!Avn4jZq?}{nohEa<-k@kRY z+}DpCKi=K|bw8*b_|xAv(%kOJ5hE1x_-a3S!9VmqcoX=UT(dS0X5KTu~rw*vBqtp`K^vy2flw^W>*G2LM;^ zq%#xcNidn`LLm?fX^l6fA2UuS4IVfj?k9gG$ud9X3-*_grKjjfx)4*ES>Y~k^bE?^ z9PjIf66TuX-oNgS01n)feTI3~-b6+%T&|qIr_XP)I&gO_NqCiQ_hUowI%zWWpzF?> zXtd0$>+>%z_PnB;!^RYY3`>L;RO`Fm?_9k<^ICh-)O#;T)gC%_yViy&bMY<*L61rq z)w*lKG+wYhFXO6fXX2D;_$0?=f)vbtC@xTQ$a0zLyEN})IRu30!6_{45y^3PZN|Bm zuXi9z`FwgLWc7B_Myu(m0x$JhSaNmWJ<>VV=p+X4!Booety2TfF=@x({ADX-5_?HV+agwEfLx)~`Zk{v>cRKu!ELCe<)y zhHao{1UJYP2=EYx597|ACc4vK8}Xj>WXo{SUq-039mLY~`YrVlobbAAcB(FP=HmHN z9V5pTj9xP=H2&iB<32Gmnj$@XRS!*h&UKBAs`<+zsRpvU4^|ngM*BNemeSK-ZM(8s zmE7uN=vvMhoj5BT+l}HG^*;*c%Jf|S2m6iE=7^~?85m`JzL1M1=!A*q_hUq(-UtMl zo4|F&0ZpJjtBx0T`e}zLQ)V-{VW))2%S3DCrg-(Mu1dT%zpTX0y6$_mV2(SxPh7h< zy`%59w>7?NqRW)9hf#t*F$~-uNR`~{@n74?Ub0B?KQ7See`e#Wp0WKoEXS%1SGvBh zLi5+32-xi8DpeUyFD<RAo04MiNTwjL<0|3YqsDI$J6W!QThbWxgRi68R*EWwh0 zIIVeF(P_F%!5NB}uci#$lXYaDVhsUZ-x;V@^0}9mR^@*ZLj@I?y#46to9b4mppFMJ z0`bx8pxM={s6m0=e8CJgcA?(l^}ZQ&-F%>#2>=9wz0PDZ^PVpLJ}K4X&$-mmeMXs> zDU@?@N4S26gM|uC>*s=_%-^=j3`G2o^SV(~-KSV3lA%E9|Gs@yx1G*CgnO^TZbHAu z9a&H6q$}8%w)3+Ju`C?XEE(Y-%eB`}^)hyRkcaY(e&mgqyzdafg3xV))sNDnxfsAn zOTv5wSpO4m|Tf|=dUVU=) zKOHItGqis4fpka(YZkGGfo)y2NA&FJboSLUg#xciw9#VZs$rfGE#SiY97|vb8z1!B z6O|VZB}MuT6)ml|j~wpY4$bD2LjvNVFjEfGFFXh_C~j!GW`oJl+T6#cgsRhu9)1YV z)7zJl^u~>k)%Uz~b!FAS#ZW zCN%jl2Ij)aKG|K`V+um+L%sI`hFdY9so>Tmq%9}YJy(*tIvTmr&C%Z}G@YwgvQoeQ zlfWEF+u5eNxZV_hl1KeLUtnqas_XCLRn`lVQc~$zYA7a&TibEyQGD3SXA+vkEo?r( zN-9xyJ?6B!4sQN}{&N$!v=nnB8U!ICXc9a>wF#boLhoDsUFatHmUf+|IC|~Ic($k8 zmJ{jk{yzK5XE}NTfLmO@h@VEU^(F4rd|#ZU{Vmh=m8wscZZ`kv-@p5}6cfD|Rh_;I z=A4FV?66@d79zBK3XkV1xi{%A^x^a4Sgndc5GmkMdxT1*CWi;GdKh>`OTe}W+GABN z*-?^TJwS&8@9m~w<18n00?hs8{v>jXUBtma&%v4t^v8ParGs)oCtu@MFM>J!v#uDZT_SPGiVPmJs^-uo`c@rNxMFb#j7! zeSGv$h+K_v26SzWKo2#yM>qnFqj$x{e3X{W-oHG{Ob!i55O~<13bDfd@5SgRe&2~K z7`K`&eV`xMw#us*c-A9z-#pF&jogX!GaH$mwb6}Kf)YP{7kzvz!~I#r-Y#70E}s^r zI1ZT>rndZGjo0PDlgjVy(p9%^y&(;VskaQ497dpT0e&_UAWIVO3T{??eEj}r^dSC* ze0(Cl9=SJS=rv)DcOGNFt9iyj1`TdUOmOdsw_oh0al1zy#QCPTO~8-hp&UatYf+om znTf&;7M8R&zuZm5I2#@Bx8Hu^vPZ5_`*D1(GNYGTZ>4!BSpuzxc84pEt+iU&Ynr$&2|Gl7|$iAyPEaW0j_@SWgPG87)}3Wq#Yf63m%;^*x}A?^8MB8ZdiX zW=WfL@z#~^(0eR9D)C8oo9maB4&pDNvrJOgmPB*P1BiI(Q+JjBJ-6XFbVKDIkkQ|{ zRjRs@C>DQ`JGfNxiY3tmp$?8>)4?Sy z3eJl=Qn@!+7&(|AtB4A~mgM}yi+WN2IwjsvzTs{0j$z8y>!21LdDg(+CekUP46jea zQ`(+9Upku5V&)0x(1KIrpZpY+)7^d;CvTI+{-h8MZgIN96gtAcA@|~YA7Hmx_X+M~ zW`sZEoKid)eltKwsT17qd3<%SvHqH36?V>0L7M+F$EJrr{#m?iGcCeg)I1ke_w>rK z<6~~ko1@+es{it@9v!;UzkQ!NT>y$>bUSURH=Y#@rIQ3Sr6 zV0{}37UlfPWZx`xej}t%Iq-OA6vI9qMh!-rKR#v7s$adv%= z7TR<}7>Dn81)Az^1Q7^ds8DZ^vI*F(x((lW0mU~BC8EM_ZUDFvS;*-ENqJ)jR z8y7MZCglx(gMY&YyiQNlj&aG~cM#lqe)Z+kf^GI-(yS%MDYN3E0_@2)W1eEH`qFW> zrB-j(gibEUz|fCG7m!6eo5#DKv9A)t&)?Esc01te(!HXhb_%UeHaa>hs@%S=a_xs-lAT5F*Qn#c?3Q`h#BOuZ# z-67K53nML^(xHSjOLy1ONHL4=5?L(yv`AJ!j-+&6BYiO zKrCTm6?{v#SYofz@W=rt(4_16CVJVe$?p^p_Bp&VLFC(VEB1XId$*NW+haP>BmWMM zda=hU^IWgl6?XH%K3&(bxEuV6+EeY*DU#g>L6>({wa@)#=rkZCmJw@A8y)rZJrL^C zTmN6nGaqbBLP%ERaDd>gLVsUQp*M@5+_^~hrf2h?XN<>=J_;u3a-Q;reib1cU5;76 zvj@a0&xQ5>CVJwhsoK#<-vqu}XE~jW5xPYhP{Ez=hr{%DE9`HntwBqCDGrDmukHQU zuGDf;hiof?jMN6RpQ=mhmq-oAHx-11o5TL|LlspjfcHp#4c{ekD@wpVdUmYeL(=a0 zDYuQ$L!NT)^bU9VJgp zhYU2^oH?Tfguu{O1j*1$Eo=RhnRrmC`$i$jDTmG(w;j^&sng05!zmH(lTHNio}!UH zFLk#oTkdn2M?9U%nYSpU;lCicoakHYTRQmi4chHv9Qw}@Roll1nZyg+#6ZYI zCn(>nDl_~ZqzW(&8*-X>&TV%>+F;9iml%(qC}OsDpK``(q#&>$>%|t`nqM6p9~!L~ zvyLE4b6VH@C=uz8UD5FwpXvv&g4nE4W`&rsdpAkRLd+-Bm9VK}=(XYikGw%IYmu=2mB@VNU z(v>*9ZaAGIyfb))>Rg8++O%q8JbAxhFPTu!ERFS%q-zQf(;5k3o+qO8=d*UfvE$I2 z@3k|SU~I}Sh+!Fxc4yPdl6(##-8WYvBuT7W|Lb9>|F4d~;@d;RNB35fBS z2O*m5fB%luKR50Et3ZYOLQT9TO=i)>1(U1%ULWIS220(cVB_&E&$3dZwHoma_wI{K z8>EXoTtBEoKk$iRIak(RLw>wp zYcTZu1-Ju=+H@L_vKu%ylBqo|f)T{Uex_F))!8=)X#c=e1hhi1cr~bPXX%&x+f%m# z{iojKCro%uJ~RTUg~gKl`X=XRowz}05B##&c;VY*XW%68_%ancL(c+}PqdCC>!Epv zB}esK$uO}#g^acR`-*u%zM~VtthN<@sO+wka9j|_mkw9FUAdHbV99ynPL=^W(iVfHC{>*9RK8ZzZt~3^n8Z>?)WMX=YSd`4dnKKsO1)hl2HMFBg}LPim=Sp80NlcYsPPvYbEM%s&MKKApOa)O&V1L!hVDNIeb ztHH;nh?^bO&xZx{at0lZ3AKFeA#|A6J){tVBV8=8#`u^2z0=h>8>+6RQnq!*?^&8^ z^g8v;kQ+${Xmsb(9`)P(f{~`fLa(x)6O!H|uMI9V4t?aE4|H!ZSXzdU&{##rF3dM; zrrqr10o)_@(Nb{z-vU`kSLPfs$R(%Qr%bGBJ6@r=#%w&t^J;fIe5R4CfeKXJ7~lG5 zfJq7H-LI{nIe&*O70^=^Ba3?*a>!1te_WXtWPj1a*^*K}YvRjPH!cy;sP3^b75NJh zLPq{0xfmIL8;;y;#*J%D$qOkj*^CA?>t?XIQ_G!e?57sz#Rr4RCf^VTWwDNFLlY2@ zJ|_pOAzIEhYFojGL@t5r;r%+{{;oI>i5?Kx81JVW6vtq)L+#wh zZ5MW!@zBP1W0#NSQ*K0MX4P6I$>?Ef#^>%%3>Wk7ZgDq*tG!;vcy@qe9n@Uy#sqx! zK0tbzES~MR(ek>aD2)h7`5@86Qf7CDlCH+-8~Z#iJ0mJHk2mZ&4;_Si4ov)Nw1)2- z-45P`=zHZ{g>Cd4O8dBU-R-I^@c+ zPmh$@^S_C#IcrONJm6Rk*mltS=?{3$d0ihypeBc|OqA9Y-EMl

    S_?eITj^9+}P3 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

    L=eN36kVGQ1i$$%YQUF%D&7|5$J02G} zxIV(z3`@g11~ci|cw^wh*{nv_Dyv5>h+D;7eYlc0<=E--i}Wgi1=skj=u?WqqVLTY zf6zOhzp{QGF|)uPN=zN|&HIYx&%QmBf#KvYNt`;ccgVA8co$Q$znZJ!|DO;H^xEQJ zdO18k>vwo!H3M@x;LaYd#u3p|YPQ=}QzpTPaLj?8{Y}`JK4i@dJO1?RUMZ_xkQiAt z>iM0{{TGK77qA>KwPBveTY#e@)fYDMJ_;nJzcwr21W(5c8uL=GCEbg~G@yF$bq0RT zeIvqtusRSLHv}7+qZ{Zz^il#(MsC{%l*D-Zczt$p#kCB@-cDeu!fq_2Ubg{2$WAQw&1qa)5!g6BvSBDEZz z6Jc)G#NQ+OEm;}S9auWNyGhW)UH9VI*PXxzO>RlQ_H7?=R-a=f+;x|d9}-*h?_-e` z!#Ku48D;twI5h-ttDdkt^5Mc!AwhzRtJmXcj(s{8uHuGR_=Cdm4L|gzoszr28!jF$ zx0fXwDIN#|F%>_GQEWNKjp-@XXYsQt8d9F6eWzB!!cc|oA@BH5qaB&H-hW*#4K`4= z@V)B?Z*zcq|6u|}&XJ;ZzKAaQKsx?!;(;8g*H2r4B(tusA1xaE8$$qq>1F}<^*B#5 z+QQVgixd(%u|I>aU>0F+`e#Y8(w_&g^E3I|OGK*|bF3B?_iT3kk4^HB`?i*q>te86fRWs%`jbcPb~D65pVmoRSy208t{`t1@GNn?`7x^E TflO(UO6WJ35 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

    t+| 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

    UT}Dy~v>>6-MtVSg-__RA+x= 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

    uf0O{o*et>dw3BG)#YGyKES~ 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

    !QN&DZi{mR=S>Wgt{c^F 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≺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 F{|7R#LjwQ+ diff --git a/matsim/src/main/java/org/matsim/core/utils/io/IOUtils.java b/matsim/src/main/java/org/matsim/core/utils/io/IOUtils.java index e8667ea8c22..9cc3cde191a 100644 --- a/matsim/src/main/java/org/matsim/core/utils/io/IOUtils.java +++ b/matsim/src/main/java/org/matsim/core/utils/io/IOUtils.java @@ -207,7 +207,7 @@ public static void setZstdCompressionLevel(int level) { public static URL resolveFileOrResource(String filename) throws UncheckedIOException { try { // I) do not handle URLs - if (filename.startsWith("jar:file:") || filename.startsWith("file:") || filename.startsWith( "https:" )) { + if (filename.startsWith("jar:file:") || filename.startsWith("file:") || filename.startsWith( "https:" ) || filename.startsWith( "http:" )) { // looks like an URI return new URL(filename); } From 156164f270ff12ede7271420495449141caae84f Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Fri, 8 Dec 2023 11:13:52 +0100 Subject: [PATCH 18/43] implemented abstract parent class to replace MatsimTestUtils --- .../contrib/bicycle/run/BicycleTest.java | 211 +++++------ .../config/ReflectiveConfigGroupTest.java | 16 +- .../matsim/testcases/MatsimJunit5Test.java | 344 ++++++++++++++++++ 3 files changed, 452 insertions(+), 119 deletions(-) create mode 100644 matsim/src/test/java/org/matsim/testcases/MatsimJunit5Test.java diff --git a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java index 0f2dea83a91..a5a798ee9de 100644 --- a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java +++ b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java @@ -21,8 +21,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; -import org.junit.Test; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -51,6 +51,7 @@ import org.matsim.core.router.TripStructureUtils; import org.matsim.core.scenario.ScenarioUtils; import org.matsim.core.utils.collections.CollectionUtils; +import org.matsim.testcases.MatsimJunit5Test; import org.matsim.testcases.MatsimTestUtils; import org.matsim.utils.eventsfilecomparison.EventsFileComparator; import org.matsim.vehicles.Vehicle; @@ -63,23 +64,19 @@ import java.util.List; import java.util.Map; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; import static org.matsim.utils.eventsfilecomparison.EventsFileComparator.Result.FILES_ARE_EQUAL; /** * @author dziemke */ -public class BicycleTest { +public class BicycleTest extends MatsimJunit5Test { private static final Logger LOG = LogManager.getLogger(BicycleTest.class); private static final String bicycleMode = "bicycle"; - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testNormal() { - Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -87,33 +84,32 @@ public void testNormal() { config.network().setInputFile("network_normal.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(utils.getOutputDirectory()); + config.controller().setOutputDirectory(getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); + final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; + Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); - Assert.assertEquals("Scores of persons " + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of persons " + personId + " are different"); } - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test public void testCobblestone() { - Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -123,7 +119,7 @@ public void testCobblestone() { config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(utils.getOutputDirectory()); + config.controller().setOutputDirectory(getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); @@ -131,22 +127,21 @@ public void testCobblestone() { { Scenario scenarioReference = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); Scenario scenarioCurrent = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); - new PopulationReader( scenarioReference ).readFile( utils.getInputDirectory() + "output_plans.xml.gz" ); - new PopulationReader( scenarioCurrent ).readFile( utils.getOutputDirectory() + "output_plans.xml.gz" ); - assertTrue( "Populations are different", PopulationUtils.equalPopulation( scenarioReference.getPopulation(), scenarioCurrent.getPopulation() ) ); + new PopulationReader( scenarioReference ).readFile( getInputDirectory() + "output_plans.xml.gz" ); + new PopulationReader( scenarioCurrent ).readFile( getOutputDirectory() + "output_plans.xml.gz" ); + Assertions.assertTrue(PopulationUtils.equalPopulation( scenarioReference.getPopulation(), scenarioCurrent.getPopulation() ), "Populations are different"); } { LOG.info( "Checking MATSim events file ..." ); - final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals( "Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew )); + final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; + Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew ), "Different event files."); } } @Test public void testPedestrian() { - Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -154,28 +149,27 @@ public void testPedestrian() { config.network().setInputFile("network_pedestrian.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(utils.getOutputDirectory()); + config.controller().setOutputDirectory(getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); + final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; + Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); + Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test public void testLane() { - Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -183,28 +177,27 @@ public void testLane() { config.network().setInputFile("network_lane.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(utils.getOutputDirectory()); + config.controller().setOutputDirectory(getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); + final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; + Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); + Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test public void testGradient() { - Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -212,28 +205,27 @@ public void testGradient() { config.network().setInputFile("network_gradient.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(utils.getOutputDirectory()); + config.controller().setOutputDirectory(getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); + final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; + Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); + Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test public void testGradientLane() { - Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -242,28 +234,27 @@ public void testGradientLane() { config.network().setInputFile("network_gradient_lane.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(utils.getOutputDirectory()); + config.controller().setOutputDirectory(getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); + final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; + Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew), "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); + Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test public void testNormal10It() { - Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -271,7 +262,7 @@ public void testNormal10It() { config.network().setInputFile("network_normal.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(utils.getOutputDirectory()); + config.controller().setOutputDirectory(getOutputDirectory()); // 10 iterations config.controller().setLastIteration(10); config.controller().setWriteEventsInterval(10); @@ -281,16 +272,15 @@ public void testNormal10It() { new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); + final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; + Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew), "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); + Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test public void testLinkBasedScoring() { @@ -301,7 +291,7 @@ public void testNormal10It() { // new RunBicycleExample().run( config ); // } Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); { Config config2 = createConfig( 0 ); BicycleConfigGroup bicycleConfigGroup2 = (BicycleConfigGroup) config2.getModules().get( "bicycle" ); @@ -309,22 +299,23 @@ public void testNormal10It() { new RunBicycleExample().run( config2 ); } Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); // LOG.info("Checking MATSim events file ..."); -// final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; -// final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; -// assertEquals("Different event files.", FILES_ARE_EQUAL, +// final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; +// final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; +// Assert.assertEquals("Different event files.", FILES_ARE_EQUAL, // new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); - Assert.assertEquals("Scores of persons " + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of persons " + personId + " are different"); } -// assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); +// Assert.assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } - @Test public void testLinkVsLegMotorizedScoring() { + @Test + public void testLinkVsLegMotorizedScoring() { // --- withOUT additional car traffic: // { // Config config2 = createConfig( 0 ); @@ -334,7 +325,7 @@ public void testNormal10It() { // new RunBicycleExample().run( config2 ); // } Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); // --- // --- WITH additional car traffic: { @@ -393,22 +384,22 @@ public void testNormal10It() { controler.run(); } Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); // --- // --- // LOG.info("Checking MATSim events file ..."); -// final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; -// final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; -// assertEquals("Different event files.", FILES_ARE_EQUAL, +// final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; +// final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; +// Assert.assertEquals("Different event files.", FILES_ARE_EQUAL, // new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); - Assert.assertEquals("Scores of person=" + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of person=" + personId + " are different"); } -// assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); +// Assert.assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } // @Test public void testMotorizedInteraction() { //// Config config = ConfigUtils.createConfig("./src/main/resources/bicycle_example/"); @@ -422,26 +413,26 @@ public void testNormal10It() { // new RunBicycleExample().run(config ); // // LOG.info("Checking MATSim events file ..."); -// final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; -// final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; -// assertEquals("Different event files.", FILES_ARE_EQUAL, +// final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; +// final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; +// Assert.assertEquals("Different event files.", FILES_ARE_EQUAL, // new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); // // Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); // Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); -// new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); -// new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); +// new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); +// new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); // for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { // double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); // double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); -// Assert.assertEquals("Scores of persons " + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); +// Assert.Assert.assertEquals("Scores of persons " + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); // } -// assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); +// Assert.assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); // } @Test public void testInfrastructureSpeedFactor() { - Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); config.controller().setWriteEventsInterval(0); @@ -486,7 +477,7 @@ public void testInfrastructureSpeedFactor() { config.plans().setInputFile("population_4.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(utils.getOutputDirectory()); + config.controller().setOutputDirectory(getOutputDirectory()); config.controller().setLastIteration(0); config.global().setNumberOfThreads(1); @@ -523,20 +514,20 @@ public void install() { controler.run(); - Assert.assertEquals("All bicycle users should use the longest but fastest route where the bicycle infrastructur speed factor is set to 1.0", 3, linkHandler.getLinkId2demand().get(Id.createLinkId("2")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Only the car user should use the shortest route", 1, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, linkHandler.getLinkId2demand().get(Id.createLinkId("2")), MatsimTestUtils.EPSILON, "All bicycle users should use the longest but fastest route where the bicycle infrastructur speed factor is set to 1.0"); + Assertions.assertEquals(1, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON, "Only the car user should use the shortest route"); - Assert.assertEquals("Wrong travel time (bicycle user)", 1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (bicycle user)", 1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(1), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (bicycle user)", 1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(0), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); + Assertions.assertEquals(1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(1), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); + Assertions.assertEquals(1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(2), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); - Assert.assertEquals("Wrong travel time (car user)", Math.ceil( 10000 / (13.88) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Math.ceil( 10000 / (13.88) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON, "Wrong travel time (car user)"); } @Test public void testInfrastructureSpeedFactorDistanceMoreRelevantThanTravelTime() { - Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(getClassInputDirectory() ); BicycleConfigGroup bicycleConfigGroup = ConfigUtils.addOrGetModule( config, BicycleConfigGroup.class ); config.controller().setWriteEventsInterval(0); @@ -580,7 +571,7 @@ public void testInfrastructureSpeedFactorDistanceMoreRelevantThanTravelTime() { config.network().setInputFile("network_infrastructure-speed-factor.xml"); config.plans().setInputFile("population_4.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(utils.getOutputDirectory()); + config.controller().setOutputDirectory(getOutputDirectory()); config.controller().setLastIteration(0); config.global().setNumberOfThreads(1); @@ -610,16 +601,16 @@ public void testInfrastructureSpeedFactorDistanceMoreRelevantThanTravelTime() { controler.run(); - Assert.assertEquals("All bicycle users should use the shortest route even though the bicycle infrastructur speed factor is set to 0.1", 4, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (car user)", Math.ceil(10000 / 13.88 ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (bicycle user)", Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(1), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (bicycle user)", Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(2), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (bicycle user)", Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON, "All bicycle users should use the shortest route even though the bicycle infrastructur speed factor is set to 0.1"); + Assertions.assertEquals(Math.ceil(10000 / 13.88 ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON, "Wrong travel time (car user)"); + Assertions.assertEquals(Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(1), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); + Assertions.assertEquals(Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(2), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); + Assertions.assertEquals(Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(3), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); } private Config createConfig( int lastIteration ){ // Config config = ConfigUtils.createConfig("./src/main/resources/bicycle_example/"); - Config config = ConfigUtils.createConfig( utils.getClassInputDirectory() ); + Config config = ConfigUtils.createConfig( getClassInputDirectory() ); config.addModule( new BicycleConfigGroup() ); RunBicycleExample.fillConfigWithBicycleStandardValues( config ); @@ -627,7 +618,7 @@ private Config createConfig( int lastIteration ){ config.network().setInputFile( "network_normal.xml" ); config.plans().setInputFile( "population_1200.xml" ); config.controller().setOverwriteFileSetting( OverwriteFileSetting.deleteDirectoryIfExists ); - config.controller().setOutputDirectory( utils.getOutputDirectory() ); + config.controller().setOutputDirectory( getOutputDirectory() ); config.controller().setLastIteration( lastIteration ); config.controller().setLastIteration( lastIteration ); config.controller().setWriteEventsInterval( 10 ); diff --git a/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java index a662f53d5ad..be71252c59f 100644 --- a/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java @@ -32,13 +32,13 @@ import java.util.Map; import java.util.Set; -import org.junit.Assert; -import org.junit.Rule; -import org.junit.Test; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.core.config.ReflectiveConfigGroup.InconsistentModuleException; +import org.matsim.testcases.MatsimJunit5Test; import org.matsim.testcases.MatsimTestUtils; import com.google.common.collect.ImmutableSet; @@ -46,9 +46,7 @@ /** * @author thibautd */ -public class ReflectiveConfigGroupTest { - @Rule - public final MatsimTestUtils utils = new MatsimTestUtils(); +public class ReflectiveConfigGroupTest extends MatsimJunit5Test { @Test public void testDumpAndRead() { @@ -128,7 +126,7 @@ private void assertEqualAfterDumpAndRead(MyModule dumpedModule) { Config dumpedConfig = new Config(); dumpedConfig.addModule(dumpedModule); - String fileName = utils.getOutputDirectory() + "/dump.xml"; + String fileName = getOutputDirectory() + "/dump.xml"; new ConfigWriter(dumpedConfig).write(fileName); Config readConfig = ConfigUtils.loadConfig(fileName); @@ -141,7 +139,7 @@ private void assertEqualAfterDumpAndRead(MyModule dumpedModule) { @Test public void testReadCollectionsIncludingEmptyString() { - String fileName = utils.getInputDirectory() + "/config_with_blank_comma_separated_elements.xml"; + String fileName = getInputDirectory() + "/config_with_blank_comma_separated_elements.xml"; final Config readConfig = ConfigUtils.loadConfig(fileName); final MyModule readModule = new MyModule(); // as a side effect, this loads the information @@ -362,7 +360,7 @@ public Object getStuff() { final String param = "my unknown param"; final String value = "my val"; testee.addParam(param, value); - Assert.assertEquals("unexpected stored value", value, testee.getValue(param)); + Assertions.assertEquals(value, testee.getValue(param), "unexpected stored value"); } @Test diff --git a/matsim/src/test/java/org/matsim/testcases/MatsimJunit5Test.java b/matsim/src/test/java/org/matsim/testcases/MatsimJunit5Test.java new file mode 100644 index 00000000000..0581a3d58d0 --- /dev/null +++ b/matsim/src/test/java/org/matsim/testcases/MatsimJunit5Test.java @@ -0,0 +1,344 @@ +/* *********************************************************************** * + * project: org.matsim.* + * * + * *********************************************************************** * + * * + * copyright : (C) 2010 by the members listed in the COPYING, * + * LICENSE and WARRANTY file. * + * email : info at matsim dot org * + * * + * *********************************************************************** * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * See also COPYING, LICENSE and WARRANTY file * + * * + * *********************************************************************** */ + +package org.matsim.testcases; + +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; +import org.junit.Assert; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.TestInfo; +import org.junit.rules.TestWatcher; +import org.junit.runner.Description; +import org.matsim.core.config.Config; +import org.matsim.core.config.ConfigGroup; +import org.matsim.core.config.ConfigUtils; +import org.matsim.core.gbl.MatsimRandom; +import org.matsim.core.utils.io.IOUtils; +import org.matsim.core.utils.misc.CRCChecksum; +import org.matsim.utils.eventsfilecomparison.EventsFileComparator; + +import java.io.BufferedReader; +import java.io.File; +import java.io.IOException; +import java.io.UncheckedIOException; +import java.lang.reflect.Method; +import java.net.MalformedURLException; +import java.net.URL; +import java.util.Objects; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +import static org.junit.Assert.assertEquals; + +/** + * //TODO + * + * @author pheinrich + */ +public abstract class MatsimJunit5Test { + private static final Logger log = LogManager.getLogger(MatsimJunit5Test.class); + + /** + * A constant for the exactness when comparing doubles. + */ + public static final double EPSILON = 1e-10; + + /** The default output directory, where files of this test should be written to. + * Includes the trailing '/' to denote a directory. */ + private String outputDirectory = null; + + /** The default input directory, where files of this test should be read from. + * Includes the trailing '/' to denote a directory. */ + private String inputDirectory = null; + + /** + * The input directory one level above the default input directory. If files are + * used by several test methods of a testcase they have to be stored in this directory. + */ + private String classInputDirectory = null; + /** + * The input directory two levels above the default input directory. If files are used + * by several test classes of a package they have to be stored in this directory. + */ + private String packageInputDirectory; + + private boolean outputDirCreated = false; + + private Class testClass = null; + private String testMethodName = null; + private String testParameterSetIndex = null; + + public MatsimJunit5Test() { + MatsimRandom.reset(); + } + + @BeforeEach + public void initEach(TestInfo testInfo) { + this.testClass = testInfo.getTestClass().orElseThrow(); + + Matcher matcher = METHOD_PARAMETERS_WITH_INDEX_PATTERN.matcher(testInfo.getTestMethod().orElseThrow().getName()); + if (!matcher.matches()) { + throw new RuntimeException("The name of the test parameter set must start with {index}"); + } + this.testMethodName = matcher.group(1); + this.testParameterSetIndex = matcher.group(2); // null for non-parametrised tests + } + + @AfterEach + public void finish() { + this.testClass = null; + this.testMethodName = null; + } + + public Config createConfigWithInputResourcePathAsContext() { + Config config = ConfigUtils.createConfig(); + config.setContext(inputResourcePath()); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + public Config createConfigWithClassInputResourcePathAsContext() { + Config config = ConfigUtils.createConfig(); + config.setContext(classInputResourcePath()); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + public Config createConfigWithPackageInputResourcePathAsContext() { + Config config = ConfigUtils.createConfig(); + config.setContext(packageInputResourcePath()); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + public URL inputResourcePath() { + return getResourceNotNull("/" + getClassInputDirectory() + getMethodName() + "/."); + } + + /** + * @return class input directory as URL + */ + public URL classInputResourcePath() { + return getResourceNotNull("/" + getClassInputDirectory() + "/."); + } + + public URL packageInputResourcePath() { + return getResourceNotNull("/" + getPackageInputDirectory() + "/."); + } + + private URL getResourceNotNull(String pathString) { + URL resource = this.testClass.getResource(pathString); + if (resource == null) { + throw new UncheckedIOException(new IOException("Not found: "+pathString)); + } + return resource; + } + + public Config createConfigWithTestInputFilePathAsContext() { + try { + Config config = ConfigUtils.createConfig(); + config.setContext(new File(this.getInputDirectory()).toURI().toURL()); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } catch (MalformedURLException e) { + throw new RuntimeException(e); + } + } + + public Config createConfig(URL context) { + Config config = ConfigUtils.createConfig(); + config.setContext(context); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + + /** + * Loads a configuration from file (or the default config if configfile is null). + * + * @param configfile The path/filename of a configuration file, or null to load the default configuration. + * @return The loaded configuration. + */ + public Config loadConfig(final String configfile, final ConfigGroup... customGroups) { + Config config; + if (configfile != null) { + config = ConfigUtils.loadConfig(configfile, customGroups); + } else { + config = ConfigUtils.createConfig( customGroups ); + } + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + public Config loadConfig(final URL configfile, final ConfigGroup... customGroups) { + Config config; + if (configfile != null) { + config = ConfigUtils.loadConfig(configfile, customGroups); + } else { + config = ConfigUtils.createConfig( customGroups ); + } + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + public Config createConfig(final ConfigGroup... customGroups) { + Config config = ConfigUtils.createConfig( customGroups ); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + private void createOutputDirectory() { + if ((!this.outputDirCreated) && (this.outputDirectory != null)) { + File directory = new File(this.outputDirectory); + if (directory.exists()) { + IOUtils.deleteDirectoryRecursively(directory.toPath()); + } + this.outputDirCreated = directory.mkdirs(); + Assert.assertTrue("Could not create the output directory " + this.outputDirectory, this.outputDirCreated); + } + } + + /** + * Returns the path to the output directory for this test including a trailing slash as directory delimiter. + * + * @return path to the output directory for this test + */ + public String getOutputDirectory() { + if (this.outputDirectory == null) { + String subDirectoryForParametrisedTests = testParameterSetIndex == null ? "" : testParameterSetIndex + "/"; + this.outputDirectory = "test/output/" + this.testClass.getCanonicalName().replace('.', '/') + "/" + getMethodName()+ "/" + + subDirectoryForParametrisedTests; + } + createOutputDirectory(); + return this.outputDirectory; + } + + /** + * Returns the path to the input directory for this test including a trailing slash as directory delimiter. + * + * @return path to the input directory for this test + */ + public String getInputDirectory() { + if (this.inputDirectory == null) { + this.inputDirectory = getClassInputDirectory() + getMethodName() + "/"; + } + return this.inputDirectory; + } + /** + * Returns the path to the input directory one level above the default input directory for this test including a trailing slash as directory delimiter. + * + * @return path to the input directory for this test + */ + public String getClassInputDirectory() { + if (this.classInputDirectory == null) { + + LogManager.getLogger(this.getClass()).info( "user.dir = " + System.getProperty("user.dir") ) ; + + this.classInputDirectory = "test/input/" + + this.testClass.getCanonicalName().replace('.', '/') + "/"; +// this.classInputDirectory = System.getProperty("user.dir") + "/test/input/" + +// this.testClass.getCanonicalName().replace('.', '/') + "/"; + // (this used to be relative, i.e. ... = "test/input/" + ... . Started failing when + // this was used in tests to read a second config file when I made the path of that + // relative to the root of the initial config file. Arghh. kai, feb'18) + // yyyyyy needs to be discussed, see MATSIM-776 and MATSIM-777. kai, feb'18 + } + return this.classInputDirectory; + } + /** + * Returns the path to the input directory two levels above the default input directory for this test including a trailing slash as directory delimiter. + * + * @return path to the input directory for this test + */ + public String getPackageInputDirectory() { + if (this.packageInputDirectory == null) { + String classDirectory = getClassInputDirectory(); + this.packageInputDirectory = classDirectory.substring(0, classDirectory.lastIndexOf('/')); + this.packageInputDirectory = this.packageInputDirectory.substring(0, this.packageInputDirectory.lastIndexOf('/') + 1); + } + return this.packageInputDirectory; + } + + /** + * @return the name of the currently-running test method + */ + public String getMethodName() { + if (this.testMethodName == null) { + throw new RuntimeException("MatsimTestUtils.getMethodName() can only be used in actual test, not in constructor or elsewhere!"); + } + return this.testMethodName; + } + + /** + * Initializes MatsimTestUtils without requiring the method of a class to be a JUnit test. + * This should be used for "fixtures" only that provide a scenario common to several + * test cases. + */ + public void initWithoutJUnitForFixture(Class fixture, Method method){ + this.testClass = fixture; + this.testMethodName = method.getName(); + } + + //captures the method name (group 1) and optionally the index of the parameter set (group 2; only if the test is parametrised) + //The matching may fail if the parameter set name does not start with {index} (at least one digit is required at the beginning) + private static final Pattern METHOD_PARAMETERS_WITH_INDEX_PATTERN = Pattern.compile( + "([\\S]*)(?:\\[(\\d+)[\\s\\S]*\\])?"); + + public static void assertEqualEventsFiles( String filename1, String filename2 ) { + Assert.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL ,EventsFileComparator.compare(filename1, filename2) ); + } + + public static void assertEqualFilesBasedOnCRC( String filename1, String filename2 ) { + long checksum1 = CRCChecksum.getCRCFromFile(filename1) ; + long checksum2 = CRCChecksum.getCRCFromFile(filename2) ; + Assert.assertEquals( "different file checksums", checksum1, checksum2 ); + } + + public static void assertEqualFilesLineByLine(String inputFilename, String outputFilename) { + try (BufferedReader readerV1Input = IOUtils.getBufferedReader(inputFilename); + BufferedReader readerV1Output = IOUtils.getBufferedReader(outputFilename)) { + + String lineInput; + String lineOutput; + + while( ((lineInput = readerV1Input.readLine()) != null) && ((lineOutput = readerV1Output.readLine()) != null) ){ + if ( !Objects.equals( lineInput.trim(), lineOutput.trim() ) ){ + log.info( "Reading line... " ); + log.info( lineInput ); + log.info( lineOutput ); + log.info( "" ); + } + assertEquals( "Lines have different content: ", lineInput.trim(), lineOutput.trim() ); + } + } catch (IOException e) { + throw new UncheckedIOException(e); + } + } + +} From 6447efa06bc5f694237bfd5444b7c3e8f63fc77d Mon Sep 17 00:00:00 2001 From: steffenaxer <26229392+steffenaxer@users.noreply.github.com> Date: Fri, 8 Dec 2023 11:59:37 +0100 Subject: [PATCH 19/43] Make TripsAndLegsWriter public again --- .../src/main/java/org/matsim/analysis/TripsAndLegsWriter.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/matsim/src/main/java/org/matsim/analysis/TripsAndLegsWriter.java b/matsim/src/main/java/org/matsim/analysis/TripsAndLegsWriter.java index ea222d892e4..79ddbd45810 100644 --- a/matsim/src/main/java/org/matsim/analysis/TripsAndLegsWriter.java +++ b/matsim/src/main/java/org/matsim/analysis/TripsAndLegsWriter.java @@ -79,7 +79,7 @@ public class TripsAndLegsWriter { private static final Logger log = LogManager.getLogger(TripsAndLegsWriter.class); @Inject - TripsAndLegsWriter(Scenario scenario, CustomTripsWriterExtension tripsWriterExtension, CustomLegsWriterExtension legWriterExtension, + public TripsAndLegsWriter(Scenario scenario, CustomTripsWriterExtension tripsWriterExtension, CustomLegsWriterExtension legWriterExtension, AnalysisMainModeIdentifier mainModeIdentifier, CustomTimeWriter customTimeWriter) { this.scenario = scenario; this.tripsWriterExtension = tripsWriterExtension; From 0fefc9f2970b336d296d8321d48270d7c7ff0430 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Fri, 8 Dec 2023 13:14:12 +0100 Subject: [PATCH 20/43] implemented Test Extension --- .../contrib/ev/example/RunEvExampleTest.java | 23 +- .../matsim/core/config/ConfigV2IOTest.java | 41 +-- .../testcases/MatsimJunit5TestExtension.java | 344 ++++++++++++++++++ 3 files changed, 367 insertions(+), 41 deletions(-) create mode 100644 matsim/src/test/java/org/matsim/testcases/MatsimJunit5TestExtension.java diff --git a/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleTest.java b/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleTest.java index 8c26016e49a..c2d26638e04 100644 --- a/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleTest.java +++ b/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleTest.java @@ -2,21 +2,22 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; -import org.junit.Rule; -import org.junit.Test; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; import org.matsim.core.events.EventsUtils; import org.matsim.core.population.PopulationUtils; -import org.matsim.testcases.MatsimTestUtils; +import org.matsim.testcases.MatsimJunit5TestExtension; import org.matsim.utils.eventsfilecomparison.EventsFileComparator; public class RunEvExampleTest{ private static final Logger log = LogManager.getLogger(RunEvExample.class ); - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension + public MatsimJunit5TestExtension utils = new MatsimJunit5TestExtension() ; @Test public void runTest(){ try { @@ -33,20 +34,20 @@ public class RunEvExampleTest{ PopulationUtils.readPopulation( actual, utils.getOutputDirectory() + "/output_plans.xml.gz" ); boolean result = PopulationUtils.comparePopulations( expected, actual ); - Assert.assertTrue( result ); + Assertions.assertTrue(result); } { String expected = utils.getInputDirectory() + "/output_events.xml.gz" ; String actual = utils.getOutputDirectory() + "/output_events.xml.gz" ; EventsFileComparator.Result result = EventsUtils.compareEventsFiles( expected, actual ); - Assert.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result ); + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result); } } catch ( Exception ee ) { log.fatal("there was an exception: \n" + ee ) ; // if one catches an exception, then one needs to explicitly fail the test: - Assert.fail(); + Assertions.fail(); } } @@ -66,20 +67,20 @@ public class RunEvExampleTest{ PopulationUtils.readPopulation( actual, utils.getOutputDirectory() + "/output_plans.xml.gz" ); boolean result = PopulationUtils.comparePopulations( expected, actual ); - Assert.assertTrue( result ); + Assertions.assertTrue(result); } { String expected = utils.getInputDirectory() + "/output_events.xml.gz" ; String actual = utils.getOutputDirectory() + "/output_events.xml.gz" ; EventsFileComparator.Result result = EventsUtils.compareEventsFiles( expected, actual ); - Assert.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result ); + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result); } } catch ( Exception ee ) { log.fatal("there was an exception: \n" + ee ) ; // if one catches an exception, then one needs to explicitly fail the test: - Assert.fail(); + Assertions.fail(); } } diff --git a/matsim/src/test/java/org/matsim/core/config/ConfigV2IOTest.java b/matsim/src/test/java/org/matsim/core/config/ConfigV2IOTest.java index f98a8e5603f..4ee31b42d7b 100644 --- a/matsim/src/test/java/org/matsim/core/config/ConfigV2IOTest.java +++ b/matsim/src/test/java/org/matsim/core/config/ConfigV2IOTest.java @@ -22,22 +22,18 @@ import java.util.Collection; import java.util.Iterator; -import org.junit.Assert; -import org.junit.Rule; -import org.junit.Test; -import org.matsim.core.config.Config; -import org.matsim.core.config.ConfigUtils; -import org.matsim.core.config.ConfigWriter; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.config.groups.ChangeLegModeConfigGroup; -import org.matsim.core.config.ConfigReaderMatsimV2; -import org.matsim.testcases.MatsimTestUtils; +import org.matsim.testcases.MatsimJunit5TestExtension; /** * @author thibautd */ public class ConfigV2IOTest { - @Rule - public final MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public final MatsimJunit5TestExtension utils = new MatsimJunit5TestExtension(); @Test public void testInputSameAsOutput() { @@ -56,10 +52,7 @@ public void testInputSameAsOutput() { private void assertTheSame( final Config outConfig, final Config inConfig) { - Assert.assertEquals( - "names of modules differ!", - outConfig.getModules().keySet(), - inConfig.getModules().keySet() ); + Assertions.assertEquals(outConfig.getModules().keySet(), inConfig.getModules().keySet(), "names of modules differ!"); for ( String name : outConfig.getModules().keySet() ) { if ( !name.equals( ChangeLegModeConfigGroup.CONFIG_MODULE ) ) { @@ -74,29 +67,17 @@ private void assertTheSame( private void assertTheSame( final ConfigGroup outModule, final ConfigGroup inModule) { - Assert.assertEquals( - "wrong module class", - outModule.getClass(), - inModule.getClass() ); + Assertions.assertEquals(outModule.getClass(), inModule.getClass(), "wrong module class"); - Assert.assertEquals( - "different parameters", - outModule.getParams(), - inModule.getParams() ); + Assertions.assertEquals(outModule.getParams(), inModule.getParams(), "different parameters"); - Assert.assertEquals( - "different parameterset types", - outModule.getParameterSets().keySet(), - inModule.getParameterSets().keySet() ); + Assertions.assertEquals(outModule.getParameterSets().keySet(), inModule.getParameterSets().keySet(), "different parameterset types"); for ( String type : outModule.getParameterSets().keySet() ) { final Collection outSets = outModule.getParameterSets( type ); final Collection inSets = inModule.getParameterSets( type ); - Assert.assertEquals( - "different number of sets for type "+type, - outSets.size(), - inSets.size() ); + Assertions.assertEquals(outSets.size(), inSets.size(), "different number of sets for type "+type); final Iterator outIter = outSets.iterator(); final Iterator inIter = inSets.iterator(); diff --git a/matsim/src/test/java/org/matsim/testcases/MatsimJunit5TestExtension.java b/matsim/src/test/java/org/matsim/testcases/MatsimJunit5TestExtension.java new file mode 100644 index 00000000000..1e4e87367c9 --- /dev/null +++ b/matsim/src/test/java/org/matsim/testcases/MatsimJunit5TestExtension.java @@ -0,0 +1,344 @@ +/* *********************************************************************** * + * project: org.matsim.* + * * + * *********************************************************************** * + * * + * copyright : (C) 2010 by the members listed in the COPYING, * + * LICENSE and WARRANTY file. * + * email : info at matsim dot org * + * * + * *********************************************************************** * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * See also COPYING, LICENSE and WARRANTY file * + * * + * *********************************************************************** */ + +package org.matsim.testcases; + +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; +import org.junit.Assert; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.TestInfo; +import org.junit.jupiter.api.extension.AfterEachCallback; +import org.junit.jupiter.api.extension.BeforeEachCallback; +import org.junit.jupiter.api.extension.ExtensionContext; +import org.matsim.core.config.Config; +import org.matsim.core.config.ConfigGroup; +import org.matsim.core.config.ConfigUtils; +import org.matsim.core.gbl.MatsimRandom; +import org.matsim.core.utils.io.IOUtils; +import org.matsim.core.utils.misc.CRCChecksum; +import org.matsim.utils.eventsfilecomparison.EventsFileComparator; + +import java.io.BufferedReader; +import java.io.File; +import java.io.IOException; +import java.io.UncheckedIOException; +import java.lang.reflect.Method; +import java.net.MalformedURLException; +import java.net.URL; +import java.util.Objects; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +import static org.junit.Assert.assertEquals; + +/** + * //TODO + * + * @author pheinrich + */ +public class MatsimJunit5TestExtension implements BeforeEachCallback, AfterEachCallback { + private static final Logger log = LogManager.getLogger(MatsimJunit5TestExtension.class); + + /** + * A constant for the exactness when comparing doubles. + */ + public static final double EPSILON = 1e-10; + + /** The default output directory, where files of this test should be written to. + * Includes the trailing '/' to denote a directory. */ + private String outputDirectory = null; + + /** The default input directory, where files of this test should be read from. + * Includes the trailing '/' to denote a directory. */ + private String inputDirectory = null; + + /** + * The input directory one level above the default input directory. If files are + * used by several test methods of a testcase they have to be stored in this directory. + */ + private String classInputDirectory = null; + /** + * The input directory two levels above the default input directory. If files are used + * by several test classes of a package they have to be stored in this directory. + */ + private String packageInputDirectory; + + private boolean outputDirCreated = false; + + private Class testClass = null; + private String testMethodName = null; + private String testParameterSetIndex = null; + + public MatsimJunit5TestExtension() { + MatsimRandom.reset(); + } + + @Override + public void beforeEach(ExtensionContext extensionContext) throws Exception { + this.testClass = extensionContext.getTestClass().orElseThrow(); + + Matcher matcher = METHOD_PARAMETERS_WITH_INDEX_PATTERN.matcher(extensionContext.getTestMethod().orElseThrow().getName()); + if (!matcher.matches()) { + throw new RuntimeException("The name of the test parameter set must start with {index}"); + } + this.testMethodName = matcher.group(1); + this.testParameterSetIndex = matcher.group(2); // null for non-parametrised tests + } + + @Override + public void afterEach(ExtensionContext extensionContext) throws Exception { + this.testClass = null; + this.testMethodName = null; + } + + public Config createConfigWithInputResourcePathAsContext() { + Config config = ConfigUtils.createConfig(); + config.setContext(inputResourcePath()); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + public Config createConfigWithClassInputResourcePathAsContext() { + Config config = ConfigUtils.createConfig(); + config.setContext(classInputResourcePath()); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + public Config createConfigWithPackageInputResourcePathAsContext() { + Config config = ConfigUtils.createConfig(); + config.setContext(packageInputResourcePath()); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + public URL inputResourcePath() { + return getResourceNotNull("/" + getClassInputDirectory() + getMethodName() + "/."); + } + + /** + * @return class input directory as URL + */ + public URL classInputResourcePath() { + return getResourceNotNull("/" + getClassInputDirectory() + "/."); + } + + public URL packageInputResourcePath() { + return getResourceNotNull("/" + getPackageInputDirectory() + "/."); + } + + private URL getResourceNotNull(String pathString) { + URL resource = this.testClass.getResource(pathString); + if (resource == null) { + throw new UncheckedIOException(new IOException("Not found: "+pathString)); + } + return resource; + } + + public Config createConfigWithTestInputFilePathAsContext() { + try { + Config config = ConfigUtils.createConfig(); + config.setContext(new File(this.getInputDirectory()).toURI().toURL()); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } catch (MalformedURLException e) { + throw new RuntimeException(e); + } + } + + public Config createConfig(URL context) { + Config config = ConfigUtils.createConfig(); + config.setContext(context); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + + /** + * Loads a configuration from file (or the default config if configfile is null). + * + * @param configfile The path/filename of a configuration file, or null to load the default configuration. + * @return The loaded configuration. + */ + public Config loadConfig(final String configfile, final ConfigGroup... customGroups) { + Config config; + if (configfile != null) { + config = ConfigUtils.loadConfig(configfile, customGroups); + } else { + config = ConfigUtils.createConfig( customGroups ); + } + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + public Config loadConfig(final URL configfile, final ConfigGroup... customGroups) { + Config config; + if (configfile != null) { + config = ConfigUtils.loadConfig(configfile, customGroups); + } else { + config = ConfigUtils.createConfig( customGroups ); + } + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + public Config createConfig(final ConfigGroup... customGroups) { + Config config = ConfigUtils.createConfig( customGroups ); + this.outputDirectory = getOutputDirectory(); + config.controller().setOutputDirectory(this.outputDirectory); + return config; + } + + private void createOutputDirectory() { + if ((!this.outputDirCreated) && (this.outputDirectory != null)) { + File directory = new File(this.outputDirectory); + if (directory.exists()) { + IOUtils.deleteDirectoryRecursively(directory.toPath()); + } + this.outputDirCreated = directory.mkdirs(); + Assert.assertTrue("Could not create the output directory " + this.outputDirectory, this.outputDirCreated); + } + } + + /** + * Returns the path to the output directory for this test including a trailing slash as directory delimiter. + * + * @return path to the output directory for this test + */ + public String getOutputDirectory() { + if (this.outputDirectory == null) { + String subDirectoryForParametrisedTests = testParameterSetIndex == null ? "" : testParameterSetIndex + "/"; + this.outputDirectory = "test/output/" + this.testClass.getCanonicalName().replace('.', '/') + "/" + getMethodName()+ "/" + + subDirectoryForParametrisedTests; + } + createOutputDirectory(); + return this.outputDirectory; + } + + /** + * Returns the path to the input directory for this test including a trailing slash as directory delimiter. + * + * @return path to the input directory for this test + */ + public String getInputDirectory() { + if (this.inputDirectory == null) { + this.inputDirectory = getClassInputDirectory() + getMethodName() + "/"; + } + return this.inputDirectory; + } + /** + * Returns the path to the input directory one level above the default input directory for this test including a trailing slash as directory delimiter. + * + * @return path to the input directory for this test + */ + public String getClassInputDirectory() { + if (this.classInputDirectory == null) { + + LogManager.getLogger(this.getClass()).info( "user.dir = " + System.getProperty("user.dir") ) ; + + this.classInputDirectory = "test/input/" + + this.testClass.getCanonicalName().replace('.', '/') + "/"; +// this.classInputDirectory = System.getProperty("user.dir") + "/test/input/" + +// this.testClass.getCanonicalName().replace('.', '/') + "/"; + // (this used to be relative, i.e. ... = "test/input/" + ... . Started failing when + // this was used in tests to read a second config file when I made the path of that + // relative to the root of the initial config file. Arghh. kai, feb'18) + // yyyyyy needs to be discussed, see MATSIM-776 and MATSIM-777. kai, feb'18 + } + return this.classInputDirectory; + } + /** + * Returns the path to the input directory two levels above the default input directory for this test including a trailing slash as directory delimiter. + * + * @return path to the input directory for this test + */ + public String getPackageInputDirectory() { + if (this.packageInputDirectory == null) { + String classDirectory = getClassInputDirectory(); + this.packageInputDirectory = classDirectory.substring(0, classDirectory.lastIndexOf('/')); + this.packageInputDirectory = this.packageInputDirectory.substring(0, this.packageInputDirectory.lastIndexOf('/') + 1); + } + return this.packageInputDirectory; + } + + /** + * @return the name of the currently-running test method + */ + public String getMethodName() { + if (this.testMethodName == null) { + throw new RuntimeException("MatsimTestUtils.getMethodName() can only be used in actual test, not in constructor or elsewhere!"); + } + return this.testMethodName; + } + + /** + * Initializes MatsimTestUtils without requiring the method of a class to be a JUnit test. + * This should be used for "fixtures" only that provide a scenario common to several + * test cases. + */ + public void initWithoutJUnitForFixture(Class fixture, Method method){ + this.testClass = fixture; + this.testMethodName = method.getName(); + } + + //captures the method name (group 1) and optionally the index of the parameter set (group 2; only if the test is parametrised) + //The matching may fail if the parameter set name does not start with {index} (at least one digit is required at the beginning) + private static final Pattern METHOD_PARAMETERS_WITH_INDEX_PATTERN = Pattern.compile( + "([\\S]*)(?:\\[(\\d+)[\\s\\S]*\\])?"); + + public static void assertEqualEventsFiles( String filename1, String filename2 ) { + Assert.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL ,EventsFileComparator.compare(filename1, filename2) ); + } + + public static void assertEqualFilesBasedOnCRC( String filename1, String filename2 ) { + long checksum1 = CRCChecksum.getCRCFromFile(filename1) ; + long checksum2 = CRCChecksum.getCRCFromFile(filename2) ; + Assert.assertEquals( "different file checksums", checksum1, checksum2 ); + } + + public static void assertEqualFilesLineByLine(String inputFilename, String outputFilename) { + try (BufferedReader readerV1Input = IOUtils.getBufferedReader(inputFilename); + BufferedReader readerV1Output = IOUtils.getBufferedReader(outputFilename)) { + + String lineInput; + String lineOutput; + + while( ((lineInput = readerV1Input.readLine()) != null) && ((lineOutput = readerV1Output.readLine()) != null) ){ + if ( !Objects.equals( lineInput.trim(), lineOutput.trim() ) ){ + log.info( "Reading line... " ); + log.info( lineInput ); + log.info( lineOutput ); + log.info( "" ); + } + assertEquals( "Lines have different content: ", lineInput.trim(), lineOutput.trim() ); + } + } catch (IOException e) { + throw new UncheckedIOException(e); + } + } +} From ea690eb0b516d21af1b037f8b91c4ec05ca909e4 Mon Sep 17 00:00:00 2001 From: nkuehnel Date: Sat, 9 Dec 2023 15:01:10 +0100 Subject: [PATCH 21/43] Consolidate request insertion schedulers for shift and standard DRT --- .../edrt/schedule/EDrtTaskFactoryImpl.java | 6 + .../run/ShiftEDrtModeOptimizerQSimModule.java | 18 +- .../schedule/ShiftEDrtTaskFactoryImpl.java | 38 +- .../scheduler/EShiftTaskScheduler.java | 1 - .../ShiftRequestInsertionScheduler.java | 375 ------------------ .../run/ShiftDrtModeOptimizerQSimModule.java | 41 +- .../schedule/ShiftDrtTaskFactoryImpl.java | 106 +++-- .../shifts/schedule/ShiftSchedules.java | 29 -- .../scheduler/ShiftTaskSchedulerImpl.java | 2 - .../contrib/drt/schedule/DrtTaskFactory.java | 3 + .../drt/schedule/DrtTaskFactoryImpl.java | 6 + .../DefaultRequestInsertionScheduler.java | 70 ++-- 12 files changed, 172 insertions(+), 523 deletions(-) delete mode 100644 contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/optimizer/ShiftRequestInsertionScheduler.java diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/edrt/schedule/EDrtTaskFactoryImpl.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/edrt/schedule/EDrtTaskFactoryImpl.java index 736355552db..4ec83dc7a15 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/edrt/schedule/EDrtTaskFactoryImpl.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/edrt/schedule/EDrtTaskFactoryImpl.java @@ -23,6 +23,7 @@ import org.matsim.contrib.drt.schedule.DrtTaskType; import org.matsim.contrib.dvrp.fleet.DvrpVehicle; import org.matsim.contrib.dvrp.path.VrpPathWithTravelData; +import org.matsim.contrib.dvrp.schedule.DefaultStayTask; import org.matsim.contrib.evrp.EvDvrpVehicle; import org.matsim.contrib.evrp.VrpPathEnergyConsumptions; import org.matsim.contrib.ev.fleet.ElectricVehicle; @@ -52,6 +53,11 @@ public EDrtStayTask createStayTask(DvrpVehicle vehicle, double beginTime, double return new EDrtStayTask(beginTime, endTime, link, 0);// no energy consumption during STAY } + @Override + public DefaultStayTask createInitialTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link) { + return createStayTask(vehicle, beginTime, endTime, link); + } + public EDrtChargingTask createChargingTask(DvrpVehicle vehicle, double beginTime, double endTime, Charger charger, double totalEnergy) { return new EDrtChargingTask(beginTime, endTime, charger, ((EvDvrpVehicle)vehicle).getElectricVehicle(), diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/run/ShiftEDrtModeOptimizerQSimModule.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/run/ShiftEDrtModeOptimizerQSimModule.java index ab537fd439d..fdc06e3cb8b 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/run/ShiftEDrtModeOptimizerQSimModule.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/run/ShiftEDrtModeOptimizerQSimModule.java @@ -1,5 +1,6 @@ package org.matsim.contrib.drt.extension.operations.eshifts.run; +import com.google.inject.Singleton; import org.matsim.api.core.v01.network.Network; import org.matsim.contrib.drt.extension.edrt.EDrtActionCreator; import org.matsim.contrib.drt.extension.edrt.optimizer.EDrtVehicleDataEntryFactory; @@ -42,8 +43,6 @@ import org.matsim.core.router.costcalculators.TravelDisutilityFactory; import org.matsim.core.router.util.TravelTime; -import com.google.inject.Singleton; - /** * @author nkuehnel / MOIA */ @@ -78,26 +77,25 @@ drtShiftParams, new EDrtShiftStartLogic(new DefaultShiftStartLogic()), bindModal(VehicleEntry.EntryFactory.class).toProvider(modalProvider(getter -> new ShiftVehicleDataEntryFactory(new EDrtVehicleDataEntryFactory(0)))).asEagerSingleton(); - final ShiftEDrtTaskFactoryImpl taskFactory = new ShiftEDrtTaskFactoryImpl(new EDrtTaskFactoryImpl()); - bindModal(DrtTaskFactory.class).toInstance(taskFactory); - bindModal(ShiftDrtTaskFactory.class).toInstance(taskFactory); + bindModal(DrtTaskFactory.class).toProvider(modalProvider(getter -> new ShiftEDrtTaskFactoryImpl(new EDrtTaskFactoryImpl(), getter.getModal(OperationFacilities.class)))).in(Singleton.class); + bindModal(ShiftDrtTaskFactory.class).toProvider(modalProvider(getter -> ((ShiftDrtTaskFactory) getter.getModal(DrtTaskFactory.class)))); bindModal(ShiftTaskScheduler.class).toProvider(modalProvider( getter -> new EShiftTaskScheduler(getter.getModal(Network.class), getter.getModal(TravelTime.class), getter.getModal(TravelDisutilityFactory.class).createTravelDisutility(getter.getModal(TravelTime.class)), - getter.get(MobsimTimer.class), taskFactory, drtShiftParams, getter.getModal(ChargingInfrastructure.class), + getter.get(MobsimTimer.class), getter.getModal(ShiftDrtTaskFactory.class), drtShiftParams, getter.getModal(ChargingInfrastructure.class), getter.getModal(OperationFacilities.class), getter.getModal(Fleet.class)) )).asEagerSingleton(); - + // See EDrtModeOptimizerQSimModule bindModal(VrpLegFactory.class).toProvider(modalProvider(getter -> { DvrpConfigGroup dvrpCfg = getter.get(DvrpConfigGroup.class); MobsimTimer timer = getter.get(MobsimTimer.class); - + // Makes basic DrtActionCreator create legs with consumption tracker return v -> EDrtActionCreator.createLeg(dvrpCfg.mobsimMode, v, timer); })).in(Singleton.class); - + bindModal(ShiftEDrtActionCreator.class).toProvider(modalProvider(getter -> { VrpAgentLogic.DynActionCreator delegate = drtCfg.getPrebookingParams().isPresent() ? getter.getModal(PrebookingActionCreator.class) @@ -107,7 +105,7 @@ drtShiftParams, new EDrtShiftStartLogic(new DefaultShiftStartLogic()), new ShiftDrtActionCreator(getter.getModal(PassengerHandler.class), delegate), getter.get(MobsimTimer.class), getter.getModal(PassengerHandler.class)); })).asEagerSingleton(); - + bindModal(VrpAgentLogic.DynActionCreator.class).to(modalKey(ShiftEDrtActionCreator.class)); } } diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/schedule/ShiftEDrtTaskFactoryImpl.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/schedule/ShiftEDrtTaskFactoryImpl.java index 87490980a22..5e0c085c1bb 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/schedule/ShiftEDrtTaskFactoryImpl.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/schedule/ShiftEDrtTaskFactoryImpl.java @@ -1,8 +1,10 @@ package org.matsim.contrib.drt.extension.operations.eshifts.schedule; +import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.drt.extension.edrt.schedule.EDrtChargingTask; import org.matsim.contrib.drt.extension.edrt.schedule.EDrtTaskFactoryImpl; +import org.matsim.contrib.drt.extension.operations.operationFacilities.OperationFacilities; import org.matsim.contrib.drt.extension.operations.operationFacilities.OperationFacility; import org.matsim.contrib.drt.extension.operations.shifts.schedule.ShiftBreakTask; import org.matsim.contrib.drt.extension.operations.shifts.schedule.ShiftChangeOverTask; @@ -16,10 +18,17 @@ import org.matsim.contrib.drt.schedule.DrtTaskType; import org.matsim.contrib.dvrp.fleet.DvrpVehicle; import org.matsim.contrib.dvrp.path.VrpPathWithTravelData; +import org.matsim.contrib.dvrp.schedule.DefaultStayTask; import org.matsim.contrib.ev.infrastructure.Charger; import org.matsim.contrib.evrp.ChargingTask; import org.matsim.contrib.evrp.ChargingTaskImpl; import org.matsim.contrib.evrp.EvDvrpVehicle; +import org.matsim.facilities.Facility; + +import java.util.List; +import java.util.Map; +import java.util.function.Supplier; +import java.util.stream.Collectors; /** * @author nkuehnel / MOIA @@ -27,10 +36,14 @@ public class ShiftEDrtTaskFactoryImpl implements ShiftDrtTaskFactory { private final EDrtTaskFactoryImpl delegate; + private final OperationFacilities operationFacilities; + - public ShiftEDrtTaskFactoryImpl(EDrtTaskFactoryImpl delegate) { + public ShiftEDrtTaskFactoryImpl(EDrtTaskFactoryImpl delegate, OperationFacilities operationFacilities) { this.delegate = delegate; - } + this.operationFacilities = operationFacilities; + + } @Override public DrtDriveTask createDriveTask(DvrpVehicle vehicle, VrpPathWithTravelData path, DrtTaskType drtTaskType) { @@ -47,7 +60,26 @@ public DrtStayTask createStayTask(DvrpVehicle vehicle, double beginTime, double return delegate.createStayTask(vehicle, beginTime, endTime, link); } - @Override + @Override + public DefaultStayTask createInitialTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link) { + final Map, List> facilitiesByLink = operationFacilities.getDrtOperationFacilities().values().stream().collect(Collectors.groupingBy(Facility::getLinkId)); + final OperationFacility operationFacility; + try { + operationFacility = facilitiesByLink.get(vehicle.getStartLink().getId()).stream().findFirst().orElseThrow((Supplier) () -> new RuntimeException("Vehicles must start at an operation facility!")); + } catch (Throwable e) { + throw new RuntimeException(e); + } + WaitForShiftStayTask waitForShiftStayTask = createWaitForShiftStayTask(vehicle, vehicle.getServiceBeginTime(), vehicle.getServiceEndTime(), + vehicle.getStartLink(), operationFacility); + boolean success = operationFacility.register(vehicle.getId()); + if (!success) { + throw new RuntimeException(String.format("Cannot register vehicle %s at facility %s at start-up. Please check" + + "facility capacity and initial fleet distribution.", vehicle.getId().toString(), operationFacility.getId().toString())); + } + return waitForShiftStayTask; + } + + @Override public ShiftBreakTask createShiftBreakTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link, DrtShiftBreak shiftBreak, OperationFacility facility) { return new EDrtShiftBreakTaskImpl(beginTime, endTime, link, shiftBreak, 0, null, facility); diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/scheduler/EShiftTaskScheduler.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/scheduler/EShiftTaskScheduler.java index 83f74ad89e0..7352f32c261 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/scheduler/EShiftTaskScheduler.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/eshifts/scheduler/EShiftTaskScheduler.java @@ -74,7 +74,6 @@ public EShiftTaskScheduler(Network network, TravelTime travelTime, TravelDisutil this.shiftsParams = shiftsParams; this.router = new SpeedyALTFactory().createPathCalculator(network, travelDisutility, travelTime); this.chargingInfrastructure = chargingInfrastructure; - ShiftSchedules.initSchedules(operationFacilities, fleet, taskFactory); } public void relocateForBreak(ShiftDvrpVehicle vehicle, OperationFacility breakFacility, DrtShift shift) { diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/optimizer/ShiftRequestInsertionScheduler.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/optimizer/ShiftRequestInsertionScheduler.java deleted file mode 100644 index a4feba591cf..00000000000 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/optimizer/ShiftRequestInsertionScheduler.java +++ /dev/null @@ -1,375 +0,0 @@ -package org.matsim.contrib.drt.extension.operations.shifts.optimizer; - -import static org.matsim.contrib.drt.schedule.DrtTaskBaseType.DRIVE; -import static org.matsim.contrib.drt.schedule.DrtTaskBaseType.STAY; - -import java.util.List; - -import org.matsim.api.core.v01.network.Link; -import org.matsim.contrib.drt.extension.operations.shifts.fleet.ShiftDvrpVehicle; -import org.matsim.contrib.drt.extension.operations.shifts.schedule.OperationalStop; -import org.matsim.contrib.drt.extension.operations.shifts.schedule.ShiftChangeOverTask; -import org.matsim.contrib.drt.extension.operations.shifts.schedule.ShiftDrtTaskFactory; -import org.matsim.contrib.drt.extension.operations.shifts.scheduler.ShiftTaskScheduler; -import org.matsim.contrib.drt.optimizer.VehicleEntry; -import org.matsim.contrib.drt.optimizer.Waypoint; -import org.matsim.contrib.drt.optimizer.insertion.InsertionWithDetourData; -import org.matsim.contrib.drt.passenger.AcceptedDrtRequest; -import org.matsim.contrib.drt.schedule.DrtDriveTask; -import org.matsim.contrib.drt.schedule.DrtStayTask; -import org.matsim.contrib.drt.schedule.DrtStopTask; -import org.matsim.contrib.drt.scheduler.RequestInsertionScheduler; -import org.matsim.contrib.drt.stops.StopTimeCalculator; -import org.matsim.contrib.dvrp.path.VrpPathWithTravelData; -import org.matsim.contrib.dvrp.path.VrpPaths; -import org.matsim.contrib.dvrp.schedule.Schedule; -import org.matsim.contrib.dvrp.schedule.ScheduleTimingUpdater; -import org.matsim.contrib.dvrp.schedule.StayTask; -import org.matsim.contrib.dvrp.schedule.Task; -import org.matsim.contrib.dvrp.tracker.OnlineDriveTaskTracker; -import org.matsim.contrib.dvrp.util.LinkTimePair; -import org.matsim.core.mobsim.framework.MobsimTimer; -import org.matsim.core.router.util.TravelTime; - -/** - * @author nkuehnel / MOIA - */ -public class ShiftRequestInsertionScheduler implements RequestInsertionScheduler { - - private final MobsimTimer timer; - private final TravelTime travelTime; - private final ScheduleTimingUpdater scheduleTimingUpdater; - private final ShiftDrtTaskFactory taskFactory; - private StopTimeCalculator stopTimeCalculator; - - - public ShiftRequestInsertionScheduler(MobsimTimer timer, TravelTime travelTime, - ScheduleTimingUpdater scheduleTimingUpdater, ShiftDrtTaskFactory taskFactory, - StopTimeCalculator stopTimeCalculator) { - this.timer = timer; - this.travelTime = travelTime; - this.scheduleTimingUpdater = scheduleTimingUpdater; - this.taskFactory = taskFactory; - this.stopTimeCalculator = stopTimeCalculator; - } - - - @Override - public PickupDropoffTaskPair scheduleRequest(AcceptedDrtRequest request, InsertionWithDetourData insertion) { - var pickupTask = insertPickup(request, insertion); - var dropoffTask = insertDropoff(request, insertion, pickupTask); - return new PickupDropoffTaskPair(pickupTask, dropoffTask); - } - - private DrtStopTask insertPickup(AcceptedDrtRequest request, InsertionWithDetourData insertionWithDetourData) { - var insertion = insertionWithDetourData.insertion; - VehicleEntry vehicleEntry = insertion.vehicleEntry; - Schedule schedule = vehicleEntry.vehicle.getSchedule(); - List stops = vehicleEntry.stops; - int pickupIdx = insertion.pickup.index; - int dropoffIdx = insertion.dropoff.index; - var detourData = insertionWithDetourData.detourData; - - Schedule.ScheduleStatus scheduleStatus = schedule.getStatus(); - Task currentTask = scheduleStatus == Schedule.ScheduleStatus.PLANNED ? null : schedule.getCurrentTask(); - Task beforePickupTask; - - if (pickupIdx == 0 && scheduleStatus != Schedule.ScheduleStatus.PLANNED && DRIVE.isBaseTypeOf(currentTask)) { - LinkTimePair diversion = ((OnlineDriveTaskTracker) currentTask.getTaskTracker()).getDiversionPoint(); - if (diversion != null) { // divert vehicle - beforePickupTask = currentTask; - VrpPathWithTravelData vrpPath = VrpPaths.createPath(vehicleEntry.start.link, request.getFromLink(), - vehicleEntry.start.time, detourData.detourToPickup, travelTime); - ((OnlineDriveTaskTracker) beforePickupTask.getTaskTracker()).divertPath(vrpPath); - } else { // too late for diversion - if (request.getFromLink() != vehicleEntry.start.link) { // add a new drive task - VrpPathWithTravelData vrpPath = VrpPaths.createPath(vehicleEntry.start.link, request.getFromLink(), - vehicleEntry.start.time, detourData.detourToPickup, travelTime); - beforePickupTask = taskFactory.createDriveTask(vehicleEntry.vehicle, vrpPath, DrtDriveTask.TYPE); - schedule.addTask(currentTask.getTaskIdx() + 1, beforePickupTask); - } else { // no need for a new drive task - beforePickupTask = currentTask; - } - } - } else { // insert pickup after an existing stop/stay task - DrtStayTask stayTask = null; - DrtStopTask stopTask = null; - if (pickupIdx == 0) { - if (scheduleStatus == Schedule.ScheduleStatus.PLANNED) {// PLANNED schedule - stayTask = (DrtStayTask) schedule.getTasks().get(0); - stayTask.setEndTime(stayTask.getBeginTime());// could get later removed with ScheduleTimingUpdater - } else if (STAY.isBaseTypeOf(currentTask)) { - stayTask = (DrtStayTask) currentTask; // ongoing stay task - double now = timer.getTimeOfDay(); - if (stayTask.getEndTime() > now) { // stop stay task; a new stop/drive task can be inserted now - stayTask.setEndTime(now); - } - } else { - stopTask = (DrtStopTask) currentTask; // ongoing stop task - } - } else { - stopTask = stops.get(pickupIdx - 1).task; // future stop task - } - - if (stopTask != null && request.getFromLink() == stopTask.getLink()) { // no detour; no new stop task - // add pickup request to stop task - stopTask.addPickupRequest(request); - if (stopTask instanceof OperationalStop) { - if (request.getEarliestStartTime() > stopTask.getEndTime()) { - throw new RuntimeException("Cannot serve request!"); - } - } else { - /* - * TODO: insertionTime should be set to "now" here to avoid adding pickups to - * ongoing tasks "for free" and generating requests with zero wait time. See - * InsertionDetourTimeCalculator.calculatePickupIfSameLink for more details. - */ - - double insertionTime = stopTask.getBeginTime(); - stopTask.setEndTime(stopTimeCalculator.updateEndTimeForPickup(vehicleEntry.vehicle, stopTask, - insertionTime, request.getRequest())); - } - - /// ADDED - //// TODO this is copied, but has not been updated !!!!!!!!!!!!!!! - // add drive from pickup - if (pickupIdx == dropoffIdx) { - // remove drive i->i+1 (if there is one) - if (pickupIdx < stops.size()) {// there is at least one following stop - DrtStopTask nextStopTask = stops.get(pickupIdx).task; - if (nextStopTask instanceof ShiftChangeOverTask) { - if (stopTask.getTaskIdx() + 3 != nextStopTask.getTaskIdx()) {// there must a drive and stay task in - // between - throw new RuntimeException(); - } - } else if (stopTask.getTaskIdx() + 2 != nextStopTask.getTaskIdx()) {// there must a drive task in - // between - throw new RuntimeException(); - } - if (nextStopTask instanceof ShiftChangeOverTask) { - if (stopTask.getTaskIdx() + 3 == nextStopTask.getTaskIdx()) {// there must a drive task and stay in - // between - int driveTaskIdx = stopTask.getTaskIdx() + 1; - final Task task = schedule.getTasks().get(driveTaskIdx); - schedule.removeTask(task); - } - } else { - if (stopTask.getTaskIdx() + 2 == nextStopTask.getTaskIdx()) {// there must a drive task in - // between - int driveTaskIdx = stopTask.getTaskIdx() + 1; - final Task task = schedule.getTasks().get(driveTaskIdx); - schedule.removeTask(task); - } - } - } - - Link toLink = request.getToLink(); // pickup->dropoff - - VrpPathWithTravelData vrpPath = VrpPaths.createPath(request.getFromLink(), toLink, - stopTask.getEndTime(), detourData.detourFromPickup, travelTime); - Task driveFromPickupTask = taskFactory.createDriveTask(vehicleEntry.vehicle, vrpPath, - DrtDriveTask.TYPE); - schedule.addTask(stopTask.getTaskIdx() + 1, driveFromPickupTask); - - // update timings - // TODO should be enough to update the timeline only till dropoffIdx... - scheduleTimingUpdater.updateTimingsStartingFromTaskIdx(vehicleEntry.vehicle, - stopTask.getTaskIdx() + 2, driveFromPickupTask.getEndTime()); - /////// - } - - return stopTask; - } else { - StayTask stayOrStopTask = stayTask != null ? stayTask : stopTask; - - // remove drive i->i+1 (if there is one) - if (pickupIdx < stops.size()) {// there is at least one following stop - - DrtStopTask nextStopTask = stops.get(pickupIdx).task; - - if (nextStopTask instanceof ShiftChangeOverTask) { - if (stayOrStopTask.getTaskIdx() + 3 == nextStopTask.getTaskIdx()) { - // removing the drive task that is in between - int driveTaskIdx = stayOrStopTask.getTaskIdx() + 1; - final Task task = schedule.getTasks().get(driveTaskIdx); - schedule.removeTask(task); - } - } else { - // check: if there is at most one drive task in between - if (stayOrStopTask.getTaskIdx() + 2 != nextStopTask.getTaskIdx() // - && stayTask != null && stayTask.getTaskIdx() + 1 != nextStopTask.getTaskIdx()) { - throw new RuntimeException(); - } - if (stayOrStopTask.getTaskIdx() + 2 == nextStopTask.getTaskIdx()) { - // removing the drive task that is in between - int driveTaskIdx = stayOrStopTask.getTaskIdx() + 1; - final Task task = schedule.getTasks().get(driveTaskIdx); - schedule.removeTask(task); - } - } - } - - if (stayTask != null && request.getFromLink() == stayTask.getLink()) { - // the bus stays where it is - beforePickupTask = stayTask; - } else {// add drive task to pickup location - // insert drive i->pickup - VrpPathWithTravelData vrpPath = VrpPaths.createPath(stayOrStopTask.getLink(), request.getFromLink(), - stayOrStopTask.getEndTime(), detourData.detourToPickup, travelTime); - beforePickupTask = taskFactory.createDriveTask(vehicleEntry.vehicle, vrpPath, DrtDriveTask.TYPE); - schedule.addTask(stayOrStopTask.getTaskIdx() + 1, beforePickupTask); - } - } - } - - // insert pickup stop task - double startTime = beforePickupTask.getEndTime(); - int taskIdx = beforePickupTask.getTaskIdx() + 1; - double stopEndTime = stopTimeCalculator.initEndTimeForPickup(vehicleEntry.vehicle, startTime, request.getRequest()); - DrtStopTask pickupStopTask = taskFactory.createStopTask(vehicleEntry.vehicle, startTime, - stopEndTime, request.getFromLink()); - schedule.addTask(taskIdx, pickupStopTask); - pickupStopTask.addPickupRequest(request); - - // add drive from pickup - Link toLink = pickupIdx == dropoffIdx ? request.getToLink() // pickup->dropoff - : stops.get(pickupIdx).task.getLink(); // pickup->i+1 - - VrpPathWithTravelData vrpPath = VrpPaths.createPath(request.getFromLink(), toLink, pickupStopTask.getEndTime(), - detourData.detourFromPickup, travelTime); - Task driveFromPickupTask = taskFactory.createDriveTask(vehicleEntry.vehicle, vrpPath, DrtDriveTask.TYPE); - schedule.addTask(taskIdx + 1, driveFromPickupTask); - - // update timings - // TODO should be enough to update the timeline only till dropoffIdx... - scheduleTimingUpdater.updateTimingsStartingFromTaskIdx(vehicleEntry.vehicle, taskIdx + 2, - driveFromPickupTask.getEndTime()); - return pickupStopTask; - } - - private DrtStopTask insertDropoff(AcceptedDrtRequest request, InsertionWithDetourData insertionWithDetourData, - DrtStopTask pickupTask) { - var insertion = insertionWithDetourData.insertion; - VehicleEntry vehicleEntry = insertion.vehicleEntry; - Schedule schedule = vehicleEntry.vehicle.getSchedule(); - List stops = vehicleEntry.stops; - int pickupIdx = insertion.pickup.index; - int dropoffIdx = insertion.dropoff.index; - var detourData = insertionWithDetourData.detourData; - - Task driveToDropoffTask; - if (pickupIdx == dropoffIdx) { // no drive to dropoff - int pickupTaskIdx = pickupTask.getTaskIdx(); - driveToDropoffTask = schedule.getTasks().get(pickupTaskIdx + 1); - } else { - DrtStopTask stopTask = stops.get(dropoffIdx - 1).task; - if (request.getToLink() == stopTask.getLink()) { // no detour; no new stop task - // add dropoff request to stop task, and extend the stop task (when incremental stop task duration is used) - stopTask.addDropoffRequest(request); - - /* - * TODO: insertionTime should be set to "now" here to avoid adding pickups to - * ongoing tasks "for free" and generating requests with zero wait time. See - * InsertionDetourTimeCalculator.calculatePickupIfSameLink for more details. - */ - - double insertionTime = stopTask.getBeginTime(); - stopTask.setEndTime(stopTimeCalculator.updateEndTimeForDropoff(vehicleEntry.vehicle, stopTask, - insertionTime, request.getRequest())); - - return stopTask; - } else { // add drive task to dropoff location - - // remove drive j->j+1 (if j is not the last stop) - if (dropoffIdx < stops.size()) { - DrtStopTask nextStopTask = stops.get(dropoffIdx).task; - - // this is new - if ((nextStopTask instanceof ShiftChangeOverTask)) { - if (stopTask.getTaskIdx() + 3 != nextStopTask.getTaskIdx() - && !stopTask.getLink().getId().equals(nextStopTask.getLink().getId())) { - //include stay task before shift changeover - throw new IllegalStateException(); - } - } - //end of new - - else { - if (stopTask.getTaskIdx() + 2 != nextStopTask.getTaskIdx()) { - throw new IllegalStateException(); - } - } - int driveTaskIdx = stopTask.getTaskIdx() + 1; - - final Task task = schedule.getTasks().get(driveTaskIdx); - schedule.removeTask(task); - } - - // insert drive i->dropoff - VrpPathWithTravelData vrpPath = VrpPaths.createPath(stopTask.getLink(), request.getToLink(), - stopTask.getEndTime(), detourData.detourToDropoff, travelTime); - driveToDropoffTask = taskFactory.createDriveTask(vehicleEntry.vehicle, vrpPath, DrtDriveTask.TYPE); - schedule.addTask(stopTask.getTaskIdx() + 1, driveToDropoffTask); - } - } - - // insert dropoff stop task - double startTime = driveToDropoffTask.getEndTime(); - int taskIdx = driveToDropoffTask.getTaskIdx() + 1; - double stopEndTime = stopTimeCalculator.initEndTimeForDropoff(vehicleEntry.vehicle, startTime, request.getRequest()); - DrtStopTask dropoffStopTask = taskFactory.createStopTask(vehicleEntry.vehicle, startTime, - stopEndTime, request.getToLink()); - schedule.addTask(taskIdx, dropoffStopTask); - dropoffStopTask.addDropoffRequest(request); - - // add drive from dropoff - if (dropoffIdx == stops.size()) {// bus stays at dropoff - if (taskIdx + 2 == schedule.getTaskCount()) {// remove stay task from the end of schedule, - DrtStayTask oldStayTask = (DrtStayTask) schedule.getTasks().get(taskIdx + 1); - schedule.removeTask(oldStayTask); - } - if (taskIdx + 1 == schedule.getTaskCount()) { - // no stay task at the end if the pickup follows the existing stay task - double beginTime = dropoffStopTask.getEndTime(); - double endTime = Math.max(beginTime, ((ShiftDvrpVehicle) vehicleEntry.vehicle).getShifts().peek().getEndTime()); - schedule.addTask(taskFactory.createStayTask(vehicleEntry.vehicle, beginTime, - endTime, dropoffStopTask.getLink())); - } else { - throw new RuntimeException(); - } - } else { - final DrtStopTask nextStopTask = stops.get(dropoffIdx).task; - Link toLink = nextStopTask.getLink(); // dropoff->j+1 - - VrpPathWithTravelData vrpPath = VrpPaths.createPath(request.getToLink(), toLink, dropoffStopTask.getEndTime(), - detourData.detourFromDropoff, travelTime); - - - Task driveFromDropoffTask; - if (nextStopTask instanceof ShiftChangeOverTask) { - driveFromDropoffTask = taskFactory.createDriveTask(vehicleEntry.vehicle, vrpPath, ShiftTaskScheduler.RELOCATE_VEHICLE_SHIFT_CHANGEOVER_TASK_TYPE); - schedule.addTask(taskIdx + 1, driveFromDropoffTask); - final List tasks = vehicleEntry.vehicle.getSchedule().getTasks(); - final Task task = tasks.get(tasks.indexOf(nextStopTask) - 1); - if (task instanceof DrtStayTask) { - schedule.removeTask(task); - } - final double arrivalTime = vrpPath.getArrivalTime(); - final double shiftEndTime = ((ShiftChangeOverTask) nextStopTask).getShift().getEndTime(); - if (arrivalTime <= shiftEndTime) { - DrtStayTask stayWaitShiftEndTask = taskFactory.createStayTask(vehicleEntry.vehicle, arrivalTime, - shiftEndTime, nextStopTask.getLink()); - schedule.addTask(tasks.indexOf(nextStopTask), stayWaitShiftEndTask); - } - } else { - driveFromDropoffTask = taskFactory.createDriveTask(vehicleEntry.vehicle, vrpPath, DrtDriveTask.TYPE); - schedule.addTask(taskIdx + 1, driveFromDropoffTask); - } - - // update timings - scheduleTimingUpdater.updateTimingsStartingFromTaskIdx(vehicleEntry.vehicle, taskIdx + 2, - driveFromDropoffTask.getEndTime()); - } - return dropoffStopTask; - } -} diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/run/ShiftDrtModeOptimizerQSimModule.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/run/ShiftDrtModeOptimizerQSimModule.java index eced5b90a1d..e7f4f58b391 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/run/ShiftDrtModeOptimizerQSimModule.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/run/ShiftDrtModeOptimizerQSimModule.java @@ -1,5 +1,7 @@ package org.matsim.contrib.drt.extension.operations.shifts.run; +import com.google.common.collect.ImmutableMap; +import com.google.inject.Singleton; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Network; import org.matsim.contrib.drt.extension.operations.DrtOperationsParams; @@ -13,7 +15,6 @@ import org.matsim.contrib.drt.extension.operations.shifts.dispatcher.DrtShiftDispatcherImpl; import org.matsim.contrib.drt.extension.operations.shifts.fleet.DefaultShiftDvrpVehicle; import org.matsim.contrib.drt.extension.operations.shifts.optimizer.ShiftDrtOptimizer; -import org.matsim.contrib.drt.extension.operations.shifts.optimizer.ShiftRequestInsertionScheduler; import org.matsim.contrib.drt.extension.operations.shifts.optimizer.ShiftVehicleDataEntryFactory; import org.matsim.contrib.drt.extension.operations.shifts.optimizer.insertion.ShiftInsertionCostCalculator; import org.matsim.contrib.drt.extension.operations.shifts.schedule.ShiftDrtActionCreator; @@ -23,17 +24,8 @@ import org.matsim.contrib.drt.extension.operations.shifts.scheduler.ShiftDrtScheduleInquiry; import org.matsim.contrib.drt.extension.operations.shifts.scheduler.ShiftTaskScheduler; import org.matsim.contrib.drt.extension.operations.shifts.scheduler.ShiftTaskSchedulerImpl; -import org.matsim.contrib.drt.extension.operations.shifts.shift.DefaultShiftBreakImpl; -import org.matsim.contrib.drt.extension.operations.shifts.shift.DrtShift; -import org.matsim.contrib.drt.extension.operations.shifts.shift.DrtShiftBreakSpecification; -import org.matsim.contrib.drt.extension.operations.shifts.shift.DrtShiftImpl; -import org.matsim.contrib.drt.extension.operations.shifts.shift.DrtShifts; -import org.matsim.contrib.drt.extension.operations.shifts.shift.DrtShiftsSpecification; -import org.matsim.contrib.drt.optimizer.DefaultDrtOptimizer; -import org.matsim.contrib.drt.optimizer.DrtOptimizer; -import org.matsim.contrib.drt.optimizer.DrtRequestInsertionRetryQueue; -import org.matsim.contrib.drt.optimizer.VehicleDataEntryFactoryImpl; -import org.matsim.contrib.drt.optimizer.VehicleEntry; +import org.matsim.contrib.drt.extension.operations.shifts.shift.*; +import org.matsim.contrib.drt.optimizer.*; import org.matsim.contrib.drt.optimizer.depot.DepotFinder; import org.matsim.contrib.drt.optimizer.insertion.CostCalculationStrategy; import org.matsim.contrib.drt.optimizer.insertion.DefaultInsertionCostCalculator; @@ -47,7 +39,6 @@ import org.matsim.contrib.drt.schedule.DrtTaskFactoryImpl; import org.matsim.contrib.drt.scheduler.DrtScheduleInquiry; import org.matsim.contrib.drt.scheduler.EmptyVehicleRelocator; -import org.matsim.contrib.drt.scheduler.RequestInsertionScheduler; import org.matsim.contrib.drt.stops.StopTimeCalculator; import org.matsim.contrib.drt.vrpagent.DrtActionCreator; import org.matsim.contrib.dvrp.fleet.DvrpVehicleImpl; @@ -68,9 +59,6 @@ import org.matsim.core.router.costcalculators.TravelDisutilityFactory; import org.matsim.core.router.util.TravelTime; -import com.google.common.collect.ImmutableMap; -import com.google.inject.Singleton; - /** * @author nkuehnel, fzwick / MOIA */ @@ -112,7 +100,7 @@ public DrtShifts get() { }).asEagerSingleton(); addModalComponent(DrtOptimizer.class, modalProvider( - getter -> { + getter -> { return new ShiftDrtOptimizer( new DefaultDrtOptimizer(drtCfg, getter.getModal(Fleet.class), getter.get(MobsimTimer.class), getter.getModal(DepotFinder.class), getter.getModal(RebalancingStrategy.class), @@ -137,32 +125,25 @@ shiftsParams, new DefaultShiftStartLogic(), new DefaultAssignShiftToVehicleLogic bindModal(VehicleEntry.EntryFactory.class).toInstance(new ShiftVehicleDataEntryFactory(new VehicleDataEntryFactoryImpl())); - final ShiftDrtTaskFactoryImpl taskFactory = new ShiftDrtTaskFactoryImpl(new DrtTaskFactoryImpl()); - bindModal(DrtTaskFactory.class).toInstance(taskFactory); - bindModal(ShiftDrtTaskFactory.class).toInstance(taskFactory); + bindModal(DrtTaskFactory.class).toProvider(modalProvider(getter -> new ShiftDrtTaskFactoryImpl(new DrtTaskFactoryImpl(), getter.getModal(OperationFacilities.class)))); + bindModal(ShiftDrtTaskFactory.class).toProvider(modalProvider(getter -> ((ShiftDrtTaskFactory) getter.getModal(DrtTaskFactory.class)))); bindModal(ShiftTaskScheduler.class).toProvider(modalProvider( getter -> new ShiftTaskSchedulerImpl(getter.getModal(Network.class), getter.getModal(TravelTime.class), getter.getModal(TravelDisutilityFactory.class).createTravelDisutility(getter.getModal(TravelTime.class)), - getter.get(MobsimTimer.class), taskFactory, shiftsParams, + getter.get(MobsimTimer.class), getter.getModal(ShiftDrtTaskFactory.class), shiftsParams, getter.getModal(OperationFacilities.class), getter.getModal(Fleet.class))) ).asEagerSingleton(); bindModal(DrtScheduleInquiry.class).to(ShiftDrtScheduleInquiry.class).asEagerSingleton(); - bindModal(RequestInsertionScheduler.class).toProvider(modalProvider( - getter -> new ShiftRequestInsertionScheduler( - getter.get(MobsimTimer.class), getter.getModal(TravelTime.class), - getter.getModal(ScheduleTimingUpdater.class), getter.getModal(ShiftDrtTaskFactory.class), - getter.getModal(StopTimeCalculator.class))) - ).asEagerSingleton(); bindModal(ScheduleTimingUpdater.class).toProvider(modalProvider( getter -> new ScheduleTimingUpdater(getter.get(MobsimTimer.class), new ShiftDrtStayTaskEndTimeCalculator(shiftsParams, new DrtStayTaskEndTimeCalculator(getter.getModal(StopTimeCalculator.class))))) ).asEagerSingleton(); - + // see DrtModeOptimizerQSimModule bindModal(VrpLegFactory.class).toProvider(modalProvider(getter -> { DvrpConfigGroup dvrpCfg = getter.get(DvrpConfigGroup.class); @@ -176,11 +157,11 @@ shiftsParams, new DefaultShiftStartLogic(), new DefaultAssignShiftToVehicleLogic VrpAgentLogic.DynActionCreator delegate = drtCfg.getPrebookingParams().isPresent() ? getter.getModal(PrebookingActionCreator.class) : getter.getModal(DrtActionCreator.class); - + // adds shift tasks return new ShiftDrtActionCreator(getter.getModal(PassengerHandler.class), delegate); })).asEagerSingleton(); - + bindModal(VrpAgentLogic.DynActionCreator.class).to(modalKey(ShiftDrtActionCreator.class)); bindModal(Fleet.class).toProvider(new ModalProviders.AbstractProvider<>(getMode(), DvrpModes::mode) { diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/schedule/ShiftDrtTaskFactoryImpl.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/schedule/ShiftDrtTaskFactoryImpl.java index bb2b56e7aec..57460d2bee6 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/schedule/ShiftDrtTaskFactoryImpl.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/schedule/ShiftDrtTaskFactoryImpl.java @@ -1,54 +1,84 @@ package org.matsim.contrib.drt.extension.operations.shifts.schedule; +import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; +import org.matsim.contrib.drt.extension.operations.operationFacilities.OperationFacilities; import org.matsim.contrib.drt.extension.operations.operationFacilities.OperationFacility; import org.matsim.contrib.drt.extension.operations.shifts.shift.DrtShift; import org.matsim.contrib.drt.extension.operations.shifts.shift.DrtShiftBreak; import org.matsim.contrib.drt.schedule.*; import org.matsim.contrib.dvrp.fleet.DvrpVehicle; import org.matsim.contrib.dvrp.path.VrpPathWithTravelData; +import org.matsim.contrib.dvrp.schedule.DefaultStayTask; +import org.matsim.facilities.Facility; + +import java.util.List; +import java.util.Map; +import java.util.function.Supplier; +import java.util.stream.Collectors; /** * @author nkuehnel, fzwick / MOIA */ public class ShiftDrtTaskFactoryImpl implements ShiftDrtTaskFactory { - private final DrtTaskFactory delegate; - - public ShiftDrtTaskFactoryImpl(DrtTaskFactory delegate) { - this.delegate = delegate; - } - - @Override - public DrtDriveTask createDriveTask(DvrpVehicle vehicle, VrpPathWithTravelData path, DrtTaskType drtTaskType) { - return delegate.createDriveTask(vehicle, path, drtTaskType); - } - - @Override - public DrtStopTask createStopTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link) { - return delegate.createStopTask(vehicle, beginTime, endTime, link); - } - - @Override - public DrtStayTask createStayTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link) { - return delegate.createStayTask(vehicle, beginTime, endTime, link); - } - - @Override - public ShiftBreakTask createShiftBreakTask(DvrpVehicle vehicle, double beginTime, double endTime, - Link link, DrtShiftBreak shiftBreak, OperationFacility facility) { - return new ShiftBreakTaskImpl(beginTime, endTime, link, shiftBreak, facility); - } - - @Override - public ShiftChangeOverTask createShiftChangeoverTask(DvrpVehicle vehicle, double beginTime, double endTime, - Link link, DrtShift shift, OperationFacility facility) { - return new ShiftChangeoverTaskImpl(beginTime, endTime, link, shift, facility); - } - - @Override - public WaitForShiftStayTask createWaitForShiftStayTask(DvrpVehicle vehicle, double beginTime, double endTime, - Link link, OperationFacility facility) { - return new WaitForShiftStayTask(beginTime, endTime, link, facility); - } + private final DrtTaskFactory delegate; + private final OperationFacilities operationFacilities; + + public ShiftDrtTaskFactoryImpl(DrtTaskFactory delegate, OperationFacilities operationFacilities) { + this.delegate = delegate; + this.operationFacilities = operationFacilities; + } + + @Override + public DrtDriveTask createDriveTask(DvrpVehicle vehicle, VrpPathWithTravelData path, DrtTaskType drtTaskType) { + return delegate.createDriveTask(vehicle, path, drtTaskType); + } + + @Override + public DrtStopTask createStopTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link) { + return delegate.createStopTask(vehicle, beginTime, endTime, link); + } + + @Override + public DrtStayTask createStayTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link) { + return delegate.createStayTask(vehicle, beginTime, endTime, link); + } + + @Override + public ShiftBreakTask createShiftBreakTask(DvrpVehicle vehicle, double beginTime, double endTime, + Link link, DrtShiftBreak shiftBreak, OperationFacility facility) { + return new ShiftBreakTaskImpl(beginTime, endTime, link, shiftBreak, facility); + } + + @Override + public ShiftChangeOverTask createShiftChangeoverTask(DvrpVehicle vehicle, double beginTime, double endTime, + Link link, DrtShift shift, OperationFacility facility) { + return new ShiftChangeoverTaskImpl(beginTime, endTime, link, shift, facility); + } + + @Override + public WaitForShiftStayTask createWaitForShiftStayTask(DvrpVehicle vehicle, double beginTime, double endTime, + Link link, OperationFacility facility) { + return new WaitForShiftStayTask(beginTime, endTime, link, facility); + } + + public DefaultStayTask createInitialTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link) { + final Map, List> facilitiesByLink = operationFacilities.getDrtOperationFacilities().values().stream().collect(Collectors.groupingBy(Facility::getLinkId)); + final OperationFacility operationFacility; + try { + operationFacility = facilitiesByLink.get(vehicle.getStartLink().getId()).stream().findFirst().orElseThrow((Supplier) () -> new RuntimeException("Vehicles must start at an operation facility!")); + } catch (Throwable e) { + throw new RuntimeException(e); + } + WaitForShiftStayTask waitForShiftStayTask = createWaitForShiftStayTask(vehicle, vehicle.getServiceBeginTime(), vehicle.getServiceEndTime(), + vehicle.getStartLink(), operationFacility); + boolean success = operationFacility.register(vehicle.getId()); + if (!success) { + throw new RuntimeException(String.format("Cannot register vehicle %s at facility %s at start-up. Please check" + + "facility capacity and initial fleet distribution.", vehicle.getId().toString(), operationFacility.getId().toString())); + } + return waitForShiftStayTask; + } + } diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/schedule/ShiftSchedules.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/schedule/ShiftSchedules.java index 95fb45131e5..045a312c38f 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/schedule/ShiftSchedules.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/schedule/ShiftSchedules.java @@ -1,21 +1,10 @@ package org.matsim.contrib.drt.extension.operations.shifts.schedule; -import org.matsim.api.core.v01.Id; -import org.matsim.api.core.v01.network.Link; -import org.matsim.contrib.drt.extension.operations.operationFacilities.OperationFacilities; -import org.matsim.contrib.drt.extension.operations.operationFacilities.OperationFacility; -import org.matsim.contrib.dvrp.fleet.DvrpVehicle; -import org.matsim.contrib.dvrp.fleet.Fleet; import org.matsim.contrib.dvrp.schedule.Schedule; import org.matsim.contrib.dvrp.schedule.Task; -import org.matsim.facilities.Facility; import java.util.Comparator; -import java.util.List; -import java.util.Map; import java.util.Optional; -import java.util.function.Supplier; -import java.util.stream.Collectors; import java.util.stream.Stream; /** @@ -31,22 +20,4 @@ public static Optional getNextShiftChangeover (Schedule sch .filter(t -> t.getTaskIdx() > taskIdx) .min(Comparator.comparingDouble(Task::getBeginTime)); } - - public static void initSchedules(OperationFacilities operationFacilities, Fleet fleet, ShiftDrtTaskFactory taskFactory) { - final Map, List> facilitiesByLink = operationFacilities.getDrtOperationFacilities().values().stream().collect(Collectors.groupingBy(Facility::getLinkId)); - for (DvrpVehicle veh : fleet.getVehicles().values()) { - try { - final OperationFacility operationFacility = facilitiesByLink.get(veh.getStartLink().getId()).stream().findFirst().orElseThrow((Supplier) () -> new RuntimeException("Vehicles must start at an operation facility!")); - veh.getSchedule() - .addTask(taskFactory.createWaitForShiftStayTask(veh, veh.getServiceBeginTime(), veh.getServiceEndTime(), - veh.getStartLink(), operationFacility)); - boolean success = operationFacility.register(veh.getId()); - if(!success) { - throw new RuntimeException(String.format("Cannot register vehicle %s at facility %s at start-up. Please check" + - "facility capacity and initial fleet distribution.", veh.getId().toString(), operationFacility.getId().toString())); - } } catch (Throwable throwable) { - throwable.printStackTrace(); - } - } - } } diff --git a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/scheduler/ShiftTaskSchedulerImpl.java b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/scheduler/ShiftTaskSchedulerImpl.java index f5101d68987..d6d272371e9 100644 --- a/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/scheduler/ShiftTaskSchedulerImpl.java +++ b/contribs/drt-extensions/src/main/java/org/matsim/contrib/drt/extension/operations/shifts/scheduler/ShiftTaskSchedulerImpl.java @@ -60,8 +60,6 @@ public ShiftTaskSchedulerImpl(Network network, TravelTime travelTime, TravelDisu this.network = network; this.drtShiftParams = drtShiftParams; this.router = new SpeedyALTFactory().createPathCalculator(network, travelDisutility, travelTime); - - ShiftSchedules.initSchedules(operationFacilities, fleet, taskFactory); } @Override diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/schedule/DrtTaskFactory.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/schedule/DrtTaskFactory.java index b7ee95be265..389094b222a 100644 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/schedule/DrtTaskFactory.java +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/schedule/DrtTaskFactory.java @@ -21,6 +21,7 @@ import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.dvrp.fleet.DvrpVehicle; import org.matsim.contrib.dvrp.path.VrpPathWithTravelData; +import org.matsim.contrib.dvrp.schedule.DefaultStayTask; /** * @author michalm @@ -31,4 +32,6 @@ public interface DrtTaskFactory { DrtStopTask createStopTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link); DrtStayTask createStayTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link); + + DefaultStayTask createInitialTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link); } diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/schedule/DrtTaskFactoryImpl.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/schedule/DrtTaskFactoryImpl.java index adb65f2d780..de227a74da4 100644 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/schedule/DrtTaskFactoryImpl.java +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/schedule/DrtTaskFactoryImpl.java @@ -21,6 +21,7 @@ import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.dvrp.fleet.DvrpVehicle; import org.matsim.contrib.dvrp.path.VrpPathWithTravelData; +import org.matsim.contrib.dvrp.schedule.DefaultStayTask; /** * @author michalm @@ -40,4 +41,9 @@ public DrtStopTask createStopTask(DvrpVehicle vehicle, double beginTime, double public DrtStayTask createStayTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link) { return new DrtStayTask(beginTime, endTime, link); } + + @Override + public DefaultStayTask createInitialTask(DvrpVehicle vehicle, double beginTime, double endTime, Link link) { + return createStayTask(vehicle, beginTime, endTime ,link); + } } diff --git a/contribs/drt/src/main/java/org/matsim/contrib/drt/scheduler/DefaultRequestInsertionScheduler.java b/contribs/drt/src/main/java/org/matsim/contrib/drt/scheduler/DefaultRequestInsertionScheduler.java index 32929a39984..a8551b6ab9b 100644 --- a/contribs/drt/src/main/java/org/matsim/contrib/drt/scheduler/DefaultRequestInsertionScheduler.java +++ b/contribs/drt/src/main/java/org/matsim/contrib/drt/scheduler/DefaultRequestInsertionScheduler.java @@ -80,7 +80,7 @@ public DefaultRequestInsertionScheduler(Fleet fleet, MobsimTimer timer, private void initSchedules(Fleet fleet) { for (DvrpVehicle veh : fleet.getVehicles().values()) { veh.getSchedule() - .addTask(taskFactory.createStayTask(veh, veh.getServiceBeginTime(), veh.getServiceEndTime(), + .addTask(taskFactory.createInitialTask(veh, veh.getServiceBeginTime(), veh.getServiceEndTime(), veh.getStartLink())); } } @@ -94,21 +94,21 @@ public PickupDropoffTaskPair scheduleRequest(AcceptedDrtRequest request, Inserti var dropoffTask = insertDropoff(request, insertion, pickupTask); verifyTimes("Inconsistent dropoff arrival time", insertion.detourTimeInfo.dropoffDetourInfo.arrivalTime, dropoffTask.getBeginTime()); - + verifyTaskContinuity(insertion); verifyConstraints(insertion); verifyStructure(insertion.insertion.vehicleEntry.vehicle.getSchedule()); - + return new PickupDropoffTaskPair(pickupTask, dropoffTask); } - + private void verifyTaskContinuity(InsertionWithDetourData insertion) { /* * During insertion of tasks the common sanity checks that happen when appending * to the schedule (next start time = previous end time) are not evaluated. This * method verifies that the timing remains intact after insertion. */ - + Schedule schedule = insertion.insertion.vehicleEntry.vehicle.getSchedule(); for (int i = 1; i < schedule.getTaskCount(); i++) { Task first = schedule.getTasks().get(i - 1); @@ -116,9 +116,9 @@ private void verifyTaskContinuity(InsertionWithDetourData insertion) { Verify.verify(first.getEndTime() == second.getBeginTime()); } } - + private final boolean verifyConstraints = false; - + private void verifyConstraints(InsertionWithDetourData insertion) { /* * Verifies that no request constraints are violated after scheduling. This @@ -142,7 +142,7 @@ private void verifyConstraints(InsertionWithDetourData insertion) { } } } - + private void verifyStructure(Schedule schedule) { boolean previousDrive = false; @@ -191,7 +191,7 @@ private DrtStopTask insertPickup(AcceptedDrtRequest request, InsertionWithDetour beforePickupTask = currentTask; VrpPathWithTravelData vrpPath = VrpPaths.createPath(vehicleEntry.start.link, request.getFromLink(), vehicleEntry.start.time, detourData.detourToPickup, travelTime); - + if (vrpPath.getArrivalTime() < request.getEarliestStartTime() && scheduleWaitBeforeDrive) { // prebooking case: we need to wait right now ((OnlineDriveTaskTracker)beforePickupTask.getTaskTracker()).divertPath(VrpPaths.createZeroLengthPathForDiversion(diversion)); @@ -229,14 +229,14 @@ private DrtStopTask insertPickup(AcceptedDrtRequest request, InsertionWithDetour } else { stopTask = stops.get(pickupIdx - 1).task; // future stop task } - + boolean canMergePickup = stopTask != null && request.getFromLink() == stopTask.getLink() && stopTask.getEndTime() >= request.getEarliestStartTime(); - + if (canMergePickup) { // no detour; no new stop task // add pickup request to stop task stopTask.addPickupRequest(request); - + // potentially extend task stopTask.setEndTime(stopTimeCalculator.updateEndTimeForPickup(vehicleEntry.vehicle, stopTask, now, request.getRequest())); @@ -280,7 +280,7 @@ private DrtStopTask insertPickup(AcceptedDrtRequest request, InsertionWithDetour if (request.getFromLink() == stayOrStopTask.getLink()) { // the bus stays where it is beforePickupTask = stayOrStopTask; - + // prebooking: but we may want to wait a bit if next stop is in a while beforePickupTask = insertWait(vehicleEntry.vehicle, beforePickupTask, request.getEarliestStartTime()); } else {// add drive task to pickup location @@ -304,7 +304,7 @@ private DrtStopTask insertPickup(AcceptedDrtRequest request, InsertionWithDetour // add drive from pickup Link toLink = pickupIdx == dropoffIdx ? request.getToLink() // pickup->dropoff : stops.get(pickupIdx).task.getLink(); // pickup->i+1 - + double nextBeginTime = pickupIdx == dropoffIdx ? // pickupStopTask.getEndTime() : // asap stops.get(pickupIdx).task.getBeginTime(); // as planned @@ -312,13 +312,13 @@ private DrtStopTask insertPickup(AcceptedDrtRequest request, InsertionWithDetour if (request.getFromLink() == toLink) { // prebooking case when we are already at the stop location, but next stop task happens in the future Task afterPickupTask = insertWait(vehicleEntry.vehicle, pickupStopTask, nextBeginTime); - + scheduleTimingUpdater.updateTimingsStartingFromTaskIdx(vehicleEntry.vehicle, afterPickupTask.getTaskIdx() + 1, afterPickupTask.getEndTime()); } else { VrpPathWithTravelData vrpPath = VrpPaths.createPath(request.getFromLink(), toLink, pickupStopTask.getEndTime(), detourData.detourFromPickup, travelTime); - + // may want to wait now or before next stop task Task afterPickupTask = insertDriveWithWait(vehicleEntry.vehicle, pickupStopTask, vrpPath, nextBeginTime); @@ -327,7 +327,7 @@ private DrtStopTask insertPickup(AcceptedDrtRequest request, InsertionWithDetour scheduleTimingUpdater.updateTimingsStartingFromTaskIdx(vehicleEntry.vehicle, afterPickupTask.getTaskIdx() + 1, afterPickupTask.getEndTime()); } - + return pickupStopTask; } @@ -404,7 +404,7 @@ private DrtStopTask insertDropoff(AcceptedDrtRequest request, InsertionWithDetou VrpPathWithTravelData vrpPath = VrpPaths.createPath(request.getToLink(), toLink, dropoffStopTask.getEndTime(), detourData.detourFromDropoff, travelTime); - + if (toLink == request.getToLink()) { // prebooking case: we stay, but may add some wait time until the next stop Task afterDropoffTask = insertWait(vehicleEntry.vehicle, dropoffStopTask, @@ -423,22 +423,22 @@ private DrtStopTask insertDropoff(AcceptedDrtRequest request, InsertionWithDetou } return dropoffStopTask; } - + /** * Removes drive and wait tasks between the startTask and the endTask */ private void removeBetween(Schedule schedule, Task startTask, Task endTask) { Verify.verify(endTask.getTaskIdx() >= startTask.getTaskIdx()); Verify.verify(endTask.getTaskIdx() <= startTask.getTaskIdx() + 3); - + int waitCount = 0; int driveCount = 0; - + int removeCount = endTask.getTaskIdx() - startTask.getTaskIdx() - 1; for (int k = 0; k < removeCount; k++) { Task task = schedule.getTasks().get(startTask.getTaskIdx() + 1); - + if (DrtTaskBaseType.DRIVE.isBaseTypeOf(task.getTaskType())) { driveCount++; } else if (DrtStayTask.TYPE.equals(task.getTaskType())) { @@ -446,17 +446,17 @@ private void removeBetween(Schedule schedule, Task startTask, Task endTask) { } else { throw new IllegalStateException("Invalid schedule structure: expected WAIT or DRIVE task"); } - + schedule.removeTask(task); } - + Verify.verify(waitCount <= 1); Verify.verify(driveCount <= 1); } - + private Task insertWait(DvrpVehicle vehicle, Task departureTask, double earliestNextStartTime) { Schedule schedule = vehicle.getSchedule(); - + final Link waitLink; if (departureTask instanceof StayTask) { waitLink = ((StayTask) departureTask).getLink(); @@ -465,39 +465,39 @@ private Task insertWait(DvrpVehicle vehicle, Task departureTask, double earliest } else { throw new IllegalStateException(); } - + if (departureTask.getEndTime() < earliestNextStartTime) { DrtStayTask waitTask = taskFactory.createStayTask(vehicle, departureTask.getEndTime(), earliestNextStartTime, waitLink); schedule.addTask(departureTask.getTaskIdx() + 1, waitTask); return waitTask; } - + return departureTask; } - + private Task insertDriveWithWait(DvrpVehicle vehicle, Task departureTask, VrpPathWithTravelData path, double latestArrivalTime) { Schedule schedule = vehicle.getSchedule(); - + Task leadingTask = departureTask; - + if (scheduleWaitBeforeDrive) { double driveDepartureTime = latestArrivalTime - path.getTravelTime(); - + if (driveDepartureTime > departureTask.getEndTime()) { // makes sense to insert a wait task before departure DrtStayTask waitTask = taskFactory.createStayTask(vehicle, departureTask.getEndTime(), driveDepartureTime, path.getFromLink()); schedule.addTask(departureTask.getTaskIdx() + 1, waitTask); - + path = path.withDepartureTime(driveDepartureTime); leadingTask = waitTask; } } - + Task driveTask = taskFactory.createDriveTask(vehicle, path, DrtDriveTask.TYPE); schedule.addTask(leadingTask.getTaskIdx() + 1, driveTask); - + if (driveTask.getEndTime() < latestArrivalTime) { DrtStayTask waitTask = taskFactory.createStayTask(vehicle, driveTask.getEndTime(), latestArrivalTime, path.getToLink()); From ea99b55ff9e79ce89df1a1236ba58e1fa20eb0bc Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 11:23:07 +0100 Subject: [PATCH 22/43] implemented HereMapsRouteValidatorTest --- .../HereMapsRouteValidator.java | 60 +++++++++++-------- .../HereMapsRouteValidatorTest.java | 41 +++++++++++++ .../GoogleMapRouteValidatorTest/route.json | 30 ++++++++++ .../HereMapsRouteValidatorTest/route.json | 49 +++++++++++++++ 4 files changed, 155 insertions(+), 25 deletions(-) create mode 100644 contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java create mode 100644 contribs/analysis/test/input/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest/route.json create mode 100644 contribs/analysis/test/input/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest/route.json diff --git a/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidator.java b/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidator.java index 9af9cff72c9..e78704027e8 100644 --- a/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidator.java +++ b/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidator.java @@ -28,6 +28,7 @@ import java.text.DecimalFormat; import java.text.NumberFormat; import java.util.Locale; +import java.util.Optional; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -41,6 +42,9 @@ import org.matsim.core.utils.io.IOUtils; import org.matsim.core.utils.misc.Time; +import javax.swing.*; +import javax.swing.text.html.Option; + /** * @author jbischoff this class requests travel times and distances between two * coordinates from HERE Maps. Please replace the API code with your own @@ -91,9 +95,6 @@ public Tuple getTravelTime(NetworkTrip trip) { @Override public Tuple getTravelTime(Coord fromCoord, Coord toCoord, double departureTime, String tripId) { - long travelTime = 0; - long distance = 0; - Coord from = transformation.transform(fromCoord); Coord to = transformation.transform(toCoord); @@ -110,36 +111,45 @@ public Tuple getTravelTime(Coord fromCoord, Coord toCoord, doubl log.info(urlString); + Optional> result; try { URL url = new URL(urlString); BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream())); - JSONParser jp = new JSONParser(); - JSONObject jsonObject = (JSONObject) jp.parse(in); - JSONArray routes = (JSONArray) jsonObject.get("routes"); - - if (!routes.isEmpty()) { - JSONObject route = (JSONObject) routes.get(0); - JSONArray sections = (JSONArray) route.get("sections"); - JSONObject section = (JSONObject) sections.get(0); - JSONObject summary = (JSONObject) section.get("summary"); - travelTime = (long) summary.get("duration"); - distance = (long) summary.get("length"); - if (writeDetailedFiles) { - String filename = outputPath + "/" + tripId + ".json.gz"; - BufferedWriter bw = IOUtils.getBufferedWriter(filename); - bw.write(jsonObject.toString()); - bw.flush(); - bw.close(); - } - } - - in.close(); + result = readFromJson(in, tripId); } catch (MalformedURLException e) { log.error("URL is not working. Please check your API key", e); + result = Optional.empty(); } catch (IOException | ParseException e) { log.error("Cannot read the content on the URL properly. Please manually check the URL", e); + result = Optional.empty(); } - return new Tuple((double) travelTime, (double) distance); + return result.orElse(new Tuple<>(0.0, 0.0)); } + Optional> readFromJson(BufferedReader reader, String tripId) throws IOException, ParseException { + JSONParser jp = new JSONParser(); + JSONObject jsonObject = (JSONObject) jp.parse(reader); + JSONArray routes = (JSONArray) jsonObject.get("routes"); + + if(routes.isEmpty()){ + return Optional.empty(); + } + + JSONObject route = (JSONObject) routes.get(0); + JSONArray sections = (JSONArray) route.get("sections"); + JSONObject section = (JSONObject) sections.get(0); + JSONObject summary = (JSONObject) section.get("summary"); + long travelTime = (long) summary.get("duration"); + long distance = (long) summary.get("length"); + if (writeDetailedFiles) { + String filename = outputPath + "/" + tripId + ".json.gz"; + BufferedWriter bw = IOUtils.getBufferedWriter(filename); + bw.write(jsonObject.toString()); + bw.flush(); + bw.close(); + } + reader.close(); + return Optional.of(new Tuple<>((double) travelTime, (double) distance)); + } + } diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java new file mode 100644 index 00000000000..d4a8c0ce063 --- /dev/null +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java @@ -0,0 +1,41 @@ +package org.matsim.contrib.analysis.vsp.traveltimedistance; + +import org.jgrapht.alg.linkprediction.PreferentialAttachmentLinkPrediction; +import org.json.simple.parser.ParseException; +import org.junit.Rule; +import org.junit.Test; +import org.matsim.core.utils.collections.Tuple; +import org.matsim.testcases.MatsimTestUtils; + +import java.io.*; +import java.util.Optional; + +import static org.junit.Assert.*; + +public class HereMapsRouteValidatorTest { + @Rule + public MatsimTestUtils utils = new MatsimTestUtils(); + + @Test + public void testReadJson() throws IOException, ParseException { + HereMapsRouteValidator hereMapsRouteValidator = getDummyValidator(false); + BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(utils.getClassInputDirectory() + "route.json"))); + Optional> result = hereMapsRouteValidator.readFromJson(reader, null); + assertTrue(result.isPresent()); + assertEquals(394, result.get().getFirst(), MatsimTestUtils.EPSILON); + assertEquals(2745, result.get().getSecond(), MatsimTestUtils.EPSILON); + } + + @Test + public void testWriteFile() throws IOException, ParseException { + HereMapsRouteValidator hereMapsRouteValidator = getDummyValidator(true); + BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(utils.getClassInputDirectory() + "route.json"))); + hereMapsRouteValidator.readFromJson(reader, "tripId"); + assertTrue(new File(utils.getOutputDirectory() + "tripId.json.gz").isFile()); + } + + //All values with null filled are not necessary for this test + private HereMapsRouteValidator getDummyValidator(boolean writeDetailedFiles) { + return new HereMapsRouteValidator(utils.getOutputDirectory(), null, null, null, null, writeDetailedFiles); + } +} diff --git a/contribs/analysis/test/input/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest/route.json b/contribs/analysis/test/input/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest/route.json new file mode 100644 index 00000000000..14e61b35177 --- /dev/null +++ b/contribs/analysis/test/input/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest/route.json @@ -0,0 +1,30 @@ +{ + "destination_addresses": [ + "Kaiserin-Augusta-Allee 104, 10553 Berlin, Germany" + ], + "origin_addresses": [ + "B2 135, 10623 Berlin, Germany" + ], + "rows": [ + { + "elements": [ + { + "distance": { + "text": "2.5 km", + "value": 2464 + }, + "duration": { + "text": "7 mins", + "value": 400 + }, + "duration_in_traffic": { + "text": "7 mins", + "value": 413 + }, + "status": "OK" + } + ] + } + ], + "status": "OK" +} \ No newline at end of file diff --git a/contribs/analysis/test/input/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest/route.json b/contribs/analysis/test/input/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest/route.json new file mode 100644 index 00000000000..2dfdae5e032 --- /dev/null +++ b/contribs/analysis/test/input/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest/route.json @@ -0,0 +1,49 @@ +{ + "routes": [ + { + "id": "ed5396be-8f97-4c25-a373-a019da78b696", + "sections": [ + { + "id": "5f0ff311-d1d0-4a6a-a631-1c59fd5eaee4", + "type": "vehicle", + "departure": { + "time": "2023-12-11T10:00:00+01:00", + "place": { + "type": "place", + "location": { + "lat": 52.5127381, + "lng": 13.3268076 + }, + "originalLocation": { + "lat": 52.512638, + "lng": 13.326826 + } + } + }, + "arrival": { + "time": "2023-12-11T10:06:34+01:00", + "place": { + "type": "place", + "location": { + "lat": 52.5258281, + "lng": 13.3209817 + }, + "originalLocation": { + "lat": 52.5256489, + "lng": 13.320944 + } + } + }, + "summary": { + "duration": 394, + "length": 2745, + "baseDuration": 325 + }, + "transport": { + "mode": "car" + } + } + ] + } + ] +} \ No newline at end of file From 98a82e69b67cc80e2b4b9d21e5d3c23c27251122 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 11:33:33 +0100 Subject: [PATCH 23/43] implemented GoogleMapRouteValidatorTest --- .../GoogleMapRouteValidator.java | 57 ++++++++++++------- .../GoogleMapRouteValidatorTest.java | 33 +++++++++++ 2 files changed, 68 insertions(+), 22 deletions(-) create mode 100644 contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java diff --git a/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidator.java b/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidator.java index b8aa76c34e1..171c5bc4469 100644 --- a/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidator.java +++ b/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidator.java @@ -9,8 +9,10 @@ import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.collections.Tuple; import org.matsim.core.utils.geometry.CoordinateTransformation; +import org.matsim.core.utils.io.IOUtils; import java.io.BufferedReader; +import java.io.BufferedWriter; import java.io.IOException; import java.io.InputStreamReader; import java.net.URL; @@ -20,6 +22,7 @@ import java.time.format.DateTimeFormatter; import java.time.temporal.ChronoUnit; import java.util.Locale; +import java.util.Optional; public class GoogleMapRouteValidator implements TravelTimeDistanceValidator { private static final Logger log = LogManager.getLogger(GoogleMapRouteValidator.class); @@ -51,9 +54,6 @@ public Tuple getTravelTime(NetworkTrip trip) { @Override public Tuple getTravelTime(Coord fromCoord, Coord toCoord, double departureTime, String tripId) { - long travelTime = 0; - long distance = 0; - double adjustedDepartureTime = calculateGoogleDepartureTime(departureTime); Coord from = ct.transform(fromCoord); Coord to = ct.transform(toCoord); @@ -71,32 +71,45 @@ public Tuple getTravelTime(Coord fromCoord, Coord toCoord, doubl "&origins=" + df.format(from.getY()) + "%2C" + df.format(from.getX()) + "&key=" + apiAccessKey; + log.info(urlString); + + Optional> result; try { - log.info(urlString); URL url = new URL(urlString); - try (BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream()))) { - JSONParser jp = new JSONParser(); - JSONObject jsonObject = (JSONObject) jp.parse(in); - JSONArray rows = (JSONArray) jsonObject.get("rows"); - if (!rows.isEmpty()) { - JSONArray elements = (JSONArray) ((JSONObject) rows.get(0)).get("elements"); - JSONObject results = (JSONObject) elements.get(0); - if (results.containsKey("distance")) { - JSONObject distanceResults = (JSONObject) results.get("distance"); - distance = (long) distanceResults.get("value"); - } - if (results.containsKey("duration_in_traffic")) { - JSONObject timeResults = (JSONObject) results.get("duration_in_traffic"); - travelTime = (long) timeResults.get("value"); - } - } - } + BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream())); + result = readFromJson(in); } catch (IOException | ParseException e) { log.error("The contents on the URL cannot be read properly. Please check your API or check the contents on URL manually", e); + result = Optional.empty(); } - return new Tuple<>((double) travelTime, (double) distance); + return result.orElse(new Tuple<>(0.0, 0.0)); } + Optional> readFromJson(BufferedReader reader) throws IOException, ParseException { + JSONParser jp = new JSONParser(); + JSONObject jsonObject = (JSONObject) jp.parse(reader); + JSONArray rows = (JSONArray) jsonObject.get("rows"); + + if (rows.isEmpty()) { + return Optional.empty(); + } + + JSONArray elements = (JSONArray) ((JSONObject) rows.get(0)).get("elements"); + JSONObject results = (JSONObject) elements.get(0); + + + if (!results.containsKey("distance") && !results.containsKey("duration_in_traffic")) { + return Optional.empty(); + } + + JSONObject distanceResults = (JSONObject) results.get("distance"); + long distance = (long) distanceResults.get("value"); + JSONObject timeResults = (JSONObject) results.get("duration_in_traffic"); + long travelTime = (long) timeResults.get("value"); + + return Optional.of(new Tuple<>((double) travelTime, (double) distance)); + } + private double calculateGoogleDepartureTime(double departureTime) { DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); LocalDate googleDate0 = LocalDate.parse("1970-01-01", dateTimeFormatter); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java new file mode 100644 index 00000000000..ee9d4dbb2f4 --- /dev/null +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java @@ -0,0 +1,33 @@ +package org.matsim.contrib.analysis.vsp.traveltimedistance; + +import org.json.simple.parser.ParseException; +import org.junit.Rule; +import org.junit.Test; +import org.matsim.core.utils.collections.Tuple; +import org.matsim.testcases.MatsimTestUtils; + +import java.io.*; +import java.util.Optional; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; + +public class GoogleMapRouteValidatorTest { + @Rule + public MatsimTestUtils utils = new MatsimTestUtils(); + + @Test + public void testReadJson() throws IOException, ParseException { + GoogleMapRouteValidator googleMapRouteValidator = getDummyValidator(); + BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(utils.getClassInputDirectory() + "route.json"))); + Optional> result = googleMapRouteValidator.readFromJson(reader); + assertTrue(result.isPresent()); + assertEquals(413, result.get().getFirst(), MatsimTestUtils.EPSILON); + assertEquals(2464, result.get().getSecond(), MatsimTestUtils.EPSILON); + } + + //All values with null filled are not necessary for this test + private GoogleMapRouteValidator getDummyValidator() { + return new GoogleMapRouteValidator(utils.getOutputDirectory(), null, null, null, null); + } +} From 11703e405ca4d700bbe81301d650271febd38a1d Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 11:53:28 +0100 Subject: [PATCH 24/43] switched to gson --- contribs/analysis/pom.xml | 12 +++--- .../GoogleMapRouteValidator.java | 39 +++++++++---------- .../HereMapsRouteValidator.java | 38 +++++++++--------- .../GoogleMapRouteValidatorTest.java | 3 +- .../HereMapsRouteValidatorTest.java | 6 +-- 5 files changed, 47 insertions(+), 51 deletions(-) diff --git a/contribs/analysis/pom.xml b/contribs/analysis/pom.xml index 83989a7fcbf..6eccfbda0b1 100644 --- a/contribs/analysis/pom.xml +++ b/contribs/analysis/pom.xml @@ -20,12 +20,12 @@ proj4j 0.1.0 - - com.googlecode.json-simple - json-simple - 1.1.1 - - + + com.google.code.gson + gson + 2.10.1 + + org.apache.commons commons-math3 diff --git a/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidator.java b/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidator.java index 171c5bc4469..7d35886428d 100644 --- a/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidator.java +++ b/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidator.java @@ -1,18 +1,16 @@ package org.matsim.contrib.analysis.vsp.traveltimedistance; +import com.google.gson.JsonArray; +import com.google.gson.JsonElement; +import com.google.gson.JsonObject; +import com.google.gson.JsonParser; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.json.simple.JSONArray; -import org.json.simple.JSONObject; -import org.json.simple.parser.JSONParser; -import org.json.simple.parser.ParseException; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.collections.Tuple; import org.matsim.core.utils.geometry.CoordinateTransformation; -import org.matsim.core.utils.io.IOUtils; import java.io.BufferedReader; -import java.io.BufferedWriter; import java.io.IOException; import java.io.InputStreamReader; import java.net.URL; @@ -78,36 +76,37 @@ public Tuple getTravelTime(Coord fromCoord, Coord toCoord, doubl URL url = new URL(urlString); BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream())); result = readFromJson(in); - } catch (IOException | ParseException e) { + } catch (IOException e) { log.error("The contents on the URL cannot be read properly. Please check your API or check the contents on URL manually", e); result = Optional.empty(); } return result.orElse(new Tuple<>(0.0, 0.0)); } - Optional> readFromJson(BufferedReader reader) throws IOException, ParseException { - JSONParser jp = new JSONParser(); - JSONObject jsonObject = (JSONObject) jp.parse(reader); - JSONArray rows = (JSONArray) jsonObject.get("rows"); + Optional> readFromJson(BufferedReader reader) throws IOException { + JsonElement jsonElement = JsonParser.parseReader(reader); + if(!jsonElement.isJsonObject()){ + return Optional.empty(); + } + JsonObject jsonObject = jsonElement.getAsJsonObject(); + JsonArray rows = jsonObject.getAsJsonArray("rows"); if (rows.isEmpty()) { return Optional.empty(); } - JSONArray elements = (JSONArray) ((JSONObject) rows.get(0)).get("elements"); - JSONObject results = (JSONObject) elements.get(0); - + JsonObject results = rows.get(0).getAsJsonObject().get("elements").getAsJsonArray().get(0).getAsJsonObject(); - if (!results.containsKey("distance") && !results.containsKey("duration_in_traffic")) { + if (!results.has("distance") && !results.has("duration_in_traffic")) { return Optional.empty(); } - JSONObject distanceResults = (JSONObject) results.get("distance"); - long distance = (long) distanceResults.get("value"); - JSONObject timeResults = (JSONObject) results.get("duration_in_traffic"); - long travelTime = (long) timeResults.get("value"); + JsonObject distanceResults = results.get("distance").getAsJsonObject(); + double distance = distanceResults.get("value").getAsDouble(); + JsonObject timeResults = results.get("duration_in_traffic").getAsJsonObject(); + double travelTime = timeResults.get("value").getAsDouble(); - return Optional.of(new Tuple<>((double) travelTime, (double) distance)); + return Optional.of(new Tuple<>(travelTime, distance)); } private double calculateGoogleDepartureTime(double departureTime) { diff --git a/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidator.java b/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidator.java index e78704027e8..b437d7dffb8 100644 --- a/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidator.java +++ b/contribs/analysis/src/main/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidator.java @@ -30,21 +30,18 @@ import java.util.Locale; import java.util.Optional; +import com.google.gson.JsonArray; +import com.google.gson.JsonElement; +import com.google.gson.JsonObject; +import com.google.gson.JsonParser; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.json.simple.JSONArray; -import org.json.simple.JSONObject; -import org.json.simple.parser.JSONParser; -import org.json.simple.parser.ParseException; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.collections.Tuple; import org.matsim.core.utils.geometry.CoordinateTransformation; import org.matsim.core.utils.io.IOUtils; import org.matsim.core.utils.misc.Time; -import javax.swing.*; -import javax.swing.text.html.Option; - /** * @author jbischoff this class requests travel times and distances between two * coordinates from HERE Maps. Please replace the API code with your own @@ -119,28 +116,31 @@ public Tuple getTravelTime(Coord fromCoord, Coord toCoord, doubl } catch (MalformedURLException e) { log.error("URL is not working. Please check your API key", e); result = Optional.empty(); - } catch (IOException | ParseException e) { + } catch (IOException e) { log.error("Cannot read the content on the URL properly. Please manually check the URL", e); result = Optional.empty(); } return result.orElse(new Tuple<>(0.0, 0.0)); } - Optional> readFromJson(BufferedReader reader, String tripId) throws IOException, ParseException { - JSONParser jp = new JSONParser(); - JSONObject jsonObject = (JSONObject) jp.parse(reader); - JSONArray routes = (JSONArray) jsonObject.get("routes"); + Optional> readFromJson(BufferedReader reader, String tripId) throws IOException { + JsonElement jsonElement = JsonParser.parseReader(reader); + if(!jsonElement.isJsonObject()){ + return Optional.empty(); + } + JsonObject jsonObject = jsonElement.getAsJsonObject(); + JsonArray routes = jsonObject.getAsJsonArray("routes"); if(routes.isEmpty()){ return Optional.empty(); } - JSONObject route = (JSONObject) routes.get(0); - JSONArray sections = (JSONArray) route.get("sections"); - JSONObject section = (JSONObject) sections.get(0); - JSONObject summary = (JSONObject) section.get("summary"); - long travelTime = (long) summary.get("duration"); - long distance = (long) summary.get("length"); + JsonObject route = routes.get(0).getAsJsonObject(); + JsonArray sections = route.get("sections").getAsJsonArray(); + JsonObject section = sections.get(0).getAsJsonObject(); + JsonObject summary = section.get("summary").getAsJsonObject(); + double travelTime = summary.get("duration").getAsDouble(); + double distance = summary.get("length").getAsDouble(); if (writeDetailedFiles) { String filename = outputPath + "/" + tripId + ".json.gz"; BufferedWriter bw = IOUtils.getBufferedWriter(filename); @@ -149,7 +149,7 @@ Optional> readFromJson(BufferedReader reader, String tripI bw.close(); } reader.close(); - return Optional.of(new Tuple<>((double) travelTime, (double) distance)); + return Optional.of(new Tuple<>(travelTime, distance)); } } diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java index ee9d4dbb2f4..694b5039e8e 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java @@ -1,6 +1,5 @@ package org.matsim.contrib.analysis.vsp.traveltimedistance; -import org.json.simple.parser.ParseException; import org.junit.Rule; import org.junit.Test; import org.matsim.core.utils.collections.Tuple; @@ -17,7 +16,7 @@ public class GoogleMapRouteValidatorTest { public MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testReadJson() throws IOException, ParseException { + public void testReadJson() throws IOException { GoogleMapRouteValidator googleMapRouteValidator = getDummyValidator(); BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(utils.getClassInputDirectory() + "route.json"))); Optional> result = googleMapRouteValidator.readFromJson(reader); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java index d4a8c0ce063..cdf03802384 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java @@ -1,7 +1,5 @@ package org.matsim.contrib.analysis.vsp.traveltimedistance; -import org.jgrapht.alg.linkprediction.PreferentialAttachmentLinkPrediction; -import org.json.simple.parser.ParseException; import org.junit.Rule; import org.junit.Test; import org.matsim.core.utils.collections.Tuple; @@ -17,7 +15,7 @@ public class HereMapsRouteValidatorTest { public MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testReadJson() throws IOException, ParseException { + public void testReadJson() throws IOException { HereMapsRouteValidator hereMapsRouteValidator = getDummyValidator(false); BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(utils.getClassInputDirectory() + "route.json"))); Optional> result = hereMapsRouteValidator.readFromJson(reader, null); @@ -27,7 +25,7 @@ public void testReadJson() throws IOException, ParseException { } @Test - public void testWriteFile() throws IOException, ParseException { + public void testWriteFile() throws IOException { HereMapsRouteValidator hereMapsRouteValidator = getDummyValidator(true); BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(utils.getClassInputDirectory() + "route.json"))); hereMapsRouteValidator.readFromJson(reader, "tripId"); From cc81f0ec97c4de41726240d242d1248a4ecc812f Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 12:00:00 +0100 Subject: [PATCH 25/43] replace dependencies of simple json --- .../accessibility/utils/GeoJsonPolygonFeatureWriter.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/contribs/accessibility/src/main/java/org/matsim/contrib/accessibility/utils/GeoJsonPolygonFeatureWriter.java b/contribs/accessibility/src/main/java/org/matsim/contrib/accessibility/utils/GeoJsonPolygonFeatureWriter.java index c022be98067..f0e3dc08db3 100644 --- a/contribs/accessibility/src/main/java/org/matsim/contrib/accessibility/utils/GeoJsonPolygonFeatureWriter.java +++ b/contribs/accessibility/src/main/java/org/matsim/contrib/accessibility/utils/GeoJsonPolygonFeatureWriter.java @@ -1,6 +1,6 @@ package org.matsim.contrib.accessibility.utils; -import org.json.simple.JSONValue; +import com.google.gson.Gson; import org.matsim.api.core.v01.Coord; import java.util.*; @@ -34,7 +34,7 @@ public String asGeoJson() { featureCollectionMap.put("features", featuresList); featureCollectionMap.put("crs", parseCRS()); featureCollectionMap.put("bbox", boundingBox.getBoundingBox()); - return JSONValue.toJSONString(featureCollectionMap); + return new Gson().toJson(featureCollectionMap); } private List> parseFeatureList() { From 30e7163cb4450a887e329b46891021b1b222351e Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 14:05:18 +0100 Subject: [PATCH 26/43] replaced rules by extensions --- .../accessibility/grid/SpatialGridTest.java | 6 +- .../CompareLogsumFormulas2Test.java | 6 +- .../CompareLogsumFormulasTest.java | 6 +- .../ComputeLogsumFormulas3Test.java | 6 +- .../run/AccessibilityIntegrationTest.java | 4 +- .../accessibility/run/NetworkUtilTest.java | 92 +-- .../run/TinyAccessibilityTest.java | 4 +- .../run/TinyMultimodalAccessibilityTest.java | 4 +- .../org/matsim/contrib/accidents/RunTest.java | 4 +- .../contrib/accidents/RunTestEquil.java | 4 +- .../PersonIntersectAreaFilterTest.java | 6 +- .../population/RouteLinkFilterTest.java | 6 +- .../kai/KNAnalysisEventsHandlerTest.java | 10 +- .../GoogleMapRouteValidatorTest.java | 6 +- .../HereMapsRouteValidatorTest.java | 6 +- .../RunEventsToTravelDiariesIT.java | 6 +- .../matsim/application/CommandRunnerTest.java | 6 +- .../application/MATSimApplicationTest.java | 6 +- .../analysis/LogFileAnalysisTest.java | 6 +- .../application/options/CsvOptionsTest.java | 11 +- .../application/options/ShpOptionsTest.java | 8 +- .../prepare/CreateLandUseShpTest.java | 8 +- .../prepare/ShapeFileTextLookupTest.java | 8 +- .../counts/CreateCountsFromBAStDataTest.java | 6 +- .../population/CloseTrajectoriesTest.java | 8 +- .../SplitActivityTypesDurationTest.java | 6 +- .../pt/CreateTransitScheduleFromGtfsTest.java | 6 +- .../CarrierReaderFromCSVTest.java | 6 +- .../DemandReaderFromCSVTest.java | 6 +- .../FreightDemandGenerationTest.java | 6 +- .../FreightDemandGenerationUtilsTest.java | 8 +- .../LanduseBuildingAnalysisTest.java | 6 +- ...nerateSmallScaleCommercialTrafficTest.java | 6 +- .../SmallScaleCommercialTrafficUtilsTest.java | 6 +- .../TrafficVolumeGenerationTest.java | 6 +- .../TripDistributionMatrixTest.java | 6 +- .../contrib/av/flow/RunAvExampleIT.java | 6 +- .../contrib/av/flow/TestAvFlowFactor.java | 6 +- .../RunTaxiPTIntermodalExampleIT.java | 6 +- .../BicycleLinkSpeedCalculatorTest.java | 5 +- .../contrib/bicycle/run/BicycleTest.java | 212 ++--- .../contrib/cadyts/car/CadytsCarIT.java | 6 +- .../utils/CalibrationStatReaderTest.java | 6 +- .../runExample/RunCarsharingIT.java | 4 +- .../always/BetaTravelTest66IT.java | 6 +- .../integration/always/BetaTravelTest6IT.java | 6 +- .../DecongestionPricingTestIT.java | 6 +- .../modules/config/ConfigTest.java | 4 +- .../DrtWithExtensionsConfigGroupTest.java | 14 +- .../RunDrtWithCompanionExampleIT.java | 6 +- .../extension/dashboards/DashboardTests.java | 6 +- .../MultiModaFixedDrtLegEstimatorTest.java | 6 +- .../MultiModalDrtLegEstimatorTest.java | 6 +- .../insertion/DrtInsertionExtensionIT.java | 6 +- .../OperationFacilitiesIOTest.java | 6 +- .../operations/shifts/ShiftsIOTest.java | 6 +- .../drt/config/ConfigBehaviorTest.java | 4 +- .../DefaultUnplannedRequestInserterTest.java | 9 +- .../insertion/DrtPoolingParameterTest.java | 4 +- ...stRule.java => ForkJoinPoolExtension.java} | 20 +- .../ExtensiveInsertionProviderTest.java | 6 +- .../SelectiveInsertionProviderTest.java | 10 +- .../drt/prebooking/AbandonAndCancelTest.java | 26 +- .../prebooking/PersonStuckPrebookingTest.java | 6 +- .../drt/prebooking/PrebookingTest.java | 38 +- .../drt/routing/DrtRoutingModuleTest.java | 6 +- .../drt/run/examples/RunDrtExampleIT.java | 28 +- .../RunOneTaxiWithPrebookingExampleIT.java | 6 +- .../contrib/emissions/EmissionModuleTest.java | 8 +- .../emissions/TestPositionEmissionModule.java | 6 +- .../analysis/EmissionGridAnalyzerTest.java | 6 +- .../FastEmissionGridAnalyzerTest.java | 6 +- .../analysis/RawEmissionEventsReaderTest.java | 8 +- .../events/VehicleLeavesTrafficEventTest.java | 6 +- ...unAverageEmissionToolOfflineExampleIT.java | 4 +- ...nDetailedEmissionToolOfflineExampleIT.java | 4 +- ...EmissionToolOnlineExampleIT_vehTypeV1.java | 4 +- ...eExampleIT_vehTypeV1FallbackToAverage.java | 4 +- ...EmissionToolOnlineExampleIT_vehTypeV2.java | 4 +- ...eExampleIT_vehTypeV2FallbackToAverage.java | 4 +- .../contrib/ev/example/RunEvExampleTest.java | 4 +- ...nEvExampleWithLTHConsumptionModelTest.java | 4 +- ...emperatureChangeModuleIntegrationTest.java | 6 +- .../carriers/CarrierEventsReadersTest.java | 4 +- .../freight/carriers/CarrierModuleTest.java | 6 +- .../carriers/CarrierPlanReaderV1Test.java | 4 +- .../carriers/CarrierPlanXmlReaderV2Test.java | 4 +- .../CarrierPlanXmlReaderV2WithDtdTest.java | 2 +- .../carriers/CarrierPlanXmlWriterV1Test.java | 6 +- .../carriers/CarrierPlanXmlWriterV2Test.java | 6 +- .../CarrierPlanXmlWriterV2_1Test.java | 6 +- .../carriers/CarrierReadWriteV2_1Test.java | 6 +- .../CarrierVehicleTypeLoaderTest.java | 4 +- .../CarrierVehicleTypeReaderTest.java | 4 +- .../carriers/CarrierVehicleTypeTest.java | 4 +- .../CarrierVehicleTypeWriterTest.java | 6 +- .../freight/carriers/CarriersUtilsTest.java | 6 +- .../EquilWithCarrierWithPersonsIT.java | 4 +- .../EquilWithCarrierWithoutPersonsIT.java | 4 +- ...istanceConstraintFromVehiclesFileTest.java | 6 +- .../jsprit/DistanceConstraintTest.java | 6 +- .../carriers/jsprit/FixedCostsTest.java | 4 +- .../carriers/jsprit/IntegrationIT.java | 6 +- .../jsprit/MatsimTransformerTest.java | 6 +- .../NetworkBasedTransportCostsTest.java | 4 +- .../freight/carriers/jsprit/SkillsIT.java | 6 +- .../usecases/chessboard/RunChessboardIT.java | 4 +- .../RunPassengerAlongWithCarriersIT.java | 6 +- .../utils/CarrierControlerUtilsIT.java | 6 +- .../utils/CarrierControlerUtilsTest.java | 10 +- .../freightreceiver/ReceiversReaderTest.java | 4 +- .../freightreceiver/ReceiversTest.java | 6 +- .../freightreceiver/ReceiversWriterTest.java | 4 +- .../matsim/modechoice/EstimateRouterTest.java | 8 +- .../org/matsim/modechoice/ScenarioTest.java | 6 +- .../org/matsim/modechoice/TestScenario.java | 2 +- .../commands/GenerateChoiceSetTest.java | 6 +- .../estimators/ComplexEstimatorTest.java | 6 +- .../modechoice/search/TopKMinMaxTest.java | 6 +- .../CreateAutomatedFDTest.java | 66 +- ...stReplyLocationChoicePlanStrategyTest.java | 6 +- .../locationchoice/LocationChoiceIT.java | 6 +- .../frozenepsilons/BestReplyIT.java | 6 +- .../FrozenEpsilonLocaChoiceIT.java | 4 +- .../frozenepsilons/SamplerTest.java | 6 +- .../LocationMutatorwChoiceSetTest.java | 6 +- .../timegeography/ManageSubchainsTest.java | 6 +- .../RandomLocationMutatorTest.java | 6 +- .../timegeography/SubChainTest.java | 6 +- .../MatrixBasedPtRouterIT.java | 14 +- .../matrixbasedptrouter/PtMatrixTest.java | 14 +- .../minibus/integration/PControlerTestIT.java | 4 +- .../integration/SubsidyContextTestIT.java | 4 +- .../minibus/integration/SubsidyTestIT.java | 4 +- .../replanning/EndRouteExtensionTest.java | 98 +-- .../MaxRandomEndTimeAllocatorTest.java | 22 +- .../MaxRandomStartTimeAllocatorTest.java | 22 +- .../SidewaysRouteExtensionTest.java | 96 +-- .../minibus/replanning/TimeProviderTest.java | 44 +- .../WeightedEndTimeExtensionTest.java | 40 +- .../WeightedStartTimeExtensionTest.java | 40 +- .../ComplexCircleScheduleProviderTest.java | 104 +-- .../SimpleCircleScheduleProviderTest.java | 62 +- ...tionApproachesAndBetweenJunctionsTest.java | 74 +- .../CreateStopsForAllCarLinksTest.java | 26 +- .../RecursiveStatsApproxContainerTest.java | 12 +- .../stats/RecursiveStatsContainerTest.java | 12 +- .../MultiModalControlerListenerTest.java | 4 +- .../multimodal/RunMultimodalExampleTest.java | 4 +- .../pt/MultiModalPTCombinationTest.java | 6 +- .../router/util/BikeTravelTimeTest.java | 6 +- .../router/util/WalkTravelTimeTest.java | 6 +- .../multimodal/simengine/StuckAgentTest.java | 6 +- .../contrib/noise/NoiseConfigGroupIT.java | 6 +- .../org/matsim/contrib/noise/NoiseIT.java | 6 +- .../contrib/noise/NoiseOnlineExampleIT.java | 6 +- .../matsim/contrib/noise/NoiseRLS19IT.java | 6 +- .../osm/networkReader/OsmBicycleReaderIT.java | 6 +- .../networkReader/OsmBicycleReaderTest.java | 6 +- .../networkReader/OsmNetworkParserTest.java | 6 +- .../networkReader/OsmSignalsParserTest.java | 8 +- .../SupersonicOsmNetworkReaderIT.java | 6 +- .../SupersonicOsmNetworkReaderTest.java | 6 +- .../org/matsim/contrib/otfvis/OTFVisIT.java | 6 +- .../run/RunWithParkingProxyIT.java | 4 +- .../run/RunParkingChoiceExampleIT.java | 4 +- .../run/RunParkingSearchScenarioIT.java | 6 +- .../contrib/protobuf/EventWriterPBTest.java | 9 +- .../contrib/pseudosimulation/RunPSimTest.java | 6 +- .../integration/RailsimIntegrationTest.java | 6 +- .../railsim/qsimengine/RailsimEngineTest.java | 6 +- .../roadpricing/AvoidTolledRouteTest.java | 6 +- .../contrib/roadpricing/CalcPaidTollTest.java | 6 +- .../contrib/roadpricing/ModuleTest.java | 6 +- .../PlansCalcRouteWithTollOrNotTest.java | 6 +- .../RoadPricingConfigGroupTest.java | 8 +- .../roadpricing/RoadPricingControlerIT.java | 6 +- .../roadpricing/RoadPricingIOTest.java | 6 +- .../TollTravelCostCalculatorTest.java | 4 +- .../run/RoadPricingByConfigfileTest.java | 4 +- .../run/RunRoadPricingExampleIT.java | 4 +- .../matsim/mobsim/qsim/SBBQSimModuleTest.java | 4 +- .../SBBTransitQSimEngineIntegrationTest.java | 4 +- .../AdaptiveSignalsExampleTest.java | 10 +- .../CreateIntergreensExampleTest.java | 12 +- .../CreateSignalInputExampleTest.java | 12 +- ...CreateSignalInputExampleWithLanesTest.java | 20 +- .../RunSignalSystemsExampleTest.java | 4 +- .../FixResponsiveSignalResultsIT.java | 14 +- .../contrib/signals/CalculateAngleTest.java | 38 +- .../analysis/DelayAnalysisToolTest.java | 58 +- .../signals/builder/QSimSignalTest.java | 40 +- .../builder/TravelTimeFourWaysTest.java | 6 +- .../builder/TravelTimeOneWayTestIT.java | 6 +- ...aultPlanbasedSignalSystemControllerIT.java | 6 +- .../controller/laemmerFix/LaemmerIT.java | 6 +- .../signals/controller/sylvia/SylviaIT.java | 6 +- .../v10/AmberTimesData10ReaderWriterTest.java | 8 +- .../SignalConflictDataReaderWriterTest.java | 38 +- .../UnprotectedLeftTurnLogicTest.java | 6 +- ...IntergreenTimesData10ReaderWriterTest.java | 10 +- .../SignalControlData20ReaderWriterTest.java | 34 +- .../v20/SignalGroups20ReaderWriterTest.java | 38 +- .../SignalSystemsData20ReaderWriterTest.java | 38 +- .../signals/integration/SignalSystemsIT.java | 6 +- .../InvertedNetworksSignalsIT.java | 6 +- .../SignalsAndLanesOsmNetworkReaderTest.java | 6 +- .../signals/oneagent/ControlerTest.java | 6 +- .../SimulatedAnnealingConfigGroupTest.java | 12 +- .../SimulatedAnnealingIT.java | 6 +- .../simwrapper/SimWrapperConfigGroupTest.java | 6 +- .../simwrapper/SimWrapperModuleTest.java | 6 +- .../org/matsim/simwrapper/SimWrapperTest.java | 6 +- .../simwrapper/dashboard/DashboardTests.java | 6 +- .../dashboard/EmissionsDashboardTest.java | 6 +- .../dashboard/TrafficCountsDashboardTest.java | 6 +- .../simwrapper/viz/PlotlyExamplesTest.java | 6 +- .../org/matsim/simwrapper/viz/PlotlyTest.java | 6 +- .../framework/population/JointPlanIOTest.java | 4 +- .../population/SocialNetworkIOTest.java | 4 +- .../replanning/grouping/FixedGroupsIT.java | 4 +- .../FullExplorationVsCuttoffTest.java | 4 +- ...intTravelingSimulationIntegrationTest.java | 10 +- .../utils/JointScenarioUtilsTest.java | 10 +- .../etaxi/run/RunETaxiBenchmarkTest.java | 4 +- .../contrib/etaxi/run/RunETaxiScenarioIT.java | 6 +- .../assignment/AssignmentTaxiOptimizerIT.java | 4 +- .../optimizer/fifo/FifoTaxiOptimizerIT.java | 4 +- .../rules/RuleBasedTaxiOptimizerIT.java | 4 +- .../optimizer/zonal/ZonalTaxiOptimizerIT.java | 4 +- .../taxi/run/RunTaxiScenarioTestIT.java | 4 +- ...oringParametersFromPersonAttributesIT.java | 6 +- ...omPersonAttributesNoSubpopulationTest.java | 6 +- ...ingParametersFromPersonAttributesTest.java | 6 +- .../FreightAnalysisEventBasedTest.java | 6 +- .../analysis/RunFreightAnalysisIT.java | 4 +- .../RunFreightAnalysisWithShipmentTest.java | 6 +- .../drtAndPt/PtAlongALine2Test.java | 6 +- .../drtAndPt/PtAlongALineTest.java | 6 +- .../osmBB/PTCountsNetworkSimplifierTest.java | 6 +- .../ModalDistanceAndCountsCadytsIT.java | 6 +- ...odalDistanceCadytsMultipleDistancesIT.java | 6 +- .../ModalDistanceCadytsSingleDistanceIT.java | 6 +- .../marginals/TripEventHandlerTest.java | 6 +- .../AdvancedMarginalCongestionPricingIT.java | 6 +- .../CombinedFlowAndStorageDelayTest.java | 32 +- ...nalCongestionHandlerFlowQueueQsimTest.java | 776 +++++++++--------- ...tionHandlerFlowSpillbackQueueQsimTest.java | 6 +- .../MarginalCongestionHandlerV3Test.java | 6 +- .../MarginalCongestionPricingTest.java | 16 +- .../MultipleSpillbackCausingLinksTest.java | 18 +- .../vsp/congestion/TestForEmergenceTime.java | 16 +- .../ev/TransferFinalSocToNextIterTest.java | 6 +- .../java/playground/vsp/ev/UrbanEVIT.java | 4 +- ...rarchicalFLowEfficiencyCalculatorTest.java | 7 +- .../cemdap/input/SynPopCreatorTest.java | 12 +- .../PlanFileModifierTest.java | 4 +- .../vsp/pt/fare/PtTripFareEstimatorTest.java | 6 +- .../vsp/pt/ptdisturbances/EditTripsTest.java | 4 +- ...nScoringParametersNoSubpopulationTest.java | 6 +- ...ityOfMoneyPersonScoringParametersTest.java | 4 +- .../vsp/zzArchive/bvwpOld/BvwpTest.java | 6 +- .../pt/raptor/SwissRailRaptorModuleTest.java | 6 +- .../org/matsim/analysis/CalcLegTimesTest.java | 6 +- .../matsim/analysis/CalcLinkStatsTest.java | 76 +- ...ationTravelStatsControlerListenerTest.java | 6 +- .../org/matsim/analysis/LegHistogramTest.java | 6 +- .../LinkStatsControlerListenerTest.java | 6 +- ...deChoiceCoverageControlerListenerTest.java | 6 +- .../ModeStatsControlerListenerTest.java | 6 +- .../analysis/OutputTravelStatsTest.java | 6 +- .../analysis/PHbyModeCalculatorTest.java | 6 +- .../analysis/PKMbyModeCalculatorTest.java | 6 +- .../ScoreStatsControlerListenerTest.java | 6 +- ...ansportPlanningMainModeIdentifierTest.java | 8 +- .../analysis/TravelDistanceStatsTest.java | 6 +- .../org/matsim/analysis/TripsAnalysisIT.java | 6 +- .../analysis/TripsAndLegsCSVWriterTest.java | 6 +- .../matsim/analysis/VolumesAnalyzerTest.java | 50 +- .../LinkPaxVolumesAnalysisTest.java | 6 +- .../PersonMoneyEventAggregatorTest.java | 6 +- .../api/core/v01/DemandGenerationTest.java | 6 +- .../api/core/v01/NetworkCreationTest.java | 6 +- .../matsim/core/config/CommandLineTest.java | 4 +- .../matsim/core/config/ConfigV2IOTest.java | 4 +- .../core/config/MaterializeConfigTest.java | 8 +- .../config/ReflectiveConfigGroupTest.java | 17 +- .../groups/ReplanningConfigGroupTest.java | 4 +- .../config/groups/RoutingConfigGroupTest.java | 4 +- .../config/groups/ScoringConfigGroupTest.java | 4 +- .../VspExperimentalConfigGroupTest.java | 6 +- .../core/controler/AbstractModuleTest.java | 4 +- .../core/controler/ControlerEventsTest.java | 6 +- .../matsim/core/controler/ControlerIT.java | 4 +- .../ControlerMobsimIntegrationTest.java | 4 +- .../controler/MatsimServicesImplTest.java | 6 +- .../core/controler/MobsimListenerTest.java | 6 +- .../core/controler/NewControlerTest.java | 6 +- .../OutputDirectoryHierarchyTest.java | 4 +- .../core/controler/TerminationTest.java | 6 +- .../TransitControlerIntegrationTest.java | 6 +- .../corelisteners/ListenersInjectionTest.java | 4 +- .../corelisteners/PlansDumpingIT.java | 4 +- .../matsim/core/events/ActEndEventTest.java | 6 +- .../matsim/core/events/ActStartEventTest.java | 6 +- .../core/events/AgentMoneyEventTest.java | 6 +- .../events/AgentWaitingForPtEventTest.java | 4 +- .../core/events/BasicEventsHandlerTest.java | 6 +- .../events/EventsHandlerHierarchyTest.java | 6 +- .../matsim/core/events/EventsReadersTest.java | 6 +- .../matsim/core/events/GenericEventTest.java | 6 +- .../core/events/LinkEnterEventTest.java | 6 +- .../core/events/LinkLeaveEventTest.java | 6 +- .../core/events/PersonArrivalEventTest.java | 6 +- .../core/events/PersonDepartureEventTest.java | 6 +- .../events/PersonEntersVehicleEventTest.java | 6 +- .../events/PersonLeavesVehicleEventTest.java | 6 +- .../core/events/PersonStuckEventTest.java | 6 +- .../events/TransitDriverStartsEventTest.java | 14 +- .../core/events/VehicleAbortsEventTest.java | 6 +- ...VehicleArrivesAtFacilityEventImplTest.java | 6 +- ...VehicleDepartsAtFacilityEventImplTest.java | 6 +- .../events/VehicleEntersTrafficEventTest.java | 6 +- .../events/VehicleLeavesTrafficEventTest.java | 6 +- .../events/algorithms/EventWriterXMLTest.java | 14 +- .../org/matsim/core/gbl/MatsimRandomTest.java | 6 +- .../matsim/core/gbl/MatsimResourceTest.java | 6 +- .../mobsim/hermes/HermesRoundaboutTest.java | 6 +- .../mobsim/jdeqsim/AbstractJDEQSimTest.java | 4 +- .../mobsim/jdeqsim/ConfigParameterTest.java | 6 +- .../core/mobsim/jdeqsim/TestEventLog.java | 6 +- .../mobsim/jdeqsim/TestMessageFactory.java | 6 +- .../core/mobsim/jdeqsim/TestMessageQueue.java | 6 +- .../mobsim/jdeqsim/util/TestEventLibrary.java | 6 +- .../mobsim/qsim/FlowStorageSpillbackTest.java | 6 +- .../qsim/QSimEventsIntegrationTest.java | 12 +- ...TeleportationEngineWDistanceCheckTest.java | 4 +- .../core/mobsim/qsim/VehicleSourceTest.java | 4 +- .../qsim/jdeqsimengine/JDEQSimPluginTest.java | 6 +- .../core/mobsim/qsim/pt/UmlaufDriverTest.java | 6 +- .../LinkSpeedCalculatorIntegrationTest.java | 4 +- .../qsim/qnetsimengine/PassingTest.java | 4 +- .../qsim/qnetsimengine/QLinkLanesTest.java | 6 +- .../mobsim/qsim/qnetsimengine/QLinkTest.java | 6 +- .../qnetsimengine/QSimComponentsTest.java | 4 +- .../SimulatedLaneFlowCapacityTest.java | 6 +- .../qnetsimengine/SpeedCalculatorTest.java | 4 +- .../qnetsimengine/VehicleHandlerTest.java | 6 +- .../AbstractNetworkWriterReaderTest.java | 6 +- .../core/network/DisallowedNextLinksTest.java | 10 +- .../NetworkChangeEventsParserWriterTest.java | 8 +- .../matsim/core/network/NetworkUtilsTest.java | 34 +- .../matsim/core/network/NetworkV2IOTest.java | 6 +- .../core/network/TimeVariantLinkImplTest.java | 6 +- .../TravelTimeCalculatorIntegrationTest.java | 6 +- .../IntersectionSimplifierTest.java | 20 +- .../containers/ConcaveHullTest.java | 24 +- .../io/NetworkAttributeConversionTest.java | 4 +- .../network/io/NetworkReaderMatsimV1Test.java | 6 +- .../network/io/NetworkReprojectionIOTest.java | 4 +- .../core/population/PersonImplTest.java | 6 +- .../io/PopulationAttributeConversionTest.java | 4 +- .../io/PopulationReprojectionIOIT.java | 4 +- .../population/io/PopulationV6IOTest.java | 4 +- .../io/PopulationWriterHandlerImplV4Test.java | 6 +- .../io/PopulationWriterHandlerImplV5Test.java | 4 +- ...mingPopulationAttributeConversionTest.java | 4 +- .../population/routes/NetworkFactoryTest.java | 6 +- .../routes/RouteFactoryIntegrationTest.java | 4 +- .../core/replanning/PlanStrategyTest.java | 6 +- .../annealing/ReplanningAnnealerTest.java | 6 +- .../ReplanningWithConflictsTest.java | 16 +- .../modules/ExternalModuleTest.java | 6 +- .../planInheritance/PlanInheritanceTest.java | 23 +- .../selectors/AbstractPlanSelectorTest.java | 4 +- ...eterministicMultithreadedReplanningIT.java | 6 +- .../strategies/InnovationSwitchOffTest.java | 6 +- .../TimeAllocationMutatorModuleTest.java | 6 +- .../AbstractLeastCostPathCalculatorTest.java | 6 +- .../router/FallbackRoutingModuleTest.java | 4 +- ...workRoutingInclAccessEgressModuleTest.java | 6 +- .../PseudoTransitRoutingModuleTest.java | 6 +- .../org/matsim/core/router/RoutingIT.java | 4 +- .../core/router/TripRouterModuleTest.java | 6 +- .../core/router/old/PlanRouterTest.java | 6 +- .../ScenarioByConfigInjectionTest.java | 4 +- .../core/scenario/ScenarioLoaderImplTest.java | 4 +- .../core/scoring/EventsToScoreTest.java | 6 +- ...yparNagelOpenTimesScoringFunctionTest.java | 6 +- .../LinkToLinkTravelTimeCalculatorTest.java | 6 +- .../TravelTimeCalculatorModuleTest.java | 6 +- .../TravelTimeCalculatorTest.java | 6 +- .../TravelTimeDataArrayTest.java | 4 +- .../core/utils/charts/BarChartTest.java | 6 +- .../core/utils/charts/LineChartTest.java | 6 +- .../core/utils/charts/XYLineChartTest.java | 6 +- .../core/utils/charts/XYScatterChartTest.java | 6 +- .../utils/geometry/GeometryUtilsTest.java | 10 +- .../core/utils/geometry/geotools/MGCTest.java | 6 +- .../GeotoolsTransformationTest.java | 6 +- .../core/utils/gis/ShapeFileReaderTest.java | 6 +- .../core/utils/gis/ShapeFileWriterTest.java | 84 +- .../org/matsim/core/utils/io/IOUtilsTest.java | 4 +- .../core/utils/io/MatsimXmlParserTest.java | 11 +- .../core/utils/io/OsmNetworkReaderTest.java | 22 +- .../core/utils/misc/ArgumentParserTest.java | 6 +- .../core/utils/misc/ByteBufferUtilsTest.java | 6 +- .../core/utils/misc/ConfigUtilsTest.java | 6 +- .../core/utils/misc/PopulationUtilsTest.java | 36 +- .../core/utils/misc/StringUtilsTest.java | 6 +- .../utils/timing/TimeInterpretationTest.java | 6 +- .../java/org/matsim/counts/CountTest.java | 6 +- .../counts/CountsComparisonAlgorithmTest.java | 6 +- .../counts/CountsControlerListenerTest.java | 4 +- .../matsim/counts/CountsErrorGraphTest.java | 6 +- .../counts/CountsHtmlAndGraphsWriterTest.java | 6 +- .../counts/CountsLoadCurveGraphTest.java | 6 +- .../org/matsim/counts/CountsParserTest.java | 6 +- .../matsim/counts/CountsParserWriterTest.java | 4 +- .../counts/CountsReaderHandlerImplV1Test.java | 6 +- .../counts/CountsReprojectionIOTest.java | 4 +- .../counts/CountsSimRealPerHourGraphTest.java | 6 +- .../matsim/counts/CountsTableWriterTest.java | 6 +- .../java/org/matsim/counts/CountsTest.java | 6 +- .../java/org/matsim/counts/CountsV2Test.java | 6 +- .../org/matsim/counts/OutputDelegateTest.java | 6 +- .../java/org/matsim/examples/EquilTest.java | 4 +- .../examples/OnePercentBerlin10sIT.java | 6 +- .../org/matsim/examples/PtTutorialIT.java | 5 +- .../matsim/examples/simple/PtScoringTest.java | 4 +- .../ActivityFacilitiesSourceTest.java | 4 +- .../FacilitiesAttributeConvertionTest.java | 4 +- .../FacilitiesParserWriterTest.java | 4 +- .../FacilitiesReprojectionIOTest.java | 4 +- .../AbstractFacilityAlgorithmTest.java | 6 +- .../HouseholdAttributeConversionTest.java | 4 +- .../matsim/households/HouseholdImplTest.java | 6 +- .../matsim/households/HouseholdsIoTest.java | 6 +- .../integration/EquilTwoAgentsTest.java | 6 +- .../integration/SimulateAndScoreTest.java | 6 +- .../PersonMoneyEventIntegrationTest.java | 6 +- .../InvertedNetworkRoutingIT.java | 6 +- .../integration/invertednetworks/LanesIT.java | 6 +- .../NonAlternatingPlanElementsIT.java | 4 +- .../pt/TransitIntegrationTest.java | 4 +- .../ChangeTripModeIntegrationTest.java | 6 +- .../integration/replanning/ReRoutingIT.java | 6 +- .../replanning/ResumableRunsIT.java | 6 +- .../QSimIntegrationTest.java | 6 +- .../lanes/data/LanesReaderWriterTest.java | 6 +- .../matsim/modules/ScoreStatsModuleTest.java | 6 +- .../matsim/other/DownloadAndReadXmlTest.java | 34 +- .../ChooseRandomLegModeForSubtourTest.java | 40 +- .../algorithms/ChooseRandomLegModeTest.java | 6 +- .../analysis/TransitLoadIntegrationTest.java | 4 +- .../pt/router/TransitRouterModuleTest.java | 4 +- .../pt/transitSchedule/DepartureTest.java | 6 +- .../pt/transitSchedule/TransitLineTest.java | 6 +- .../transitSchedule/TransitRouteStopTest.java | 6 +- .../pt/transitSchedule/TransitRouteTest.java | 6 +- .../TransitScheduleFormatV1Test.java | 6 +- .../TransitScheduleReaderTest.java | 6 +- .../TransitScheduleReprojectionIOTest.java | 4 +- .../TransitScheduleWriterTest.java | 14 +- .../TransitStopFacilityTest.java | 6 +- .../org/matsim/run/CreateFullConfigTest.java | 4 +- .../java/org/matsim/run/InitRoutesTest.java | 6 +- .../java/org/matsim/run/XY2LinksTest.java | 6 +- .../matsim/testcases/MatsimJunit5Test.java | 344 -------- .../testcases/MatsimJunit5TestExtension.java | 344 -------- .../org/matsim/testcases/MatsimTestUtils.java | 104 ++- .../EventsFileComparatorTest.java | 6 +- .../network/Network2ESRIShapeTest.java | 6 +- .../plans/SelectedPlans2ESRIShapeTest.java | 6 +- .../ObjectAttributesXmlIOTest.java | 11 +- .../ObjectAttributesXmlReaderTest.java | 4 +- .../vehicles/MatsimVehicleWriterTest.java | 6 +- .../matsim/vehicles/VehicleReaderV1Test.java | 6 +- .../matsim/vehicles/VehicleReaderV2Test.java | 6 +- .../matsim/vehicles/VehicleWriteReadTest.java | 4 +- .../matsim/vehicles/VehicleWriterV1Test.java | 6 +- .../matsim/vehicles/VehicleWriterV2Test.java | 6 +- .../vis/snapshotwriters/PositionInfoTest.java | 6 +- .../ExampleWithinDayControllerTest.java | 6 +- .../ExperiencedPlansWriterTest.java | 6 +- .../tools/ActivityReplanningMapTest.java | 6 +- .../tools/LinkReplanningMapTest.java | 6 +- .../trafficmonitoring/TtmobsimListener.java | 28 +- .../WithinDayTravelTimeTest.java | 6 +- ...TravelTimeWithNetworkChangeEventsTest.java | 6 +- .../withinday/utils/EditRoutesTest.java | 6 +- .../utils/ReplacePlanElementsTest.java | 6 +- 492 files changed, 2750 insertions(+), 3434 deletions(-) rename contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/{ForkJoinPoolTestRule.java => ForkJoinPoolExtension.java} (78%) delete mode 100644 matsim/src/test/java/org/matsim/testcases/MatsimJunit5Test.java delete mode 100644 matsim/src/test/java/org/matsim/testcases/MatsimJunit5TestExtension.java diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java index b9f82d4cfa1..3b1ea9c2c9b 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.accessibility.grid; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.network.Network; import org.matsim.contrib.accessibility.SpatialGrid; @@ -11,8 +11,8 @@ public class SpatialGridTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private double cellSize = 10.; diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java index b561798a16d..046d187a965 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java @@ -23,7 +23,7 @@ package org.matsim.contrib.accessibility.logsumComputations; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -33,8 +33,8 @@ */ public class CompareLogsumFormulas2Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java index 8c85aabbe9f..3c25e7c59d0 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java @@ -23,7 +23,7 @@ package org.matsim.contrib.accessibility.logsumComputations; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -33,8 +33,8 @@ */ public class CompareLogsumFormulasTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** * underlying network diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java index 81eb7bc3254..0b358229465 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java @@ -23,7 +23,7 @@ package org.matsim.contrib.accessibility.logsumComputations; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -33,8 +33,8 @@ */ public class ComputeLogsumFormulas3Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** * underlying network diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java index b843e1ae3b5..c4835291ee3 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java @@ -29,7 +29,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.geom.Envelope; import org.matsim.api.core.v01.Coord; @@ -74,7 +74,7 @@ public class AccessibilityIntegrationTest { private static final Logger LOG = LogManager.getLogger(AccessibilityIntegrationTest.class); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Ignore @Test diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java index 405bc54c3e9..aa9360e8013 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -39,11 +39,11 @@ * @author dziemke */ public class NetworkUtilTest { - + private static final Logger log = LogManager.getLogger(NetworkUtilTest.class); - - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public void testNetworkUtil() { @@ -62,10 +62,10 @@ public void testNetworkUtil() { * * The network contains an exactly horizontal, an exactly vertical, an exactly diagonal * and another link with no special slope to also test possible special cases. - * + * * why is that a "special case"? in a normal network all sort of slopes are *normally* present. dz, feb'16 */ - + Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createAndAddNode(network, Id.create("2", Node.class), new Coord((double) 0, (double) 1000)); @@ -76,7 +76,7 @@ public void testNetworkUtil() { Link link2 = NetworkUtils.createAndAddLink(network, Id.create("2", Link.class), node2, node3, 1500, 1, 3600, 1); Link link3 = NetworkUtils.createAndAddLink(network, Id.create("3", Link.class), node3, node4, 1000, 1, 3600, 1); Link link4 = NetworkUtils.createAndAddLink(network, Id.create("4", Link.class), node4, node5, 2800, 1, 3600, 1); - + Coord a = new Coord(100., 0.); Coord b = new Coord(100., 100.); Coord c = new Coord(100., 1000.); @@ -86,89 +86,89 @@ public void testNetworkUtil() { Coord g = new Coord(2300., 2000.); Coord h = new Coord(1700., 1000.); Coord i = new Coord(0., 1200.); - - + + Distances distanceA11 = NetworkUtil.getDistances2NodeViaGivenLink(a, link1, node1); Assert.assertEquals("distanceA11.getDistancePoint2Road()", 100., distanceA11.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceA11.getDistanceRoad2Node()", 0., distanceA11.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionA11 = CoordUtils.orthogonalProjectionOnLineSegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), a); Assert.assertEquals("projectionA11.getX()", 0., projectionA11.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionA11.getY()", 0., projectionA11.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceB11 = NetworkUtil.getDistances2NodeViaGivenLink(b, link1, node1); Assert.assertEquals("distanceB11.getDistancePoint2Road()", 100., distanceB11.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceB11.getDistanceRoad2Node()", 100., distanceB11.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionB11 = CoordUtils.orthogonalProjectionOnLineSegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), b); Assert.assertEquals("projectionB11.getX()", 0., projectionB11.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionB11.getY()", 100., projectionB11.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceB12 = NetworkUtil.getDistances2NodeViaGivenLink(b, link1, node2); Assert.assertEquals("distanceB12.getDistancePoint2Road()", 100., distanceB12.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceB12.getDistanceRoad2Node()", 900., distanceB12.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionB12 = CoordUtils.orthogonalProjectionOnLineSegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), b); Assert.assertEquals("projectionB12.getX()", 0., projectionB12.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionB12.getY()", 100., projectionB12.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceC11 = NetworkUtil.getDistances2NodeViaGivenLink(c, link1, node1); Assert.assertEquals("distanceC11.getDistancePoint2Road()", 100., distanceC11.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceC11.getDistanceRoad2Node()", 1000., distanceC11.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionC11 = CoordUtils.orthogonalProjectionOnLineSegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), c); Assert.assertEquals("projectionC11.getX()", 0., projectionC11.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionC11.getY()", 1000., projectionC11.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceC12 = NetworkUtil.getDistances2NodeViaGivenLink(c, link1, node2); Assert.assertEquals("distanceC12.getDistancePoint2Road()", 100., distanceC12.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceC12.getDistanceRoad2Node()", 0., distanceC12.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionC12 = CoordUtils.orthogonalProjectionOnLineSegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), c); Assert.assertEquals("projectionC12.getX()", 0., projectionC12.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionC12.getY()", 1000., projectionC12.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceC22 = NetworkUtil.getDistances2NodeViaGivenLink(c, link2, node2); Assert.assertEquals("distanceC22.getDistancePoint2Road()", Math.sqrt(2.) / 2. * 100., distanceC22.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceC22.getDistanceRoad2Node()", Math.sqrt(2.) / 2. * 100., distanceC22.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionC22 = CoordUtils.orthogonalProjectionOnLineSegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), c); Assert.assertEquals("projectionC22.getX()", 50., projectionC22.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionC22.getY()", 1050., projectionC22.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceC23 = NetworkUtil.getDistances2NodeViaGivenLink(c, link2, node3); Assert.assertEquals("distanceC23.getDistancePoint2Road()", Math.sqrt(2.) / 2. * 100., distanceC23.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceC23.getDistanceRoad2Node()", Math.sqrt(2) * 1000. - Math.sqrt(2.) / 2. * 100., distanceC23.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionC23 = CoordUtils.orthogonalProjectionOnLineSegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), c); Assert.assertEquals("projectionC23.getX()", 50., projectionC23.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionC23.getY()", 1050., projectionC23.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceD22 = NetworkUtil.getDistances2NodeViaGivenLink(d, link2, node2); Assert.assertEquals("distanceD22.getDistancePoint2Road()", Math.sqrt(2.) / 2. * 100.0, distanceD22.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceD22.getDistanceRoad2Node()", Math.sqrt(2.) / 2. * 100.0 + Math.sqrt(2) * 200., distanceD22.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionD22 = CoordUtils.orthogonalProjectionOnLineSegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), d); Assert.assertEquals("projectionD22.getX()", 250., projectionD22.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionD22.getY()", 1250., projectionD22.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceD23 = NetworkUtil.getDistances2NodeViaGivenLink(d, link2, node3); Assert.assertEquals("distanceD23.getDistancePoint2Road()", Math.sqrt(2.)/2.*100.0, distanceD23.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceD23.getDistanceRoad2Node()", Math.sqrt(2.)/2.*100.0 + Math.sqrt(2) * 700., distanceD23.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionD23 = CoordUtils.orthogonalProjectionOnLineSegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), d); Assert.assertEquals("projectionD23.getX()", 250., projectionD23.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionD23.getY()", 1250., projectionD23.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceE33 = NetworkUtil.getDistances2NodeViaGivenLink(e, link3, node3); Assert.assertEquals("distanceE33.getDistancePoint2Road()", 100.0, distanceE33.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceE33.getDistanceRoad2Node()", 300.0, distanceE33.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); @@ -176,8 +176,8 @@ public void testNetworkUtil() { Coord projectionE33 = CoordUtils.orthogonalProjectionOnLineSegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), e); Assert.assertEquals("projectionE33.getX()", 1300., projectionE33.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionE33.getY()", 2000., projectionE33.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceE34 = NetworkUtil.getDistances2NodeViaGivenLink(e, link3, node4); Assert.assertEquals("distanceE34.getDistancePoint2Road()", 100.0, distanceE34.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceE34.getDistanceRoad2Node()", 700.0, distanceE34.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); @@ -185,23 +185,23 @@ public void testNetworkUtil() { Coord projectionE34 = CoordUtils.orthogonalProjectionOnLineSegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), e); Assert.assertEquals("projectionE34.getX()", 1300., projectionE34.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionE34.getY()", 2000., projectionE34.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceF33 = NetworkUtil.getDistances2NodeViaGivenLink(f, link3, node3); Assert.assertEquals("distanceF33.getDistancePoint2Road()", Math.sqrt(Math.pow(100, 2) + Math.pow(300, 2)), distanceF33.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceF33.getDistanceRoad2Node()", 1000., distanceF33.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionF33 = CoordUtils.orthogonalProjectionOnLineSegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), e); Assert.assertEquals("projectionF33.getX()", 1300., projectionF33.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionF33.getY()", 2000., projectionF33.getY(), MatsimTestUtils.EPSILON); - - + + Distances distanceF34 = NetworkUtil.getDistances2NodeViaGivenLink(f, link3, node4); Assert.assertEquals("distanceF34.getDistancePoint2Road()", Math.sqrt(Math.pow(100, 2) + Math.pow(300, 2)), distanceF34.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); Assert.assertEquals("distanceF34.getDistanceRoad2Node()", 0., distanceF34.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); - + Coord projectionF34 = CoordUtils.orthogonalProjectionOnLineSegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), f); Assert.assertEquals("projectionF34.getX()", 2000., projectionF34.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals("projectionF34.getY()", 2000., projectionF34.getY(), MatsimTestUtils.EPSILON); } -} \ No newline at end of file +} diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java index 29283b26ede..a0a2f6548f7 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -57,7 +57,7 @@ public class TinyAccessibilityTest { private static final Logger LOG = LogManager.getLogger(TinyAccessibilityTest.class); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void runFromEvents() { diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java index bde5a98c612..51081fd61b1 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -65,7 +65,7 @@ public class TinyMultimodalAccessibilityTest { private static final Logger LOG = LogManager.getLogger(TinyMultimodalAccessibilityTest.class); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test @Ignore // non-deterministic presumably because of multi-threading. kai, sep'19 diff --git a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java index b98c144164f..bd0daad8082 100644 --- a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java +++ b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java @@ -4,7 +4,7 @@ import java.io.IOException; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -24,7 +24,7 @@ */ public class RunTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void test1() { diff --git a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java index d537b8c40e4..de2a0923944 100644 --- a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java +++ b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java @@ -3,7 +3,7 @@ import java.io.BufferedReader; import java.io.IOException; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -19,7 +19,7 @@ public class RunTestEquil { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void test1() { diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java index 2c856118e92..848a370fb01 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java @@ -25,7 +25,7 @@ import java.util.HashMap; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -51,8 +51,8 @@ */ public class PersonIntersectAreaFilterTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testFilter() throws Exception { diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java index 01f4b00a334..206f1a7c2a9 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java @@ -23,7 +23,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertTrue; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -50,8 +50,8 @@ public class RouteLinkFilterTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRouteLinkFilter() { diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java index 8d6e64b29f9..ee36629cfc1 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java @@ -26,7 +26,7 @@ import org.junit.Assert; import org.junit.Before; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -55,10 +55,10 @@ public class KNAnalysisEventsHandlerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); - // yy this test is probably not doing anything with respect to some of the newer statistics, such as money. kai, mar'14 + // yy this test is probably not doing anything with respect to some of the newer statistics, such as money. kai, mar'14 public static final String BASE_FILE_NAME = "stats_"; public final Id DEFAULT_PERSON_ID = Id.create(123, Person.class); @@ -124,7 +124,7 @@ public void testNoEvents() { @Test @Ignore public void testAveraging() { - // yy this test is probably not doing anything with respect to some of the newer statistics, such as money. kai, mar'14 + // yy this test is probably not doing anything with respect to some of the newer statistics, such as money. kai, mar'14 KNAnalysisEventsHandler testee = new KNAnalysisEventsHandler(this.scenario); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java index 694b5039e8e..0b8723a704b 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.analysis.vsp.traveltimedistance; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.utils.collections.Tuple; import org.matsim.testcases.MatsimTestUtils; @@ -12,8 +12,8 @@ import static org.junit.Assert.assertTrue; public class GoogleMapRouteValidatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testReadJson() throws IOException { diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java index cdf03802384..e08bf8c5b00 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.analysis.vsp.traveltimedistance; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.utils.collections.Tuple; import org.matsim.testcases.MatsimTestUtils; @@ -11,8 +11,8 @@ import static org.junit.Assert.*; public class HereMapsRouteValidatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testReadJson() throws IOException { diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/travelsummary/events2traveldiaries/RunEventsToTravelDiariesIT.java b/contribs/analysis/src/test/java/org/matsim/contrib/travelsummary/events2traveldiaries/RunEventsToTravelDiariesIT.java index 2fd76b243bd..58ee087e1fe 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/travelsummary/events2traveldiaries/RunEventsToTravelDiariesIT.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/travelsummary/events2traveldiaries/RunEventsToTravelDiariesIT.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.contrib.travelsummary.events2traveldiaries; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -26,8 +26,8 @@ * @author nagel */ public class RunEventsToTravelDiariesIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @SuppressWarnings("static-method") @Test diff --git a/contribs/application/src/test/java/org/matsim/application/CommandRunnerTest.java b/contribs/application/src/test/java/org/matsim/application/CommandRunnerTest.java index 67f566eb5ae..3f3cff914d1 100644 --- a/contribs/application/src/test/java/org/matsim/application/CommandRunnerTest.java +++ b/contribs/application/src/test/java/org/matsim/application/CommandRunnerTest.java @@ -1,7 +1,7 @@ package org.matsim.application; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.application.analysis.TestDependentAnalysis; import org.matsim.application.analysis.TestOtherAnalysis; @@ -12,8 +12,8 @@ public class CommandRunnerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void runner() { diff --git a/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java b/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java index 9be98d76122..4decf8ec93b 100644 --- a/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java +++ b/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java @@ -2,7 +2,7 @@ import org.junit.Assume; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.application.options.SampleOptions; import org.matsim.application.prepare.freight.tripExtraction.ExtractRelevantFreightTrips; @@ -28,8 +28,8 @@ public class MATSimApplicationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void help() { diff --git a/contribs/application/src/test/java/org/matsim/application/analysis/LogFileAnalysisTest.java b/contribs/application/src/test/java/org/matsim/application/analysis/LogFileAnalysisTest.java index 4b1c121aa72..043845b921f 100644 --- a/contribs/application/src/test/java/org/matsim/application/analysis/LogFileAnalysisTest.java +++ b/contribs/application/src/test/java/org/matsim/application/analysis/LogFileAnalysisTest.java @@ -1,7 +1,7 @@ package org.matsim.application.analysis; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.application.ApplicationUtils; import org.matsim.application.MATSimApplication; @@ -16,8 +16,8 @@ public class LogFileAnalysisTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void output() throws IOException { diff --git a/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java b/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java index fff884efa77..8fd5097116a 100644 --- a/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java @@ -2,8 +2,9 @@ import org.apache.commons.csv.CSVFormat; import org.apache.commons.csv.CSVPrinter; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; +import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import java.io.IOException; @@ -14,15 +15,15 @@ public class CsvOptionsTest { - @Rule - public TemporaryFolder f = new TemporaryFolder(); + @TempDir + public Path f; @Test public void output() throws IOException { CsvOptions csv = new CsvOptions(CSVFormat.Predefined.TDF); - Path tmp = f.getRoot().toPath().resolve("test.csv"); + Path tmp = f.resolve("test.csv"); CSVPrinter printer = csv.createPrinter(tmp); @@ -34,4 +35,4 @@ public void output() throws IOException { .hasContent("header\tcolumn\n1\t2"); } -} \ No newline at end of file +} diff --git a/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java b/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java index 8874cfaf671..48c70be2e1b 100644 --- a/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java @@ -2,7 +2,7 @@ import org.junit.Assert; import org.junit.Assume; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.geom.Geometry; import org.locationtech.jts.geom.GeometryFactory; @@ -19,8 +19,8 @@ public class ShpOptionsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void readZip() { @@ -88,4 +88,4 @@ public void testGetGeometry() { Assert.assertTrue(geometry.equals(expectedGeometry)); } -} \ No newline at end of file +} diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java index 7068b755e78..7830166223f 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java @@ -1,7 +1,7 @@ package org.matsim.application.prepare; import org.junit.Assume; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -12,8 +12,8 @@ public class CreateLandUseShpTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void convert() { @@ -34,4 +34,4 @@ public void convert() { .isRegularFile(); } -} \ No newline at end of file +} diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java index 02f1892fc47..0fb5fe666c5 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java @@ -1,7 +1,7 @@ package org.matsim.application.prepare; import org.junit.Assume; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import picocli.CommandLine; @@ -14,8 +14,8 @@ public class ShapeFileTextLookupTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test public void main() { @@ -40,4 +40,4 @@ public void main() { .exists(); } -} \ No newline at end of file +} diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java index 2bb18be2668..6706676043b 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java @@ -1,7 +1,7 @@ package org.matsim.application.prepare.counts; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -17,8 +17,8 @@ public class CreateCountsFromBAStDataTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); String countsOutput = "test-counts.xml.gz"; diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/population/CloseTrajectoriesTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/population/CloseTrajectoriesTest.java index d8fb62a6e30..b3db595cfb0 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/population/CloseTrajectoriesTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/population/CloseTrajectoriesTest.java @@ -1,7 +1,7 @@ package org.matsim.application.prepare.population; import org.assertj.core.api.Condition; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.population.Activity; import org.matsim.api.core.v01.population.Person; @@ -17,8 +17,8 @@ public class CloseTrajectoriesTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void main() { @@ -45,4 +45,4 @@ public void main() { } -} \ No newline at end of file +} diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/population/SplitActivityTypesDurationTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/population/SplitActivityTypesDurationTest.java index c88c1f977eb..0e3e98374a1 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/population/SplitActivityTypesDurationTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/population/SplitActivityTypesDurationTest.java @@ -1,7 +1,7 @@ package org.matsim.application.prepare.population; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.population.Activity; import org.matsim.api.core.v01.population.Person; @@ -17,8 +17,8 @@ public class SplitActivityTypesDurationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void split() { diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/pt/CreateTransitScheduleFromGtfsTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/pt/CreateTransitScheduleFromGtfsTest.java index 9d0b2553537..89ce36a5691 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/pt/CreateTransitScheduleFromGtfsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/pt/CreateTransitScheduleFromGtfsTest.java @@ -1,7 +1,7 @@ package org.matsim.application.prepare.pt; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; @@ -12,8 +12,8 @@ public class CreateTransitScheduleFromGtfsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void run() { diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java index 9d2ec63b41c..b067e5e2a43 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java @@ -10,7 +10,7 @@ import java.util.Set; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -39,8 +39,8 @@ */ public class CarrierReaderFromCSVTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void carrierCreation() throws IOException { diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java index d9ff39a695c..a8b19900587 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java @@ -9,7 +9,7 @@ import java.util.Set; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -37,8 +37,8 @@ * */ public class DemandReaderFromCSVTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testLinkForPerson() throws IOException { diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java index 82ee3fc674a..5d42bcd5ab3 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java @@ -2,7 +2,7 @@ import org.apache.logging.log4j.LogManager; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -15,8 +15,8 @@ */ public class FreightDemandGenerationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testMain() { diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java index c8dbaeff5df..ea14e21ad6b 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java @@ -4,7 +4,7 @@ import java.util.Collection; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.geom.Point; import org.matsim.api.core.v01.Coord; @@ -26,9 +26,9 @@ */ public class FreightDemandGenerationUtilsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public void testPreparePopulation() { String populationLocation = utils.getPackageInputDirectory() + "testPopulation.xml"; diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java index 9ba27596185..5ad5e0de362 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java @@ -21,7 +21,7 @@ import it.unimi.dsi.fastutil.objects.Object2DoubleMap; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.application.options.ShpOptions; import org.matsim.application.options.ShpOptions.Index; @@ -42,8 +42,8 @@ */ public class LanduseBuildingAnalysisTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testReadOfDataDistributionPerZoneAndBuildingAnalysis() throws IOException { diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java index d0f4620ac71..a916ccae961 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java @@ -20,7 +20,7 @@ package org.matsim.smallScaleCommercialTrafficGeneration; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -43,8 +43,8 @@ */ public class RunGenerateSmallScaleCommercialTrafficTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testMainRunAndResults() { diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java index 84c5e0bd188..fab0c22abc4 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java @@ -20,7 +20,7 @@ package org.matsim.smallScaleCommercialTrafficGeneration; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -46,8 +46,8 @@ */ public class SmallScaleCommercialTrafficUtilsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void findZoneOfLinksTest() throws IOException, URISyntaxException { diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java index fe522f7462d..05d4e824089 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java @@ -21,7 +21,7 @@ import it.unimi.dsi.fastutil.objects.Object2DoubleMap; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -49,8 +49,8 @@ */ public class TrafficVolumeGenerationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testTrafficVolumeGenerationCommercialPersonTraffic() throws IOException { diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java index 4392957d1c9..9694505cbf2 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java @@ -21,7 +21,7 @@ import it.unimi.dsi.fastutil.objects.Object2DoubleMap; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -43,8 +43,8 @@ */ public class TripDistributionMatrixTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testTripDistributionCommercialPersonTrafficTraffic() throws IOException { diff --git a/contribs/av/src/test/java/org/matsim/contrib/av/flow/RunAvExampleIT.java b/contribs/av/src/test/java/org/matsim/contrib/av/flow/RunAvExampleIT.java index 442047d0674..ed3476fc8ea 100644 --- a/contribs/av/src/test/java/org/matsim/contrib/av/flow/RunAvExampleIT.java +++ b/contribs/av/src/test/java/org/matsim/contrib/av/flow/RunAvExampleIT.java @@ -26,7 +26,7 @@ import java.net.MalformedURLException; import java.net.URL; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -34,8 +34,8 @@ * @author jbischoff */ public class RunAvExampleIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testAvFlowExample() throws MalformedURLException { diff --git a/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java b/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java index 67837840838..916bd3c9e12 100644 --- a/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java +++ b/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java @@ -27,7 +27,7 @@ import java.net.URL; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -44,8 +44,8 @@ import org.matsim.vis.otfvis.OTFVisConfigGroup; public class TestAvFlowFactor { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testAvFlowFactor() throws MalformedURLException { diff --git a/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java b/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java index 7fe1d1624c6..d9573384ef0 100644 --- a/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java +++ b/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java @@ -30,7 +30,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -48,8 +48,8 @@ * @author jbischoff */ public class RunTaxiPTIntermodalExampleIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testIntermodalExample() throws MalformedURLException { diff --git a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java index 1af7f1aec93..8ee7bcdc13d 100644 --- a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java +++ b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.bicycle; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -34,7 +34,8 @@ import static org.junit.Assert.assertTrue; public class BicycleLinkSpeedCalculatorTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); private static final double MAX_BICYCLE_SPEED = 15; private final Config config = ConfigUtils.createConfig(); diff --git a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java index a5a798ee9de..e3a50e711df 100644 --- a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java +++ b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java @@ -21,8 +21,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.jupiter.api.Assertions; -import org.junit.jupiter.api.Test; +import org.junit.Test; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -51,7 +51,6 @@ import org.matsim.core.router.TripStructureUtils; import org.matsim.core.scenario.ScenarioUtils; import org.matsim.core.utils.collections.CollectionUtils; -import org.matsim.testcases.MatsimJunit5Test; import org.matsim.testcases.MatsimTestUtils; import org.matsim.utils.eventsfilecomparison.EventsFileComparator; import org.matsim.vehicles.Vehicle; @@ -64,19 +63,24 @@ import java.util.List; import java.util.Map; +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; import static org.matsim.utils.eventsfilecomparison.EventsFileComparator.Result.FILES_ARE_EQUAL; /** * @author dziemke */ -public class BicycleTest extends MatsimJunit5Test { +public class BicycleTest { private static final Logger LOG = LogManager.getLogger(BicycleTest.class); private static final String bicycleMode = "bicycle"; + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); + @Test public void testNormal() { - Config config = ConfigUtils.createConfig(getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -84,32 +88,33 @@ public void testNormal() { config.network().setInputFile("network_normal.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(getOutputDirectory()); + config.controller().setOutputDirectory(utils.getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; - Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), "Different event files."); + final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; + assertEquals("Different event files.", FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); - Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of persons " + personId + " are different"); + Assert.assertEquals("Scores of persons " + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); } - Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); + assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } @Test public void testCobblestone() { - Config config = ConfigUtils.createConfig(getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -119,7 +124,7 @@ public void testCobblestone() { config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(getOutputDirectory()); + config.controller().setOutputDirectory(utils.getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); @@ -127,21 +132,22 @@ public void testCobblestone() { { Scenario scenarioReference = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); Scenario scenarioCurrent = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); - new PopulationReader( scenarioReference ).readFile( getInputDirectory() + "output_plans.xml.gz" ); - new PopulationReader( scenarioCurrent ).readFile( getOutputDirectory() + "output_plans.xml.gz" ); - Assertions.assertTrue(PopulationUtils.equalPopulation( scenarioReference.getPopulation(), scenarioCurrent.getPopulation() ), "Populations are different"); + new PopulationReader( scenarioReference ).readFile( utils.getInputDirectory() + "output_plans.xml.gz" ); + new PopulationReader( scenarioCurrent ).readFile( utils.getOutputDirectory() + "output_plans.xml.gz" ); + assertTrue( "Populations are different", PopulationUtils.equalPopulation( scenarioReference.getPopulation(), scenarioCurrent.getPopulation() ) ); } { LOG.info( "Checking MATSim events file ..." ); - final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; - Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew ), "Different event files."); + final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; + assertEquals( "Different event files.", FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew )); } } @Test public void testPedestrian() { - Config config = ConfigUtils.createConfig(getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -149,27 +155,28 @@ public void testPedestrian() { config.network().setInputFile("network_pedestrian.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(getOutputDirectory()); + config.controller().setOutputDirectory(utils.getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; - Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), "Different event files."); + final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; + assertEquals("Different event files.", FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); - Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); + new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); + assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } @Test public void testLane() { - Config config = ConfigUtils.createConfig(getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -177,27 +184,28 @@ public void testLane() { config.network().setInputFile("network_lane.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(getOutputDirectory()); + config.controller().setOutputDirectory(utils.getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; - Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), "Different event files."); + final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; + assertEquals("Different event files.", FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); - Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); + new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); + assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } @Test public void testGradient() { - Config config = ConfigUtils.createConfig(getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -205,27 +213,28 @@ public void testGradient() { config.network().setInputFile("network_gradient.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(getOutputDirectory()); + config.controller().setOutputDirectory(utils.getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; - Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), "Different event files."); + final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; + assertEquals("Different event files.", FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); - Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); + new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); + assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } @Test public void testGradientLane() { - Config config = ConfigUtils.createConfig(getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -234,27 +243,28 @@ public void testGradientLane() { config.network().setInputFile("network_gradient_lane.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(getOutputDirectory()); + config.controller().setOutputDirectory(utils.getOutputDirectory()); config.controller().setLastIteration(0); config.controller().setCreateGraphs(false); new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; - Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew), "Different event files."); + final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; + assertEquals("Different event files.", FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); - Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); + new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); + assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } @Test public void testNormal10It() { - Config config = ConfigUtils.createConfig(getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -262,7 +272,7 @@ public void testNormal10It() { config.network().setInputFile("network_normal.xml"); config.plans().setInputFile("population_1200.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(getOutputDirectory()); + config.controller().setOutputDirectory(utils.getOutputDirectory()); // 10 iterations config.controller().setLastIteration(10); config.controller().setWriteEventsInterval(10); @@ -272,15 +282,16 @@ public void testNormal10It() { new RunBicycleExample().run(config ); LOG.info("Checking MATSim events file ..."); - final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; - final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; - Assertions.assertEquals(FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew), "Different event files."); + final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; + final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; + assertEquals("Different event files.", FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); - new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); - Assertions.assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); + new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); + assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } @Test public void testLinkBasedScoring() { @@ -291,7 +302,7 @@ public void testNormal10It() { // new RunBicycleExample().run( config ); // } Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); { Config config2 = createConfig( 0 ); BicycleConfigGroup bicycleConfigGroup2 = (BicycleConfigGroup) config2.getModules().get( "bicycle" ); @@ -299,23 +310,22 @@ public void testNormal10It() { new RunBicycleExample().run( config2 ); } Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); // LOG.info("Checking MATSim events file ..."); -// final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; -// final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; -// Assert.assertEquals("Different event files.", FILES_ARE_EQUAL, +// final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; +// final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; +// assertEquals("Different event files.", FILES_ARE_EQUAL, // new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); - Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of persons " + personId + " are different"); + Assert.assertEquals("Scores of persons " + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); } -// Assert.assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); +// assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } - @Test - public void testLinkVsLegMotorizedScoring() { + @Test public void testLinkVsLegMotorizedScoring() { // --- withOUT additional car traffic: // { // Config config2 = createConfig( 0 ); @@ -325,7 +335,7 @@ public void testLinkVsLegMotorizedScoring() { // new RunBicycleExample().run( config2 ); // } Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); // --- // --- WITH additional car traffic: { @@ -384,22 +394,22 @@ public void testLinkVsLegMotorizedScoring() { controler.run(); } Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); + new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); // --- // --- // LOG.info("Checking MATSim events file ..."); -// final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; -// final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; -// Assert.assertEquals("Different event files.", FILES_ARE_EQUAL, +// final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; +// final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; +// assertEquals("Different event files.", FILES_ARE_EQUAL, // new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); - Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of person=" + personId + " are different"); + Assert.assertEquals("Scores of person=" + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); } -// Assert.assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); +// assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } // @Test public void testMotorizedInteraction() { //// Config config = ConfigUtils.createConfig("./src/main/resources/bicycle_example/"); @@ -413,26 +423,26 @@ public void testLinkVsLegMotorizedScoring() { // new RunBicycleExample().run(config ); // // LOG.info("Checking MATSim events file ..."); -// final String eventsFilenameReference = getInputDirectory() + "output_events.xml.gz"; -// final String eventsFilenameNew = getOutputDirectory() + "output_events.xml.gz"; -// Assert.assertEquals("Different event files.", FILES_ARE_EQUAL, +// final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; +// final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; +// assertEquals("Different event files.", FILES_ARE_EQUAL, // new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); // // Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); // Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); -// new PopulationReader(scenarioReference).readFile(getInputDirectory() + "output_plans.xml.gz"); -// new PopulationReader(scenarioCurrent).readFile(getOutputDirectory() + "output_plans.xml.gz"); +// new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); +// new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); // for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { // double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); // double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); -// Assert.Assert.assertEquals("Scores of persons " + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); +// Assert.assertEquals("Scores of persons " + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); // } -// Assert.assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); +// assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); // } @Test public void testInfrastructureSpeedFactor() { - Config config = ConfigUtils.createConfig(getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); config.controller().setWriteEventsInterval(0); @@ -477,7 +487,7 @@ public void testInfrastructureSpeedFactor() { config.plans().setInputFile("population_4.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(getOutputDirectory()); + config.controller().setOutputDirectory(utils.getOutputDirectory()); config.controller().setLastIteration(0); config.global().setNumberOfThreads(1); @@ -514,20 +524,20 @@ public void install() { controler.run(); - Assertions.assertEquals(3, linkHandler.getLinkId2demand().get(Id.createLinkId("2")), MatsimTestUtils.EPSILON, "All bicycle users should use the longest but fastest route where the bicycle infrastructur speed factor is set to 1.0"); - Assertions.assertEquals(1, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON, "Only the car user should use the shortest route"); + Assert.assertEquals("All bicycle users should use the longest but fastest route where the bicycle infrastructur speed factor is set to 1.0", 3, linkHandler.getLinkId2demand().get(Id.createLinkId("2")), MatsimTestUtils.EPSILON); + Assert.assertEquals("Only the car user should use the shortest route", 1, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON); - Assertions.assertEquals(1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(0), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); - Assertions.assertEquals(1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(1), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); - Assertions.assertEquals(1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(2), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); + Assert.assertEquals("Wrong travel time (bicycle user)", 1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(0), MatsimTestUtils.EPSILON); + Assert.assertEquals("Wrong travel time (bicycle user)", 1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(1), MatsimTestUtils.EPSILON); + Assert.assertEquals("Wrong travel time (bicycle user)", 1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(2), MatsimTestUtils.EPSILON); - Assertions.assertEquals(Math.ceil( 10000 / (13.88) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON, "Wrong travel time (car user)"); + Assert.assertEquals("Wrong travel time (car user)", Math.ceil( 10000 / (13.88) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON); } @Test public void testInfrastructureSpeedFactorDistanceMoreRelevantThanTravelTime() { - Config config = ConfigUtils.createConfig(getClassInputDirectory() ); + Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); BicycleConfigGroup bicycleConfigGroup = ConfigUtils.addOrGetModule( config, BicycleConfigGroup.class ); config.controller().setWriteEventsInterval(0); @@ -571,7 +581,7 @@ public void testInfrastructureSpeedFactorDistanceMoreRelevantThanTravelTime() { config.network().setInputFile("network_infrastructure-speed-factor.xml"); config.plans().setInputFile("population_4.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); - config.controller().setOutputDirectory(getOutputDirectory()); + config.controller().setOutputDirectory(utils.getOutputDirectory()); config.controller().setLastIteration(0); config.global().setNumberOfThreads(1); @@ -601,16 +611,16 @@ public void testInfrastructureSpeedFactorDistanceMoreRelevantThanTravelTime() { controler.run(); - Assertions.assertEquals(4, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON, "All bicycle users should use the shortest route even though the bicycle infrastructur speed factor is set to 0.1"); - Assertions.assertEquals(Math.ceil(10000 / 13.88 ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON, "Wrong travel time (car user)"); - Assertions.assertEquals(Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(1), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); - Assertions.assertEquals(Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(2), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); - Assertions.assertEquals(Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(3), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); + Assert.assertEquals("All bicycle users should use the shortest route even though the bicycle infrastructur speed factor is set to 0.1", 4, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON); + Assert.assertEquals("Wrong travel time (car user)", Math.ceil(10000 / 13.88 ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON); + Assert.assertEquals("Wrong travel time (bicycle user)", Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(1), MatsimTestUtils.EPSILON); + Assert.assertEquals("Wrong travel time (bicycle user)", Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(2), MatsimTestUtils.EPSILON); + Assert.assertEquals("Wrong travel time (bicycle user)", Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(3), MatsimTestUtils.EPSILON); } private Config createConfig( int lastIteration ){ // Config config = ConfigUtils.createConfig("./src/main/resources/bicycle_example/"); - Config config = ConfigUtils.createConfig( getClassInputDirectory() ); + Config config = ConfigUtils.createConfig( utils.getClassInputDirectory() ); config.addModule( new BicycleConfigGroup() ); RunBicycleExample.fillConfigWithBicycleStandardValues( config ); @@ -618,7 +628,7 @@ private Config createConfig( int lastIteration ){ config.network().setInputFile( "network_normal.xml" ); config.plans().setInputFile( "population_1200.xml" ); config.controller().setOverwriteFileSetting( OverwriteFileSetting.deleteDirectoryIfExists ); - config.controller().setOutputDirectory( getOutputDirectory() ); + config.controller().setOutputDirectory( utils.getOutputDirectory() ); config.controller().setLastIteration( lastIteration ); config.controller().setLastIteration( lastIteration ); config.controller().setWriteEventsInterval( 10 ); diff --git a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java index 6b72ab1b664..815fc250dc3 100644 --- a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java +++ b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java @@ -24,7 +24,7 @@ import cadyts.utilities.io.tabularFileParser.TabularFileParser; import cadyts.utilities.misc.DynamicData; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -78,8 +78,8 @@ */ public class CadytsCarIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public final void testInitialization() { diff --git a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java index cf1c31b9126..f8512146bf5 100644 --- a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java +++ b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java @@ -22,7 +22,7 @@ import java.io.IOException; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -30,8 +30,8 @@ public class CalibrationStatReaderTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testReader() throws IOException { diff --git a/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java b/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java index 9431005a492..6b95a948fbe 100644 --- a/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java +++ b/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.analysis.LegHistogram; import org.matsim.api.core.v01.Scenario; @@ -55,7 +55,7 @@ public class RunCarsharingIT { private final static Logger log = LogManager.getLogger(RunCarsharingIT.class); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public final void test() { diff --git a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java index 935e4c61fb8..4e6afb73afd 100644 --- a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java +++ b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java @@ -32,7 +32,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -90,8 +90,8 @@ */ public class BetaTravelTest66IT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /* This TestCase uses a custom Controler, named TestControler, to load diff --git a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java index 9db009cbcf8..de0ecae4685 100644 --- a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java +++ b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java @@ -32,7 +32,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -91,8 +91,8 @@ */ public class BetaTravelTest6IT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /* This TestCase uses a custom Controler, named TestControler, to load diff --git a/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java b/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java index 58477477f23..a59cc8f2027 100644 --- a/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java +++ b/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java @@ -23,7 +23,7 @@ package org.matsim.contrib.decongestion; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.analysis.ScoreStatsControlerListener.ScoreItem; import org.matsim.api.core.v01.Id; @@ -54,8 +54,8 @@ */ public class DecongestionPricingTestIT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); /** * Kp = 0.0123 diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java index b212182d3bc..32697f90a8d 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java @@ -11,7 +11,7 @@ import java.util.Arrays; import java.util.HashSet; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contribs.discrete_mode_choice.modules.config.DiscreteModeChoiceConfigGroup; import org.matsim.core.config.Config; @@ -21,7 +21,7 @@ import org.matsim.testcases.MatsimTestUtils; public class ConfigTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java index bc0f9e22ba3..8790d1a5341 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java @@ -19,13 +19,15 @@ package org.matsim.contrib.drt.extension; +import java.io.File; import java.io.IOException; import java.nio.file.Path; import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; +import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.matsim.contrib.drt.extension.DrtWithExtensionsConfigGroup; import org.matsim.contrib.drt.extension.companions.DrtCompanionParams; @@ -45,10 +47,8 @@ public class DrtWithExtensionsConfigGroupTest { private final static double WEIGHT_2 = 1337.; private final static double WEIGHT_3 = 911.; - - @Rule - public TemporaryFolder tempFolder = new TemporaryFolder(); - + @TempDir + public File tempFolder; private static Config createConfig(List values) { Config config = ConfigUtils.createConfig(); @@ -70,9 +70,9 @@ private static Config createConfig(List values) { return config; } - private static Path writeConfig(final TemporaryFolder tempFolder, List weights) throws IOException { + private static Path writeConfig(final File tempFolder, List weights) throws IOException { Config config = createConfig(weights); - Path configFile = tempFolder.newFile("config.xml").toPath(); + Path configFile = new File(tempFolder, "config.xml").toPath(); ConfigUtils.writeConfig(config, configFile.toString()); return configFile; } diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/companions/RunDrtWithCompanionExampleIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/companions/RunDrtWithCompanionExampleIT.java index 9ac24985fe4..749cc23e8ea 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/companions/RunDrtWithCompanionExampleIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/companions/RunDrtWithCompanionExampleIT.java @@ -28,7 +28,7 @@ import java.util.stream.Collectors; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.drt.extension.DrtWithExtensionsConfigGroup; @@ -48,8 +48,8 @@ */ public class RunDrtWithCompanionExampleIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRunDrtWithCompanions() { diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/dashboards/DashboardTests.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/dashboards/DashboardTests.java index c26a623fec8..f078e00e07b 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/dashboards/DashboardTests.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/dashboards/DashboardTests.java @@ -1,7 +1,7 @@ package org.matsim.contrib.drt.extension.dashboards; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.application.MATSimApplication; import org.matsim.contrib.drt.extension.DrtTestScenario; @@ -17,8 +17,8 @@ public class DashboardTests { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private void run() { diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java index de1c98e62d1..1a149837266 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.drt.extension.estimator; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.application.MATSimApplication; import org.matsim.contrib.drt.extension.DrtTestScenario; @@ -27,8 +27,8 @@ public class MultiModaFixedDrtLegEstimatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private Controler controler; diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java index 8d61ef68123..c35ac36af49 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.drt.extension.estimator; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.application.MATSimApplication; import org.matsim.contrib.drt.extension.DrtTestScenario; @@ -26,8 +26,8 @@ public class MultiModalDrtLegEstimatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private Controler controler; diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java index 001bae2a1e7..7f7f76fe71c 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java @@ -9,7 +9,7 @@ import java.util.List; import java.util.Set; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; @@ -52,8 +52,8 @@ import org.matsim.vis.otfvis.OTFVisConfigGroup; public class DrtInsertionExtensionIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private Controler createController() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_drt_config.xml"); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java index d1e2e231a43..3afc583589b 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.drt.extension.operations.operationFacilities; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -13,8 +13,8 @@ public class OperationFacilitiesIOTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test public void test() { diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java index 37a86a85098..d7ff41c3846 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java @@ -5,7 +5,7 @@ import java.io.File; import java.util.Optional; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.drt.extension.operations.operationFacilities.OperationFacility; @@ -22,8 +22,8 @@ */ public class ShiftsIOTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final String TESTSHIFTSINPUT = "testShifts.xml"; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java index ff70b6e4808..38880db6bcb 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java @@ -3,7 +3,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.drt.run.DrtConfigGroup; import org.matsim.contrib.drt.run.MultiModeDrtConfigGroup; @@ -16,7 +16,7 @@ public class ConfigBehaviorTest{ private static final Logger log = LogManager.getLogger(ConfigBehaviorTest.class ); - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DefaultUnplannedRequestInserterTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DefaultUnplannedRequestInserterTest.java index 5730c59ea46..2f33a567b87 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DefaultUnplannedRequestInserterTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DefaultUnplannedRequestInserterTest.java @@ -32,8 +32,9 @@ import java.util.*; import org.apache.commons.lang3.mutable.MutableInt; -import org.junit.Rule; +import org.junit.jupiter.api.extension.ExtendWith; import org.junit.Test; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Identifiable; import org.matsim.api.core.v01.network.Link; @@ -69,8 +70,8 @@ public class DefaultUnplannedRequestInserterTest { private final EventsManager eventsManager = mock(EventsManager.class); - @Rule - public final ForkJoinPoolTestRule rule = new ForkJoinPoolTestRule(); + @RegisterExtension + public final ForkJoinPoolExtension forkJoinPoolExtension = new ForkJoinPoolExtension(); @Test public void nothingToSchedule() { @@ -285,7 +286,7 @@ private DefaultUnplannedRequestInserter newInserter(Fleet fleet, double now, DrtInsertionSearch insertionSearch, RequestInsertionScheduler insertionScheduler) { return new DefaultUnplannedRequestInserter(mode, fleet, () -> now, eventsManager, insertionScheduler, vehicleEntryFactory, insertionRetryQueue, insertionSearch, DrtOfferAcceptor.DEFAULT_ACCEPTOR, - rule.forkJoinPool, StaticPassengerStopDurationProvider.of(10.0, 0.0)); + forkJoinPoolExtension.forkJoinPool, StaticPassengerStopDurationProvider.of(10.0, 0.0)); } private Link link(String id) { diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java index c708e623de0..26c4c3f6f7d 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java @@ -4,7 +4,7 @@ import java.util.*; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -52,7 +52,7 @@ */ public class DrtPoolingParameterTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/ForkJoinPoolTestRule.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/ForkJoinPoolExtension.java similarity index 78% rename from contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/ForkJoinPoolTestRule.java rename to contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/ForkJoinPoolExtension.java index 548decd28b6..e6f204bdf58 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/ForkJoinPoolTestRule.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/ForkJoinPoolExtension.java @@ -22,27 +22,17 @@ import java.util.concurrent.ForkJoinPool; -import org.junit.rules.TestRule; -import org.junit.runner.Description; -import org.junit.runners.model.Statement; +import org.junit.jupiter.api.extension.AfterEachCallback; +import org.junit.jupiter.api.extension.ExtensionContext; /** * @author Michal Maciejewski (michalm) */ -public class ForkJoinPoolTestRule implements TestRule { +public class ForkJoinPoolExtension implements AfterEachCallback { public final ForkJoinPool forkJoinPool = new ForkJoinPool(1); @Override - public Statement apply(Statement base, Description description) { - return new Statement() { - @Override - public void evaluate() throws Throwable { - try { - base.evaluate(); - } finally { - forkJoinPool.shutdown(); - } - } - }; + public void afterEach(ExtensionContext extensionContext) throws Exception { + forkJoinPool.shutdown(); } } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/ExtensiveInsertionProviderTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/ExtensiveInsertionProviderTest.java index 3e94e70dfd5..4d05fbc2397 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/ExtensiveInsertionProviderTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/ExtensiveInsertionProviderTest.java @@ -29,8 +29,8 @@ import java.util.List; -import org.junit.Rule; import org.junit.Test; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.drt.optimizer.VehicleEntry; import org.matsim.contrib.drt.optimizer.Waypoint; import org.matsim.contrib.drt.optimizer.insertion.*; @@ -43,8 +43,8 @@ * @author Michal Maciejewski (michalm) */ public class ExtensiveInsertionProviderTest { - @Rule - public final ForkJoinPoolTestRule rule = new ForkJoinPoolTestRule(); + @RegisterExtension + public final ForkJoinPoolExtension rule = new ForkJoinPoolExtension(); @Test public void getInsertions_noInsertionsGenerated() { diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SelectiveInsertionProviderTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SelectiveInsertionProviderTest.java index a88df5ac539..d6ed2a51d7b 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SelectiveInsertionProviderTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SelectiveInsertionProviderTest.java @@ -31,11 +31,11 @@ import java.util.Optional; import java.util.Set; -import org.junit.Rule; -import org.junit.Test; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.drt.optimizer.VehicleEntry; import org.matsim.contrib.drt.optimizer.insertion.BestInsertionFinder; -import org.matsim.contrib.drt.optimizer.insertion.ForkJoinPoolTestRule; +import org.matsim.contrib.drt.optimizer.insertion.ForkJoinPoolExtension; import org.matsim.contrib.drt.optimizer.insertion.InsertionGenerator; import org.matsim.contrib.drt.optimizer.insertion.InsertionGenerator.Insertion; import org.matsim.contrib.drt.optimizer.insertion.InsertionWithDetourData; @@ -47,8 +47,8 @@ * @author Michal Maciejewski (michalm) */ public class SelectiveInsertionProviderTest { - @Rule - public final ForkJoinPoolTestRule rule = new ForkJoinPoolTestRule(); + @RegisterExtension + public final ForkJoinPoolExtension rule = new ForkJoinPoolExtension(); private final BestInsertionFinder initialInsertionFinder = mock(BestInsertionFinder.class); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java index c3dc7f546b0..ba9f10a787e 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java @@ -3,7 +3,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertTrue; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Leg; @@ -21,9 +21,9 @@ * @author Sebastian Hörl (sebhoerl) / IRT SystemX */ public class AbandonAndCancelTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public void noAbandonTest() { /* @@ -64,7 +64,7 @@ public void abandonTest() { * One person requests to depart at 2000 and also is there at 2000. Another * person asks also to depart at 2000, but only arrives at 4000, i.e. the person * has 1000s delay. - * + * * We configure that the vehicle should leave without the passenger if it waits * longer than 500s. The late request will be rejected! */ @@ -103,7 +103,7 @@ public void abandonThenImmediateTest() { * One person requests to depart at 2000 and also is there at 2000. Another * person asks also to depart at 2000, but only arrives at 4000, i.e. the person * has 1000s delay. - * + * * We configure that the vehicle should leave without the passenger if it waits * longer than 500s. The person will, however, send a new request when arriving * at the departure point and get an immediate vehicle. @@ -146,7 +146,7 @@ public void cancelEarlyTest() { * One person requests to depart at 2000 and also is there at 2000. Another * person asks also to depart at 2000, but only arrives at 4000, i.e. the person * has 1000s delay. - * + * * In this test we manually cancel the second request at 500.0 (so before * departure of any agent). */ @@ -174,9 +174,9 @@ public void notifyMobsimBeforeSimStep(MobsimBeforeSimStepEvent e) { if (e.getSimulationTime() == 500.0) { PlanAgent planAgent = (PlanAgent) qsim.getAgents() .get(Id.createPersonId("personLate")); - + Leg leg = TripStructureUtils.getLegs(planAgent.getCurrentPlan()).get(1); - + prebookingManager.cancel(leg); } } @@ -202,14 +202,14 @@ public void notifyMobsimBeforeSimStep(MobsimBeforeSimStepEvent e) { assertTrue(requestInfo.rejected); } } - + @Test public void cancelLateTest() { /* * One person requests to depart at 2000 and also is there at 2000. Another * person asks also to depart at 2000, but only arrives at 4000, i.e. the person * has 1000s delay. - * + * * In this test we manually cancel the second request at 3000.0 (so after * departure of the first agent). */ @@ -237,9 +237,9 @@ public void notifyMobsimBeforeSimStep(MobsimBeforeSimStepEvent e) { if (e.getSimulationTime() == 3000.0) { PlanAgent planAgent = (PlanAgent) qsim.getAgents() .get(Id.createPersonId("personLate")); - + Leg leg = TripStructureUtils.getLegs(planAgent.getCurrentPlan()).get(1); - + prebookingManager.cancel(leg); } } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java index 11d3951b632..1c017bc5f1a 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java @@ -6,7 +6,7 @@ import java.util.Collections; import java.util.Set; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; @@ -37,8 +37,8 @@ * @author Sebastian Hörl (sebhoerl) / IRT SystemX */ public class PersonStuckPrebookingTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void baselineTest() { diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java index 35d9a0ef62b..2845a5d7af4 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java @@ -2,7 +2,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.drt.prebooking.PrebookingTestEnvironment.RequestInfo; import org.matsim.contrib.drt.prebooking.logic.AttributeBasedPrebookingLogic; @@ -14,9 +14,9 @@ * @author Sebastian Hörl (sebhoerl) / IRT SystemX */ public class PrebookingTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public void withoutPrebookedRequests() { /*- @@ -49,7 +49,7 @@ public void withoutPrebookedRequests() { assertEquals(2086.0, taskInfo.get(2).startTime, 1e-3); assertEquals(2146.0, taskInfo.get(2).endTime, 1e-3); } - + static PrebookingParams installPrebooking(Controler controller) { return installPrebooking(controller, true); } @@ -57,11 +57,11 @@ static PrebookingParams installPrebooking(Controler controller) { static PrebookingParams installPrebooking(Controler controller, boolean installLogic) { DrtConfigGroup drtConfig = DrtConfigGroup.getSingleModeDrtConfig(controller.getConfig()); drtConfig.addParameterSet(new PrebookingParams()); - + if (installLogic) { AttributeBasedPrebookingLogic.install(controller, drtConfig); } - + return drtConfig.getPrebookingParams().get(); } @@ -212,7 +212,7 @@ public void twoSequentialRequests_inverseSubmission() { @Test public void sameTrip_differentDepartureTime() { /*- - * Two requests with the same origin and destination, but distinct departure time. + * Two requests with the same origin and destination, but distinct departure time. * - First, early one is submitted, then late one. * - Vehicle picks up and drops off early one, then late one. * - In total four stops (P,D,P,D) @@ -250,7 +250,7 @@ public void sameTrip_differentDepartureTime() { @Test public void sameTrip_sameDepartureTime() { /*- - * Two requests with the same origin and destination, and same departure time. + * Two requests with the same origin and destination, and same departure time. * - First, A is submitted, then B. * - Vehicle picks up and A and B, then drops off A and B. * - In total two stops (P,D) @@ -382,26 +382,26 @@ public void sameTrip_inverseSubmission_noPrepending() { * Two requests with the same origin and destination, different departure times. * - First, A is submitted with departure time 2020 * - Then, B is submitted with departure time 2000 - * - * - This is inverse of sameTrip_extendPickupDuration above, the request with the earlier departure + * + * - This is inverse of sameTrip_extendPickupDuration above, the request with the earlier departure * time is submitted second. * - We would expect the requests to be merged, but this is not so trivial with the current code base: - * It would be necessary to shift the stop task to the past and extend it. Theoretically, this is + * It would be necessary to shift the stop task to the past and extend it. Theoretically, this is * possible but it would be nice to embed this in a more robust way in the code base. * - Plus, it may change the current DRT behavior because we have these situations also in non-prebooked * simulations: We may submit an immediate request and find an insertion for a stop task that starts - * in 5 seconds. This case is treated in standard DRT as any other request (extending the task but + * in 5 seconds. This case is treated in standard DRT as any other request (extending the task but * keeping the start time fixed). - * - We follow this default behaviour here: Instead of *prepending* the task with the new request, we + * - We follow this default behaviour here: Instead of *prepending* the task with the new request, we * *append* it as usual. If there is at least one pickup in the stop task with the standard stop * durations, there is no additional cost of adding the request, but the person experiences a wait * delay that could be minimized if we were able to prepend the task. * - (Then again, do we actually want to do this, it would reserve the vehicle a few seconds more than * necessary for a stop that is potentially prebooked in a long time). - * + * * - Expected behavior in current implementation: Merge new request with the later departing existing * one, which generates wait time for the customer. - * + * * - In total two stops (P, D) */ @@ -438,14 +438,14 @@ public void sameTrip_inverseSubmission_noPrepending() { public void sameTrip_inverseSubmission_splitPickup() { /*- * Two requests with the same origin and destination, different departure times. - * - First, A is submitted with departure time 2020 + * - First, A is submitted with departure time 2020 * - Then, B is submitted with departure time 1770 - * - B's departure is 250s before A, so appending it to A would lead to more than 300s + * - B's departure is 250s before A, so appending it to A would lead to more than 300s * of wait time, which is not a valid insertion * - Hence, the insertion *after* the pickup of A is not valid * - But the insertion *before* A is possible (it is usually evaluated but dominated by the insertion after) * - TODO: May think this through and eliminate these insertion upfront - * + * * - Expectation: Standard scheduling a prebooked request before another one (as if they had not the * same origin link). * - In total three stops (P,P,D) diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java index 365c5e04dff..2bf9646c17a 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java @@ -23,7 +23,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -66,8 +66,8 @@ * @author jbischoff */ public class DrtRoutingModuleTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testCottbusClosestAccessEgressStopFinder() { diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java index b95f6d8de61..7878dad8604 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java @@ -31,7 +31,7 @@ import java.util.Map; import java.util.stream.Collectors; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.drt.optimizer.DrtRequestInsertionRetryParams; @@ -72,8 +72,8 @@ */ public class RunDrtExampleIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRunDrtExampleWithNoRejections_ExtensiveSearch() { @@ -319,30 +319,30 @@ public void install() { verifyDrtCustomerStatsCloseToExpectedStats(utils.getOutputDirectory(), expectedStats); } - + @Test public void testRunDrtWithPrebooking() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_drt_config.xml"); - + Config config = ConfigUtils.loadConfig(configUrl, new MultiModeDrtConfigGroup(), new DvrpConfigGroup(), new OTFVisConfigGroup()); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); config.controller().setOutputDirectory(utils.getOutputDirectory()); - + DrtConfigGroup drtConfig = DrtConfigGroup.getSingleModeDrtConfig(config); drtConfig.addParameterSet(new PrebookingParams()); - + Controler controller = DrtControlerCreator.createControler(config, false); ProbabilityBasedPrebookingLogic.install(controller, drtConfig, 0.5, 4.0 * 3600.0); - + PrebookingTracker tracker = new PrebookingTracker(); tracker.install(controller); - + controller.run(); - + assertEquals(157, tracker.immediateScheduled); assertEquals(205, tracker.prebookedScheduled); assertEquals(26, tracker.immediateRejected); @@ -467,13 +467,13 @@ public Stats build() { } } } - + static private class PrebookingTracker implements PassengerRequestRejectedEventHandler, PassengerRequestScheduledEventHandler { int immediateScheduled = 0; int prebookedScheduled = 0; int immediateRejected = 0; int prebookedRejected = 0; - + @Override public void handleEvent(PassengerRequestScheduledEvent event) { if (event.getRequestId().toString().contains("prebooked")) { @@ -491,10 +491,10 @@ public void handleEvent(PassengerRequestRejectedEvent event) { immediateRejected++; } } - + void install(Controler controller) { PrebookingTracker thisTracker = this; - + controller.addOverridingModule(new AbstractModule() { @Override public void install() { diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java index b6c7e2ed828..55e0e574dac 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java @@ -33,7 +33,7 @@ import org.apache.logging.log4j.Logger; import org.assertj.core.data.Offset; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -68,8 +68,8 @@ public class RunOneTaxiWithPrebookingExampleIT { private static final Logger log = LogManager.getLogger(RunOneTaxiWithPrebookingExampleIT.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Ignore @Test diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java index 5f61653ebc3..6af6c9b7abe 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.emissions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -22,8 +22,8 @@ */ public class EmissionModuleTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils testUtils = new MatsimTestUtils(); @Test(expected = RuntimeException.class) public void testWithIncorrectNetwork() { @@ -63,4 +63,4 @@ public void install() { fail("Was expecting exception"); } -} \ No newline at end of file +} diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java index c48f5254b39..3e9d93e186a 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java @@ -1,7 +1,7 @@ package org.matsim.contrib.emissions; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -55,8 +55,8 @@ public class TestPositionEmissionModule { private static final String configFile = IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "emissions-sampleScenario/testv2_Vehv2" ), "config_detailed.xml" ).toString(); // (I changed the above from veh v1 to veh v2 since veh v1 is deprecated, especially for emissions. kai, apr'21) - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils testUtils = new MatsimTestUtils(); @Test @Ignore diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java index 3f764cd6b88..7cf055ff33e 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java @@ -3,7 +3,7 @@ import org.apache.commons.csv.CSVFormat; import org.apache.commons.csv.CSVPrinter; import org.apache.commons.csv.CSVRecord; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; @@ -37,8 +37,8 @@ public class EmissionGridAnalyzerTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils testUtils = new MatsimTestUtils(); private Geometry createRect(double maxX, double maxY) { return new GeometryFactory().createPolygon(new Coordinate[]{ diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java index ceb4b2a093d..25c0a8b4122 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.emissions.analysis; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -20,8 +20,8 @@ public class FastEmissionGridAnalyzerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test public void rasterNetwork_singleLink() { diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java index 3eda5f417e8..08678b9549f 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.emissions.analysis; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.emissions.Pollutant; @@ -16,8 +16,8 @@ public class RawEmissionEventsReaderTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test public void handleNonEventNode() { @@ -95,4 +95,4 @@ public void handleWarmEmissionEvent() { assertEquals(expectedEventsCount, counter.get()); } -} \ No newline at end of file +} diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java index e8a0513f36a..bc2a404634c 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.emissions.events; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.EmissionModule; @@ -36,7 +36,7 @@ */ public class VehicleLeavesTrafficEventTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public final void testRareEventsFromBerlinScenario (){ @@ -85,4 +85,4 @@ public void install(){ Assert.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result); } -} \ No newline at end of file +} diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java index 5f231f96650..eb79ad597b5 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java @@ -19,7 +19,7 @@ package org.matsim.contrib.emissions.example; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.emissions.EmissionUtils; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -39,7 +39,7 @@ * */ public class RunAverageEmissionToolOfflineExampleIT{ - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test public final void testAverage_vehTypeV1() { diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java index 35735730695..4a3edaf60dd 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java @@ -19,7 +19,7 @@ package org.matsim.contrib.emissions.example; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup.DetailedVsAverageLookupBehavior; @@ -34,7 +34,7 @@ * */ public class RunDetailedEmissionToolOfflineExampleIT { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; /* * diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java index a762a196a4a..375cae0855b 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java @@ -20,7 +20,7 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -35,7 +35,7 @@ * */ public class RunDetailedEmissionToolOnlineExampleIT_vehTypeV1 { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; /** * Test method for {@link RunDetailedEmissionToolOnlineExample#main(String[])}. diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java index a046d363371..fc23f2cefbd 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -35,7 +35,7 @@ * */ public class RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; /** * Test method for {@link RunDetailedEmissionToolOnlineExample#main(java.lang.String[])}. diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java index 1a247d71217..213c933c504 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java @@ -20,7 +20,7 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -35,7 +35,7 @@ * */ public class RunDetailedEmissionToolOnlineExampleIT_vehTypeV2 { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; /** * Test method for {@link RunDetailedEmissionToolOnlineExample#main(String[])}. diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java index 42f65e0010b..1c387a47d73 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -36,7 +36,7 @@ * */ public class RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; /** * Test method for {@link RunDetailedEmissionToolOnlineExample#main(String[])}. diff --git a/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleTest.java b/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleTest.java index c2d26638e04..e8bb29fea1c 100644 --- a/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleTest.java +++ b/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleTest.java @@ -9,7 +9,7 @@ import org.matsim.core.config.ConfigUtils; import org.matsim.core.events.EventsUtils; import org.matsim.core.population.PopulationUtils; -import org.matsim.testcases.MatsimJunit5TestExtension; +import org.matsim.testcases.MatsimTestUtils; import org.matsim.utils.eventsfilecomparison.EventsFileComparator; public class RunEvExampleTest{ @@ -17,7 +17,7 @@ public class RunEvExampleTest{ private static final Logger log = LogManager.getLogger(RunEvExample.class ); @RegisterExtension - public MatsimJunit5TestExtension utils = new MatsimJunit5TestExtension() ; + public MatsimTestUtils utils = new MatsimTestUtils() ; @Test public void runTest(){ try { diff --git a/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java b/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java index 0aedc60e902..543e1a643da 100644 --- a/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java +++ b/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java @@ -3,7 +3,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; @@ -20,7 +20,7 @@ public class RunEvExampleWithLTHConsumptionModelTest{ private static final Logger log = LogManager.getLogger(RunEvExample.class ); - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test public void runTest(){ try { diff --git a/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java b/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java index 7c39936e0b6..a7c51e597b1 100644 --- a/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java +++ b/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java @@ -22,7 +22,7 @@ import jakarta.inject.Inject; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -41,8 +41,8 @@ * created by jbischoff, 16.08.2018 */ public class TemperatureChangeModuleIntegrationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testTemperatureChangeModule() { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java index 37a4cabaf82..60c0c236e32 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; @@ -49,7 +49,7 @@ public class CarrierEventsReadersTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); private final Id linkId = Id.createLinkId("demoLink"); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierModuleTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierModuleTest.java index 69938d9c14d..6971e244003 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierModuleTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierModuleTest.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -47,8 +47,8 @@ public class CarrierModuleTest { FreightCarriersConfigGroup freightCarriersConfigGroup; - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils testUtils = new MatsimTestUtils(); @Before public void setUp(){ diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java index 10f95ad59cc..e99df84a363 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.population.routes.NetworkRoute; @@ -38,7 +38,7 @@ */ public class CarrierPlanReaderV1Test { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java index 29887701aa4..1a491be3e95 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java @@ -23,7 +23,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -44,7 +44,7 @@ public class CarrierPlanXmlReaderV2Test { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); private Carrier testCarrier; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java index 64a078eecb5..1732949b629 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java @@ -33,7 +33,7 @@ public class CarrierPlanXmlReaderV2WithDtdTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); private Carrier testCarrier; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV1Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV1Test.java index 21b0ba0ed8f..4dd9a950d5a 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV1Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV1Test.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.freight.carriers.*; @@ -33,8 +33,8 @@ */ public class CarrierPlanXmlWriterV1Test { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testCarrierPlanWriterWrites() { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java index f8b84d04382..252254f9a24 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -37,8 +37,8 @@ public class CarrierPlanXmlWriterV2Test { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); private Carrier testCarrier; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java index 268bae2dd71..a122bae47cb 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -37,8 +37,8 @@ public class CarrierPlanXmlWriterV2_1Test { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); private Carrier testCarrier; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierReadWriteV2_1Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierReadWriteV2_1Test.java index 50453b95881..741d20cb168 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierReadWriteV2_1Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierReadWriteV2_1Test.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.freight.carriers.*; import org.matsim.testcases.MatsimTestUtils; @@ -32,8 +32,8 @@ public class CarrierReadWriteV2_1Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void readWriteTest() throws FileNotFoundException, IOException { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java index aa0a0ec281a..06a24c9e6ee 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java @@ -23,7 +23,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.freight.carriers.*; @@ -33,7 +33,7 @@ public class CarrierVehicleTypeLoaderTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); private CarrierVehicleTypes types; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java index 43c73857e44..720dcb63c32 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -34,7 +34,7 @@ import static org.junit.Assert.assertTrue; public class CarrierVehicleTypeReaderTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; private static final Logger log = LogManager.getLogger(CarrierVehicleTypeReaderTest.class) ; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java index 6516c4933a8..a17f15744aa 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java @@ -23,7 +23,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.freight.carriers.CarrierVehicleTypes; @@ -33,7 +33,7 @@ public class CarrierVehicleTypeTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); CarrierVehicleTypes types; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeWriterTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeWriterTest.java index 551c5b6eac8..c47029826e6 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeWriterTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeWriterTest.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.freight.carriers.CarrierVehicleTypeReader; import org.matsim.freight.carriers.CarrierVehicleTypeWriter; @@ -30,8 +30,8 @@ public class CarrierVehicleTypeWriterTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils() ; @Test public void testTypeWriter(){ diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java index e6224ced05c..b1a831f0763 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.freight.carriers.*; @@ -36,8 +36,8 @@ */ public class CarriersUtilsTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testAddAndGetVehicleToCarrier() { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java index 648a61edff2..7a157805173 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java @@ -23,7 +23,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -43,7 +43,7 @@ public class EquilWithCarrierWithPersonsIT { private Controler controler; - @Rule public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); static Config commonConfig( MatsimTestUtils testUtils ) { Config config = ConfigUtils.createConfig(); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java index 51a28a88ed0..4de7e0d3267 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers.controler; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -44,7 +44,7 @@ public class EquilWithCarrierWithoutPersonsIT { private Controler controler; - @Rule public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); public void setUp() { Config config = EquilWithCarrierWithPersonsIT.commonConfig( testUtils ); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java index 71b63d36035..99f0c7ebe80 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -63,8 +63,8 @@ */ public class DistanceConstraintFromVehiclesFileTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); static final Logger log = LogManager.getLogger(DistanceConstraintFromVehiclesFileTest.class); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java index cff10f42763..f55ccf201ed 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -64,8 +64,8 @@ */ public class DistanceConstraintTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); static final Logger log = LogManager.getLogger(DistanceConstraintTest.class); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java index a1811281682..1adec7e30a1 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java @@ -31,7 +31,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -56,7 +56,7 @@ */ public class FixedCostsTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); private final static Logger log = LogManager.getLogger(FixedCostsTest.class); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java index 984bdd3e5e8..1e0988f6529 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java @@ -28,7 +28,7 @@ import com.graphhopper.jsprit.core.reporting.SolutionPrinter; import com.graphhopper.jsprit.core.util.Solutions; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; @@ -44,8 +44,8 @@ public class IntegrationIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testJsprit() throws ExecutionException, InterruptedException { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java index 7b3060643a3..16cef601c1a 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java @@ -31,7 +31,7 @@ import com.graphhopper.jsprit.core.problem.vehicle.Vehicle; import com.graphhopper.jsprit.core.problem.vehicle.VehicleImpl; import com.graphhopper.jsprit.core.problem.vehicle.VehicleTypeImpl; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -54,8 +54,8 @@ public class MatsimTransformerTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void whenTransforming_jSpritType2matsimType_itIsMadeCorrectly() { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java index e85cb3ce9a1..bc8bc2d0e81 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java @@ -25,7 +25,7 @@ import com.graphhopper.jsprit.core.problem.driver.Driver; import com.graphhopper.jsprit.core.problem.vehicle.Vehicle; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -47,7 +47,7 @@ public class NetworkBasedTransportCostsTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java index 3201a4cd5c9..41f746ec87a 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java @@ -27,7 +27,7 @@ import com.graphhopper.jsprit.core.reporting.SolutionPrinter; import com.graphhopper.jsprit.core.util.Solutions; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -41,8 +41,8 @@ import org.matsim.vehicles.VehicleType; public class SkillsIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private final Id carrierLocation = Id.createLinkId("i(1,0)"); @Test diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java index 593b7786a62..eb884308c2c 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers.usecases.chessboard; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; @@ -36,7 +36,7 @@ public class RunChessboardIT { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test public void runChessboard() { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java index 0749341e978..4fdfd06b0fb 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java @@ -22,15 +22,15 @@ package org.matsim.freight.carriers.usecases.chessboard; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.testcases.MatsimTestUtils; public class RunPassengerAlongWithCarriersIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils() ; @Test public void runChessboard() { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java index 05f0eeb244d..d297d904034 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java @@ -28,7 +28,7 @@ import com.graphhopper.jsprit.core.util.Solutions; import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -64,8 +64,8 @@ public class CarrierControlerUtilsIT { private Carrier carrierWShipmentsOnlyFromCarrierWServices; private Carrier carrierWShipmentsOnlyFromCarrierWShipments; - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Before public void setUp() { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java index 0f4354005b1..4253b81d269 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java @@ -30,7 +30,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -60,8 +60,8 @@ public class CarrierControlerUtilsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(CarrierControlerUtilsTest.class); @@ -74,8 +74,8 @@ public class CarrierControlerUtilsTest { private Carrier carrierWShipmentsOnlyFromCarrierWServices; private Carrier carrierWShipmentsOnlyFromCarrierWShipments; - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Before public void setUp() { diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java index f5ba3475e0b..6568d0d0bdd 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java @@ -21,7 +21,7 @@ package org.matsim.contrib.freightreceiver; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.freight.carriers.Carrier; @@ -31,7 +31,7 @@ import org.matsim.testcases.MatsimTestUtils; public class ReceiversReaderTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); /** * This is just a simplified version of {@link #testV2()} with the main diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java index f06e6dbe79a..9a1a34dd34a 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.freightreceiver; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -19,8 +19,8 @@ */ public class ReceiversTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testSetupReceivers() { diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java index 2020662eca9..aba05df627e 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java @@ -21,7 +21,7 @@ package org.matsim.contrib.freightreceiver; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.freightreceiver.run.chessboard.ReceiverChessboardScenario; @@ -33,7 +33,7 @@ public class ReceiversWriterTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testV1() { diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java index 5e509b0a02a..0b192d3bb83 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java @@ -2,7 +2,7 @@ import com.google.inject.Injector; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -24,8 +24,8 @@ public class EstimateRouterTest { private InformedModeChoiceConfigGroup group; private Controler controler; - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Before public void setUp() throws Exception { @@ -57,4 +57,4 @@ public void routing() { } -} \ No newline at end of file +} diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java index d52365dc081..4e38c743ab9 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java @@ -2,7 +2,7 @@ import com.google.inject.Injector; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.application.MATSimApplication; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -15,8 +15,8 @@ public class ScenarioTest { protected Controler controler; protected Injector injector; - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Before public void setUp() throws Exception { diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/TestScenario.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/TestScenario.java index 98798263fad..f62d2ec7277 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/TestScenario.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/TestScenario.java @@ -59,7 +59,7 @@ public TestScenario(@Nullable Config config) { /** * Load scenario config. - * @param utils needed to set correct output directory {@code @Rule public MatsimTestUtils utils = new MatsimTestUtils();} + * @param utils needed to set correct output directory {@code @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils();} */ public static Config loadConfig(MatsimTestUtils utils) { diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/commands/GenerateChoiceSetTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/commands/GenerateChoiceSetTest.java index b1b0a619110..f166bae8767 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/commands/GenerateChoiceSetTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/commands/GenerateChoiceSetTest.java @@ -1,6 +1,6 @@ package org.matsim.modechoice.commands; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; @@ -13,8 +13,8 @@ public class GenerateChoiceSetTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void command() throws URISyntaxException { diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/ComplexEstimatorTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/ComplexEstimatorTest.java index 5d3dd6a7a36..497e69a631c 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/ComplexEstimatorTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/ComplexEstimatorTest.java @@ -1,6 +1,6 @@ package org.matsim.modechoice.estimators; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.application.MATSimApplication; import org.matsim.core.config.Config; @@ -13,8 +13,8 @@ public class ComplexEstimatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void bindings() { diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java index e57a6413116..166a19d9aac 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java @@ -6,7 +6,7 @@ import org.assertj.core.api.InstanceOfAssertFactories; import org.assertj.core.data.Offset; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.matsim.api.core.v01.Coord; @@ -47,8 +47,8 @@ @RunWith(MockitoJUnitRunner.class) public class TopKMinMaxTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private TopKChoicesGenerator generator; private Injector injector; diff --git a/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java b/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java index 072ff3bac05..0a99e7e8054 100644 --- a/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java +++ b/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java @@ -43,7 +43,7 @@ import org.jfree.chart.renderer.xy.XYLineAndShapeRenderer; import org.jfree.data.xy.XYSeries; import org.jfree.data.xy.XYSeriesCollection; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -121,7 +121,7 @@ public static Collection createFds() { } } return Arrays.asList(combos2run); - + } @Test @@ -135,18 +135,18 @@ public void fdsCarBike(){ run(false); } - @Test + @Test public void fdsCarBikeFastCapacityUpdate(){ run(true); } - + @Test public void fdsCarOnly(){ this.travelModes = new String [] {"car"}; run(false); } - @Rule public MatsimTestUtils helper = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils helper = new MatsimTestUtils(); private String [] travelModes; public final Id flowDynamicsMeasurementLinkId = Id.createLinkId(0); @@ -170,14 +170,14 @@ private void run(final boolean isUsingFastCapacityUpdate) { config.qsim().setSeepModeStorageFree(false); config.qsim().setRestrictingSeepage(true); } - + config.vspExperimental().setVspDefaultsCheckingLevel( VspDefaultsCheckingLevel.abort ); config.qsim().setTrafficDynamics(trafficDynamics); config.qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); - + // --- - + Scenario scenario = ScenarioUtils.loadScenario(config); createNetwork(scenario); @@ -185,17 +185,17 @@ private void run(final boolean isUsingFastCapacityUpdate) { double networkDensity = 3.*(1000./7.5); - + double sumOfPCUInEachStep = 0.; - + //equal modal split run for (String mode : travelModes) { sumOfPCUInEachStep += modeVehicleTypes.get(mode).getPcuEquivalents() * getMinNumberOfAgentAtStart(mode) ; }; - + int reduceNoOfDataPointsInPlot = 4; // 1--> will generate all possible data points; if( sumOfPCUInEachStep >=3 ) reduceNoOfDataPointsInPlot = 1 ; - + int numberOfPoints = (int) Math.ceil( networkDensity/ (reduceNoOfDataPointsInPlot * sumOfPCUInEachStep) ) + 5; List> points2Run = new ArrayList<>(); @@ -237,7 +237,7 @@ private void run(final boolean isUsingFastCapacityUpdate) { EventsManager events = EventsUtils.createEventsManager(); globalFlowDynamicsUpdator = new GlobalFlowDynamicsUpdator(mode2FlowData); events.addHandler(globalFlowDynamicsUpdator); - + final QSim qSim = new QSimBuilder(config) // .useDefaults() .configureQSimComponents( components -> { @@ -263,11 +263,11 @@ public void insertAgentsIntoMobsim() { final Vehicle vehicle = VehicleUtils.getFactory().createVehicle(Id.create(agent.getId(), Vehicle.class), travelModesTypes.get(travelMode)); final Id linkId4VehicleInsertion = Id.createLinkId("home"); - + // qSim.createAndParkVehicleOnLink(vehicle, linkId4VehicleInsertion); QVehicle qVehicle = new QVehicleImpl( vehicle ) ; // yyyyyy should use factory. kai, nov'18 qSim.addParkedVehicle( qVehicle, linkId4VehicleInsertion ); - + } } }; @@ -279,7 +279,7 @@ public void insertAgentsIntoMobsim() { Map> mode2FlowSpeed = new HashMap<>(); for(int i=0; i < travelModes.length; i++){ - Tuple flowSpeed = + Tuple flowSpeed = new Tuple<>(this.mode2FlowData.get(Id.create(travelModes[i],VehicleType.class)).getPermanentFlow(), this.mode2FlowData.get(Id.create(travelModes[i],VehicleType.class)).getPermanentAverageVelocity()); mode2FlowSpeed.put(travelModes[i], flowSpeed); @@ -290,8 +290,8 @@ public void insertAgentsIntoMobsim() { /* * Basically overriding the helper.getOutputDirectory() method, such that, * if file directory does not exists or same file already exists, remove and re-creates the whole dir hierarchy so that - * all existing files are re-written - * else, just keep adding files in the directory. + * all existing files are re-written + * else, just keep adding files in the directory. * This is necessary in order to allow writing different tests results from JUnit parameterization. */ @@ -309,7 +309,7 @@ public void insertAgentsIntoMobsim() { //plotting data scatterPlot(outData,outFile); } - + static int getMinNumberOfAgentAtStart(final String mode) {//equal modal split run // only three different modes (and pcus) are used in this test ie -- car(1), truck(3), bike(0.25) switch (mode) { @@ -320,7 +320,7 @@ static int getMinNumberOfAgentAtStart(final String mode) {//equal modal split ru default : throw new RuntimeException("The test is not designed for this "+ mode + "yet."); } } - + class MySimplifiedRoundAndRoundAgent implements MobsimAgent, MobsimDriverAgent { private final Id ORIGIN_LINK_ID = Id.createLinkId("home"); @@ -364,8 +364,8 @@ public Id getId() { @Override public Id chooseNextLinkId() { - if (globalFlowDynamicsUpdator.isPermanent()){ - isArriving = true; + if (globalFlowDynamicsUpdator.isPermanent()){ + isArriving = true; } if( ORIGIN_LINK_ID.equals(this.currentLinkId ) ){ @@ -544,7 +544,7 @@ private void scatterPlot (Map>> inputD XYSeries bikeFlow = null; XYSeries bikeSpeed = null; - + if(travelModes.length==2) { bikeFlow = new XYSeries(travelModes[1]+" flow"); bikeSpeed = new XYSeries(travelModes[1]+" speed"); @@ -553,7 +553,7 @@ private void scatterPlot (Map>> inputD for(double d :inputData.keySet()){ carFlow.add(d, inputData.get(d).get(mode1).getFirst()); carSpeed.add(d, inputData.get(d).get(mode1).getSecond()); - + if(travelModes.length == 2) { bikeFlow.add(d, inputData.get(d).get(travelModes[1]).getFirst()); bikeSpeed.add(d, inputData.get(d).get(travelModes[1]).getSecond()); @@ -573,14 +573,14 @@ private void scatterPlot (Map>> inputD // speed vs density XYSeriesCollection speedDataset = new XYSeriesCollection(); speedDataset.addSeries(carSpeed); - + if ( travelModes.length==2 ) { flowDataset.addSeries(bikeFlow); speedDataset.addSeries(bikeSpeed); } NumberAxis speedAxis = new NumberAxis("Speed (m/s)"); - speedAxis.setRange(0.0, 17.0); + speedAxis.setRange(0.0, 17.0); XYPlot plot2 = new XYPlot(speedDataset, null, speedAxis, new XYLineAndShapeRenderer(false,true)); plot2.setRangeAxisLocation(AxisLocation.TOP_OR_LEFT); @@ -791,7 +791,7 @@ private void saveDynamicVariables(){ this.permanentAverageVelocity = this.getActualAverageVelocity(); LOG.info("Calculated permanent Speed from "+modeId+"'s lastXSpeeds : "+speedTable+"\nResult is : "+this.permanentAverageVelocity); this.permanentFlow = this.getSlidingAverageLastXFlows900(); - LOG.info("Calculated permanent Flow from "+modeId+"'s lastXFlows900 : "+lastXFlows900+"\nResult is :"+this.permanentFlow); + LOG.info("Calculated permanent Flow from "+modeId+"'s lastXFlows900 : "+lastXFlows900+"\nResult is :"+this.permanentFlow); } //Getters/Setters @@ -869,7 +869,7 @@ class GlobalFlowDynamicsUpdator implements LinkEnterEventHandler { private boolean permanentRegime; /** - * container to store static properties of vehicles and dynamic flow properties during simulation + * container to store static properties of vehicles and dynamic flow properties during simulation */ public GlobalFlowDynamicsUpdator(Map, TravelModesFlowDynamicsUpdator> travelModeFlowDataContainer){ this.travelModesFlowData = travelModeFlowDataContainer; @@ -883,7 +883,7 @@ public GlobalFlowDynamicsUpdator(Map, TravelModesFlowDynamicsUpd } @Override - public void reset(int iteration) { + public void reset(int iteration) { for (Id vehTyp : this.travelModesFlowData .keySet()){ this.travelModesFlowData.get(vehTyp).reset(); } @@ -905,16 +905,16 @@ public void handleEvent(LinkEnterEvent event) { //Aggregated data update double nowTime = event.getTime(); - if (event.getLinkId().equals(flowDynamicsMeasurementLinkId)){ + if (event.getLinkId().equals(flowDynamicsMeasurementLinkId)){ this.globalFlowData.updateFlow900(nowTime, pcuVeh); this.globalFlowData.updateSpeedTable(nowTime, event.getVehicleId()); //Waiting for all agents to be on the track before studying stability if ((this.globalFlowData.getNumberOfDrivingAgents() == this.globalFlowData.numberOfAgents) && (nowTime>1800)){ //TODO parametrize this correctly /*//Taking speed check out, as it is not reliable on the global speed table - * Maybe making a list of moving averages could be smart, + * Maybe making a list of moving averages could be smart, * but there is no reliable converging process even in that case. (ssix, 25.10.13) * if (!(this.globalData.isSpeedStable())){ - this.globalData.checkSpeedStability(); + this.globalData.checkSpeedStability(); System.out.println("Checking speed stability in global data for: "+this.globalData.getSpeedTable()); }*/ if (!(this.globalFlowData.isFlowStable())){ @@ -928,7 +928,7 @@ public void handleEvent(LinkEnterEvent event) { if (! this.travelModesFlowData.get(vehTyp).isSpeedStable() || !(this.travelModesFlowData.get(vehTyp).isFlowStable())) { modesStable = false; break; - } + } } } if (modesStable){ diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/BestReplyLocationChoicePlanStrategyTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/BestReplyLocationChoicePlanStrategyTest.java index 2309a1e4dbc..a22dd55b20a 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/BestReplyLocationChoicePlanStrategyTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/BestReplyLocationChoicePlanStrategyTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.locationchoice; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -37,8 +37,8 @@ public class BestReplyLocationChoicePlanStrategyTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testOne() { diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java index 82fbd9e7a0e..3ef0156f7dc 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java @@ -24,7 +24,7 @@ import jakarta.inject.Provider; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -73,8 +73,8 @@ public class LocationChoiceIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/BestReplyIT.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/BestReplyIT.java index 133a45fc886..e76efbcf390 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/BestReplyIT.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/BestReplyIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.locationchoice.frozenepsilons; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -14,8 +14,8 @@ public class BestReplyIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRunControler() { diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java index 08af97c8a0c..a09f75758c9 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java @@ -15,7 +15,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -72,7 +72,7 @@ public class FrozenEpsilonLocaChoiceIT{ private static final Logger log = LogManager.getLogger( FrozenEpsilonLocaChoiceIT.class ) ; - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; /** * This one is, I think, testing the frozen epsilon location choice. kai, mar'19 diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java index d969373ed86..eee860fb1a1 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java @@ -23,7 +23,7 @@ package org.matsim.contrib.locationchoice.frozenepsilons; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -38,8 +38,8 @@ public class SamplerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); private DestinationChoiceContext context; private Scenario scenario; diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java index 7251ae4e31a..960cca8b706 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java @@ -24,7 +24,7 @@ import java.util.List; import java.util.Random; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -37,8 +37,8 @@ public class LocationMutatorwChoiceSetTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private MutableScenario scenario; diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java index 85d1a30def9..d1c4aa34efc 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java @@ -21,7 +21,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; @@ -34,8 +34,8 @@ public class ManageSubchainsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testPrimarySecondaryActivityFound() { diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/RandomLocationMutatorTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/RandomLocationMutatorTest.java index 47846eaf550..351ca1c1da1 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/RandomLocationMutatorTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/RandomLocationMutatorTest.java @@ -21,7 +21,7 @@ import java.util.Random; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -32,8 +32,8 @@ public class RandomLocationMutatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private MutableScenario scenario; diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java index 9b22f6f9e7d..16fccf1abd0 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java @@ -2,14 +2,14 @@ import static org.junit.Assert.assertNotNull; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class SubChainTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testConstructorandGetSlActs() { diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java index 2e10edddfa8..b8529245eff 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java @@ -22,11 +22,13 @@ */ package org.matsim.contrib.matrixbasedptrouter; +import java.io.File; import java.io.IOException; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; +import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Scenario; @@ -51,10 +53,10 @@ * */ public class MatrixBasedPtRouterIT { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Rule - public TemporaryFolder folder = new TemporaryFolder(); + @TempDir + public File folder; /** * This method tests the travel time computation with pseudo pt. @@ -79,8 +81,8 @@ public void testIntegration() throws IOException { new PopulationWriter(population, network).write(path+"plans.xml"); //dummy csv files for pt stops, travel times and travel distances fitting into the dummy network are created - String stopsLocation = CreateTestNetwork.createTestPtStationCSVFile(folder.newFile("ptStops.csv")); - String timesLocation = CreateTestNetwork.createTestPtTravelTimesAndDistancesCSVFile(folder.newFile("ptTravelInfo.csv")); + String stopsLocation = CreateTestNetwork.createTestPtStationCSVFile( new File(folder, "ptStops.csv")); + String timesLocation = CreateTestNetwork.createTestPtTravelTimesAndDistancesCSVFile(new File(folder, "ptTravelInfo.csv")); //add stops, travel times and travel distances file to the pseudo pt config group final MatrixBasedPtRouterConfigGroup matrixBasedPtRouterConfigGroup = new MatrixBasedPtRouterConfigGroup(); diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java index 0b029d1f749..9296f93e9ef 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java @@ -22,6 +22,7 @@ */ package org.matsim.contrib.matrixbasedptrouter; +import java.io.File; import java.io.IOException; import java.util.List; @@ -30,8 +31,9 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; +import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.TransportMode; @@ -72,8 +74,8 @@ public class PtMatrixTest { private static final Logger log = LogManager.getLogger(PtMatrixTest.class); - @Rule - public TemporaryFolder folder = new TemporaryFolder(); + @TempDir + public File folder; @Before public void setUp() throws Exception { @@ -103,7 +105,7 @@ public void testPtMatrixStops() throws IOException{ config.routing().setTeleportedModeSpeed(TransportMode.pt, defaultPtSpeed ) ; Network network = CreateTestNetwork.createTestNetwork(); // creates a dummy network - String location = CreateTestNetwork.createTestPtStationCSVFile(folder.newFile("ptStops.csv")); // creates a dummy csv file with pt stops fitting into the dummy network + String location = CreateTestNetwork.createTestPtStationCSVFile(new File(folder, "ptStops.csv")); // creates a dummy csv file with pt stops fitting into the dummy network MatrixBasedPtRouterConfigGroup module = new MatrixBasedPtRouterConfigGroup(); module.setPtStopsInputFile(location); // this is to be compatible with real code @@ -207,8 +209,8 @@ public void testPtMatrixTimesAndDistances() throws IOException{ Network network = CreateTestNetwork.createTestNetwork(); // creates a dummy network - String stopsLocation = CreateTestNetwork.createTestPtStationCSVFile(folder.newFile("ptStops.csv")); // creates a dummy csv file with pt stops fitting into the dummy network - String timesLocation = CreateTestNetwork.createTestPtTravelTimesAndDistancesCSVFile(folder.newFile("ptTravelInfo.csv")); // creates a dummy csv file with pt travel times fitting into the dummy network + String stopsLocation = CreateTestNetwork.createTestPtStationCSVFile(new File(folder, "ptStops.csv")); // creates a dummy csv file with pt stops fitting into the dummy network + String timesLocation = CreateTestNetwork.createTestPtTravelTimesAndDistancesCSVFile(new File(folder, "ptTravelInfo.csv")); // creates a dummy csv file with pt travel times fitting into the dummy network MatrixBasedPtRouterConfigGroup module = new MatrixBasedPtRouterConfigGroup(); module.setUsingPtStops(true); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java index 3429d672745..7ea50ed1e8e 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java @@ -25,7 +25,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.minibus.PConfigGroup; @@ -47,7 +47,7 @@ */ public class PControlerTestIT implements TabularFileHandler{ - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); private final ArrayList pStatsResults = new ArrayList<>(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java index f9881ed715e..3c22dcac81e 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java @@ -26,7 +26,7 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.minibus.PConfigGroup; @@ -51,7 +51,7 @@ public class SubsidyContextTestIT implements TabularFileHandler { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); private final ArrayList pStatsResults = new ArrayList<>(); private String gridScenarioDirectory ="../../example-scenario/input/"; diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java index 5b84b9f964c..33af461049a 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java @@ -25,7 +25,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.minibus.PConfigGroup; @@ -49,7 +49,7 @@ public class SubsidyTestIT implements TabularFileHandler { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); private final ArrayList pStatsResults = new ArrayList<>(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java index a6e905e1f55..d2a097f60bf 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.minibus.replanning; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.minibus.PConstants; import org.matsim.contrib.minibus.hook.Operator; @@ -33,160 +33,160 @@ public class EndRouteExtensionTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testRun() { - + Operator coop = PScenarioHelper.createCoop2111to2333(); - + new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); ArrayList parameter = new ArrayList<>(); parameter.add("1000.0"); parameter.add("0.0"); - + EndRouteExtension strat = new EndRouteExtension(parameter); - + PPlan testPlan = null; - + Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start stop", "p_2111", coop.getBestPlan().getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare end stop", "p_2333", coop.getBestPlan().getStopsToBeServed().get(1).getId().toString()); Assert.assertNull("Test plan should be null", testPlan); - + // buffer too small testPlan = strat.run(coop); - + Assert.assertNull("Test plan should be null", testPlan); - + parameter = new ArrayList<>(); parameter.add("1000.0"); parameter.add("0.5"); - + strat = new EndRouteExtension(parameter); - + testPlan = strat.run(coop); - + Assert.assertNotNull("Test plan should not be null", testPlan); - + Assert.assertEquals("Compare start stop", "p_2111", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2333", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3343", testPlan.getStopsToBeServed().get(2).getId().toString()); - - + + parameter = new ArrayList<>(); parameter.add("2000.0"); parameter.add("0.5"); - + strat = new EndRouteExtension(parameter); - + testPlan = strat.run(coop); - + Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2111", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2333", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3334", testPlan.getStopsToBeServed().get(2).getId().toString()); - + coop.getBestPlan().setStopsToBeServed(testPlan.getStopsToBeServed()); - + testPlan = strat.run(coop); - + // remaining stops are covered now by the buffer of the otherwise wiggly route Assert.assertNull("Test plan should be null", testPlan); } - + @Test public final void testRunVShapedRoute() { - + Operator coop = PScenarioHelper.createCoopRouteVShaped(); - + new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); ArrayList parameter = new ArrayList<>(); parameter.add("1000.0"); parameter.add("0.0"); - + EndRouteExtension strat = new EndRouteExtension(parameter); - + PPlan testPlan = null; - + Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start stop", "p_2111", coop.getBestPlan().getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare middle stop", "p_3141", coop.getBestPlan().getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3222", coop.getBestPlan().getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare middle stop", "p_3141", coop.getBestPlan().getStopsToBeServed().get(3).getId().toString()); Assert.assertNull("Test plan should be null", testPlan); - + // buffer too small testPlan = strat.run(coop); - + Assert.assertNull("Test plan should be null", testPlan); - + parameter = new ArrayList<>(); parameter.add("1000.0"); parameter.add("0.8"); parameter.add("true"); parameter.add("false"); - + strat = new EndRouteExtension(parameter); - + testPlan = strat.run(coop); - + Assert.assertNotNull("Test plan should not be null", testPlan); - + Assert.assertEquals("Compare start stop", "p_2111", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare former end stop", "p_3222", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare new end stop", "p_2223", testPlan.getStopsToBeServed().get(3).getId().toString()); Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(4).getId().toString()); - + parameter = new ArrayList<>(); parameter.add("1000.0"); parameter.add("0.8"); parameter.add("true"); parameter.add("false"); - + strat = new EndRouteExtension(parameter); - + testPlan = strat.run(coop); - + Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2111", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare former end stop", "p_3222", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare new end stop", "p_1323", testPlan.getStopsToBeServed().get(3).getId().toString()); Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(4).getId().toString()); - + parameter = new ArrayList<>(); parameter.add("1500.0"); parameter.add("0.8"); parameter.add("true"); parameter.add("false"); - + strat = new EndRouteExtension(parameter); - + testPlan = strat.run(coop); - + Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2111", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare former end stop", "p_3222", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare new end stop", "p_1413", testPlan.getStopsToBeServed().get(3).getId().toString()); Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(4).getId().toString()); - + coop.getBestPlan().setStopsToBeServed(testPlan.getStopsToBeServed()); coop.getBestPlan().setLine(testPlan.getLine()); - + testPlan = strat.run(coop); - + // Adds stop 2414 Assert.assertEquals("Compare new end stop", "p_2414", testPlan.getStopsToBeServed().get(4).getId().toString()); - + coop.getBestPlan().setStopsToBeServed(testPlan.getStopsToBeServed()); coop.getBestPlan().setLine(testPlan.getLine()); testPlan = strat.run(coop); - + // remaining stops are covered now by the buffer of the otherwise wiggly route Assert.assertNull("Test plan should be null", testPlan); } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java index a1e7e34f096..af6b404c1a2 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.minibus.replanning; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.minibus.hook.Operator; import org.matsim.contrib.minibus.hook.PPlan; @@ -31,11 +31,11 @@ public class MaxRandomEndTimeAllocatorTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testRun() { - + Operator coop = PScenarioHelper.createTestCooperative(utils.getOutputDirectory()); ArrayList param = new ArrayList<>(); param.add("0"); @@ -43,33 +43,33 @@ public final void testRun() { param.add("false"); MaxRandomEndTimeAllocator strat = new MaxRandomEndTimeAllocator(param); PPlan testPlan = null; - + coop.getBestPlan().setEndTime(40000.0); Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare end time", 40000.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); Assert.assertNull("Test plan should be null", testPlan); - + coop.getBestPlan().setNVehicles(2); - + // enough vehicles for testing, but mutation range 0 testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare end time", 40000.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare end time", 40000.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON); - + param = new ArrayList<>(); param.add("900"); param.add("10"); param.add("false"); strat = new MaxRandomEndTimeAllocator(param); - + // enough vehicles for testing testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 40000.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java index f3c4827ab06..d3086cf9ced 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.minibus.replanning; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.minibus.hook.Operator; import org.matsim.contrib.minibus.hook.PPlan; @@ -31,11 +31,11 @@ public class MaxRandomStartTimeAllocatorTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testRun() { - + Operator coop = PScenarioHelper.createTestCooperative(utils.getOutputDirectory()); ArrayList param = new ArrayList<>(); param.add("0"); @@ -43,34 +43,34 @@ public final void testRun() { param.add("false"); MaxRandomStartTimeAllocator strat = new MaxRandomStartTimeAllocator(param); PPlan testPlan = null; - + coop.getBestPlan().setStartTime(12000.0); coop.getBestPlan().setEndTime(36000.0); Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 12000.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); Assert.assertNull("Test plan should be null", testPlan); - + coop.getBestPlan().setNVehicles(2); - + // run strategy - time mutation is zero, thus no change testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 12000.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 12000.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON); - + param = new ArrayList<>(); param.add("900"); param.add("10"); param.add("false"); strat = new MaxRandomStartTimeAllocator(param); - + // enough vehicles for testing testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 12000.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java index cf21adf8319..615ef2f3412 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.minibus.replanning; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.minibus.PConstants; import org.matsim.contrib.minibus.hook.Operator; @@ -44,73 +44,73 @@ * -mrieser/2019Sept30 */ public class SidewaysRouteExtensionTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testRun() { - + Operator coop = PScenarioHelper.createCoop2414to3444(); - + new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); ArrayList parameter = new ArrayList<>(); parameter.add("0.0"); parameter.add("0.0"); parameter.add("true"); - + SidewaysRouteExtension strat = new SidewaysRouteExtension(parameter); - + PPlan testPlan = null; - + Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start stop", "p_2414", coop.getBestPlan().getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", coop.getBestPlan().getStopsToBeServed().get(1).getId().toString()); Assert.assertNull("Test plan should be null", testPlan); - + // buffer too small testPlan = strat.run(coop); - + Assert.assertNull("Test plan should be null", testPlan); - + parameter = new ArrayList<>(); parameter.add("100.0"); parameter.add("0.0"); parameter.add("true"); - + strat = new SidewaysRouteExtension(parameter); - + testPlan = strat.run(coop); - + // enough buffer to add a stop located directly at the beeline Assert.assertNotNull("Test plan should not be null", testPlan); - + Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2324", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_2324", testPlan.getStopsToBeServed().get(3).getId().toString()); - - + + parameter = new ArrayList<>(); parameter.add("100.0"); parameter.add("0.5"); parameter.add("true"); - + strat = new SidewaysRouteExtension(parameter); - + testPlan = strat.run(coop); - - // enough buffer 0.5 * 3000m = 1500m + + // enough buffer 0.5 * 3000m = 1500m Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2223", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare start stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_2223", testPlan.getStopsToBeServed().get(3).getId().toString()); - + coop.getBestPlan().setStopsToBeServed(testPlan.getStopsToBeServed()); coop.getBestPlan().setLine(coop.getRouteProvider().createTransitLineFromOperatorPlan(coop.getId(), testPlan)); - + testPlan = strat.run(coop); - + // and again stacking - therefore, enlarging the effective buffer Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); @@ -119,106 +119,106 @@ public final void testRun() { Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(3).getId().toString()); Assert.assertEquals("Compare start stop", "p_2212", testPlan.getStopsToBeServed().get(4).getId().toString()); Assert.assertEquals("Compare end stop", "p_2223", testPlan.getStopsToBeServed().get(5).getId().toString()); - + parameter = new ArrayList<>(); parameter.add("4000.0"); parameter.add("0.5"); parameter.add("true"); - + strat = new SidewaysRouteExtension(parameter); coop = PScenarioHelper.createCoop2414to3444(); - + testPlan = strat.run(coop); - + // quite a lot buffer covering all nodes Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2324", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_2324", testPlan.getStopsToBeServed().get(3).getId().toString()); - + testPlan = strat.run(coop); - + // quite a lot buffer covering all nodes Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2223", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_2223", testPlan.getStopsToBeServed().get(3).getId().toString()); - + testPlan = strat.run(coop); - + // quite a lot buffer covering all nodes Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2223", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_2223", testPlan.getStopsToBeServed().get(3).getId().toString()); - + testPlan = strat.run(coop); - + // quite a lot buffer covering all nodes Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_3323", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_3323", testPlan.getStopsToBeServed().get(3).getId().toString()); - + testPlan = strat.run(coop); - + // quite a lot buffer covering all nodes Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_3433", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_3433", testPlan.getStopsToBeServed().get(3).getId().toString()); - + testPlan = strat.run(coop); - + // quite a lot buffer covering all nodes Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2423", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_2423", testPlan.getStopsToBeServed().get(3).getId().toString()); - + testPlan = strat.run(coop); - + // quite a lot buffer covering all nodes Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2322", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_2322", testPlan.getStopsToBeServed().get(3).getId().toString()); - + testPlan = strat.run(coop); - + // quite a lot buffer covering all nodes Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2221", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_2221", testPlan.getStopsToBeServed().get(3).getId().toString()); - + parameter = new ArrayList<>(); parameter.add("100.0"); parameter.add("0.0"); parameter.add("false"); - + strat = new SidewaysRouteExtension(parameter); coop = PScenarioHelper.createCoop2414to3444(); - + testPlan = strat.run(coop); - + // can now choose among stops at the outer edges Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); Assert.assertEquals("Compare start stop", "p_2324", testPlan.getStopsToBeServed().get(1).getId().toString()); Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); Assert.assertEquals("Compare end stop", "p_2324", testPlan.getStopsToBeServed().get(3).getId().toString()); - + testPlan = strat.run(coop); - + // can now choose among stops at the outer edges Assert.assertNotNull("Test plan should not be null", testPlan); Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java index 7284273616f..61744081b5d 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java @@ -22,7 +22,7 @@ import java.io.File; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -36,66 +36,66 @@ public class TimeProviderTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testGetRandomTimeInIntervalOneTimeSlot() { - + new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); - + PConfigGroup pConfig = new PConfigGroup(); pConfig.addParam("timeSlotSize", "99999999"); - + TimeProvider tP = new TimeProvider(pConfig, utils.getOutputDirectory()); tP.reset(0); - + double startTime = 3600.0; double endTime = startTime; - + Assert.assertEquals("New time (There is only one slot, thus time is zero)", 0.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); } - + @Test public final void testGetRandomTimeInIntervalOneSameStartEndTime() { - + new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); - + PConfigGroup pConfig = new PConfigGroup(); pConfig.addParam("timeSlotSize", "900"); - + TimeProvider tP = new TimeProvider(pConfig, utils.getOutputDirectory()); tP.reset(0); - + double startTime = 3600.0; double endTime = startTime; - + Assert.assertEquals("Same start and end time. Should return start time", 3600.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); } - + @Test public final void testGetRandomTimeInIntervalDifferentStartEndTime() { - + new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); - + PConfigGroup pConfig = new PConfigGroup(); pConfig.addParam("timeSlotSize", "900"); - + TimeProvider tP = new TimeProvider(pConfig, utils.getOutputDirectory()); tP.reset(0); - + double startTime = 7500.0; double endTime = 19400.0; - + Assert.assertEquals("Check time", 7200.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); Assert.assertEquals("Check time", 11700.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); - + Id agentId = Id.create("id", Person.class); Id linkId = Id.create("id", Link.class); Id facilityId = Id.create("id", ActivityFacility.class); for (int i = 0; i < 100; i++) { tP.handleEvent(new ActivityEndEvent(500.0 * i, agentId, linkId, facilityId, "type")); } - + Assert.assertEquals("Check time", 9000.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); Assert.assertEquals("Check time", 10800.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java index 922bd2073a0..ba4fb39e8d8 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java @@ -23,7 +23,7 @@ import java.util.ArrayList; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -40,52 +40,52 @@ public class WeightedEndTimeExtensionTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testRun() { - + Operator coop = PScenarioHelper.createTestCooperative(utils.getOutputDirectory()); - + new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); - + PConfigGroup pConfig = new PConfigGroup(); pConfig.addParam("timeSlotSize", "900"); - + TimeProvider tP = new TimeProvider(pConfig, utils.getOutputDirectory()); tP.reset(0); - + WeightedEndTimeExtension strat = new WeightedEndTimeExtension(new ArrayList()); strat.setTimeProvider(tP); - + PPlan testPlan = null; - + coop.getBestPlan().setEndTime(19500.0); Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); Assert.assertNull("Test plan should be null", testPlan); - + coop.getBestPlan().setNVehicles(2); - + // enough vehicles for testing testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 50400.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON); - + // enough vehicles for testing testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 24300.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON); - + // Now same with acts Id agentId = Id.create("id", Person.class); Id linkId = Id.create("id", Link.class); @@ -94,18 +94,18 @@ public final void testRun() { for (int i = 0; i < 100; i++) { tP.handleEvent(new ActivityEndEvent(36600.0, agentId, linkId, facilityId, "type")); } - + testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 36000.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON); - + tP.reset(1); testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java index 104413f6dd7..8c2dd102cd7 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java @@ -23,7 +23,7 @@ import java.util.ArrayList; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -40,52 +40,52 @@ public class WeightedStartTimeExtensionTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testRun() { - + Operator coop = PScenarioHelper.createTestCooperative(utils.getOutputDirectory()); - + new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); - + PConfigGroup pConfig = new PConfigGroup(); pConfig.addParam("timeSlotSize", "900"); - + TimeProvider tP = new TimeProvider(pConfig, utils.getOutputDirectory()); tP.reset(0); - + WeightedStartTimeExtension strat = new WeightedStartTimeExtension(new ArrayList()); strat.setTimeProvider(tP); - + PPlan testPlan = null; - + coop.getBestPlan().setStartTime(19500.0); Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); Assert.assertNull("Test plan should be null", testPlan); - + coop.getBestPlan().setNVehicles(2); - + // enough vehicles for testing testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 9000.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON); - + // enough vehicles for testing testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 900.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON); - + // Now same with acts Id agentId = Id.create("id", Person.class); Id linkId = Id.create("id", Link.class); @@ -94,18 +94,18 @@ public final void testRun() { for (int i = 0; i < 100; i++) { tP.handleEvent(new ActivityEndEvent(9600.0, agentId, linkId, facilityId, "type")); } - + testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 9000.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON); - + tP.reset(1); testPlan = strat.run(coop); - + Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); Assert.assertNotNull("Test plan should be not null", testPlan); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java index e7f462d4211..70a363892ed 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java @@ -22,7 +22,7 @@ import java.util.ArrayList; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -41,23 +41,23 @@ import org.matsim.testcases.MatsimTestUtils; public class ComplexCircleScheduleProviderTest { - -@Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + +@RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testCreateTransitLineLikeSimpleCircleScheduleProvider() { - + Scenario scenario = PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); - - + + TransitSchedule tS = CreateStopsForAllCarLinks.createStopsForAllCarLinks(scenario.getNetwork(), pC); - + ComplexCircleScheduleProvider prov = new ComplexCircleScheduleProvider(tS, scenario.getNetwork(), null, pC.getVehicleMaximumVelocity(), pC.getPlanningSpeedFactor(), pC.getDriverRestTime(), pC.getMode()); - + Id lineId = Id.create("line1", Operator.class); Id routeId = Id.create("route1", PPlan.class); - + PPlan plan = new PPlan(routeId, "noCreator", PConstants.founderPlanId); plan.setStartTime(7.0 * 3600.0); plan.setEndTime(9.0 * 3600.0); @@ -68,55 +68,55 @@ public final void testCreateTransitLineLikeSimpleCircleScheduleProvider() { stopsToBeServed.add(startStop); stopsToBeServed.add(endStop); plan.setStopsToBeServed(stopsToBeServed); - + ArrayList> refIds = new ArrayList<>(); refIds.add(Id.create("1424", Link.class)); refIds.add(Id.create("2434", Link.class)); refIds.add(Id.create("3444", Link.class)); refIds.add(Id.create("4434", Link.class)); refIds.add(Id.create("3424", Link.class)); refIds.add(Id.create("2414", Link.class)); refIds.add(Id.create("1424", Link.class)); - + TransitLine line = prov.createTransitLineFromOperatorPlan(lineId, plan); - + Assert.assertEquals("Transit line ids have to be the same", Id.create(lineId, TransitLine.class), line.getId()); - + for (TransitRoute route : line.getRoutes().values()) { Assert.assertEquals("Route id have to be the same", Id.create(lineId + "-" + routeId, TransitRoute.class), route.getId()); Assert.assertEquals("Number of departures", 14.0, route.getDepartures().size(), MatsimTestUtils.EPSILON); - - // check links + + // check links Assert.assertEquals("Start link id has to be the same", refIds.get(0), route.getRoute().getStartLinkId()); - + int i = 1; for (Id linkId : route.getRoute().getLinkIds()) { Assert.assertEquals("Route link ids have to be the same", refIds.get(i), linkId); i++; } - + Assert.assertEquals("End link id has to be the same", refIds.get(refIds.size() - 1), route.getRoute().getEndLinkId()); - + // check stops i = 0; for (TransitRouteStop stop : route.getStops()) { Assert.assertEquals("Route stop ids have to be the same", Id.create(pC.getPIdentifier() + refIds.get(i), TransitStopFacility.class), stop.getStopFacility().getId()); i++; - } - } + } + } } - + @Test public final void testCreateTransitLineWithMoreStops() { - + Scenario scenario = PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); - - + + TransitSchedule tS = CreateStopsForAllCarLinks.createStopsForAllCarLinks(scenario.getNetwork(), pC); - + ComplexCircleScheduleProvider prov = new ComplexCircleScheduleProvider(tS, scenario.getNetwork(), null, pC.getVehicleMaximumVelocity(), pC.getPlanningSpeedFactor(), pC.getDriverRestTime(), pC.getMode()); - + Id lineId = Id.create("line1", Operator.class); Id routeId = Id.create("route1", PPlan.class); - + PPlan plan = new PPlan(routeId, "noCreator",PConstants.founderPlanId); plan.setStartTime(7.0 * 3600.0); plan.setEndTime(9.0 * 3600.0); @@ -132,72 +132,72 @@ public final void testCreateTransitLineWithMoreStops() { stopsToBeServed.add(stop3); stopsToBeServed.add(stop4); stopsToBeServed.add(stop5); - + plan.setStopsToBeServed(stopsToBeServed); - + ArrayList> refIds = new ArrayList<>(); refIds.add(Id.create("1424", Link.class)); refIds.add(Id.create("2423", Link.class)); refIds.add(Id.create("2333", Link.class)); refIds.add(Id.create("3334", Link.class)); refIds.add(Id.create("3433", Link.class)); refIds.add(Id.create("3334", Link.class)); refIds.add(Id.create("3424", Link.class)); refIds.add(Id.create("2414", Link.class)); refIds.add(Id.create("1424", Link.class)); - + TransitLine line = prov.createTransitLineFromOperatorPlan(lineId, plan); - + Assert.assertEquals("Transit line ids have to be the same", Id.create(lineId, TransitLine.class), line.getId()); - + for (TransitRoute route : line.getRoutes().values()) { Assert.assertEquals("Route id have to be the same", Id.create(lineId + "-" + routeId, TransitRoute.class), route.getId()); - - // check links + + // check links Assert.assertEquals("Start link id has to be the same", refIds.get(0), route.getRoute().getStartLinkId()); - + int i = 1; for (Id linkId : route.getRoute().getLinkIds()) { Assert.assertEquals("Route link ids have to be the same", refIds.get(i), linkId); i++; } - + Assert.assertEquals("End link id has to be the same", refIds.get(refIds.size() - 1), route.getRoute().getEndLinkId()); - + // check stops i = 0; for (TransitRouteStop stop : route.getStops()) { Assert.assertEquals("Route stop ids have to be the same", Id.create(pC.getPIdentifier() + refIds.get(i), TransitStopFacility.class), stop.getStopFacility().getId()); i++; } - - Assert.assertEquals("Number of departures", 11.0, route.getDepartures().size(), MatsimTestUtils.EPSILON); - } + + Assert.assertEquals("Number of departures", 11.0, route.getDepartures().size(), MatsimTestUtils.EPSILON); + } } - + @Test public final void testGetRandomTransitStop() { - + MutableScenario scenario = (MutableScenario) PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); RandomStopProvider randomStopProvider = new RandomStopProvider(pC, scenario.getPopulation(), scenario.getTransitSchedule(), null); - + SimpleCircleScheduleProvider prov = new SimpleCircleScheduleProvider(pC.getPIdentifier(), scenario.getTransitSchedule(), scenario.getNetwork(), randomStopProvider, pC.getVehicleMaximumVelocity(), pC.getDriverRestTime(), pC.getMode()); - + for (int i = 0; i < 5; i++) { TransitStopFacility stop1 = prov.getRandomTransitStop(0); TransitStopFacility stop2 = prov.getRandomTransitStop(0); - Assert.assertNotSame("Stop should not be the same", stop1.getId(), stop2.getId()); + Assert.assertNotSame("Stop should not be the same", stop1.getId(), stop2.getId()); } - } - + } + @Test public final void testCreateEmptyLine() { - + MutableScenario scenario = (MutableScenario) PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); - + Id lineId = Id.create("1", Operator.class); - + SimpleCircleScheduleProvider prov = new SimpleCircleScheduleProvider(pC.getPIdentifier(), scenario.getTransitSchedule(), scenario.getNetwork(), null, pC.getVehicleMaximumVelocity(), pC.getDriverRestTime(), pC.getMode()); TransitLine line = prov.createEmptyLineFromOperator(lineId); - + Assert.assertEquals("Transit line ids have to be the same", Id.create(lineId, TransitLine.class), line.getId()); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java index 44875c05220..4b09480162c 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java @@ -22,7 +22,7 @@ import java.util.ArrayList; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -41,23 +41,23 @@ import org.matsim.testcases.MatsimTestUtils; public class SimpleCircleScheduleProviderTest { - -@Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + +@RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testCreateTransitLine() { - + Scenario scenario = PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); - - + + TransitSchedule tS = CreateStopsForAllCarLinks.createStopsForAllCarLinks(scenario.getNetwork(), pC); - + SimpleCircleScheduleProvider prov = new SimpleCircleScheduleProvider(pC.getPIdentifier(), tS, scenario.getNetwork(), null, pC.getVehicleMaximumVelocity(), pC.getDriverRestTime(), pC.getMode()); - + Id lineId = Id.create("line1", PPlan.class); Id routeId = Id.create("route1", PPlan.class); - + PPlan plan = new PPlan(routeId, "noCreator", PConstants.founderPlanId); plan.setStartTime(7.0 * 3600.0); plan.setEndTime(9.0 * 3600.0); @@ -68,68 +68,68 @@ public final void testCreateTransitLine() { stopsToBeServed.add(startStop); stopsToBeServed.add(endStop); plan.setStopsToBeServed(stopsToBeServed); - + ArrayList> refIds = new ArrayList<>(); refIds.add(Id.create("1424", Link.class)); refIds.add(Id.create("2434", Link.class)); refIds.add(Id.create("3444", Link.class)); refIds.add(Id.create("4434", Link.class)); refIds.add(Id.create("3424", Link.class)); refIds.add(Id.create("2414", Link.class)); refIds.add(Id.create("1424", Link.class)); - + TransitLine line = prov.createTransitLineFromOperatorPlan(Id.create(lineId, Operator.class), plan); - + Assert.assertEquals("Transit line ids have to be the same", Id.create(lineId, TransitLine.class), line.getId()); - + for (TransitRoute route : line.getRoutes().values()) { Assert.assertEquals("Route id have to be the same", Id.create(lineId + "-" + routeId, TransitRoute.class), route.getId()); Assert.assertEquals("Number of departures", 14.0, route.getDepartures().size(), MatsimTestUtils.EPSILON); - + // check stops int i = 0; for (TransitRouteStop stop : route.getStops()) { Assert.assertEquals("Route stop ids have to be the same", Id.create(pC.getPIdentifier() + refIds.get(i), TransitStopFacility.class), stop.getStopFacility().getId()); i++; } - - // check links + + // check links Assert.assertEquals("Start link id has to be the same", refIds.get(0), route.getRoute().getStartLinkId()); - + i = 1; for (Id linkId : route.getRoute().getLinkIds()) { Assert.assertEquals("Route link ids have to be the same", refIds.get(i), linkId); i++; } - + Assert.assertEquals("End link id has to be the same", refIds.get(refIds.size() - 1), route.getRoute().getEndLinkId()); - } + } } - + @Test public final void testGetRandomTransitStop() { - + MutableScenario scenario = (MutableScenario) PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); RandomStopProvider randomStopProvider = new RandomStopProvider(pC, scenario.getPopulation(), scenario.getTransitSchedule(), null); - + SimpleCircleScheduleProvider prov = new SimpleCircleScheduleProvider(pC.getPIdentifier(), scenario.getTransitSchedule(), scenario.getNetwork(), randomStopProvider, pC.getVehicleMaximumVelocity(), pC.getDriverRestTime(), pC.getMode()); - + for (int i = 0; i < 5; i++) { TransitStopFacility stop1 = prov.getRandomTransitStop(0); TransitStopFacility stop2 = prov.getRandomTransitStop(0); - Assert.assertNotSame("Stop should not be the same", stop1.getId(), stop2.getId()); + Assert.assertNotSame("Stop should not be the same", stop1.getId(), stop2.getId()); } - } - + } + @Test public final void testCreateEmptyLine() { - + MutableScenario scenario = (MutableScenario) PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); - + Id lineId = Id.create("1", Operator.class); - + SimpleCircleScheduleProvider prov = new SimpleCircleScheduleProvider(pC.getPIdentifier(), scenario.getTransitSchedule(), scenario.getNetwork(), null, pC.getVehicleMaximumVelocity(), pC.getDriverRestTime(), pC.getMode()); TransitLine line = prov.createEmptyLineFromOperator(lineId); - + Assert.assertEquals("Transit line ids have to be the same", Id.create(lineId, TransitLine.class), line.getId()); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java index 14bcd4e148c..260a6a7d7f1 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.minibus.schedule; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -39,18 +39,18 @@ public class CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testPScenarioHelperTestNetwork() { - + Network net = PScenarioHelper.createTestNetwork().getNetwork(); PConfigGroup pC = new PConfigGroup(); pC.addParam("stopLocationSelector", "outsideJunctionAreas"); pC.addParam("stopLocationSelectorParameter", "50.0,2,Double.positiveInfinity"); - + String realPtStopLink = "3233"; - + /* Modify some link attributes to check whether these links are excluded as specified in the config */ String tooLowCapacityLink = "2122"; String tooHighFreespeedLink = "2223"; @@ -58,93 +58,93 @@ public final void testPScenarioHelperTestNetwork() { net.getLinks().get(Id.createLinkId(tooHighFreespeedLink)).setFreespeed(100); pC.addParam("minCapacityForStops", "0"); pC.addParam("speedLimitForStops", "1000"); - + TransitSchedule transitSchedule = CreatePStopsOnJunctionApproachesAndBetweenJunctions.createPStops(net, pC, new NetworkConfigGroup()); - + int numberOfParaStops = 0; for (TransitStopFacility stopFacility : transitSchedule.getFacilities().values()) { if (stopFacility.getId().toString().startsWith(pC.getPIdentifier())) { numberOfParaStops++; } } - + /* 4 inner junctions with 4 approaches + 8 outer junctions with 3 approaches + 4 corners without junctions = 40 approach links */ Assert.assertEquals("All 40 junction approach links got a paratransit stop", 40, numberOfParaStops, MatsimTestUtils.EPSILON); - + /* Check whether these links are included as specified in the config */ Assert.assertNotNull("Paratransit stop at link without real pt stop", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + realPtStopLink, TransitStopFacility.class))); Assert.assertNotNull("Paratransit stop at link with small capacity", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooLowCapacityLink, TransitStopFacility.class))); Assert.assertNotNull("Paratransit stop at link with high freespeed", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooHighFreespeedLink, TransitStopFacility.class))); TransitScheduleFactoryImpl tSF = new TransitScheduleFactoryImpl(); - + TransitSchedule realTransitSchedule = tSF.createTransitSchedule(); TransitStopFacility stop1 = tSF.createTransitStopFacility(Id.create(realPtStopLink, TransitStopFacility.class), new Coord(0.0, 0.0), false); stop1.setLinkId(Id.create(realPtStopLink, Link.class)); realTransitSchedule.addStopFacility(stop1); - + /* Modify config to exclude some links */ pC.addParam("minCapacityForStops", "800"); pC.addParam("speedLimitForStops", "20"); - + transitSchedule = CreatePStopsOnJunctionApproachesAndBetweenJunctions.createPStops(net, pC, realTransitSchedule, new NetworkConfigGroup()); - + numberOfParaStops = 0; for (TransitStopFacility stopFacility : transitSchedule.getFacilities().values()) { if (stopFacility.getId().toString().startsWith(pC.getPIdentifier())) { numberOfParaStops++; } } - + Assert.assertEquals("All car links minus one stop from formal transit got a paratransit stop", 40 - 3, numberOfParaStops, MatsimTestUtils.EPSILON); - + Assert.assertNull("No paratransit stop at link with real pt stop", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + realPtStopLink, TransitStopFacility.class))); Assert.assertNull("No paratransit stop at link with too small capacity", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooLowCapacityLink, TransitStopFacility.class))); Assert.assertNull("No paratransit stop at link with too high freespeed", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooHighFreespeedLink, TransitStopFacility.class))); - + } - - /** {@link org.matsim.core.network.algorithms.intersectionSimplifier.IntersectionSimplifierTest} */ + + /** {@link org.matsim.core.network.algorithms.intersectionSimplifier.IntersectionSimplifierTest} */ @Test public final void testComplexIntersection() { - + Network network = buildComplexIntersection(); PConfigGroup pC = new PConfigGroup(); pC.addParam("stopLocationSelector", "outsideJunctionAreas"); pC.addParam("stopLocationSelectorParameter", "30.0,2,500"); - + TransitSchedule transitSchedule = CreatePStopsOnJunctionApproachesAndBetweenJunctions.createPStops(network, pC, new NetworkConfigGroup()); - + int numberOfParaStops = 0; for (TransitStopFacility stopFacility : transitSchedule.getFacilities().values()) { if (stopFacility.getId().toString().startsWith(pC.getPIdentifier())) { numberOfParaStops++; } } - + Assert.assertEquals("Check number of paratransit stops", 16, numberOfParaStops, MatsimTestUtils.EPSILON); - + /* approaches to (unclustered) dead-ends */ Assert.assertNotNull("Should find paratransit stop 'p_2_1'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "2_1", TransitStopFacility.class))); Assert.assertNotNull("Should find paratransit stop 'p_4_3'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "4_3", TransitStopFacility.class))); Assert.assertNotNull("Should find paratransit stop 'p_9_10'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "9_10", TransitStopFacility.class))); Assert.assertNotNull("Should find paratransit stop 'p_30_31'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "30_31", TransitStopFacility.class))); - + /* left junction: clustered nodes 5-6-7-8 */ Assert.assertNotNull("Should find junction approach paratransit stop 'p_2_5'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "2_5", TransitStopFacility.class))); Assert.assertNotNull("Should find junction approach paratransit stop 'p_4_6'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "4_6", TransitStopFacility.class))); Assert.assertNotNull("Should find junction approach paratransit stop 'p_19_8'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "19_8", TransitStopFacility.class))); Assert.assertNotNull("Should find junction approach paratransit stop 'p_9_7'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "9_7", TransitStopFacility.class))); - + Assert.assertNull("Should NOT find paratransit stop at link in junction '5_6'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "5_6", TransitStopFacility.class))); Assert.assertNull("Should NOT find paratransit stop at link in junction '6_8'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "6_8", TransitStopFacility.class))); Assert.assertNull("Should NOT find paratransit stop at link in junction '8_7'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "8_7", TransitStopFacility.class))); Assert.assertNull("Should NOT find paratransit stop at link in junction '7_5'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "7_5", TransitStopFacility.class))); - + /* clustered nodes 11-12: dead-end, therefore only one stop approaching */ Assert.assertNotNull("Should find junction approach paratransit stop 'p_13_12'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "13_12", TransitStopFacility.class))); - + /* right junction: clustered nodes 13-14-15-16-17-18-19-20-21-22-23-24 */ Assert.assertNotNull("Should find junction approach paratransit stop 'p_6_15'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "6_15", TransitStopFacility.class))); Assert.assertNotNull("Should find junction approach paratransit stop 'p_12_14'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "12_14", TransitStopFacility.class))); @@ -174,29 +174,29 @@ public final void testComplexIntersection() { Assert.assertNull("Should NOT find paratransit stop at link in junction '20_17'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "20_17", TransitStopFacility.class))); Assert.assertNull("Should NOT find paratransit stop at link in junction '16_21'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "16_21", TransitStopFacility.class))); Assert.assertNull("Should NOT find paratransit stop at link in junction '21_16'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "21_16", TransitStopFacility.class))); - + /* clustered nodes 25-26: dead-end, therefore only one stop approaching */ Assert.assertNotNull("Should find junction approach paratransit stop 'p_24_25'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "24_25", TransitStopFacility.class))); - + /* links exiting junctions (towards dead-ends) */ Assert.assertNull("Should NOT find paratransit stop at link exiting junction '7_2'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "7_2", TransitStopFacility.class))); Assert.assertNull("Should NOT find paratransit stop at link exiting junction '5_4'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "5_4", TransitStopFacility.class))); Assert.assertNull("Should NOT find paratransit stop at link exiting junction '8_9'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "8_9", TransitStopFacility.class))); Assert.assertNull("Should NOT find paratransit stop at link exiting junction '18_19'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "7_2", TransitStopFacility.class))); - + /* Infill Stops between junctions / dead-ends */ Assert.assertNotNull("Should find infill paratransit stop 'p_30_29'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "30_29", TransitStopFacility.class))); Assert.assertNotNull("Should find infill paratransit stop 'p_27_28'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "27_28", TransitStopFacility.class))); - + /* Check whether CalcTopoTypes is considered (type 8 : intersections only) */ pC.addParam("TopoTypesForStops", "8"); - + transitSchedule = CreatePStopsOnJunctionApproachesAndBetweenJunctions.createPStops(network, pC, new NetworkConfigGroup()); Assert.assertNull("Should NOT find paratransit stop at link with wrong topo type (not an intersection) '30_31'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "30_31", TransitStopFacility.class))); } /** - * The following layout is not according to scale, but shows the structure + * The following layout is not according to scale, but shows the structure * of the two 'complex' intersections. * 11 * | @@ -204,7 +204,7 @@ public final void testComplexIntersection() { * 12 * 3 / \ * | / \ - * | .__ 13 14 __. + * | .__ 13 14 __. * 4 / | | \ * / \ | | | | * .____ 5 ___ 6 _____> 110m _____ 15 ___ 16 ___ 17 ___ 18 ___. @@ -309,12 +309,12 @@ private Network buildComplexIntersection() { /* Link the two clusters */ NetworkUtils.createAndAddLink(network, Id.createLinkId("6_15"), n06, n15, 50.0, 80.0/3.6, 1000.0, 2.0 ); NetworkUtils.createAndAddLink(network, Id.createLinkId("19_8"), n19, n08, 50.0, 80.0/3.6, 1000.0, 2.0 ); - + /* Eastern extension, note length different from beeline distance */ Node n29 = NetworkUtils.createAndAddNode(network, Id.createNodeId(29), CoordUtils.createCoord(700.0, 85.0)); Node n30 = NetworkUtils.createAndAddNode(network, Id.createNodeId(30), CoordUtils.createCoord(800.0, 85.0)); Node n31 = NetworkUtils.createAndAddNode(network, Id.createNodeId(31), CoordUtils.createCoord(900.0, 85.0)); - + NetworkUtils.createAndAddLink(network, Id.createLinkId("28_29"), n28, n29, 400.0, 80.0/3.6, 1000.0, 1.0 ); NetworkUtils.createAndAddLink(network, Id.createLinkId("29_28"), n29, n28, 400.0, 80.0/3.6, 1000.0, 1.0 ); NetworkUtils.createAndAddLink(network, Id.createLinkId("29_30"), n29, n30, 100.0, 80.0/3.6, 1000.0, 1.0 ); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java index 74b1c64162c..50453286821 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.minibus.schedule; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -36,50 +36,50 @@ public class CreateStopsForAllCarLinksTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + @Test public final void testCreateStopsForAllCarLinks() { - + Network net = PScenarioHelper.createTestNetwork().getNetwork(); PConfigGroup pC = new PConfigGroup(); - + int numberOfCarLinks = 0; for (Link link : net.getLinks().values()) { if (link.getAllowedModes().contains(TransportMode.car)) { numberOfCarLinks++; } } - + TransitSchedule transitSchedule = CreateStopsForAllCarLinks.createStopsForAllCarLinks(net, pC); - + int numberOfParaStops = 0; for (TransitStopFacility stopFacility : transitSchedule.getFacilities().values()) { if (stopFacility.getId().toString().startsWith(pC.getPIdentifier())) { numberOfParaStops++; } } - + Assert.assertEquals("All car links got a paratransit stop", numberOfCarLinks, numberOfParaStops, MatsimTestUtils.EPSILON); TransitScheduleFactoryImpl tSF = new TransitScheduleFactoryImpl(); - + TransitSchedule realTransitSchedule = tSF.createTransitSchedule(); TransitStopFacility stop1 = tSF.createTransitStopFacility(Id.create("1314", TransitStopFacility.class), new Coord(0.0, 0.0), false); stop1.setLinkId(Id.create("1314", Link.class)); realTransitSchedule.addStopFacility(stop1); - + transitSchedule = CreateStopsForAllCarLinks.createStopsForAllCarLinks(net, pC, realTransitSchedule); - + numberOfParaStops = 0; for (TransitStopFacility stopFacility : transitSchedule.getFacilities().values()) { if (stopFacility.getId().toString().startsWith(pC.getPIdentifier())) { numberOfParaStops++; } } - + Assert.assertEquals("All car links minus one stop from formal transit got a paratransit stop", numberOfCarLinks - 1, numberOfParaStops, MatsimTestUtils.EPSILON); - + } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java index 6173890e187..fc160716cfb 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java @@ -20,14 +20,14 @@ package org.matsim.contrib.minibus.stats; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.minibus.stats.RecursiveStatsApproxContainer; import org.matsim.testcases.MatsimTestUtils; public class RecursiveStatsApproxContainerTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public final void testRecursiveStatsContainer() { @@ -43,7 +43,7 @@ public final void testRecursiveStatsContainer() { Assert.assertEquals("std dev route", Double.NaN, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev pax", Double.NaN, stats.getStdDevPax(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev veh", Double.NaN, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); - + stats.handleNewEntry(2.0, 3.0, 3.0, 1.0); Assert.assertEquals("mean coop", 1.5, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); Assert.assertEquals("mean route", 3.5, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); @@ -53,7 +53,7 @@ public final void testRecursiveStatsContainer() { Assert.assertEquals("std dev route", 0.7071067811865476, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev pax", 0.7071067811865476, stats.getStdDevPax(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev veh", 1.4142135623730951, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); - + stats.handleNewEntry(3.0, 2.0, 1.0, 2.0); Assert.assertEquals("mean coop", 2.0, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); Assert.assertEquals("mean route", 3.0, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); @@ -63,7 +63,7 @@ public final void testRecursiveStatsContainer() { Assert.assertEquals("std dev route", 1.0, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev pax", 1.0, stats.getStdDevPax(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev veh", 1.0, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); - + stats.handleNewEntry(1.0, 4.0, 2.0, 3.0); stats.handleNewEntry(2.0, 3.0, 3.0, 1.0); stats.handleNewEntry(12.0, 12345.0, 123.0, 1234.0); @@ -76,4 +76,4 @@ public final void testRecursiveStatsContainer() { Assert.assertEquals("std dev pax", 11.691, stats.getStdDevPax(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev veh", 111.7719, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); } -} \ No newline at end of file +} diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java index c51536689a4..5b51ce6808d 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java @@ -20,14 +20,14 @@ package org.matsim.contrib.minibus.stats; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.minibus.stats.RecursiveStatsContainer; import org.matsim.testcases.MatsimTestUtils; public class RecursiveStatsContainerTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public final void testRecursiveStatsContainer() { @@ -43,7 +43,7 @@ public final void testRecursiveStatsContainer() { Assert.assertEquals("std dev route", Double.NaN, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev pax", Double.NaN, stats.getStdDevPax(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev veh", Double.NaN, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); - + stats.handleNewEntry(2.0, 3.0, 3.0, 1.0); Assert.assertEquals("mean coop", 1.5, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); Assert.assertEquals("mean route", 3.5, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); @@ -53,7 +53,7 @@ public final void testRecursiveStatsContainer() { Assert.assertEquals("std dev route", 0.7071067811865476, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev pax", 0.7071067811865476, stats.getStdDevPax(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev veh", 1.4142135623730951, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); - + stats.handleNewEntry(3.0, 2.0, 1.0, 2.0); Assert.assertEquals("mean coop", 2.0, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); Assert.assertEquals("mean route", 3.0, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); @@ -63,7 +63,7 @@ public final void testRecursiveStatsContainer() { Assert.assertEquals("std dev route", 1.0, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev pax", 1.0, stats.getStdDevPax(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev veh", 1.0, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); - + stats.handleNewEntry(1.0, 4.0, 2.0, 3.0); stats.handleNewEntry(2.0, 3.0, 3.0, 1.0); stats.handleNewEntry(12.0, 12345.0, 123.0, 1234.0); @@ -76,4 +76,4 @@ public final void testRecursiveStatsContainer() { Assert.assertEquals("std dev pax", 49.32207078648124, stats.getStdDevPax(), MatsimTestUtils.EPSILON); Assert.assertEquals("std dev veh", 502.962689139728, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); } -} \ No newline at end of file +} diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java index 28c96b9e39d..e94aeb5073c 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java @@ -69,8 +69,8 @@ public class MultiModalControlerListenerTest { private static final Logger log = LogManager.getLogger(MultiModalControlerListenerTest.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @SuppressWarnings("static-method") @Test diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java index 77e61902f97..99407837927 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java @@ -3,7 +3,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; @@ -13,7 +13,7 @@ public class RunMultimodalExampleTest{ private static final Logger log = LogManager.getLogger( RunMultimodalExampleTest.class ) ; - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void main(){ diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java index c4bb7388e2c..52aa33e2fc2 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -60,8 +60,8 @@ public class MultiModalPTCombinationTest { private static final Logger log = LogManager.getLogger(MultiModalPTCombinationTest.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** * Two things are tested here: diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java index 7f95d342870..9f2cfda7ee0 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -46,8 +46,8 @@ public class BikeTravelTimeTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(BikeTravelTimeTest.class); diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java index ca66b5a25d5..2136ca6a756 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -46,8 +46,8 @@ public class WalkTravelTimeTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(WalkTravelTimeTest.class); diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java index ffb8924a15c..d7d87c67e8d 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -62,8 +62,8 @@ public class StuckAgentTest { private static final Logger log = LogManager.getLogger(StuckAgentTest.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testStuckEvents() { diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java index 7e07654ace8..0862fe22736 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java @@ -23,7 +23,7 @@ package org.matsim.contrib.noise; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -40,8 +40,8 @@ public class NoiseConfigGroupIT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public final void test0(){ diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java index aa179afd113..5d8569ad0e9 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java @@ -30,7 +30,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -72,8 +72,8 @@ public class NoiseIT { private static final Logger log = LogManager.getLogger( NoiseIT.class ); - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); // Tests the NoisSpatialInfo functionality separately for each function @Test diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java index c03d5d04e57..fa0e8c0c1e5 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.analysis.XYTRecord; import org.matsim.api.core.v01.Coord; @@ -54,8 +54,8 @@ public class NoiseOnlineExampleIT { private static final Logger log = LogManager.getLogger( NoiseOnlineExampleIT.class ) ; - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public final void test0(){ diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java index 3c9b486bb7a..096250d46d4 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java @@ -23,7 +23,7 @@ package org.matsim.contrib.noise; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; @@ -50,8 +50,8 @@ */ public class NoiseRLS19IT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testShielding() { diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderIT.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderIT.java index 613776996ad..e5a9f4558e9 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderIT.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.osm.networkReader; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.network.Network; import org.matsim.core.network.NetworkUtils; @@ -15,8 +15,8 @@ public class OsmBicycleReaderIT { private static final CoordinateTransformation coordinateTransformation = TransformationFactory.getCoordinateTransformation(TransformationFactory.WGS84, "EPSG:32631"); - @Rule - public MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); @Test public void test_andorra() { diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java index 9a00864be0b..bc7b8479342 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java @@ -2,7 +2,7 @@ import de.topobyte.osm4j.core.model.iface.OsmTag; import de.topobyte.osm4j.core.model.impl.Tag; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -23,8 +23,8 @@ public class OsmBicycleReaderTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void test_singleLinkWithAttributes() { diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java index ea2eef09583..03be0ed6ca9 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java @@ -4,7 +4,7 @@ import de.topobyte.osm4j.core.model.iface.OsmWay; import org.junit.After; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.geometry.CoordinateTransformation; @@ -25,8 +25,8 @@ public class OsmNetworkParserTest { private final ExecutorService executor = Executors.newSingleThreadExecutor(); private static final CoordinateTransformation transformation = new IdentityTransformation(); - @Rule - public MatsimTestUtils matsimUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils matsimUtils = new MatsimTestUtils(); @After public void shutDownExecutor() { diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java index cf47fdc1b91..c5ba94aab22 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java @@ -7,7 +7,7 @@ import de.topobyte.osm4j.core.model.impl.Tag; import org.junit.After; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.utils.geometry.CoordinateTransformation; import org.matsim.core.utils.geometry.transformations.IdentityTransformation; @@ -30,8 +30,8 @@ public class OsmSignalsParserTest { private final ExecutorService executor = Executors.newSingleThreadExecutor(); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @After @@ -229,4 +229,4 @@ private OsmRelation createRestriction(long id, OsmWay from, OsmWay to, OsmNode v return new Relation(id, members, tags); } -} \ No newline at end of file +} diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderIT.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderIT.java index 999e26a0dbb..423233c2079 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderIT.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderIT.java @@ -2,7 +2,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.network.Network; import org.matsim.core.network.NetworkUtils; @@ -17,8 +17,8 @@ public class SupersonicOsmNetworkReaderIT { private static final CoordinateTransformation coordinateTransformation = TransformationFactory.getCoordinateTransformation(TransformationFactory.WGS84, "EPSG:32631"); private static final Logger log = LogManager.getLogger(SupersonicOsmNetworkReaderIT.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void test_andorra() { diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java index 35e73c6cd71..95f68fad504 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java @@ -9,7 +9,7 @@ import de.topobyte.osm4j.pbf.seq.PbfWriter; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -39,8 +39,8 @@ public class SupersonicOsmNetworkReaderTest { private static final String MOTORWAY = "motorway"; private static final String TERTIARY = "tertiary"; - @Rule - public MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); private static void writeOsmData(Collection nodes, Collection ways, Path file) { diff --git a/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java b/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java index d713edcd6ab..b16a6a5d01d 100644 --- a/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java +++ b/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java @@ -24,7 +24,7 @@ package org.matsim.contrib.otfvis; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -48,8 +48,8 @@ */ public class OTFVisIT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testConvert() { diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java index 828685aec99..fcbc247bd76 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; @@ -34,7 +34,7 @@ public class RunWithParkingProxyIT { private static final Logger log = LogManager.getLogger(RunWithParkingProxyIT.class); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test @Ignore diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingChoiceExampleIT.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingChoiceExampleIT.java index 57792fb205d..483a118e22e 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingChoiceExampleIT.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingChoiceExampleIT.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.contrib.parking.run; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.parking.parkingchoice.run.RunParkingChoiceExample; import org.matsim.core.config.Config; @@ -30,7 +30,7 @@ * */ public class RunParkingChoiceExampleIT { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; /** * Test method for {@link org.matsim.contrib.parking.parkingchoice.run.RunParkingChoiceExample#run(org.matsim.core.config.Config)}. diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java index ef761cedee2..16f1a7f8525 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java @@ -20,7 +20,7 @@ package org.matsim.contrib.parking.run; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -39,8 +39,8 @@ * @author jbischoff */ public class RunParkingSearchScenarioIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRunParkingBenesonStrategy() { diff --git a/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java b/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java index b1c18d8ab07..5941d7c17dd 100644 --- a/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java +++ b/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java @@ -3,7 +3,7 @@ import com.google.protobuf.Descriptors; import org.assertj.core.api.Assertions; import org.assertj.core.api.Condition; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Id; @@ -27,11 +27,8 @@ public class EventWriterPBTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); - - @Rule - public TemporaryFolder tmp = new TemporaryFolder(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test public void writer() throws IOException { diff --git a/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java b/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java index 2a82fc13096..9e7f626e248 100644 --- a/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java +++ b/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java @@ -5,7 +5,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.FixMethodOrder; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runners.MethodSorters; import org.matsim.analysis.ScoreStatsControlerListener; @@ -33,8 +33,8 @@ @FixMethodOrder(MethodSorters.NAME_ASCENDING) public class RunPSimTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private final Logger logger = LogManager.getLogger(RunPSimTest.class ); diff --git a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java index f49a5b0901c..3fe816aff64 100644 --- a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java +++ b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java @@ -23,7 +23,7 @@ import ch.sbb.matsim.contrib.railsim.events.RailsimTrainStateEvent; import ch.sbb.matsim.contrib.railsim.qsimengine.RailsimQSimModule; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -58,8 +58,8 @@ public class RailsimIntegrationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testMicroSimpleBiDirectionalTrack() { diff --git a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java index a993b46fd49..922fbb513e5 100644 --- a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java +++ b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java @@ -24,7 +24,7 @@ import ch.sbb.matsim.contrib.railsim.qsimengine.disposition.SimpleDisposition; import ch.sbb.matsim.contrib.railsim.qsimengine.router.TrainRouter; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -39,8 +39,8 @@ public class RailsimEngineTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private EventsManager eventsManager; private RailsimTestUtils.EventCollector collector; diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java index 2f79155d1e4..e9877f905ca 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java @@ -26,7 +26,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -51,8 +51,8 @@ */ public class AvoidTolledRouteTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public final void test1(){ diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java index 6d8dabfc109..2ca1f243fff 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -50,8 +50,8 @@ * @author mrieser */ public class CalcPaidTollTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); static private final Logger log = LogManager.getLogger(CalcPaidTollTest.class); diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/ModuleTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/ModuleTest.java index 118dac01eb9..912a2cff00b 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/ModuleTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/ModuleTest.java @@ -22,7 +22,7 @@ package org.matsim.contrib.roadpricing; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -32,8 +32,8 @@ public class ModuleTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test(expected = RuntimeException.class) public void testControlerWithoutRoadPricingDoesntWork() { diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/PlansCalcRouteWithTollOrNotTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/PlansCalcRouteWithTollOrNotTest.java index df6e547c898..339abde2d1e 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/PlansCalcRouteWithTollOrNotTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/PlansCalcRouteWithTollOrNotTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -64,8 +64,8 @@ public class PlansCalcRouteWithTollOrNotTest { private static final Logger log = LogManager.getLogger( PlansCalcRouteWithTollOrNotTest.class ); - @Rule - public MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); /** * Tests a few cases where the router can decide if it is better to pay the diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java index 3d852263e75..ca59e1d482f 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java @@ -1,15 +1,15 @@ package org.matsim.contrib.roadpricing; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class RoadPricingConfigGroupTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void getTollLinksFile() { @@ -47,4 +47,4 @@ public void setEnforcementProbability() { cg.setEnforcementProbability(0.95); } -} \ No newline at end of file +} diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java index e45608b4fbd..b4d8412ea5c 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java @@ -21,7 +21,7 @@ package org.matsim.contrib.roadpricing; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -39,8 +39,8 @@ */ public class RoadPricingControlerIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testPaidTollsEndUpInScores() { diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java index 7ce688e6671..a93960aeb94 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java @@ -25,7 +25,7 @@ import java.io.File; import java.util.Iterator; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -41,8 +41,8 @@ */ public class RoadPricingIOTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java index b0c99aab041..6407bf1136d 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java @@ -27,7 +27,7 @@ import jakarta.inject.Provider; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -69,7 +69,7 @@ * @author mrieser */ public class TollTravelCostCalculatorTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java index 077f9d88514..98ce6fec965 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; @@ -39,7 +39,7 @@ * */ public class RoadPricingByConfigfileTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; private static final Logger log = LogManager.getLogger( RoadPricingByConfigfileTest.class ); diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java index e49a6410dfa..b73a1169381 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java @@ -1,12 +1,12 @@ package org.matsim.contrib.roadpricing.run; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class RunRoadPricingExampleIT { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); private static final String TEST_CONFIG = "./test/input/org/matsim/contrib/roadpricing/AvoidTolledRouteTest/config.xml"; diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java index 59043264ed7..f40c02b6b02 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java @@ -26,7 +26,7 @@ import java.nio.charset.StandardCharsets; import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -44,7 +44,7 @@ */ public class SBBQSimModuleTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Before public void setUp() { diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java index 579f960e19b..54dcc62891c 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.controler.Controler; import org.matsim.core.mobsim.framework.Mobsim; @@ -40,7 +40,7 @@ public class SBBTransitQSimEngineIntegrationTest { private static final Logger log = LogManager.getLogger(SBBTransitQSimEngineIntegrationTest.class); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testIntegration() { diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/adaptiveSignals/AdaptiveSignalsExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/adaptiveSignals/AdaptiveSignalsExampleTest.java index c351f323f17..a8f3454f627 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/adaptiveSignals/AdaptiveSignalsExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/adaptiveSignals/AdaptiveSignalsExampleTest.java @@ -20,7 +20,7 @@ */ package org.matsim.codeexamples.adaptiveSignals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -29,13 +29,13 @@ */ public class AdaptiveSignalsExampleTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); - + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); + @Test public void testAdaptiveSignalsExample() { String configFileName = "./examples/tutorial/singleCrossingScenario/config.xml"; RunAdaptiveSignalsExample.run(configFileName, testUtils.getOutputDirectory() + "/", false); } - + } diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java index 6ff30744d37..3068410bbba 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java @@ -24,7 +24,7 @@ import java.io.IOException; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.utils.misc.CRCChecksum; import org.matsim.testcases.MatsimTestUtils; @@ -37,8 +37,8 @@ public class CreateIntergreensExampleTest { private static final String DIR_TO_COMPARE_WITH = "./examples/tutorial/example90TrafficLights/useSignalInput/"; - @Rule public MatsimTestUtils testUtils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); + @Test public void testIntergreenExample(){ try { @@ -49,9 +49,9 @@ public void testIntergreenExample(){ Assert.fail("something went wrong") ; } // compare intergreen output - Assert.assertEquals("different intergreen files", - CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "intergreens.xml"), + Assert.assertEquals("different intergreen files", + CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "intergreens.xml"), CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "intergreens.xml")); } - + } diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java index 65a23d47da6..c52847d338b 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.utils.misc.CRCChecksum; import org.matsim.testcases.MatsimTestUtils; @@ -40,7 +40,7 @@ public class CreateSignalInputExampleTest { private static final String DIR_TO_COMPARE_WITH = "./examples/tutorial/example90TrafficLights/useSignalInput/woLanes/"; - @Rule public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testCreateSignalInputExample(){ @@ -56,14 +56,14 @@ public void testCreateSignalInputExample(){ final String referenceFilename = DIR_TO_COMPARE_WITH + "signal_systems.xml"; log.info( "outputFilename=" + outputFilename ) ; log.info( "referenceFilename=" + referenceFilename ) ; - Assert.assertEquals("different signal system files", - CRCChecksum.getCRCFromFile(outputFilename), + Assert.assertEquals("different signal system files", + CRCChecksum.getCRCFromFile(outputFilename), CRCChecksum.getCRCFromFile(referenceFilename)); } - Assert.assertEquals("different signal group files", + Assert.assertEquals("different signal group files", CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml")); - Assert.assertEquals("different signal control files", + Assert.assertEquals("different signal control files", CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml")); } diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java index 3aaeb001258..fd10d568b5c 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java @@ -24,7 +24,7 @@ import java.io.IOException; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.utils.misc.CRCChecksum; import org.matsim.testcases.MatsimTestUtils; @@ -36,9 +36,9 @@ public class CreateSignalInputExampleWithLanesTest { private static final String DIR_TO_COMPARE_WITH = "./examples/tutorial/example90TrafficLights/useSignalInput/withLanes/"; - - @Rule public MatsimTestUtils testUtils = new MatsimTestUtils(); - + + @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); + @Test public void testCreateSignalInputExampleWithLanes(){ try { @@ -48,18 +48,18 @@ public void testCreateSignalInputExampleWithLanes(){ Assert.fail("something went wrong") ; } // compare signal output - Assert.assertEquals("different signal system files", - CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_systems.xml"), + Assert.assertEquals("different signal system files", + CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_systems.xml"), CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_systems.xml")); - Assert.assertEquals("different signal group files", + Assert.assertEquals("different signal group files", CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml")); - Assert.assertEquals("different signal control files", + Assert.assertEquals("different signal control files", CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml")); - Assert.assertEquals("different lane files", + Assert.assertEquals("different lane files", CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "lane_definitions_v2.0.xml"), CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "lane_definitions_v2.0.xml")); } - + } diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java index ee8adba17bf..0b63f1b71a0 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java @@ -19,7 +19,7 @@ package org.matsim.codeexamples.fixedTimeSignals; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -32,7 +32,7 @@ */ public class RunSignalSystemsExampleTest { - @Rule public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public final void testExampleWithHoles() { diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java b/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java index 159fbf0ee6b..486848880db 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.data.SignalsData; @@ -46,16 +46,16 @@ public class FixResponsiveSignalResultsIT { private static final Logger LOG = LogManager.getLogger(FixResponsiveSignalResultsIT.class); - - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testOneCrossingExample() { LOG.info("Fix the results from the simple one-crossing-example in RunSimpleResponsiveSignalExample."); RunSimpleResponsiveSignalExample responsiveSignal = new RunSimpleResponsiveSignalExample(); responsiveSignal.run(); - + SignalsData signalsData = (SignalsData) responsiveSignal.getControler().getScenario().getScenarioElement(SignalsData.ELEMENT_NAME); SignalSystemControllerData signalControlSystem1 = signalsData.getSignalControlData().getSignalSystemControllerDataBySystemId() .get(Id.create("SignalSystem1", SignalSystem.class)); @@ -63,7 +63,7 @@ public void testOneCrossingExample() { SortedMap, SignalGroupSettingsData> signalGroupSettings = signalPlan.getSignalGroupSettingsDataByGroupId(); SignalGroupSettingsData group1Setting = signalGroupSettings.get(Id.create("SignalGroup1", SignalGroup.class)); SignalGroupSettingsData group2Setting = signalGroupSettings.get(Id.create("SignalGroup2", SignalGroup.class)); - + LOG.info("SignalGroup1: onset " + group1Setting.getOnset() + ", dropping " + group1Setting.getDropping()); LOG.info("SignalGroup2: onset " + group2Setting.getOnset() + ", dropping " + group2Setting.getDropping()); Assert.assertEquals(0, group1Setting.getOnset()); @@ -71,5 +71,5 @@ public void testOneCrossingExample() { Assert.assertEquals(30, group2Setting.getOnset()); Assert.assertEquals(55, group2Setting.getDropping()); } - + } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java index 5cde4a3e867..d8ffa385400 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java @@ -6,7 +6,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -29,15 +29,15 @@ * @author dgrether */ public class CalculateAngleTest { - + private static final Logger log = LogManager.getLogger(CalculateAngleTest.class); - - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + /** * @author aneumann */ - @Test + @Test public void testGetLeftLane() { Config conf = utils.loadConfig(utils.getClassInputDirectory() + "config.xml"); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(conf); @@ -51,18 +51,18 @@ public void testGetLeftLane() { Assert.assertEquals( scenario.getNetwork().getLinks().get(Id.create("3", Link.class)), NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("22", Link.class)))); - + Assert.assertEquals( scenario.getNetwork().getLinks().get(Id.create("4", Link.class)), NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("33", Link.class)))); - + Assert.assertEquals( scenario.getNetwork().getLinks().get(Id.create("1", Link.class)), NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("44", Link.class)))); - + Assert.assertEquals( scenario.getNetwork().getLinks().get(Id.create("5", Link.class)), NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("3", Link.class)))); - + } - + /** * @author dgrether */ @@ -82,13 +82,13 @@ public void testGetOutLinksSortedByAngle(){ Assert.assertEquals("For angle " + angle + "CalculateAngle returns not the correct order of outlinks", Id.create(3, Link.class), entry.getValue().getId()); entry = m.higherEntry(entry.getKey()); Assert.assertEquals("For angle " + angle + "CalculateAngle returns not the correct order of outlinks", Id.create(4, Link.class), entry.getValue().getId()); - + Link leftLane = NetworkUtils.getLeftmostTurnExcludingU(net.getLinks().get(Id.create(1, Link.class))); Assert.assertEquals(Id.create(2, Link.class), leftLane.getId()); - + } } - + /** * creates a network with node 5 at 0,0 the other nodes build a cross spanning 200 m * coordinates: @@ -98,7 +98,7 @@ public void testGetOutLinksSortedByAngle(){ * | * 1 * @param sc - * @param ids + * @param ids */ private void createNetwork(Scenario sc, double alpha){ Network net = sc.getNetwork(); @@ -138,7 +138,7 @@ private void createNetwork(Scenario sc, double alpha){ link = netfac.createLink(Id.create(4, Link.class), node5, node4); net.addLink(link); } - - - -} \ No newline at end of file + + + +} diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java index 6d053ad2930..468f9e7f376 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java @@ -4,7 +4,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -36,52 +36,52 @@ import org.matsim.testcases.MatsimTestUtils; /** - * + * * @author tschlenther * this class tests the functionality of TtTotalDelay in playground.dgrether.koehlerstrehlersignal.analysis - * which calculates the total delay of all agents in a network - * + * which calculates the total delay of all agents in a network + * * having only one agent in a network, the total delay should be 0 (testGetTotalDelayOnePerson) * calculation of the delay of all persons in a network should be made in awareness of matsim's step logic * * the network generated in this tests basically consists of 4 links of 1000m with a free speed of 201 m/s * output is optionally written to outputDirectory of this testClass * -> set field writeOutput to do so - * + * * the number of persons to be set in the network for the test can be modified * they will get an insertion delay due to the capacity of the first link */ public class DelayAnalysisToolTest { - - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + private final Id LINK_ID1 = Id.create("Link1", Link.class); private final Id LINK_ID2 = Id.create("Link2", Link.class); private final Id LINK_ID3 = Id.create("Link3", Link.class); private final Id LINK_ID4 = Id.create("Link4", Link.class); - + //optionally to be modified private static final boolean WRITE_OUTPUT = false; private static final int NUMBER_OF_PERSONS = 5; - + @Test public void testGetTotalDelayOnePerson(){ Scenario scenario = prepareTest(1); - + EventsManager events = EventsUtils.createEventsManager(); DelayAnalysisTool handler = new DelayAnalysisTool(scenario.getNetwork(), events); - + final List eventslist = new ArrayList(); events.addHandler(new BasicEventHandler(){ @Override public void reset(int iteration) { - eventslist.clear(); + eventslist.clear(); } @Override public void handleEvent(Event event) { - eventslist.add(event); + eventslist.add(event); } }); @@ -97,19 +97,19 @@ public void handleEvent(Event event) { @Test public void testGetTotalDelaySeveralPerson(){ Scenario scenario = prepareTest(NUMBER_OF_PERSONS); - + EventsManager events = EventsUtils.createEventsManager(); DelayAnalysisTool handler = new DelayAnalysisTool(scenario.getNetwork(), events); - + final List eventslist = new ArrayList(); events.addHandler(new BasicEventHandler(){ @Override public void reset(int iteration) { - eventslist.clear(); + eventslist.clear(); } @Override public void handleEvent(Event event) { - eventslist.add(event); + eventslist.add(event); } }); @@ -119,7 +119,7 @@ public void handleEvent(Event event) { if(WRITE_OUTPUT){ generateOutput(scenario, eventslist); } - + //expectedDelay = inserting delay as a result of capacity of first link being 3600 vh/h int expectedDelay = 0; for(int i=0; i eventslist) { + private void generateOutput(Scenario scenario, final List eventslist) { EventWriterXML eventWriter = new EventWriterXML(utils.getOutputDirectory() + "events.xml"); for (Event e : eventslist) { eventWriter.handleEvent(e); @@ -145,7 +145,7 @@ private Scenario prepareTest(int numberOfPersons) { createPopulation(scenario, numberOfPersons); return scenario; } - + void createNetwork(Scenario scenario){ Network network = scenario.getNetwork(); NetworkFactory factory = network.getFactory(); @@ -167,26 +167,26 @@ void createNetwork(Scenario scenario){ link1.setLength(1000); link1.setFreespeed(201); network.addLink(link1); - - Link link2 = factory.createLink((LINK_ID2), node2, node3); + + Link link2 = factory.createLink((LINK_ID2), node2, node3); link2.setCapacity(3600); link2.setLength(1000); link2.setFreespeed(201); - network.addLink(link2); - + network.addLink(link2); + Link link3 = factory.createLink((LINK_ID3), node3 , node4); link3.setCapacity(3600); link3.setLength(1000); link3.setFreespeed(201); network.addLink(link3); - - Link link4 = factory.createLink((LINK_ID4), node4, node5); + + Link link4 = factory.createLink((LINK_ID4), node4, node5); link4.setCapacity(3600); link4.setLength(1000); link4.setFreespeed(201); - network.addLink(link4); + network.addLink(link4); } - + private void createPopulation(Scenario scenario, int numberOfPersons) { Population population = scenario.getPopulation(); PopulationFactory popFactory = (PopulationFactory) scenario.getPopulation().getFactory(); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java index ef406e1aa02..62d0078f7c3 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.LinkEnterEvent; @@ -56,12 +56,12 @@ public class QSimSignalTest implements private double link2EnterTime = Double.NaN; - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); - + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); + private final Fixture fixture = new Fixture(); - - + + /** * Tests the setup with a traffic light that shows all the time green */ @@ -69,17 +69,17 @@ public class QSimSignalTest implements public void testTrafficLightIntersection2arms1AgentV20() { // configure and load standard scenario Scenario scenario = fixture.createAndLoadTestScenarioOneSignal(false ); - + this.link2EnterTime = 38.0; runQSimWithSignals(scenario, true); } /** - * Tests the setup with a traffic light that shows red up to second 99 then in sec 100 green. + * Tests the setup with a traffic light that shows red up to second 99 then in sec 100 green. */ @Test - public void testSignalSystems1AgentGreenAtSec100() { + public void testSignalSystems1AgentGreenAtSec100() { // configure and load standard scenario Scenario scenario = fixture.createAndLoadTestScenarioOneSignal(false ); // modify scenario @@ -97,7 +97,7 @@ public void testSignalSystems1AgentGreenAtSec100() { this.link2EnterTime = 100.0; runQSimWithSignals(scenario, true); } - + /** * Tests the setup with a traffic light that shows red less than the specified intergreen time of five seconds. */ @@ -115,14 +115,14 @@ public void testIntergreensAbortOneAgentDriving() { planData.setCycleTime(60); SignalGroupSettingsData groupData = planData.getSignalGroupSettingsDataByGroupId().get( fixture.signalGroupId100 ); groupData.setOnset(0); - groupData.setDropping(59); - + groupData.setDropping(59); + runQSimWithSignals(scenario, false); // if this code is reached, no exception has been thrown Assert.fail("The simulation should abort because of intergreens violation."); } - + /** * Tests the setup with a traffic light which red time corresponds to the specified intergreen time of five seconds. */ @@ -140,12 +140,12 @@ public void testIntergreensNoAbortOneAgentDriving() { planData.setCycleTime(60); SignalGroupSettingsData groupData = planData.getSignalGroupSettingsDataByGroupId().get( fixture.signalGroupId100 ); groupData.setOnset(30); - groupData.setDropping(25); - + groupData.setDropping(25); + this.link2EnterTime = 38.0; runQSimWithSignals(scenario, true); } - + /** * Tests the setup with two conflicting directions showing green together */ @@ -159,7 +159,7 @@ public void testConflictingDirectionsAbortOneAgentDriving() { // if this code is reached, no exception has been thrown Assert.fail("The simulation should abort because of intergreens violation."); } - + /** * Tests the setup with two conflicting directions not showing green together */ @@ -177,8 +177,8 @@ public void testConflictingDirectionsNoAbortOneAgentDriving() { runQSimWithSignals(scenario, false); } - - + + private void runQSimWithSignals(final Scenario scenario, boolean handleEvents) throws RuntimeException { // /* // * this is the old version how to build an injector without a controler and @@ -195,7 +195,7 @@ private void runQSimWithSignals(final Scenario scenario, boolean handleEvents) t // install(new ScenarioByInstanceModule(scenario)); // } // }), new SignalsModule())); -// +// // EventsManager events = injector.getInstance(EventsManager.class); // if (handleEvents){ // events.addHandler(this); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java index da098163ddb..350093c5ec6 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java @@ -21,7 +21,7 @@ package org.matsim.contrib.signals.builder; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.signals.SignalSystemsConfigGroup; @@ -49,8 +49,8 @@ public class TravelTimeFourWaysTest { private static final String EVENTSFILE = "events.xml.gz"; - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testTrafficLightIntersection4arms() { diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java index fde085e7b61..0dc9ba78923 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -66,8 +66,8 @@ public class TravelTimeOneWayTestIT { private static final Logger log = LogManager.getLogger(TravelTimeOneWayTestIT.class); - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testSignalOutflow_withLanes() { diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java index 9e5a726548a..b7498921eae 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -81,8 +81,8 @@ public class DefaultPlanbasedSignalSystemControllerIT { private static final Logger log = LogManager.getLogger(DefaultPlanbasedSignalSystemControllerIT.class); - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void test2SequentialPlansCompleteDay(){ diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java index d5e9aaf88ca..570bb7374d4 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -64,8 +64,8 @@ public class LaemmerIT { private static final Logger log = LogManager.getLogger(LaemmerIT.class); - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); private static final int maxCycleTime = 90; private static final int cycleIntergreenTime = 10; diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java index 3954235366d..2d083c75e07 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -85,8 +85,8 @@ public class SylviaIT { private static final Logger log = LogManager.getLogger(SylviaIT.class); - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); /** * Test sylvia with two conflicting streams at a single intersection. A fixed diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java index 30524b50342..5cccb0ced12 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.model.Signal; @@ -37,7 +37,7 @@ /** * @author jbischoff * @author dgrether - * + * */ public class AmberTimesData10ReaderWriterTest { @@ -45,8 +45,8 @@ public class AmberTimesData10ReaderWriterTest { private static final String TESTXML = "testAmberTimes_v1.0.xml"; - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testParser() throws IOException, JAXBException, SAXException, diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java index 64bc0458e0d..6513066495f 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -37,31 +37,31 @@ * @author tthunig */ public class SignalConflictDataReaderWriterTest { - + private static final Logger LOG = LogManager.getLogger(SignalConflictDataReaderWriterTest.class); - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); - + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); + @Test public void testReaderAndWriter() { LOG.info("create conflict data"); ConflictData conflictData = createConflictDataForTestCase(); - + LOG.info("write conflict data"); ConflictingDirectionsWriter writer = new ConflictingDirectionsWriter(conflictData); String filename = this.testUtils.getOutputDirectory() + "signalConflictData.xml"; writer.write(filename); - + LOG.info("read conflict data"); ConflictData readConflictData = new ConflictDataImpl(); ConflictingDirectionsReader reader = new ConflictingDirectionsReader(readConflictData); reader.readFile(filename); - + LOG.info("compare written and read conflict data"); compare(conflictData, readConflictData); } - + private void compare(ConflictData conflictData1, ConflictData conflictData2) { Assert.assertEquals("not the same number of intersections", conflictData1.getConflictsPerNode().size(), conflictData2.getConflictsPerNode().size()); for (IntersectionDirections intersection1 : conflictData1.getConflictsPerSignalSystem().values()) { @@ -103,7 +103,7 @@ private void compare(ConflictData conflictData1, ConflictData conflictData2) { * < --- 1 --- > x < --- 3 --- > x < --- 4 --- > */ private ConflictData createConflictDataForTestCase() { - + Id signalSystemId1 = Id.create("sys1", SignalSystem.class); Id nodeId1 = Id.createNodeId("node1"); Id linkId1 = Id.createLinkId("link1"); @@ -118,46 +118,46 @@ private ConflictData createConflictDataForTestCase() { Id dirId23 = Id.create(linkId2 + "-" + linkId3, Direction.class); Id dirId34 = Id.create(linkId3 + "-" + linkId4, Direction.class); Id dirId43 = Id.create(linkId4 + "-" + linkId3, Direction.class); - + ConflictData conflictData = new ConflictDataImpl(); IntersectionDirections intersection1 = conflictData.getFactory().createConflictingDirectionsContainerForIntersection(signalSystemId1, nodeId1); conflictData.addConflictingDirectionsForIntersection(signalSystemId1, nodeId1, intersection1); - + Direction dir13 = conflictData.getFactory().createDirection(signalSystemId1, nodeId1, linkId1, linkId3, dirId13); intersection1.addDirection(dir13); dir13.addNonConflictingDirection(dirId31); dir13.addNonConflictingDirection(dirId12); dir13.addConflictingDirection(dirId23); - + Direction dir31 = conflictData.getFactory().createDirection(signalSystemId1, nodeId1, linkId3, linkId1, dirId31); intersection1.addDirection(dir31); dir31.addNonConflictingDirection(dirId13); dir31.addDirectionWhichMustYield(dirId12); dir31.addConflictingDirection(dirId23); - + Direction dir12 = conflictData.getFactory().createDirection(signalSystemId1, nodeId1, linkId1, linkId2, dirId12); intersection1.addDirection(dir12); dir12.addNonConflictingDirection(dirId13); dir12.addDirectionWithRightOfWay(dirId31); dir12.addConflictingDirection(dirId23); - + Direction dir23 = conflictData.getFactory().createDirection(signalSystemId1, nodeId1, linkId2, linkId3, dirId23); intersection1.addDirection(dir23); dir23.addConflictingDirection(dirId12); dir23.addConflictingDirection(dirId13); dir23.addConflictingDirection(dirId31); - + IntersectionDirections intersection2 = conflictData.getFactory().createConflictingDirectionsContainerForIntersection(signalSystemId2, nodeId2); conflictData.addConflictingDirectionsForIntersection(signalSystemId2, nodeId2, intersection2); - + Direction dir34 = conflictData.getFactory().createDirection(signalSystemId2, nodeId2, linkId3, linkId4, dirId34); intersection2.addDirection(dir34); dir34.addNonConflictingDirection(dirId43); - + Direction dir43 = conflictData.getFactory().createDirection(signalSystemId2, nodeId2, linkId4, linkId3, dirId43); intersection2.addDirection(dir43); dir43.addNonConflictingDirection(dirId43); - + return conflictData; } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java index e33fed5dc46..92eef4f43c2 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java @@ -21,7 +21,7 @@ package org.matsim.contrib.signals.data.conflicts; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.signals.SignalSystemsConfigGroup; @@ -41,8 +41,8 @@ */ public class UnprotectedLeftTurnLogicTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testSingleIntersectionScenarioWithLeftTurns() { diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java index 593cc5868da..794b36a3482 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.model.SignalGroup; @@ -37,7 +37,7 @@ /** * @author dgrether - * + * */ public class IntergreenTimesData10ReaderWriterTest { @@ -45,8 +45,8 @@ public class IntergreenTimesData10ReaderWriterTest { private static final String TESTXML = "testIntergreenTimes_v1.0.xml"; - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); private Id groupId1 = Id.create("1", SignalGroup.class); private Id groupId2 = Id.create("2", SignalGroup.class); @@ -97,7 +97,7 @@ private void checkContent(IntergreenTimesData itd) { Assert.assertEquals(Integer.valueOf(3), ig23.getIntergreenTime(groupId1, groupId3)); Assert.assertEquals(Integer.valueOf(3), ig23.getIntergreenTime(groupId1, groupId4)); Assert.assertNull(ig23.getIntergreenTime(groupId2, groupId3)); - + IntergreensForSignalSystemData ig42 = itd.getIntergreensForSignalSystemDataMap().get(systemId42); Assert.assertNotNull(ig42); Assert.assertEquals(Integer.valueOf(5), ig42.getIntergreenTime(groupId1, groupId2)); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java index 26956aa1cbe..7decd766c3a 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.data.signalsystems.v20.SignalSystemControllerData; @@ -39,7 +39,7 @@ /** * @author dgrether - * + * */ public class SignalControlData20ReaderWriterTest { @@ -48,19 +48,19 @@ public class SignalControlData20ReaderWriterTest { private static final String TESTXML = "testSignalControl_v2.0.xml"; private Id systemId42 = Id.create("42", SignalSystem.class); - + private Id signalPlanId8 = Id.create("8", SignalPlan.class); - + private Id groupId23 = Id.create("23", SignalGroup.class); - + private Id systemId43 = Id.create("43", SignalSystem.class); - + // private Id id24 = new IdImpl("24"); // private Id id5 = new IdImpl("5"); - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testReader() throws JAXBException, SAXException, ParserConfigurationException, IOException{ @@ -69,7 +69,7 @@ public void testReader() throws JAXBException, SAXException, ParserConfiguration reader.readFile(this.testUtils.getPackageInputDirectory() + TESTXML); checkContent(controlData); } - + @Test public void testWriter() throws JAXBException, SAXException, ParserConfigurationException, IOException { String testoutput = this.testUtils.getOutputDirectory() + "testSignalControlOutput.xml"; @@ -78,12 +78,12 @@ public void testWriter() throws JAXBException, SAXException, ParserConfiguration SignalControlData controlData = new SignalControlDataImpl(); SignalControlReader20 reader = new SignalControlReader20(controlData); reader.readFile(this.testUtils.getPackageInputDirectory() + TESTXML); - + //write the test file log.debug("write the test file..."); SignalControlWriter20 writer = new SignalControlWriter20(controlData); writer.write(testoutput); - + log.debug("and read it again"); controlData = new SignalControlDataImpl(); reader = new SignalControlReader20(controlData); @@ -91,13 +91,13 @@ public void testWriter() throws JAXBException, SAXException, ParserConfiguration checkContent(controlData); } - - - + + + private void checkContent(SignalControlData controlData) { Assert.assertNotNull(controlData); Assert.assertEquals(2, controlData.getSignalSystemControllerDataBySystemId().size()); - + //first controller SignalSystemControllerData systemController = controlData.getSignalSystemControllerDataBySystemId().get(systemId42); Assert.assertNotNull(systemController); @@ -114,7 +114,7 @@ private void checkContent(SignalControlData controlData) { Assert.assertNotNull(cycleTime); Assert.assertEquals(Integer.valueOf(60), cycleTime); Assert.assertEquals(3, plan.getOffset()); - + Assert.assertNotNull(plan.getSignalGroupSettingsDataByGroupId()); SignalGroupSettingsData signalGroupSettings = plan.getSignalGroupSettingsDataByGroupId().get(groupId23); Assert.assertNotNull(signalGroupSettings); @@ -123,7 +123,7 @@ private void checkContent(SignalControlData controlData) { Assert.assertEquals(0, signalGroupSettings.getOnset()); Assert.assertNotNull(signalGroupSettings.getDropping()); Assert.assertEquals(45, signalGroupSettings.getDropping()); - + //second controller systemController = controlData.getSignalSystemControllerDataBySystemId().get(systemId43); Assert.assertNotNull(systemController); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java index 6b36fac7401..a6d27f26127 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java @@ -30,7 +30,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.model.Signal; @@ -42,15 +42,15 @@ /** * @author jbischoff * @author dgrether -* +* */ public class SignalGroups20ReaderWriterTest { private static final Logger log = LogManager.getLogger(SignalGroups20ReaderWriterTest.class); private static final String TESTXML = "testSignalGroups_v2.0.xml"; - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); private Id id23 = Id.create("23", SignalSystem.class); private Id id1 = Id.create("1", Signal.class); @@ -71,7 +71,7 @@ public void testParser() throws IOException, JAXBException, SAXException, checkContent(sgd); } - + @Test public void testWriter() throws JAXBException, SAXException, ParserConfigurationException, IOException { @@ -93,21 +93,21 @@ public void testWriter() throws JAXBException, SAXException, ParserConfiguration reader.readFile(testoutput); checkContent(sgd); } - - + + private void checkContent(SignalGroupsData sgd) { Assert.assertNotNull(sgd); Assert.assertNotNull(sgd.getSignalGroupDataBySignalSystemId()); Assert.assertNotNull(sgd.getSignalGroupDataBySystemId(id23)); - + //sg23 Map,SignalGroupData> ss23 = sgd.getSignalGroupDataBySystemId(id23); Assert.assertEquals(id23,ss23.get(idSg1).getSignalSystemId()); Set> sg = ss23.get(idSg1).getSignalIds(); Assert.assertTrue(sg.contains(id1)); - + //sg42 Assert.assertNotNull(sgd.getSignalGroupDataBySystemId(id42)); Map,SignalGroupData> ss42 = sgd.getSignalGroupDataBySystemId(id42); @@ -119,17 +119,17 @@ private void checkContent(SignalGroupsData sgd) { Assert.assertTrue(sg.contains(id1)); Assert.assertTrue(sg.contains(id4)); Assert.assertTrue(sg.contains(id5)); - - - - + + + + } - - + + } - - - - + + + + diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java index 17ab6161634..88fa1c1e46d 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -44,37 +44,37 @@ * @author dgrether */ public class SignalSystemsData20ReaderWriterTest { - + private static final Logger log = LogManager.getLogger(SignalSystemsData20ReaderWriterTest.class); - + private static final String TESTXML = "testSignalSystems_v2.0.xml"; - - @Rule public MatsimTestUtils testUtils = new MatsimTestUtils(); - + + @RegisterExtension public MatsimTestUtils testUtils = new MatsimTestUtils(); + private Id systemId1 = Id.create("1", SignalSystem.class); private Id signalId1 = Id.create("1", Signal.class); private Id laneId1 = Id.create("1", Lane.class); private Id linkId1 = Id.create("1", Link.class); - + private Id systemId2 = Id.create("2", SignalSystem.class); private Id signalId2 = Id.create("2", Signal.class); private Id linkId2 = Id.create("2", Link.class); private Id laneId2 = Id.create("2", Lane.class); - + private Id signalId3 = Id.create("3", Signal.class); private Id linkId3 = Id.create("3", Link.class); - + private Id linkId4 = Id.create("4", Link.class); - + @Test public void testParser() throws IOException, JAXBException, SAXException, ParserConfigurationException { SignalSystemsData lss = new SignalSystemsDataImpl(); SignalSystemsReader20 reader = new SignalSystemsReader20(lss); reader.readFile(this.testUtils.getPackageInputDirectory() + TESTXML); - + checkContent(lss); } - + @Test public void testWriter() throws JAXBException, SAXException, ParserConfigurationException, IOException { String testoutput = this.testUtils.getOutputDirectory() + "testLssOutput.xml"; @@ -83,12 +83,12 @@ public void testWriter() throws JAXBException, SAXException, ParserConfiguration SignalSystemsData lss = new SignalSystemsDataImpl(); SignalSystemsReader20 reader = new SignalSystemsReader20(lss); reader.readFile(this.testUtils.getPackageInputDirectory() + TESTXML); - + //write the test file log.debug("write the test file..."); SignalSystemsWriter20 writer = new SignalSystemsWriter20(lss); writer.write(testoutput); - + log.debug("and read it again"); lss = new SignalSystemsDataImpl(); reader = new SignalSystemsReader20(lss); @@ -101,14 +101,14 @@ private void checkContent(SignalSystemsData ss) { SignalSystemData ssdata = ss.getSignalSystemData().get(systemId1); Assert.assertNotNull(ssdata); Assert.assertEquals(2, ssdata.getSignalData().size()); - + SignalData signaldata = ssdata.getSignalData().get(signalId1); Assert.assertNotNull(signaldata); Assert.assertEquals(signalId1, signaldata.getId()); Assert.assertEquals(linkId1, signaldata.getLinkId()); Assert.assertNull(signaldata.getLaneIds()); Assert.assertNull(signaldata.getTurningMoveRestrictions()); - + signaldata = ssdata.getSignalData().get(signalId2); Assert.assertNotNull(signaldata); Assert.assertEquals(signalId2, signaldata.getId()); @@ -117,8 +117,8 @@ private void checkContent(SignalSystemsData ss) { Assert.assertEquals(1, signaldata.getTurningMoveRestrictions().size()); Assert.assertEquals(linkId3, signaldata.getTurningMoveRestrictions().iterator().next()); Assert.assertNull(signaldata.getLaneIds()); - - //system id 2 + + //system id 2 ssdata = ss.getSignalSystemData().get(systemId2); Assert.assertNotNull(ssdata); @@ -141,7 +141,7 @@ private void checkContent(SignalSystemsData ss) { Assert.assertNotNull(signaldata.getTurningMoveRestrictions()); Assert.assertEquals(1, signaldata.getTurningMoveRestrictions().size()); Assert.assertTrue(signaldata.getTurningMoveRestrictions().contains(linkId3)); - + } } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java index 96b73fa8a3d..c3be6656303 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java @@ -20,7 +20,7 @@ package org.matsim.contrib.signals.integration; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.signals.builder.Signals; @@ -48,8 +48,8 @@ public class SignalSystemsIT { private final static String CONFIG_FILE_NAME = "signalSystemsIntegrationConfig.xml"; - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testSignalSystems() { diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java index 3515b7fba6e..643e89a87b8 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java @@ -20,7 +20,7 @@ package org.matsim.contrib.signals.integration.invertednetworks; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -43,8 +43,8 @@ * */ public class InvertedNetworksSignalsIT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public final void testSignalsInvertedNetworkRouting() { diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java index 7a8db642e1c..f2dd03ed0a0 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java @@ -14,7 +14,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -63,8 +63,8 @@ public class SignalsAndLanesOsmNetworkReaderTest { private static final Logger log = LogManager.getLogger(SignalsAndLanesOsmNetworkReaderTest.class); - @Rule - public MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); @Parameterized.Parameters public static Collection data() { diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java index 6b981e6ba59..8f1d630c363 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java @@ -21,7 +21,7 @@ import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -50,8 +50,8 @@ */ public class ControlerTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); /** * Tests the setup with a traffic light that shows all the time green in the 0th iteration. diff --git a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java index be3f8870410..f9fd687abc1 100644 --- a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java +++ b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java @@ -9,14 +9,16 @@ package org.matsim.contrib.simulatedannealing; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; +import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.testcases.MatsimTestUtils; import org.matsim.contrib.simulatedannealing.temperature.TemperatureFunction; +import java.io.File; import java.io.IOException; import java.nio.file.Path; import java.util.Map; @@ -26,8 +28,8 @@ */ public class SimulatedAnnealingConfigGroupTest { - @Rule - public TemporaryFolder tempFolder = new TemporaryFolder(); + @TempDir + public File tempFolder; private static Config createConfig() { Config config = ConfigUtils.createConfig(); @@ -42,9 +44,9 @@ private static Config createConfig() { } - private static Path writeConfig(final TemporaryFolder tempFolder) throws IOException { + private static Path writeConfig(final File tempFolder) throws IOException { Config config = createConfig(); - Path configFile = tempFolder.newFile("config.xml").toPath(); + Path configFile = new File(tempFolder,"config.xml").toPath(); ConfigUtils.writeConfig(config, configFile.toString()); return configFile; } diff --git a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingIT.java b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingIT.java index a8622e6ba36..87e9026ec3e 100644 --- a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingIT.java +++ b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingIT.java @@ -1,7 +1,7 @@ package org.matsim.contrib.simulatedannealing; import com.google.inject.TypeLiteral; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkLeaveEvent; @@ -31,8 +31,8 @@ */ public class SimulatedAnnealingIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testIntegratedAnnealingInQSim() { diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperConfigGroupTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperConfigGroupTest.java index 76798aa58bb..9d3f59ae4e8 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperConfigGroupTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperConfigGroupTest.java @@ -1,7 +1,7 @@ package org.matsim.simwrapper; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -10,8 +10,8 @@ public class SimWrapperConfigGroupTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void config() { diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperModuleTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperModuleTest.java index 0e781bb830d..8a6cdeba974 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperModuleTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperModuleTest.java @@ -1,6 +1,6 @@ package org.matsim.simwrapper; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -13,8 +13,8 @@ public class SimWrapperModuleTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void runScenario() { diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperTest.java index 91ab0825970..b9e985f1fee 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperTest.java @@ -1,7 +1,7 @@ package org.matsim.simwrapper; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.simwrapper.viz.*; @@ -14,8 +14,8 @@ public class SimWrapperTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void vizElementsTest() throws IOException { diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/DashboardTests.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/DashboardTests.java index 394797cdea9..1b103bdd313 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/DashboardTests.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/DashboardTests.java @@ -1,7 +1,7 @@ package org.matsim.simwrapper.dashboard; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.application.MATSimApplication; import org.matsim.core.config.Config; @@ -16,8 +16,8 @@ import java.nio.file.Path; public class DashboardTests { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private void run(Dashboard... dashboards) { diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java index 5fd6f285973..c14a93d3d82 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java @@ -3,7 +3,7 @@ import com.google.common.collect.Iterables; import org.assertj.core.api.Assertions; import org.junit.Assume; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -33,8 +33,8 @@ public class EmissionsDashboardTest { private static final String HBEFA_FILE_COLD_AVERAGE = HBEFA_2020_PATH + "r9230ru2n209r30u2fn0c9rn20n2rujkhkjhoewt84202.enc"; private static final String HBEFA_FILE_WARM_AVERAGE = HBEFA_2020_PATH + "7eff8f308633df1b8ac4d06d05180dd0c5fdf577.enc"; - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void generate() { diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/TrafficCountsDashboardTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/TrafficCountsDashboardTest.java index 876e5d01552..8078e9c6e44 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/TrafficCountsDashboardTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/TrafficCountsDashboardTest.java @@ -1,7 +1,7 @@ package org.matsim.simwrapper.dashboard; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -28,8 +28,8 @@ public class TrafficCountsDashboardTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void generate() { diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java index 1bbd1c1e631..6fc28108a5b 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java @@ -2,7 +2,7 @@ import com.fasterxml.jackson.databind.ObjectWriter; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import tech.tablesaw.api.IntColumn; @@ -27,8 +27,8 @@ */ public class PlotlyExamplesTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private ObjectWriter writer; diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java index 8009eb1d981..987f1464e0b 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java @@ -11,7 +11,7 @@ import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule; import org.assertj.core.api.Assertions; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.simwrapper.ComponentMixin; import org.matsim.testcases.MatsimTestUtils; @@ -28,8 +28,8 @@ public class PlotlyTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private ObjectWriter writer; diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java index 95c103aa9c7..56cf258be11 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java @@ -27,7 +27,7 @@ import java.util.Random; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -46,7 +46,7 @@ * @author thibautd */ public class JointPlanIOTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java index 86d755078b6..9bc61d77eee 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java @@ -25,7 +25,7 @@ import java.util.Set; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -39,7 +39,7 @@ * @author thibautd */ public class SocialNetworkIOTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java index 08b2ba9c53f..80a234c05fe 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -46,7 +46,7 @@ * @author thibautd */ public class FixedGroupsIT { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java index e3e19d4dba3..5bc566bb884 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.population.Plan; import org.matsim.core.utils.collections.Tuple; @@ -44,7 +44,7 @@ public class FullExplorationVsCuttoffTest { private static final Logger log = LogManager.getLogger(FullExplorationVsCuttoffTest.class); - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java index 5aadbb30477..9a86bd3f1bb 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -79,7 +79,7 @@ public class JointTravelingSimulationIntegrationTest { private static final Logger log = LogManager.getLogger(JointTravelingSimulationIntegrationTest.class); - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); private static enum RouteType { @@ -87,7 +87,7 @@ private static enum RouteType { puAtDo, puAtDoFullCycle, everythingAtOrigin - }; + }; // helps to understand test failures, but makes the test more expensive. // => to set to true when fixing tests only @@ -454,7 +454,7 @@ private Scenario createTestScenario( fixture.puLink, fixture.doLink ); dRoute.setLinkIds( - fixture.puLink , + fixture.puLink , fixture.puToDoRoute, fixture.doLink); dRoute.addPassenger( passengerId1 ); @@ -489,7 +489,7 @@ private Scenario createTestScenario( driverPlan.addActivity( act ); } - // passengers + // passengers for (Id passengerId : new Id[]{ passengerId1 , passengerId2 }) { final Person p1 = factory.createPerson( passengerId ); final Plan p1Plan = factory.createPlan(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java index 99da384c041..ceeca695ac9 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java @@ -23,7 +23,7 @@ import java.util.Collection; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -47,7 +47,7 @@ * @author thibautd */ public class JointScenarioUtilsTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test @@ -80,7 +80,7 @@ public void testJointTripsImport() throws Exception { final Leg dumpedLeg = (Leg) dumpedPlan.getPlanElements().get( 1 ); final Leg loadedLeg = (Leg) loadedPlan.getPlanElements().get( 1 ); - + if (dumpedLeg.getMode().equals( JointActingTypes.DRIVER )) { assertEquals( "wrong route class", @@ -121,7 +121,7 @@ private static Population createPopulation() { final Plan driverPlan = population.getFactory().createPlan(); driverPlan.setPerson( driver ); driver.addPlan( driverPlan ); - + driverPlan.addActivity( population.getFactory().createActivityFromLinkId( "h" , Id.create( 1 , Link.class ) ) ); final Leg driverLeg = population.getFactory().createLeg( JointActingTypes.DRIVER ); final DriverRoute dRoute = new DriverRoute( Id.create( 1 , Link.class ) , Id.create( 1 , Link.class ) ); @@ -137,7 +137,7 @@ private static Population createPopulation() { final Plan passengerPlan = population.getFactory().createPlan(); passengerPlan.setPerson( passenger ); passenger.addPlan( passengerPlan ); - + passengerPlan.addActivity( population.getFactory().createActivityFromLinkId( "h" , Id.create( 1 , Link.class ) ) ); final Leg passengerLeg = population.getFactory().createLeg( JointActingTypes.PASSENGER ); final PassengerRoute pRoute = new PassengerRoute( Id.create( 1 , Link.class ) , Id.create( 1 , Link.class ) ); diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiBenchmarkTest.java b/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiBenchmarkTest.java index 9d1febf7f0e..364bbb5a39a 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiBenchmarkTest.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiBenchmarkTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; @@ -34,7 +34,7 @@ public class RunETaxiBenchmarkTest { private static final Logger log = LogManager.getLogger(RunETaxiBenchmarkTest.class); - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java index b3a755f34bb..218ca340f49 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java @@ -19,7 +19,7 @@ package org.matsim.contrib.etaxi.run; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Population; @@ -35,8 +35,8 @@ * @author michalm */ public class RunETaxiScenarioIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testOneTaxi() { diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/assignment/AssignmentTaxiOptimizerIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/assignment/AssignmentTaxiOptimizerIT.java index 515c8e718ad..baae47ffdb2 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/assignment/AssignmentTaxiOptimizerIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/assignment/AssignmentTaxiOptimizerIT.java @@ -21,13 +21,13 @@ import static org.matsim.contrib.taxi.optimizer.TaxiOptimizerTests.runBenchmark; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.taxi.optimizer.assignment.TaxiToRequestAssignmentCostProvider.Mode; import org.matsim.testcases.MatsimTestUtils; public class AssignmentTaxiOptimizerIT { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/fifo/FifoTaxiOptimizerIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/fifo/FifoTaxiOptimizerIT.java index e3b68f9c374..3e4b0ebefdf 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/fifo/FifoTaxiOptimizerIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/fifo/FifoTaxiOptimizerIT.java @@ -21,12 +21,12 @@ import static org.matsim.contrib.taxi.optimizer.TaxiOptimizerTests.runBenchmark; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class FifoTaxiOptimizerIT { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/rules/RuleBasedTaxiOptimizerIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/rules/RuleBasedTaxiOptimizerIT.java index 41259b9828e..2d58410b364 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/rules/RuleBasedTaxiOptimizerIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/rules/RuleBasedTaxiOptimizerIT.java @@ -21,13 +21,13 @@ import static org.matsim.contrib.taxi.optimizer.TaxiOptimizerTests.runBenchmark; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.taxi.optimizer.rules.RuleBasedRequestInserter.Goal; import org.matsim.testcases.MatsimTestUtils; public class RuleBasedTaxiOptimizerIT { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/zonal/ZonalTaxiOptimizerIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/zonal/ZonalTaxiOptimizerIT.java index 648b36a8da7..370a7f37e3a 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/zonal/ZonalTaxiOptimizerIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/zonal/ZonalTaxiOptimizerIT.java @@ -22,7 +22,7 @@ import static org.matsim.contrib.taxi.optimizer.TaxiOptimizerTests.runBenchmark; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.taxi.optimizer.rules.RuleBasedRequestInserter.Goal; import org.matsim.contrib.taxi.optimizer.rules.RuleBasedTaxiOptimizerParams; @@ -30,7 +30,7 @@ import org.matsim.testcases.MatsimTestUtils; public class ZonalTaxiOptimizerIT { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTestIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTestIT.java index 7e991fdfebe..714104455e7 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTestIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTestIT.java @@ -21,7 +21,7 @@ import java.net.URL; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.contrib.dvrp.run.DvrpConfigGroup; import org.matsim.core.config.Config; @@ -32,7 +32,7 @@ import org.matsim.vis.otfvis.OTFVisConfigGroup; public class RunTaxiScenarioTestIT { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java index 7d838d4178a..3ed9158cf9f 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java @@ -20,7 +20,7 @@ package org.matsim.core.scoring.functions; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -41,8 +41,8 @@ public class PersonScoringParametersFromPersonAttributesIT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils testUtils = new MatsimTestUtils(); @SuppressWarnings("unchecked") @Test diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java index bb9ca23ac4a..2db28b64006 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java @@ -21,7 +21,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -50,8 +50,8 @@ */ public class PersonScoringParametersFromPersonAttributesNoSubpopulationTest { - @Rule - public MatsimTestUtils utils; + @RegisterExtension + private MatsimTestUtils utils; private PersonScoringParametersFromPersonAttributes personScoringParams; private Population population; diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java index cb7da7c9069..f7cd61abd9c 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java @@ -21,7 +21,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -50,8 +50,8 @@ */ public class PersonScoringParametersFromPersonAttributesTest { - @Rule - public MatsimTestUtils utils; + @RegisterExtension + private MatsimTestUtils utils; private PersonScoringParametersFromPersonAttributes personScoringParams; private Population population; diff --git a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/FreightAnalysisEventBasedTest.java b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/FreightAnalysisEventBasedTest.java index b34c72ac10b..da7035be7e5 100644 --- a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/FreightAnalysisEventBasedTest.java +++ b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/FreightAnalysisEventBasedTest.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers.analysis; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -29,8 +29,8 @@ public class FreightAnalysisEventBasedTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void runFreightAnalysisEventBasedTest() throws IOException { diff --git a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java index 8dec71ea7f9..54d9471758b 100644 --- a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java +++ b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java @@ -38,8 +38,8 @@ public class RunFreightAnalysisIT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Before public void runAnalysis(){ diff --git a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java index 358b79d8ad4..6a60941db1f 100644 --- a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java +++ b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers.analysis; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -44,8 +44,8 @@ public class RunFreightAnalysisWithShipmentTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void runShipmentTrackerTest(){ diff --git a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java index f9daad794d9..c42b548f626 100644 --- a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java +++ b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java @@ -11,7 +11,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -68,8 +68,8 @@ public class PtAlongALine2Test { private static final Logger log = LogManager.getLogger(PtAlongALine2Test.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); enum DrtMode {none, teleportBeeline, teleportBasedOnNetworkRoute, full, withPrebooking} diff --git a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java index 67534b4b205..d8736f176fc 100644 --- a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java +++ b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java @@ -4,7 +4,7 @@ import java.util.Set; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -48,8 +48,8 @@ public class PtAlongALineTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Ignore @Test diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java index 4e787e84544..d549920130b 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java @@ -24,7 +24,7 @@ import java.util.TreeSet; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -38,8 +38,8 @@ public class PTCountsNetworkSimplifierTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** * Test simple network diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java index 0974c7e40da..db7023afb6a 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java @@ -1,6 +1,6 @@ package playground.vsp.cadyts.marginals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -54,8 +54,8 @@ public static Collection parameterObjects() { }); } - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private double countsWeight; private double modalDistanceWeight; diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java index c1a5a6a1e74..ad2500ce36f 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java @@ -1,6 +1,6 @@ package playground.vsp.cadyts.marginals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -43,8 +43,8 @@ import static org.junit.Assert.assertEquals; public class ModalDistanceCadytsMultipleDistancesIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** * This test runs a population of 1000 agents which have the same home and work place. All agents start with two plans. diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java index cbd93316434..94c68a9d5bd 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java @@ -19,7 +19,7 @@ package playground.vsp.cadyts.marginals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -58,8 +58,8 @@ public class ModalDistanceCadytsSingleDistanceIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); /** * This test runs a population of 1000 agents which have the same home and work place. All agents start with two plans. diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java index 83439dd2480..e0c7d42e18a 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java @@ -1,6 +1,6 @@ package playground.vsp.cadyts.marginals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -28,8 +28,8 @@ public class TripEventHandlerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** * This test takes the pt-tutorial from the scenarios module and performs one iteration. Afterwards it is tested diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java b/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java index 78942907bdf..22b9e50abc3 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java @@ -29,7 +29,7 @@ import jakarta.inject.Provider; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -71,8 +71,8 @@ */ public class AdvancedMarginalCongestionPricingIT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); // test normal activities @Test diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java index 1a9ea4b22fe..792eb498409 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java @@ -22,7 +22,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -57,16 +57,16 @@ /** * Accounting for flow delays even if leaving agents list is empty. - * + * * @author amit */ public class CombinedFlowAndStorageDelayTest { - + private final boolean usingOTFVis = false; - - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); /** * Basically agent first delay due to flow cap and then when agent can leave the link, it is delayed due to storage cap @@ -77,40 +77,40 @@ public class CombinedFlowAndStorageDelayTest { @Test public final void implV4Test(){ /* - * In the test, two routes (1-2-3-4 and 5-3-4) are assigned to agents. First two agents (1,2) start on first route and next two (3,4) on + * In the test, two routes (1-2-3-4 and 5-3-4) are assigned to agents. First two agents (1,2) start on first route and next two (3,4) on * other route. After agent 1 leave the link 2 (marginal flow delay =100), agent 2 is delayed. Mean while, before agent 2 can move to next link, * link 3 is blocked by agent 3 (departed on link 5). Thus, agent 2 on link 2 is delayed. Causing agents should be 1 (flow cap), 4 (storage cap). */ List congestionEvents = getAffectedPersonId2Delays("v4"); - + for(CongestionEvent e : congestionEvents){ if(e.getAffectedAgentId().equals(Id.createPersonId("2")) && e.getCausingAgentId().equals(Id.createPersonId("1"))){ Assert.assertEquals("Delay caused by agent 2 is not correct.", 100, e.getDelay(), MatsimTestUtils.EPSILON); // this is not captured by only leaving agents list. - } + } } - + Assert.assertEquals("Number of congestion events are not correct.", 4, congestionEvents.size(), MatsimTestUtils.EPSILON); } // @Test public final void implV6Test(){ /* - * In the test, two routes (1-2-3-4 and 5-3-4) are assigned to agents. First two agents (1,2) start on first route and next two (3,4) on + * In the test, two routes (1-2-3-4 and 5-3-4) are assigned to agents. First two agents (1,2) start on first route and next two (3,4) on * other route. After agent 1 leave the link 2 (marginal flow delay =100), agent 2 is delayed. Mean while, before agent 2 can move to next link, * link 3 is blocked by agent 3 (departed on link 5). Thus, agent 2 on link 2 is delayed. Causing agents should be 1 (flow cap), 4 (storage cap). */ List congestionEvents = getAffectedPersonId2Delays("v6"); - + for(CongestionEvent e : congestionEvents){ if(e.getAffectedAgentId().equals(Id.createPersonId("2")) && e.getLinkId().equals(Id.createLinkId("2"))){ Assert.assertEquals("Wrong causing agent", Id.createPersonId("1"), e.getCausingAgentId()); // this is not captured by only leaving agents list. - } + } } Assert.assertEquals("Number of congestion events are not correct.", 3, congestionEvents.size(), MatsimTestUtils.EPSILON); } - + private List getAffectedPersonId2Delays(String congestionPricingImpl){ createPseudoInputs pseudoInputs = new createPseudoInputs(); @@ -132,7 +132,7 @@ private List getAffectedPersonId2Delays(String congestionPricin events.addHandler( new CongestionEventHandler() { @Override - public void reset(int iteration) { + public void reset(int iteration) { } @Override @@ -190,7 +190,7 @@ private void createNetwork(){ link4 = NetworkUtils.createAndAddLink(network,Id.createLinkId(String.valueOf("4")), fromNode3, toNode3, 100.0, 20.0, (double) 3600, (double) 1, null, (String) "7"); final Node fromNode4 = node1; final Node toNode4 = node3; - + link5 = NetworkUtils.createAndAddLink(network,Id.createLinkId(String.valueOf("5")), fromNode4, toNode4, 100.0, 20.0, (double) 3600, (double) 1, null, (String) "7"); } diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java index 3e8bb3f8909..06b51cf1a47 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java @@ -1,388 +1,388 @@ -/* *********************************************************************** * - * project: org.matsim.* - * * - * *********************************************************************** * - * * - * copyright : (C) 2013 by the members listed in the COPYING, * - * LICENSE and WARRANTY file. * - * email : info at matsim dot org * - * * - * *********************************************************************** * - * * - * This program is free software; you can redistribute it and/or modify * - * it under the terms of the GNU General Public License as published by * - * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * - * See also COPYING, LICENSE and WARRANTY file * - * * - * *********************************************************************** */ - -/** - * - */ -package playground.vsp.congestion; - -import java.util.ArrayList; -import java.util.HashSet; -import java.util.List; -import java.util.Set; - -import org.junit.Assert; -import org.junit.Rule; -import org.junit.Test; -import org.matsim.api.core.v01.Coord; -import org.matsim.api.core.v01.Id; -import org.matsim.api.core.v01.Scenario; -import org.matsim.api.core.v01.network.Link; -import org.matsim.api.core.v01.network.Network; -import org.matsim.api.core.v01.network.Node; -import org.matsim.api.core.v01.population.Activity; -import org.matsim.api.core.v01.population.Leg; -import org.matsim.api.core.v01.population.Person; -import org.matsim.api.core.v01.population.Plan; -import org.matsim.api.core.v01.population.Population; -import org.matsim.api.core.v01.population.PopulationFactory; -import org.matsim.core.api.experimental.events.EventsManager; -import org.matsim.core.config.Config; -import org.matsim.core.config.groups.QSimConfigGroup; -import org.matsim.core.controler.PrepareForSimUtils; -import org.matsim.core.events.EventsUtils; -import org.matsim.core.mobsim.qsim.QSim; -import org.matsim.core.mobsim.qsim.QSimBuilder; -import org.matsim.core.population.PopulationUtils; -import org.matsim.core.population.routes.LinkNetworkRouteFactory; -import org.matsim.core.population.routes.NetworkRoute; -import org.matsim.core.scenario.ScenarioUtils; -import org.matsim.testcases.MatsimTestUtils; - -import playground.vsp.congestion.events.CongestionEvent; -import playground.vsp.congestion.handlers.CongestionEventHandler; -import playground.vsp.congestion.handlers.CongestionHandlerImplV3; -import playground.vsp.congestion.handlers.CongestionHandlerImplV7; -import playground.vsp.congestion.handlers.CongestionHandlerImplV8; - -/** - * Simple scenario setup: - * Three agents moving along a corridor with unlimited storage capacity; arriving simultaneously at the bottleneck. - * - * @author ikaddoura , lkroeger - * - */ - -public class MarginalCongestionHandlerFlowQueueQsimTest { - - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); - - private EventsManager events; - - private Id testAgent1 = Id.create("agentA", Person.class); - private Id testAgent2 = Id.create("agentB", Person.class); - private Id testAgent3 = Id.create("agentC", Person.class); - - private Id linkId1 = Id.create("link1", Link.class); - private Id linkId2 = Id.create("link2", Link.class); - private Id linkId3 = Id.create("link3", Link.class); - private Id linkId4 = Id.create("link4", Link.class); - private Id linkId5 = Id.create("link5", Link.class); - - double avgValue1 = 0.0; - double avgValue2 = 0.0; - double avgOldValue1 = 0.0; - double avgOldValue2 = 0.0; - double avgValue3 = 0.0; - double avgValue4 = 0.0; - double avgOldValue3 = 0.0; - double avgOldValue4 = 0.0; - - //++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ - - /** - * V3 - */ - @Test - public final void testFlowCongestion_3agents_V3(){ - - Scenario sc = loadScenario1(); - setPopulation1(sc); - - final List congestionEvents = new ArrayList(); - final CongestionHandlerImplV3 congestionHandler = new CongestionHandlerImplV3(events, sc); - - events.addHandler( new CongestionEventHandler() { - - @Override - public void reset(int iteration) { - } - - @Override - public void handleEvent(CongestionEvent event) { - congestionEvents.add(event); - } - }); - - events.addHandler(congestionHandler); - - PrepareForSimUtils.createDefaultPrepareForSim(sc).run(); - QSim sim = createQSim(sc, events); - sim.run(); - - for (CongestionEvent event : congestionEvents) { - Assert.assertEquals("here the delay should be equal to the inverse of the flow capacity", 3., event.getDelay(), MatsimTestUtils.EPSILON); - } - - Assert.assertEquals("wrong total delay", 9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong total internalized delay", 9., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON); - - } - - /** - * V7 - */ - @Test - public final void testFlowCongestion_3agents_V7(){ - - Scenario sc = loadScenario1(); - setPopulation1(sc); - - final List congestionEvents = new ArrayList(); - final CongestionHandlerImplV7 congestionHandler = new CongestionHandlerImplV7(events, sc); - - events.addHandler( new CongestionEventHandler() { - - @Override - public void reset(int iteration) { - } - - @Override - public void handleEvent(CongestionEvent event) { - congestionEvents.add(event); - } - }); - - events.addHandler(congestionHandler); - - PrepareForSimUtils.createDefaultPrepareForSim(sc).run(); - QSim sim = createQSim(sc, events); - sim.run(); - - for (CongestionEvent event : congestionEvents) { - if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentB")) { - Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); - } - - if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentA")) { - Assert.assertEquals("wrong delay", 6., event.getDelay(), MatsimTestUtils.EPSILON); - } - - if (event.getCausingAgentId().toString().equals("agentB") && event.getAffectedAgentId().toString().equals("agentA")) { - Assert.assertEquals("wrong delay", 6., event.getDelay(), MatsimTestUtils.EPSILON); - } - } - - Assert.assertEquals("wrong total delay", 9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON); - - // the second agent is 3 sec delayed and charges the first agent with these 3 sec - // the third agent is 6 sec delayed and charges the first and the second agent with each 6 sec - Assert.assertEquals("wrong total internalized delay", 15., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON); - } - - /** - * V8 - */ - @Test - public final void testFlowCongestion_3agents_V8(){ - - Scenario sc = loadScenario1(); - setPopulation1(sc); - - final List congestionEvents = new ArrayList(); - final CongestionHandlerImplV8 congestionHandler = new CongestionHandlerImplV8(events, sc); - - events.addHandler( new CongestionEventHandler() { - - @Override - public void reset(int iteration) { - } - - @Override - public void handleEvent(CongestionEvent event) { - congestionEvents.add(event); - } - }); - - events.addHandler(congestionHandler); - - PrepareForSimUtils.createDefaultPrepareForSim(sc).run(); - QSim sim = createQSim(sc, events); - sim.run(); - - for (CongestionEvent event : congestionEvents) { - if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentB")) { - Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); - } - - if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentA")) { - Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); - } - - if (event.getCausingAgentId().toString().equals("agentB") && event.getAffectedAgentId().toString().equals("agentA")) { - Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); - } - } - - Assert.assertEquals("wrong total delay", 9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON); - - // the second agent is 3 sec delayed and charges the first agent with these 3 sec - // the third agent is 6 sec delayed and charges the first and the second agent with each 6 sec - Assert.assertEquals("wrong total internalized delay", 9., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON); - } - - private void setPopulation1(Scenario scenario) { - - Population population = scenario.getPopulation(); - PopulationFactory popFactory = (PopulationFactory) scenario.getPopulation().getFactory(); - LinkNetworkRouteFactory routeFactory = new LinkNetworkRouteFactory(); - - Activity workActLink5 = popFactory.createActivityFromLinkId("work", linkId5); - - // leg: 1,2,3,4,5 - Leg leg_1_5 = popFactory.createLeg("car"); - List> linkIds234 = new ArrayList>(); - linkIds234.add(linkId2); - linkIds234.add(linkId3); - linkIds234.add(linkId4); - NetworkRoute route1_5 = (NetworkRoute) routeFactory.createRoute(linkId1, linkId5); - route1_5.setLinkIds(linkId1, linkIds234, linkId5); - leg_1_5.setRoute(route1_5); - - Person person1 = popFactory.createPerson(testAgent1); - Plan plan1 = popFactory.createPlan(); - Activity homeActLink1_1 = popFactory.createActivityFromLinkId("home", linkId1); - homeActLink1_1.setEndTime(100); - plan1.addActivity(homeActLink1_1); - plan1.addLeg(leg_1_5); - plan1.addActivity(workActLink5); - person1.addPlan(plan1); - population.addPerson(person1); - - Person person2 = popFactory.createPerson(testAgent2); - Plan plan2 = popFactory.createPlan(); - Activity homeActLink1_2 = popFactory.createActivityFromLinkId("home", linkId1); - homeActLink1_2.setEndTime(100); - plan2.addActivity(homeActLink1_2); - { - Leg leg = popFactory.createLeg(leg_1_5.getMode()); - PopulationUtils.copyFromTo(leg_1_5, leg); - plan2.addLeg(leg); - } - plan2.addActivity(workActLink5); - person2.addPlan(plan2); - population.addPerson(person2); - - Person person3 = popFactory.createPerson(testAgent3); - Plan plan3 = popFactory.createPlan(); - Activity homeActLink1_3 = popFactory.createActivityFromLinkId("home", linkId1); - homeActLink1_3.setEndTime(100); - plan3.addActivity(homeActLink1_3); - { - Leg leg = popFactory.createLeg(leg_1_5.getMode()); - PopulationUtils.copyFromTo(leg_1_5, leg); - plan3.addLeg(leg); - } - plan3.addActivity(workActLink5); - person3.addPlan(plan3); - population.addPerson(person3); -} - - private Scenario loadScenario1() { - - // (0) (1) (2) (3) (4) (5) - // -----link1---- ----link2---- ----link3---- ----link4---- ----link5---- - - Config config = testUtils.createConfig(); - QSimConfigGroup qSimConfigGroup = config.qsim(); - qSimConfigGroup.setFlowCapFactor(1.0); - qSimConfigGroup.setStorageCapFactor(1.0); - qSimConfigGroup.setInsertingWaitingVehiclesBeforeDrivingVehicles(true); - qSimConfigGroup.setRemoveStuckVehicles(true); - qSimConfigGroup.setStuckTime(3600.0); - Scenario scenario = (ScenarioUtils.createScenario(config)); - - Network network = (Network) scenario.getNetwork(); - network.setEffectiveCellSize(7.5); - network.setCapacityPeriod(3600.); - - Node node0 = network.getFactory().createNode(Id.create("0", Node.class), new Coord(0., 0.)); - Node node1 = network.getFactory().createNode(Id.create("1", Node.class), new Coord(100., 0.)); - Node node2 = network.getFactory().createNode(Id.create("2", Node.class), new Coord(200., 0.)); - Node node3 = network.getFactory().createNode(Id.create("3", Node.class), new Coord(300., 0.)); - Node node4 = network.getFactory().createNode(Id.create("4", Node.class), new Coord(400., 0.)); - Node node5 = network.getFactory().createNode(Id.create("5", Node.class), new Coord(500., 0.)); - - Link link1 = network.getFactory().createLink(this.linkId1, node0, node1); - Link link2 = network.getFactory().createLink(this.linkId2, node1, node2); - Link link3 = network.getFactory().createLink(this.linkId3, node2, node3); - Link link4 = network.getFactory().createLink(this.linkId4, node3, node4); - Link link5 = network.getFactory().createLink(this.linkId5, node4, node5); - - Set modes = new HashSet(); - modes.add("car"); - - // link without capacity restrictions - link1.setAllowedModes(modes); - link1.setCapacity(999999); - link1.setFreespeed(250); // one time step - link1.setNumberOfLanes(100); - link1.setLength(500); - - // link without capacity restrictions - link2.setAllowedModes(modes); - link2.setCapacity(999999); - link2.setFreespeed(166.66666667); // two time steps - link2.setNumberOfLanes(100); - link2.setLength(500); - - // capacity: one car every 3 sec - link3.setAllowedModes(modes); - link3.setCapacity(1200); - link3.setFreespeed(250); // one time step - link3.setNumberOfLanes(100); - link3.setLength(7.5); - - // link without capacity restrictions - link4.setAllowedModes(modes); - link4.setCapacity(999999); - link4.setFreespeed(166.66666667); // two time steps - link4.setNumberOfLanes(100); - link4.setLength(500); - - // link without capacity restrictions - link5.setAllowedModes(modes); - link5.setCapacity(999999); - link5.setFreespeed(250); // one time step - link5.setNumberOfLanes(100); - link5.setLength(500); - - network.addNode(node0); - network.addNode(node1); - network.addNode(node2); - network.addNode(node3); - network.addNode(node4); - network.addNode(node5); - - network.addLink(link1); - network.addLink(link2); - network.addLink(link3); - network.addLink(link4); - network.addLink(link5); - - this.events = EventsUtils.createEventsManager(); - return scenario; - } - - private QSim createQSim(Scenario sc, EventsManager events) { - return new QSimBuilder(sc.getConfig()).useDefaults().build(sc, events); - } - -} \ No newline at end of file +/* *********************************************************************** * + * project: org.matsim.* + * * + * *********************************************************************** * + * * + * copyright : (C) 2013 by the members listed in the COPYING, * + * LICENSE and WARRANTY file. * + * email : info at matsim dot org * + * * + * *********************************************************************** * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * See also COPYING, LICENSE and WARRANTY file * + * * + * *********************************************************************** */ + +/** + * + */ +package playground.vsp.congestion; + +import java.util.ArrayList; +import java.util.HashSet; +import java.util.List; +import java.util.Set; + +import org.junit.Assert; +import org.junit.jupiter.api.extension.RegisterExtension; +import org.junit.Test; +import org.matsim.api.core.v01.Coord; +import org.matsim.api.core.v01.Id; +import org.matsim.api.core.v01.Scenario; +import org.matsim.api.core.v01.network.Link; +import org.matsim.api.core.v01.network.Network; +import org.matsim.api.core.v01.network.Node; +import org.matsim.api.core.v01.population.Activity; +import org.matsim.api.core.v01.population.Leg; +import org.matsim.api.core.v01.population.Person; +import org.matsim.api.core.v01.population.Plan; +import org.matsim.api.core.v01.population.Population; +import org.matsim.api.core.v01.population.PopulationFactory; +import org.matsim.core.api.experimental.events.EventsManager; +import org.matsim.core.config.Config; +import org.matsim.core.config.groups.QSimConfigGroup; +import org.matsim.core.controler.PrepareForSimUtils; +import org.matsim.core.events.EventsUtils; +import org.matsim.core.mobsim.qsim.QSim; +import org.matsim.core.mobsim.qsim.QSimBuilder; +import org.matsim.core.population.PopulationUtils; +import org.matsim.core.population.routes.LinkNetworkRouteFactory; +import org.matsim.core.population.routes.NetworkRoute; +import org.matsim.core.scenario.ScenarioUtils; +import org.matsim.testcases.MatsimTestUtils; + +import playground.vsp.congestion.events.CongestionEvent; +import playground.vsp.congestion.handlers.CongestionEventHandler; +import playground.vsp.congestion.handlers.CongestionHandlerImplV3; +import playground.vsp.congestion.handlers.CongestionHandlerImplV7; +import playground.vsp.congestion.handlers.CongestionHandlerImplV8; + +/** + * Simple scenario setup: + * Three agents moving along a corridor with unlimited storage capacity; arriving simultaneously at the bottleneck. + * + * @author ikaddoura , lkroeger + * + */ + +public class MarginalCongestionHandlerFlowQueueQsimTest { + + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); + + private EventsManager events; + + private Id testAgent1 = Id.create("agentA", Person.class); + private Id testAgent2 = Id.create("agentB", Person.class); + private Id testAgent3 = Id.create("agentC", Person.class); + + private Id linkId1 = Id.create("link1", Link.class); + private Id linkId2 = Id.create("link2", Link.class); + private Id linkId3 = Id.create("link3", Link.class); + private Id linkId4 = Id.create("link4", Link.class); + private Id linkId5 = Id.create("link5", Link.class); + + double avgValue1 = 0.0; + double avgValue2 = 0.0; + double avgOldValue1 = 0.0; + double avgOldValue2 = 0.0; + double avgValue3 = 0.0; + double avgValue4 = 0.0; + double avgOldValue3 = 0.0; + double avgOldValue4 = 0.0; + + //++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + + /** + * V3 + */ + @Test + public final void testFlowCongestion_3agents_V3(){ + + Scenario sc = loadScenario1(); + setPopulation1(sc); + + final List congestionEvents = new ArrayList(); + final CongestionHandlerImplV3 congestionHandler = new CongestionHandlerImplV3(events, sc); + + events.addHandler( new CongestionEventHandler() { + + @Override + public void reset(int iteration) { + } + + @Override + public void handleEvent(CongestionEvent event) { + congestionEvents.add(event); + } + }); + + events.addHandler(congestionHandler); + + PrepareForSimUtils.createDefaultPrepareForSim(sc).run(); + QSim sim = createQSim(sc, events); + sim.run(); + + for (CongestionEvent event : congestionEvents) { + Assert.assertEquals("here the delay should be equal to the inverse of the flow capacity", 3., event.getDelay(), MatsimTestUtils.EPSILON); + } + + Assert.assertEquals("wrong total delay", 9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON); + Assert.assertEquals("wrong total internalized delay", 9., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON); + + } + + /** + * V7 + */ + @Test + public final void testFlowCongestion_3agents_V7(){ + + Scenario sc = loadScenario1(); + setPopulation1(sc); + + final List congestionEvents = new ArrayList(); + final CongestionHandlerImplV7 congestionHandler = new CongestionHandlerImplV7(events, sc); + + events.addHandler( new CongestionEventHandler() { + + @Override + public void reset(int iteration) { + } + + @Override + public void handleEvent(CongestionEvent event) { + congestionEvents.add(event); + } + }); + + events.addHandler(congestionHandler); + + PrepareForSimUtils.createDefaultPrepareForSim(sc).run(); + QSim sim = createQSim(sc, events); + sim.run(); + + for (CongestionEvent event : congestionEvents) { + if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentB")) { + Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); + } + + if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentA")) { + Assert.assertEquals("wrong delay", 6., event.getDelay(), MatsimTestUtils.EPSILON); + } + + if (event.getCausingAgentId().toString().equals("agentB") && event.getAffectedAgentId().toString().equals("agentA")) { + Assert.assertEquals("wrong delay", 6., event.getDelay(), MatsimTestUtils.EPSILON); + } + } + + Assert.assertEquals("wrong total delay", 9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON); + + // the second agent is 3 sec delayed and charges the first agent with these 3 sec + // the third agent is 6 sec delayed and charges the first and the second agent with each 6 sec + Assert.assertEquals("wrong total internalized delay", 15., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON); + } + + /** + * V8 + */ + @Test + public final void testFlowCongestion_3agents_V8(){ + + Scenario sc = loadScenario1(); + setPopulation1(sc); + + final List congestionEvents = new ArrayList(); + final CongestionHandlerImplV8 congestionHandler = new CongestionHandlerImplV8(events, sc); + + events.addHandler( new CongestionEventHandler() { + + @Override + public void reset(int iteration) { + } + + @Override + public void handleEvent(CongestionEvent event) { + congestionEvents.add(event); + } + }); + + events.addHandler(congestionHandler); + + PrepareForSimUtils.createDefaultPrepareForSim(sc).run(); + QSim sim = createQSim(sc, events); + sim.run(); + + for (CongestionEvent event : congestionEvents) { + if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentB")) { + Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); + } + + if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentA")) { + Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); + } + + if (event.getCausingAgentId().toString().equals("agentB") && event.getAffectedAgentId().toString().equals("agentA")) { + Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); + } + } + + Assert.assertEquals("wrong total delay", 9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON); + + // the second agent is 3 sec delayed and charges the first agent with these 3 sec + // the third agent is 6 sec delayed and charges the first and the second agent with each 6 sec + Assert.assertEquals("wrong total internalized delay", 9., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON); + } + + private void setPopulation1(Scenario scenario) { + + Population population = scenario.getPopulation(); + PopulationFactory popFactory = (PopulationFactory) scenario.getPopulation().getFactory(); + LinkNetworkRouteFactory routeFactory = new LinkNetworkRouteFactory(); + + Activity workActLink5 = popFactory.createActivityFromLinkId("work", linkId5); + + // leg: 1,2,3,4,5 + Leg leg_1_5 = popFactory.createLeg("car"); + List> linkIds234 = new ArrayList>(); + linkIds234.add(linkId2); + linkIds234.add(linkId3); + linkIds234.add(linkId4); + NetworkRoute route1_5 = (NetworkRoute) routeFactory.createRoute(linkId1, linkId5); + route1_5.setLinkIds(linkId1, linkIds234, linkId5); + leg_1_5.setRoute(route1_5); + + Person person1 = popFactory.createPerson(testAgent1); + Plan plan1 = popFactory.createPlan(); + Activity homeActLink1_1 = popFactory.createActivityFromLinkId("home", linkId1); + homeActLink1_1.setEndTime(100); + plan1.addActivity(homeActLink1_1); + plan1.addLeg(leg_1_5); + plan1.addActivity(workActLink5); + person1.addPlan(plan1); + population.addPerson(person1); + + Person person2 = popFactory.createPerson(testAgent2); + Plan plan2 = popFactory.createPlan(); + Activity homeActLink1_2 = popFactory.createActivityFromLinkId("home", linkId1); + homeActLink1_2.setEndTime(100); + plan2.addActivity(homeActLink1_2); + { + Leg leg = popFactory.createLeg(leg_1_5.getMode()); + PopulationUtils.copyFromTo(leg_1_5, leg); + plan2.addLeg(leg); + } + plan2.addActivity(workActLink5); + person2.addPlan(plan2); + population.addPerson(person2); + + Person person3 = popFactory.createPerson(testAgent3); + Plan plan3 = popFactory.createPlan(); + Activity homeActLink1_3 = popFactory.createActivityFromLinkId("home", linkId1); + homeActLink1_3.setEndTime(100); + plan3.addActivity(homeActLink1_3); + { + Leg leg = popFactory.createLeg(leg_1_5.getMode()); + PopulationUtils.copyFromTo(leg_1_5, leg); + plan3.addLeg(leg); + } + plan3.addActivity(workActLink5); + person3.addPlan(plan3); + population.addPerson(person3); +} + + private Scenario loadScenario1() { + + // (0) (1) (2) (3) (4) (5) + // -----link1---- ----link2---- ----link3---- ----link4---- ----link5---- + + Config config = testUtils.createConfig(); + QSimConfigGroup qSimConfigGroup = config.qsim(); + qSimConfigGroup.setFlowCapFactor(1.0); + qSimConfigGroup.setStorageCapFactor(1.0); + qSimConfigGroup.setInsertingWaitingVehiclesBeforeDrivingVehicles(true); + qSimConfigGroup.setRemoveStuckVehicles(true); + qSimConfigGroup.setStuckTime(3600.0); + Scenario scenario = (ScenarioUtils.createScenario(config)); + + Network network = (Network) scenario.getNetwork(); + network.setEffectiveCellSize(7.5); + network.setCapacityPeriod(3600.); + + Node node0 = network.getFactory().createNode(Id.create("0", Node.class), new Coord(0., 0.)); + Node node1 = network.getFactory().createNode(Id.create("1", Node.class), new Coord(100., 0.)); + Node node2 = network.getFactory().createNode(Id.create("2", Node.class), new Coord(200., 0.)); + Node node3 = network.getFactory().createNode(Id.create("3", Node.class), new Coord(300., 0.)); + Node node4 = network.getFactory().createNode(Id.create("4", Node.class), new Coord(400., 0.)); + Node node5 = network.getFactory().createNode(Id.create("5", Node.class), new Coord(500., 0.)); + + Link link1 = network.getFactory().createLink(this.linkId1, node0, node1); + Link link2 = network.getFactory().createLink(this.linkId2, node1, node2); + Link link3 = network.getFactory().createLink(this.linkId3, node2, node3); + Link link4 = network.getFactory().createLink(this.linkId4, node3, node4); + Link link5 = network.getFactory().createLink(this.linkId5, node4, node5); + + Set modes = new HashSet(); + modes.add("car"); + + // link without capacity restrictions + link1.setAllowedModes(modes); + link1.setCapacity(999999); + link1.setFreespeed(250); // one time step + link1.setNumberOfLanes(100); + link1.setLength(500); + + // link without capacity restrictions + link2.setAllowedModes(modes); + link2.setCapacity(999999); + link2.setFreespeed(166.66666667); // two time steps + link2.setNumberOfLanes(100); + link2.setLength(500); + + // capacity: one car every 3 sec + link3.setAllowedModes(modes); + link3.setCapacity(1200); + link3.setFreespeed(250); // one time step + link3.setNumberOfLanes(100); + link3.setLength(7.5); + + // link without capacity restrictions + link4.setAllowedModes(modes); + link4.setCapacity(999999); + link4.setFreespeed(166.66666667); // two time steps + link4.setNumberOfLanes(100); + link4.setLength(500); + + // link without capacity restrictions + link5.setAllowedModes(modes); + link5.setCapacity(999999); + link5.setFreespeed(250); // one time step + link5.setNumberOfLanes(100); + link5.setLength(500); + + network.addNode(node0); + network.addNode(node1); + network.addNode(node2); + network.addNode(node3); + network.addNode(node4); + network.addNode(node5); + + network.addLink(link1); + network.addLink(link2); + network.addLink(link3); + network.addLink(link4); + network.addLink(link5); + + this.events = EventsUtils.createEventsManager(); + return scenario; + } + + private QSim createQSim(Scenario sc, EventsManager events) { + return new QSimBuilder(sc.getConfig()).useDefaults().build(sc, events); + } + +} diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java index 0a5aae8bb70..6a545ed494e 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java @@ -34,7 +34,7 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -99,8 +99,8 @@ public class MarginalCongestionHandlerFlowSpillbackQueueQsimTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); private EventsManager events; diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java index 2c040502c4d..52ba06a0f54 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java @@ -31,7 +31,7 @@ import jakarta.inject.Provider; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -60,8 +60,8 @@ public class MarginalCongestionHandlerV3Test { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public final void testCongestionExample(){ diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java index 377c35e92d8..b3633c5a13b 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java @@ -24,7 +24,7 @@ import java.util.Set; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -63,8 +63,8 @@ */ public class MarginalCongestionPricingTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public final void implV4Test(){ @@ -89,7 +89,7 @@ public final void implV4Test(){ events.addHandler( new CongestionEventHandler() { @Override - public void reset(int iteration) { + public void reset(int iteration) { } @Override @@ -114,7 +114,7 @@ public void handleEvent(CongestionEvent event) { double person6Delay=0; double person8_6Delay=0; double person8_4Delay=0; - + int repetationPerson6Count=0; int repetationPerson8_6Count=0; int repetationPerson8_4Count=0; @@ -153,7 +153,7 @@ public void handleEvent(CongestionEvent event) { // delays are 10, 10 person8_6Delay+=event.getDelay(); if(repetationPerson8_6Count>0){ - Assert.assertEquals("wrong delay.", 20, person8_6Delay, MatsimTestUtils.EPSILON); + Assert.assertEquals("wrong delay.", 20, person8_6Delay, MatsimTestUtils.EPSILON); } repetationPerson8_6Count++; link3Delays++; @@ -187,7 +187,7 @@ public void handleEvent(CongestionEvent event) { } else if (event.getCausingAgentId().toString().equals("8") && event.getAffectedAgentId().toString().equals("9")) { Assert.assertEquals("wrong delay.", 1, event.getDelay(), MatsimTestUtils.EPSILON); link2Delays++; - } + } } else throw new RuntimeException("Delay can not occur on link id - "+event.getLinkId().toString()); } @@ -208,7 +208,7 @@ public void handleEvent(CongestionEvent event) { * generates network with 6 links. Even persons will go on one branch (up) and odd persons will go on other (down). *

    o----4----o *

    | - *

    3 + *

    3 *

    | *

    | *

    o--1---o---2---o diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java index 5ec75a5ce3b..c6ae3343755 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java @@ -22,7 +22,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -60,13 +60,13 @@ public class MultipleSpillbackCausingLinksTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); /** - * This test shows that (1) an agent can have spill back delays due to more than one link and + * This test shows that (1) an agent can have spill back delays due to more than one link and * therefore, need to iterate through all spill back causing links. - * (2) an agent may have two different links as next link in the route and therefore correct one should be adopted. + * (2) an agent may have two different links as next link in the route and therefore correct one should be adopted. */ @Test public final void multipleSpillBackTest(){ @@ -97,7 +97,7 @@ public final void multipleSpillBackTest(){ // second next link in the // route is link 6 // agent 3 and 4 leave prior to agent 2 during home work (trip3) - if(e.getCausingAgentId().equals(Id.createPersonId("3"))){ + if(e.getCausingAgentId().equals(Id.createPersonId("3"))){ Assert.assertEquals("Delay on second next link in the route is not correct.", 10.0, e.getDelay(), MatsimTestUtils.EPSILON); } else if (e.getCausingAgentId().equals(Id.createPersonId("4"))){ Assert.assertEquals("Delay on second next link in the route is not correct.", 10.0, e.getDelay(), MatsimTestUtils.EPSILON); @@ -116,7 +116,7 @@ public final void multipleSpillBackTest(){ } } - // now check, for agent 2, first link in the route (trip1) is occur first and rest later time i.e. during index ==1. + // now check, for agent 2, first link in the route (trip1) is occur first and rest later time i.e. during index ==1. Assert.assertFalse("Congestion event for first next link in the route should occur first.", eventTimes.get(0) > eventTimes.get(1)); // all other congestion event for agent 2 while leaving link 1 should occur at the same time. @@ -144,7 +144,7 @@ private List getAffectedPersonId2Delays(){ events.addHandler( new CongestionEventHandler() { @Override - public void reset(int iteration) { + public void reset(int iteration) { } @Override @@ -270,7 +270,7 @@ private void createPopulation(){ Activity a4 = population.getFactory().createActivityFromLinkId("w", link4.getId()); plan.addActivity(a4); } - population.addPerson(p); + population.addPerson(p); } } } diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java b/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java index 840c08836d4..7b4be2a2cf1 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java @@ -22,7 +22,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -60,8 +60,8 @@ */ public class TestForEmergenceTime { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public final void emergenceTimeTest_v4(){ @@ -94,7 +94,7 @@ public final void emergenceTimeTest_v4(){ // } // } // } - + private List getAffectedPersonId2Delays(String congestionPricingImpl){ int numberOfPersonInPlan = 10; @@ -117,7 +117,7 @@ private List getAffectedPersonId2Delays(String congestionPricin events.addHandler( new CongestionEventHandler() { @Override - public void reset(int iteration) { + public void reset(int iteration) { } @Override @@ -137,8 +137,8 @@ public void handleEvent(CongestionEvent event) { } /** - * generates network with 8 links. Even persons will go on one branch (down) and odd persons will go on other (up). A person come from top. - *

    + * generates network with 8 links. Even persons will go on one branch (down) and odd persons will go on other (up). A person come from top. + *

    *

    o *

    | *

    8 @@ -146,7 +146,7 @@ public void handleEvent(CongestionEvent event) { *

    | *

    o *

    | - *

    7 + *

    7 *

    | *

    | *

    o--1---o---2---o----3----o----4----o diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java b/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java index 172fc201ad2..330e4bff5ad 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java @@ -24,7 +24,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -45,8 +45,8 @@ public class TransferFinalSocToNextIterTest { private static final Integer LAST_ITERATION = 1; private static final double INITIAL_SOC = 0.95; - @Rule - public MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); @Test public void test() { diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java index 9a94e91d15c..b35592a42ca 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java @@ -2,7 +2,7 @@ import org.apache.logging.log4j.LogManager; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; @@ -16,7 +16,7 @@ import java.net.URL; public class UrbanEVIT { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void run() { diff --git a/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java b/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java index d8033195348..dc6fc153dbc 100644 --- a/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java @@ -3,7 +3,7 @@ import com.google.inject.Provides; import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -61,9 +61,8 @@ */ public class HierarchicalFLowEfficiencyCalculatorTest { - - public @Rule - MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); private FlowEfficiencyHandler handler; @Test diff --git a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java index 2e77d5aa867..524f1f3816e 100644 --- a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java @@ -1,7 +1,7 @@ package playground.vsp.openberlinscenario.cemdap.input; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Population; @@ -19,8 +19,8 @@ */ public class SynPopCreatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void TestGenerateDemand() { @@ -39,13 +39,13 @@ public void TestGenerateDemand() { SynPopCreator demandGeneratorCensus = new SynPopCreator(commuterFilesOutgoing, censusFile, utils.getOutputDirectory(), numberOfPlansPerPerson, idsOfFederalStatesIncluded, defaultAdultsToEmployeesRatio, defaultEmployeesToCommutersRatio); - + demandGeneratorCensus.setShapeFileForSpatialRefinement(utils.getInputDirectory() + "Bezirksregion_EPSG_25833.shp"); demandGeneratorCensus.setIdsOfMunicipalitiesForSpatialRefinement(Arrays.asList("11000000")); demandGeneratorCensus.setRefinementFeatureKeyInShapefile("SCHLUESSEL"); demandGeneratorCensus.generateDemand(); - + String municipal = "Breydin"; ArrayList possibleLocationsOfWork = readPossibleLocationsOfWork(commuterFileOutgoingTest, municipal); @@ -172,4 +172,4 @@ private String[] getCensusDataLine(String censusFile, String municipal) { } return line; } -} \ No newline at end of file +} diff --git a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java index 9952e81b744..594390f486c 100644 --- a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java @@ -19,8 +19,8 @@ public class PlanFileModifierTest { private final static Logger LOG = LogManager.getLogger(PlanFileModifierTest.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); private final static double SELECTION_PROBABILITY = 0.70; private final CoordinateTransformation ct = new IdentityTransformation(); diff --git a/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java b/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java index e4b686fc810..2d5797dc1b8 100644 --- a/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java @@ -5,7 +5,7 @@ import org.assertj.core.api.InstanceOfAssertFactories; import org.assertj.core.data.Offset; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -33,8 +33,8 @@ public class PtTripFareEstimatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); protected InformedModeChoiceConfigGroup group; protected Controler controler; diff --git a/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java b/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java index c9e063abf12..341ad741a91 100644 --- a/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java @@ -33,7 +33,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -102,7 +102,7 @@ public class EditTripsTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(EditTripsTest.class); // this is messy, but DisturbanceAndReplanningEngine needs to be static and there is no // constructor or similar to pass the replanning time diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java index f7a08b4ea4b..42fd52d8119 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java @@ -2,7 +2,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -28,8 +28,8 @@ */ public class IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest { - @Rule - public MatsimTestUtils utils; + @RegisterExtension + private MatsimTestUtils utils; private IncomeDependentUtilityOfMoneyPersonScoringParameters personScoringParams; private Population population; diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java index daa410350d4..247e54a45e5 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java @@ -25,8 +25,8 @@ */ public class IncomeDependentUtilityOfMoneyPersonScoringParametersTest { - @Rule - public MatsimTestUtils utils; + @RegisterExtension + private MatsimTestUtils utils; private IncomeDependentUtilityOfMoneyPersonScoringParameters personScoringParams; private Population population; diff --git a/contribs/vsp/src/test/java/playground/vsp/zzArchive/bvwpOld/BvwpTest.java b/contribs/vsp/src/test/java/playground/vsp/zzArchive/bvwpOld/BvwpTest.java index f9a06f7ec15..fe8cee1a096 100644 --- a/contribs/vsp/src/test/java/playground/vsp/zzArchive/bvwpOld/BvwpTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/zzArchive/bvwpOld/BvwpTest.java @@ -20,7 +20,7 @@ package playground.vsp.zzArchive.bvwpOld; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -28,8 +28,8 @@ public class BvwpTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testOne() { diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java index a5fc49cfefe..13ab81099e8 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java @@ -25,7 +25,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -82,8 +82,8 @@ */ public class SwissRailRaptorModuleTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Before public void setUp() { diff --git a/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java b/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java index caf7ae06c75..f04fdbd7ffc 100644 --- a/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java +++ b/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java @@ -26,7 +26,7 @@ import org.junit.After; import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -56,8 +56,8 @@ public class CalcLegTimesTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); public static final String BASE_FILE_NAME = "legdurations.txt"; diff --git a/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java b/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java index 2ee9d5fddb0..72eaa88a2bb 100644 --- a/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java +++ b/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java @@ -22,7 +22,7 @@ import java.io.File; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -47,8 +47,8 @@ */ public class CalcLinkStatsTest { - @Rule public MatsimTestUtils util = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); + @Test public void testAddData() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -65,32 +65,32 @@ public void testAddData() { Link link2 = nf.createLink(Id.create("102", Link.class), node2, node3); network.addLink(link1); network.addLink(link2); - + VolumesAnalyzer analyzer = new VolumesAnalyzer(3600, 86400, network); TravelTime ttimes = new FreeSpeedTravelTime(); CalcLinkStats cls = new CalcLinkStats(network); - + Id vehId = Id.create("1001", Vehicle.class); // generate some pseudo traffic for hour 0: 3 veh on link 1; 1 veh on link 2 analyzer.handleEvent(new LinkLeaveEvent(1000, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(1010, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(1020, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(1030, vehId, link2.getId())); - + // generate some pseudo traffic for hour 0: 1 veh on link 1; 4 veh on link 2 analyzer.handleEvent(new LinkLeaveEvent(4000, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(4010, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4020, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4030, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4040, vehId, link2.getId())); - + cls.addData(analyzer, ttimes); - + Assert.assertEquals(3.0, cls.getAvgLinkVolumes(link1.getId())[0], 1e-8); Assert.assertEquals(1.0, cls.getAvgLinkVolumes(link2.getId())[0], 1e-8); Assert.assertEquals(1.0, cls.getAvgLinkVolumes(link1.getId())[1], 1e-8); Assert.assertEquals(4.0, cls.getAvgLinkVolumes(link2.getId())[1], 1e-8); - + analyzer.reset(1); // generate some pseudo traffic for hour 0: 4 veh on link 1; 3 veh on link 2 analyzer.handleEvent(new LinkLeaveEvent(1000, vehId, link1.getId())); @@ -100,7 +100,7 @@ public void testAddData() { analyzer.handleEvent(new LinkLeaveEvent(1040, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(1050, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(1060, vehId, link2.getId())); - + // generate some pseudo traffic for hour 0: 4 veh on link 1; 2 veh on link 2 analyzer.handleEvent(new LinkLeaveEvent(4000, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(4010, vehId, link1.getId())); @@ -108,26 +108,26 @@ public void testAddData() { analyzer.handleEvent(new LinkLeaveEvent(4030, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(4040, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4040, vehId, link2.getId())); - + cls.addData(analyzer, ttimes); - + Assert.assertEquals(3.5, cls.getAvgLinkVolumes(link1.getId())[0], 1e-8); Assert.assertEquals(2.0, cls.getAvgLinkVolumes(link2.getId())[0], 1e-8); Assert.assertEquals(2.5, cls.getAvgLinkVolumes(link1.getId())[1], 1e-8); Assert.assertEquals(3.0, cls.getAvgLinkVolumes(link2.getId())[1], 1e-8); - + cls.reset(); Assert.assertEquals(0, cls.getAvgLinkVolumes(link1.getId()).length); Assert.assertEquals(0, cls.getAvgLinkVolumes(link2.getId()).length); } - + /** * Tests the travel times that are written out by {@link CalcLinkStats}. - * + * * Currently, the travel times are only correct if the time bin size in {@link TravelTimeCalculatorConfigGroup} is set to 3600. * If the time bin size is set to the default (900, see TODO below), {@link CalcLinkStats} wrongly assumes hourly time bins resulting in wrong travel times. - * + * * @author ikaddoura */ @Test @@ -146,16 +146,16 @@ public void testAddDataObservedTravelTime() { Link link2 = nf.createLink(Id.create("102", Link.class), node2, node3); network.addLink(link1); network.addLink(link2); - + VolumesAnalyzer analyzer = new VolumesAnalyzer(3600, 86400, network); TravelTimeCalculatorConfigGroup ttcalcConfig = new TravelTimeCalculatorConfigGroup(); - + ttcalcConfig.setTraveltimeBinSize(3600); // ttcalcConfig.setTraveltimeBinSize(900); // TODO - + TravelTimeCalculator ttimeCalculator = new TravelTimeCalculator(network, ttcalcConfig); CalcLinkStats cls = new CalcLinkStats(network); - + Id vehId1 = Id.create("1001", Vehicle.class); Id vehId2 = Id.create("1002", Vehicle.class); Id vehId3 = Id.create("1003", Vehicle.class); @@ -172,9 +172,9 @@ public void testAddDataObservedTravelTime() { analyzer.handleEvent(new LinkLeaveEvent(1010, vehId2, link1.getId())); ttimeCalculator.handleEvent(new LinkLeaveEvent(1020, vehId3, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(1020, vehId3, link1.getId())); - ttimeCalculator.handleEvent(new LinkLeaveEvent(1030, vehId1, link2.getId())); + ttimeCalculator.handleEvent(new LinkLeaveEvent(1030, vehId1, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(1030, vehId1, link2.getId())); - + // generate some pseudo traffic for hour 1: 1 veh on link 1; 4 veh on link 2 ttimeCalculator.handleEvent(new LinkEnterEvent(3800, vehId1, link1.getId())); ttimeCalculator.handleEvent(new LinkLeaveEvent(4000, vehId1, link1.getId())); @@ -182,37 +182,37 @@ public void testAddDataObservedTravelTime() { ttimeCalculator.handleEvent(new LinkEnterEvent(4000, vehId1, link2.getId())); ttimeCalculator.handleEvent(new LinkEnterEvent(4000, vehId2, link2.getId())); ttimeCalculator.handleEvent(new LinkEnterEvent(4000, vehId3, link2.getId())); - ttimeCalculator.handleEvent(new LinkEnterEvent(4000, vehId4, link2.getId())); - ttimeCalculator.handleEvent(new LinkLeaveEvent(4010, vehId1, link2.getId())); - analyzer.handleEvent(new LinkLeaveEvent(4010, vehId1, link2.getId())); + ttimeCalculator.handleEvent(new LinkEnterEvent(4000, vehId4, link2.getId())); + ttimeCalculator.handleEvent(new LinkLeaveEvent(4010, vehId1, link2.getId())); + analyzer.handleEvent(new LinkLeaveEvent(4010, vehId1, link2.getId())); ttimeCalculator.handleEvent(new LinkLeaveEvent(4020, vehId2, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4020, vehId2, link2.getId())); ttimeCalculator.handleEvent(new LinkLeaveEvent(4030, vehId3, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4030, vehId3, link2.getId())); ttimeCalculator.handleEvent(new LinkLeaveEvent(4040, vehId4, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4040, vehId4, link2.getId())); - + TravelTime ttimes = ttimeCalculator.getLinkTravelTimes(); cls.addData(analyzer, ttimes); - + // volumes Assert.assertEquals(3.0, cls.getAvgLinkVolumes(link1.getId())[0], 1e-8); Assert.assertEquals(1.0, cls.getAvgLinkVolumes(link2.getId())[0], 1e-8); Assert.assertEquals(1.0, cls.getAvgLinkVolumes(link1.getId())[1], 1e-8); Assert.assertEquals(4.0, cls.getAvgLinkVolumes(link2.getId())[1], 1e-8); - + // travel times Assert.assertEquals( 1530/3., cls.getAvgTravelTimes(link1.getId())[0], 1e-8 ); Assert.assertEquals( 30./1., cls.getAvgTravelTimes(link2.getId())[0], 1e-8 ); Assert.assertEquals( 200./1., cls.getAvgTravelTimes(link1.getId())[1], 1e-8 ); Assert.assertEquals( 100./4., cls.getAvgTravelTimes(link2.getId())[1], 1e-8 ); Assert.assertEquals( link2.getLength() / link2.getFreespeed(), cls.getAvgTravelTimes(link2.getId())[3], 1e-8 ); - + cls.reset(); Assert.assertEquals(0, cls.getAvgLinkVolumes(link1.getId()).length); Assert.assertEquals(0, cls.getAvgLinkVolumes(link2.getId()).length); - } + } @Test public void testWriteRead() { @@ -230,27 +230,27 @@ public void testWriteRead() { Link link2 = nf.createLink(Id.create("102", Link.class), node2, node3); network.addLink(link1); network.addLink(link2); - + VolumesAnalyzer analyzer = new VolumesAnalyzer(3600, 86400, network); TravelTime ttimes = new FreeSpeedTravelTime(); CalcLinkStats cls = new CalcLinkStats(network); - + Id vehId = Id.create("1001", Vehicle.class); // generate some pseudo traffic for hour 0: 3 veh on link 1; 1 veh on link 2 analyzer.handleEvent(new LinkLeaveEvent(1000, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(1010, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(1020, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(1030, vehId, link2.getId())); - + // generate some pseudo traffic for hour 0: 1 veh on link 1; 4 veh on link 2 analyzer.handleEvent(new LinkLeaveEvent(4000, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(4010, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4020, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4030, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4040, vehId, link2.getId())); - + cls.addData(analyzer, ttimes); - + analyzer.reset(1); // generate some pseudo traffic for hour 0: 4 veh on link 1; 3 veh on link 2 analyzer.handleEvent(new LinkLeaveEvent(1000, vehId, link1.getId())); @@ -260,7 +260,7 @@ public void testWriteRead() { analyzer.handleEvent(new LinkLeaveEvent(1040, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(1050, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(1060, vehId, link2.getId())); - + // generate some pseudo traffic for hour 0: 4 veh on link 1; 2 veh on link 2 analyzer.handleEvent(new LinkLeaveEvent(4000, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(4010, vehId, link1.getId())); @@ -268,9 +268,9 @@ public void testWriteRead() { analyzer.handleEvent(new LinkLeaveEvent(4030, vehId, link1.getId())); analyzer.handleEvent(new LinkLeaveEvent(4040, vehId, link2.getId())); analyzer.handleEvent(new LinkLeaveEvent(4040, vehId, link2.getId())); - + cls.addData(analyzer, ttimes); - + String filename = this.util.getOutputDirectory() + "linkstats.txt"; cls.writeFile(filename); Assert.assertTrue(new File(filename).exists()); diff --git a/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java index d665683747a..10c333db369 100644 --- a/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java @@ -11,7 +11,7 @@ import java.util.zip.GZIPInputStream; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; @@ -50,8 +50,8 @@ public class IterationTravelStatsControlerListenerTest { private int first_act_y; private int first_act_type; - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testIterationTravelStatsControlerListener() { diff --git a/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java b/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java index 72456c9cdac..9146970dde1 100644 --- a/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java +++ b/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java @@ -24,7 +24,7 @@ import java.util.Set; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -45,8 +45,8 @@ */ public class LegHistogramTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java index e72013364c3..17538d237d8 100644 --- a/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java @@ -21,7 +21,7 @@ import com.google.inject.*; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -57,8 +57,8 @@ */ public class LinkStatsControlerListenerTest { - @Rule - public MatsimTestUtils util = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils util = new MatsimTestUtils(); @Test public void testlinksOutputCSV() throws IOException { diff --git a/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java index 051f1485cf6..76927ec7a57 100644 --- a/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java @@ -1,7 +1,7 @@ package org.matsim.analysis; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -30,8 +30,8 @@ */ public class ModeChoiceCoverageControlerListenerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java index daf5a8cd90d..ab15ea48c94 100644 --- a/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java @@ -11,7 +11,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -52,8 +52,8 @@ public class ModeStatsControlerListenerTest { HashMap person1modes = new HashMap<>(); HashMap person2modes = new HashMap<>(); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testModeStatsControlerListener() { diff --git a/matsim/src/test/java/org/matsim/analysis/OutputTravelStatsTest.java b/matsim/src/test/java/org/matsim/analysis/OutputTravelStatsTest.java index 2ed4392921c..da31465d1c5 100644 --- a/matsim/src/test/java/org/matsim/analysis/OutputTravelStatsTest.java +++ b/matsim/src/test/java/org/matsim/analysis/OutputTravelStatsTest.java @@ -19,7 +19,7 @@ package org.matsim.analysis; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.controler.Controler; @@ -36,8 +36,8 @@ public class OutputTravelStatsTest { - @Rule - public MatsimTestUtils util = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils util = new MatsimTestUtils(); @Test public void testActivitiesOutputCSV() throws IOException { diff --git a/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java b/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java index e123bfceea9..4622a31b6b9 100644 --- a/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java @@ -10,7 +10,7 @@ import java.util.Iterator; import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; @@ -46,8 +46,8 @@ public class PHbyModeCalculatorTest { Id person3 = Id.create("person3", Person.class); Id person4 = Id.create("person4", Person.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); final IdMap map = new IdMap<>(Person.class); diff --git a/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java b/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java index ba62f04f994..8af9981fb13 100644 --- a/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java @@ -9,7 +9,7 @@ import java.util.HashMap; import java.util.stream.Collectors; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; @@ -40,8 +40,8 @@ public class PKMbyModeCalculatorTest { Person person3 = PopulationUtils.getFactory().createPerson(Id.create(3, Person.class)); Person person4 = PopulationUtils.getFactory().createPerson(Id.create(4, Person.class)); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testPKMbyModeCalculator() { diff --git a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java index 33345fdfb2b..9c6d251a048 100644 --- a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java @@ -7,7 +7,7 @@ import org.assertj.core.api.Assertions; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -40,8 +40,8 @@ */ public class ScoreStatsControlerListenerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private int avgexecuted; private int avgworst; diff --git a/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java b/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java index ada9b7872a0..d2141c89b78 100644 --- a/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java @@ -1,5 +1,5 @@ /** - * + * */ package org.matsim.analysis; @@ -7,7 +7,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Leg; @@ -23,8 +23,8 @@ public class TransportPlanningMainModeIdentifierTest { private final List modeHierarchy = new ArrayList<>(); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testIterationTravelStatsControlerListener() { diff --git a/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java b/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java index e1e0a8fb0d2..4836dbb1e1c 100644 --- a/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java @@ -10,7 +10,7 @@ import java.util.stream.Collectors; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; @@ -51,8 +51,8 @@ public class TravelDistanceStatsTest { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Person person2 = PopulationUtils.getFactory().createPerson(Id.create(2, Person.class)); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testTravelDistanceStats() { diff --git a/matsim/src/test/java/org/matsim/analysis/TripsAnalysisIT.java b/matsim/src/test/java/org/matsim/analysis/TripsAnalysisIT.java index 7abdeff8aea..e0a372d519b 100644 --- a/matsim/src/test/java/org/matsim/analysis/TripsAnalysisIT.java +++ b/matsim/src/test/java/org/matsim/analysis/TripsAnalysisIT.java @@ -23,7 +23,7 @@ import org.apache.commons.csv.CSVParser; import org.apache.commons.csv.CSVRecord; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -42,8 +42,8 @@ public class TripsAnalysisIT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testMainMode() { diff --git a/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java b/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java index 788452ea7bb..cfb58800664 100644 --- a/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java @@ -21,7 +21,7 @@ package org.matsim.analysis; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.analysis.TripsAndLegsCSVWriter.NoLegsWriterExtension; import org.matsim.analysis.TripsAndLegsCSVWriter.NoTripWriterExtension; @@ -112,8 +112,8 @@ public class TripsAndLegsCSVWriterTest { ArrayList legsfromplan = new ArrayList<>(); Map persontrips = new HashMap<>(); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testTripsAndLegsCSVWriter() { diff --git a/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java b/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java index 54a18fd2047..01ade096cca 100644 --- a/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java @@ -1,10 +1,10 @@ /** - * + * */ package org.matsim.analysis; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -28,26 +28,26 @@ */ public class VolumesAnalyzerTest { - @Rule - public MatsimTestUtils util = new MatsimTestUtils(); - + @RegisterExtension + private MatsimTestUtils util = new MatsimTestUtils(); + @Test public void performTest() { - + final Id link1 = Id.create(10723, Link.class); final Id link2 = Id.create(123160, Link.class); final Id link3 = Id.create(130181, Link.class); - + Id person1 = Id.create("1", Person.class); Id person2 = Id.create("2", Person.class); Id person3 = Id.create("3", Person.class); Id person4 = Id.create("4", Person.class); Id person5 = Id.create("5", Person.class); - + Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); NetworkFactory factory = network.getFactory(); - + Node n0, n1, n2, n3; network.addNode(n0 = factory.createNode(Id.createNodeId(0), new Coord(30.0, 50.0))); network.addNode(n1 = factory.createNode(Id.createNodeId(1), new Coord(1800.0, 2500.0))); @@ -56,50 +56,50 @@ public void performTest() { Link LinkOne = factory.createLink(link1, n0, n1); Link LinkTwo = factory.createLink(link2, n1, n2); Link LinkThree = factory.createLink(link3, n2, n3); - + network.addLink(LinkOne); network.addLink(LinkTwo); network.addLink(LinkThree); - + VolumesAnalyzer analyzer = new VolumesAnalyzer(3600, 86400, network); Id veh1 = Id.create("1001", Vehicle.class); Id veh2 = Id.create("1002", Vehicle.class); Id veh3 = Id.create("1003", Vehicle.class); Id veh4 = Id.create("1004", Vehicle.class); Id veh5 = Id.create("1005", Vehicle.class); - + analyzer.handleEvent(new VehicleEntersTrafficEvent(3600.0, person4, link1, veh4, TransportMode.car, 1.0)); analyzer.handleEvent(new VehicleEntersTrafficEvent(3610.0, person1, link1, veh1, TransportMode.car, 2.0)); - + analyzer.handleEvent(new LinkLeaveEvent(5100, veh4, link1)); analyzer.handleEvent(new LinkLeaveEvent(5410, veh1, link1)); - + analyzer.handleEvent(new VehicleEntersTrafficEvent(7200.0, person2, link1, veh2, TransportMode.car, 1.0)); analyzer.handleEvent(new VehicleEntersTrafficEvent(7210.0, person5, link1, veh5, TransportMode.car, 2.0)); analyzer.handleEvent(new VehicleEntersTrafficEvent(7215.0, person4, link1, veh4, TransportMode.car, 3.0)); - + analyzer.handleEvent(new LinkLeaveEvent(9000, veh2, link1)); analyzer.handleEvent(new LinkLeaveEvent(8710, veh5, link1)); analyzer.handleEvent(new LinkLeaveEvent(8895, veh4, link1)); - + analyzer.handleEvent(new VehicleEntersTrafficEvent(10800.0, person1, link1, veh1, TransportMode.car, 1.0)); analyzer.handleEvent(new VehicleEntersTrafficEvent(10810.0, person3, link1, veh3, TransportMode.car, 2.0)); - + analyzer.handleEvent(new LinkLeaveEvent(12600, veh1, link1)); analyzer.handleEvent(new LinkLeaveEvent(12370, veh3, link1)); - + analyzer.handleEvent(new VehicleEntersTrafficEvent(21600.0, person1, link1, veh1, TransportMode.car, 1.0)); analyzer.handleEvent(new VehicleEntersTrafficEvent(21650.0, person2, link1, veh2, TransportMode.car, 2.0)); analyzer.handleEvent(new VehicleEntersTrafficEvent(21700.0, person3, link1, veh3, TransportMode.car, 3.0)); analyzer.handleEvent(new VehicleEntersTrafficEvent(21750.0, person4, link1, veh4, TransportMode.car, 4.0)); analyzer.handleEvent(new VehicleEntersTrafficEvent(21800.0, person5, link1, veh5, TransportMode.car, 5.0)); - + analyzer.handleEvent(new LinkLeaveEvent(22800, veh1, link1)); analyzer.handleEvent(new LinkLeaveEvent(23450, veh2, link1)); analyzer.handleEvent(new LinkLeaveEvent(22800, veh3, link1)); analyzer.handleEvent(new LinkLeaveEvent(22800, veh4, link1)); analyzer.handleEvent(new LinkLeaveEvent(22800, veh5, link1)); - + double[] volume = analyzer.getVolumesPerHourForLink(link1); int[] volumeForLink = analyzer.getVolumesForLink(link1); @@ -111,25 +111,25 @@ public void performTest() { Assert.assertEquals(volumeForLink[2], 3, 0); Assert.assertEquals(volumeForLink[3], 2, 0); Assert.assertEquals(volumeForLink[6], 5, 0); - + VolumesAnalyzer analyzerBike = new VolumesAnalyzer(3600, 86400, network, true); - + analyzerBike.handleEvent(new VehicleEntersTrafficEvent(21600.0, person1, link2, veh1, TransportMode.bike, 1.0)); analyzerBike.handleEvent(new VehicleEntersTrafficEvent(21650.0, person2, link2, veh2, TransportMode.bike, 2.0)); analyzerBike.handleEvent(new VehicleEntersTrafficEvent(21700.0, person3, link2, veh3, TransportMode.bike, 3.0)); analyzerBike.handleEvent(new VehicleEntersTrafficEvent(21750.0, person4, link2, veh4, TransportMode.car, 4.0)); analyzerBike.handleEvent(new VehicleEntersTrafficEvent(21800.0, person5, link2, veh5, TransportMode.car, 5.0)); - + analyzerBike.handleEvent(new LinkLeaveEvent(22800, veh1, link2)); analyzerBike.handleEvent(new LinkLeaveEvent(23450, veh2, link2)); analyzerBike.handleEvent(new LinkLeaveEvent(22800, veh3, link2)); analyzerBike.handleEvent(new LinkLeaveEvent(22800, veh4, link2)); analyzerBike.handleEvent(new LinkLeaveEvent(22800, veh5, link2)); - + double[] volumeBike = analyzerBike.getVolumesPerHourForLink(link2, TransportMode.bike); int[] volumeForLinkBike = analyzerBike.getVolumesForLink(link2, TransportMode.bike); Assert.assertEquals(volumeBike[6], 3.0, 0); Assert.assertEquals(volumeForLinkBike[6], 3, 0); - + } } diff --git a/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java b/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java index bbcb71c47b7..126b90c8dcf 100644 --- a/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java +++ b/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java @@ -23,7 +23,7 @@ import org.apache.commons.csv.CSVParser; import org.apache.commons.csv.CSVRecord; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.analysis.linkpaxvolumes.LinkPaxVolumesAnalysis; import org.matsim.analysis.linkpaxvolumes.LinkPaxVolumesWriter; @@ -52,8 +52,8 @@ public class LinkPaxVolumesAnalysisTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); /** * Test method for {@link LinkPaxVolumesAnalysis}. diff --git a/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java b/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java index b892032ccf9..542b72deb15 100644 --- a/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java @@ -23,7 +23,7 @@ import org.apache.commons.csv.CSVRecord; import org.apache.commons.lang3.mutable.MutableDouble; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonMoneyEvent; @@ -39,8 +39,8 @@ public class PersonMoneyEventAggregatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** * Test method for {@link org.matsim.analysis.personMoney.PersonMoneyEventsCollector}. diff --git a/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java b/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java index f03feb96de7..254e8a05703 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java @@ -25,7 +25,7 @@ import org.junit.After; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -49,8 +49,8 @@ */ public class DemandGenerationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final String populationFile = "population.xml"; diff --git a/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java b/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java index 203a7000a36..ce259d996c2 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -39,8 +39,8 @@ */ public class NetworkCreationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testCreateNetwork() { diff --git a/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java b/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java index e9f32150370..4d623e74764 100644 --- a/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java +++ b/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java @@ -1,7 +1,7 @@ package org.matsim.core.config; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -9,7 +9,7 @@ public class CommandLineTest{ - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test public void testStandardUsage() { diff --git a/matsim/src/test/java/org/matsim/core/config/ConfigV2IOTest.java b/matsim/src/test/java/org/matsim/core/config/ConfigV2IOTest.java index 4ee31b42d7b..2ed89e288fd 100644 --- a/matsim/src/test/java/org/matsim/core/config/ConfigV2IOTest.java +++ b/matsim/src/test/java/org/matsim/core/config/ConfigV2IOTest.java @@ -26,14 +26,14 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.config.groups.ChangeLegModeConfigGroup; -import org.matsim.testcases.MatsimJunit5TestExtension; +import org.matsim.testcases.MatsimTestUtils; /** * @author thibautd */ public class ConfigV2IOTest { @RegisterExtension - public final MatsimJunit5TestExtension utils = new MatsimJunit5TestExtension(); + public final MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testInputSameAsOutput() { diff --git a/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java b/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java index cdf645c7141..57f77ab8bca 100644 --- a/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java +++ b/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java @@ -3,15 +3,15 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class MaterializeConfigTest { private static final Logger log = LogManager.getLogger(MaterializeConfigTest.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public final void testMaterializeAfterReadParameterSets() { @@ -107,4 +107,4 @@ public String getParameter() { public void setParameter(String parameter) { this.parameter = parameter; } -} \ No newline at end of file +} diff --git a/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java index be71252c59f..a0302aea465 100644 --- a/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java @@ -32,13 +32,14 @@ import java.util.Map; import java.util.Set; -import org.junit.jupiter.api.Assertions; -import org.junit.jupiter.api.Test; +import org.junit.Assert; +import org.junit.jupiter.api.extension.RegisterExtension; +import org.junit.Test; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.core.config.ReflectiveConfigGroup.InconsistentModuleException; -import org.matsim.testcases.MatsimJunit5Test; import org.matsim.testcases.MatsimTestUtils; import com.google.common.collect.ImmutableSet; @@ -46,7 +47,9 @@ /** * @author thibautd */ -public class ReflectiveConfigGroupTest extends MatsimJunit5Test { +public class ReflectiveConfigGroupTest { + @RegisterExtension + public final MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testDumpAndRead() { @@ -126,7 +129,7 @@ private void assertEqualAfterDumpAndRead(MyModule dumpedModule) { Config dumpedConfig = new Config(); dumpedConfig.addModule(dumpedModule); - String fileName = getOutputDirectory() + "/dump.xml"; + String fileName = utils.getOutputDirectory() + "/dump.xml"; new ConfigWriter(dumpedConfig).write(fileName); Config readConfig = ConfigUtils.loadConfig(fileName); @@ -139,7 +142,7 @@ private void assertEqualAfterDumpAndRead(MyModule dumpedModule) { @Test public void testReadCollectionsIncludingEmptyString() { - String fileName = getInputDirectory() + "/config_with_blank_comma_separated_elements.xml"; + String fileName = utils.getInputDirectory() + "/config_with_blank_comma_separated_elements.xml"; final Config readConfig = ConfigUtils.loadConfig(fileName); final MyModule readModule = new MyModule(); // as a side effect, this loads the information @@ -360,7 +363,7 @@ public Object getStuff() { final String param = "my unknown param"; final String value = "my val"; testee.addParam(param, value); - Assertions.assertEquals(value, testee.getValue(param), "unexpected stored value"); + Assert.assertEquals("unexpected stored value", value, testee.getValue(param)); } @Test diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java index 17409e3ec33..ba0fae597fa 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.config.Config; @@ -46,7 +46,7 @@ public class ReplanningConfigGroupTest { private static final Logger log = LogManager.getLogger(ReplanningConfigGroupTest.class); - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java index 7b765cd84bb..5b04311c78f 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.Config; @@ -40,7 +40,7 @@ public class RoutingConfigGroupTest { private final static Logger log = LogManager.getLogger(RoutingConfigGroupTest.class); private final static int N_MODE_ROUTING_PARAMS_DEFAULT = 5 ; - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java index 16e7f336a44..d75ee413732 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java @@ -29,7 +29,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.Config; @@ -45,7 +45,7 @@ public class ScoringConfigGroupTest { private static final Logger log = LogManager.getLogger(ScoringConfigGroupTest.class); - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); private void testResultsBeforeCheckConsistency( Config config, boolean fullyHierarchical ) { diff --git a/matsim/src/test/java/org/matsim/core/config/groups/VspExperimentalConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/VspExperimentalConfigGroupTest.java index 74a908bbbdd..088d486fea7 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/VspExperimentalConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/VspExperimentalConfigGroupTest.java @@ -22,14 +22,14 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class VspExperimentalConfigGroupTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(VspExperimentalConfigGroupTest.class); diff --git a/matsim/src/test/java/org/matsim/core/controler/AbstractModuleTest.java b/matsim/src/test/java/org/matsim/core/controler/AbstractModuleTest.java index ae3c97c0a8e..5651097897f 100644 --- a/matsim/src/test/java/org/matsim/core/controler/AbstractModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/AbstractModuleTest.java @@ -5,7 +5,7 @@ import com.google.inject.name.Named; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -22,7 +22,7 @@ public class AbstractModuleTest{ private static final Logger log = LogManager.getLogger( AbstractModuleTest.class ); - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test public void test1() { diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java b/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java index 4a696e4e606..a1739b52361 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java @@ -28,7 +28,7 @@ import org.junit.After; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.controler.events.IterationEndsEvent; @@ -42,8 +42,8 @@ */ public class ControlerEventsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private List calledStartupListener = null; diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java index a0c6bc24154..3f49cbf2b46 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java @@ -34,7 +34,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -79,7 +79,7 @@ public class ControlerIT { private final static Logger log = LogManager.getLogger(ControlerIT.class); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); private final boolean isUsingFastCapacityUpdate; diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java b/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java index a66fc10c46c..d20bc0a6222 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.api.experimental.events.EventsManager; @@ -40,7 +40,7 @@ public class ControlerMobsimIntegrationTest { private final static Logger log = LogManager.getLogger(ControlerMobsimIntegrationTest.class); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRunMobsim_customMobsim() { diff --git a/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java b/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java index b4ad53a30d1..9c7e303230d 100644 --- a/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java @@ -23,7 +23,7 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -33,8 +33,8 @@ public class MatsimServicesImplTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Ignore @Test diff --git a/matsim/src/test/java/org/matsim/core/controler/MobsimListenerTest.java b/matsim/src/test/java/org/matsim/core/controler/MobsimListenerTest.java index 099e07ca091..8818f2b63b6 100644 --- a/matsim/src/test/java/org/matsim/core/controler/MobsimListenerTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/MobsimListenerTest.java @@ -22,7 +22,7 @@ package org.matsim.core.controler; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.mobsim.framework.events.MobsimInitializedEvent; @@ -33,8 +33,8 @@ public class MobsimListenerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRunMobsim_listenerTransient() { diff --git a/matsim/src/test/java/org/matsim/core/controler/NewControlerTest.java b/matsim/src/test/java/org/matsim/core/controler/NewControlerTest.java index cbb1eabbe43..b10a0509487 100644 --- a/matsim/src/test/java/org/matsim/core/controler/NewControlerTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/NewControlerTest.java @@ -21,7 +21,7 @@ package org.matsim.core.controler; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -35,8 +35,8 @@ public class NewControlerTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testInjectionBeforeControler() { diff --git a/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java b/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java index 0431939f972..9f9e788218e 100644 --- a/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java @@ -19,7 +19,7 @@ package org.matsim.core.controler; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.groups.ControllerConfigGroup; import org.matsim.core.utils.io.IOUtils; @@ -34,7 +34,7 @@ * @author thibautd */ public class OutputDirectoryHierarchyTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java b/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java index 65de1dea5b9..6bfbc27f763 100644 --- a/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java @@ -3,7 +3,7 @@ import java.io.File; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.PersonDepartureEvent; @@ -30,8 +30,8 @@ * TerminationCriterion. */ public class TerminationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testSimulationEndsOnInterval() { diff --git a/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java b/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java index 3d2999caa20..b02ba76fbe4 100644 --- a/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java @@ -25,7 +25,7 @@ import java.util.ArrayList; import java.util.Collections; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -61,8 +61,8 @@ public class TransitControlerIntegrationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testTransitRouteCopy() { diff --git a/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java b/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java index ca53da64631..300296fbc27 100644 --- a/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java @@ -20,7 +20,7 @@ package org.matsim.core.controler.corelisteners; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.analysis.IterationStopWatch; import org.matsim.core.config.Config; @@ -42,7 +42,7 @@ * @author thibautd */ public class ListenersInjectionTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java b/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java index ee429308a3a..68e67547cb2 100644 --- a/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java +++ b/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java @@ -19,7 +19,7 @@ package org.matsim.core.controler.corelisteners; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.controler.Controler; @@ -35,7 +35,7 @@ */ public class PlansDumpingIT { - @Rule public MatsimTestUtils util = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test public void testPlansDump_Interval() { diff --git a/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java b/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java index d4319c90c12..aee383139ab 100644 --- a/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -37,8 +37,8 @@ */ public class ActEndEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java b/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java index baa4b067f6a..7a57d2334e3 100644 --- a/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -37,8 +37,8 @@ */ public class ActStartEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java b/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java index df91a68fa3a..0a40dc47137 100644 --- a/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonMoneyEvent; @@ -34,8 +34,8 @@ */ public class AgentMoneyEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java b/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java index 827470698d8..08e5667ce31 100644 --- a/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -34,7 +34,7 @@ */ public class AgentWaitingForPtEventTest { - @Rule public MatsimTestUtils helper = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils helper = new MatsimTestUtils(); @Test public void testReadWriteXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java b/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java index e2f24659ea1..d8c25c4eaa5 100644 --- a/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java +++ b/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -39,8 +39,8 @@ public class BasicEventsHandlerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testLinkEnterEventHandler() { diff --git a/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java b/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java index 5dedc88f8b3..6c09b3bd184 100644 --- a/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java +++ b/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; @@ -37,8 +37,8 @@ public class EventsHandlerHierarchyTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); int eventHandled = 0; diff --git a/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java b/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java index 4dd891c976c..24f43377b2d 100644 --- a/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java +++ b/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java @@ -26,7 +26,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -53,8 +53,8 @@ public class EventsReadersTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); diff --git a/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java b/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java index e46bc1ac1ed..b24edda5020 100644 --- a/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java @@ -21,7 +21,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.events.GenericEvent; import org.matsim.testcases.MatsimTestUtils; @@ -32,8 +32,8 @@ */ public class GenericEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java b/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java index a057273b468..c098d01d14a 100644 --- a/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkEnterEvent; @@ -35,8 +35,8 @@ */ public class LinkEnterEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java b/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java index 7608932471d..10c7c168aee 100644 --- a/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkLeaveEvent; @@ -35,8 +35,8 @@ */ public class LinkLeaveEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java index 08d6192f944..b5a2e03edca 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -36,8 +36,8 @@ */ public class PersonArrivalEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java index 95e8fda3a8b..7f42ea5a472 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -36,8 +36,8 @@ */ public class PersonDepartureEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java index 04f74f23db9..bb554d35908 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonEntersVehicleEvent; @@ -38,8 +38,8 @@ */ public class PersonEntersVehicleEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testReadWriteXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java index ffaf19b3c30..bd0c7ac42c6 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonLeavesVehicleEvent; @@ -38,8 +38,8 @@ */ public class PersonLeavesVehicleEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java index 0f3a062a0bb..090c2512aa5 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -36,8 +36,8 @@ */ public class PersonStuckEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java b/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java index 7b81c9a31ea..4f9076d4f51 100644 --- a/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; @@ -36,15 +36,15 @@ */ public class TransitDriverStartsEventTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { - final TransitDriverStartsEvent event1 = new TransitDriverStartsEvent(36095.2, - Id.create("ptDrvr-1", Person.class), - Id.create("vehicle-bus5", Vehicle.class), - Id.create("line L-1", TransitLine.class), - Id.create("route-R1", TransitRoute.class), + final TransitDriverStartsEvent event1 = new TransitDriverStartsEvent(36095.2, + Id.create("ptDrvr-1", Person.class), + Id.create("vehicle-bus5", Vehicle.class), + Id.create("line L-1", TransitLine.class), + Id.create("route-R1", TransitRoute.class), Id.create("departure-D-1", Departure.class)); final TransitDriverStartsEvent event2 = XmlEventsTester.testWriteReadXml(this.utils.getOutputDirectory() + "events.xml", event1); Assert.assertEquals(event1.getTime(), event2.getTime(), 1.0e-9); diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java index 77b154c4282..274cb9b762a 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.VehicleAbortsEvent; @@ -35,8 +35,8 @@ */ public class VehicleAbortsEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java index 644f47ca99c..05929edf7e8 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.api.experimental.events.VehicleArrivesAtFacilityEvent; @@ -33,8 +33,8 @@ public class VehicleArrivesAtFacilityEventImplTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java index a425d4118a0..99b3396177a 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.api.experimental.events.VehicleDepartsAtFacilityEvent; @@ -33,8 +33,8 @@ public class VehicleDepartsAtFacilityEventImplTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java index 420f8de3ad7..45f4676e80b 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -37,8 +37,8 @@ */ public class VehicleEntersTrafficEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java index b577e4d0afc..241e0b9f382 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -37,8 +37,8 @@ */ public class VehicleLeavesTrafficEventTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXml() { diff --git a/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java b/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java index cf510a4e60f..a84b21baf2d 100644 --- a/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java +++ b/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java @@ -22,7 +22,7 @@ import java.io.File; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.GenericEvent; @@ -40,8 +40,8 @@ */ public class EventWriterXMLTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + /** * Some people use the ids as names, including special characters in there... so make sure attribute * values are correctly encoded when written to a file. @@ -50,7 +50,7 @@ public class EventWriterXMLTest { public void testSpecialCharacters() { String filename = this.utils.getOutputDirectory() + "testEvents.xml"; EventWriterXML writer = new EventWriterXML(filename); - + writer.handleEvent(new LinkLeaveEvent(3600.0, Id.create("vehicle>3", Vehicle.class), Id.create("link<2", Link.class))); writer.handleEvent(new LinkLeaveEvent(3601.0, Id.create("vehicle\"4", Vehicle.class), Id.create("link'3", Link.class))); writer.closeFile(); @@ -79,20 +79,20 @@ public void testSpecialCharacters() { public void testNullAttribute() { String filename = this.utils.getOutputDirectory() + "testEvents.xml"; EventWriterXML writer = new EventWriterXML(filename); - + GenericEvent event = new GenericEvent("TEST", 3600.0); event.getAttributes().put("dummy", null); writer.handleEvent(event); writer.closeFile(); Assert.assertTrue(new File(filename).exists()); - + EventsManager events = EventsUtils.createEventsManager(); EventsCollector collector = new EventsCollector(); events.addHandler(collector); events.initProcessing(); // this is already a test: is the XML valid so it can be parsed again? new MatsimEventsReader(events).readFile(filename); - + events.finishProcessing(); Assert.assertEquals("there must be 1 event.", 1, collector.getEvents().size()); } diff --git a/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java b/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java index cfc7b4ba1bb..c9e1aa8c73c 100644 --- a/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java +++ b/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java @@ -25,7 +25,7 @@ import java.util.Random; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -34,8 +34,8 @@ */ public class MatsimRandomTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java b/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java index 4058168db0c..40394904b1f 100644 --- a/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java +++ b/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java @@ -24,7 +24,7 @@ import java.awt.Image; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -33,8 +33,8 @@ */ public class MatsimResourceTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public final void testGetAsImage() { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesRoundaboutTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesRoundaboutTest.java index ff2e28c9e31..e8dcd098d1b 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesRoundaboutTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesRoundaboutTest.java @@ -20,7 +20,7 @@ import java.util.List; import java.util.Map; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.util.Assert; import org.matsim.api.core.v01.Coord; @@ -60,8 +60,8 @@ public class HermesRoundaboutTest { public static final Coord A_START = new Coord(0, -60); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java index 6017b868bed..cd7c0b8a0da 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java @@ -32,7 +32,7 @@ import org.junit.After; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -69,7 +69,7 @@ public abstract class AbstractJDEQSimTest { - @Rule + @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); protected Map, Id> vehicleToDriver = null; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/ConfigParameterTest.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/ConfigParameterTest.java index 3e14d2281e8..f95aa9149da 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/ConfigParameterTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/ConfigParameterTest.java @@ -21,7 +21,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -29,8 +29,8 @@ public class ConfigParameterTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testParametersSetCorrectly() { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestEventLog.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestEventLog.java index 8fe15767525..fb8231a0859 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestEventLog.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestEventLog.java @@ -23,15 +23,15 @@ import java.util.ArrayList; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.mobsim.jdeqsim.util.CppEventFileParser; import org.matsim.testcases.MatsimTestUtils; public class TestEventLog { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testGetTravelTime(){ diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageFactory.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageFactory.java index cdac5815578..0906d2c8814 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageFactory.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageFactory.java @@ -23,7 +23,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -35,8 +35,8 @@ public class TestMessageFactory { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); // check if gc turned on @Test public void testMessageFactory1(){ diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageQueue.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageQueue.java index bda50e8a94a..23bc2712123 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageQueue.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageQueue.java @@ -23,7 +23,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.mobsim.jdeqsim.util.DummyMessage; import org.matsim.testcases.MatsimTestUtils; @@ -31,8 +31,8 @@ public class TestMessageQueue { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testPutMessage1(){ MessageQueue mq=new MessageQueue(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/util/TestEventLibrary.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/util/TestEventLibrary.java index 88554925a0e..314faf79eb5 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/util/TestEventLibrary.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/util/TestEventLibrary.java @@ -25,7 +25,7 @@ import java.util.LinkedList; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -38,8 +38,8 @@ public class TestEventLibrary { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testGetTravelTime(){ diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java index 2ac3bee129f..0b5d2e4d65c 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java @@ -24,7 +24,7 @@ import java.util.*; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -61,8 +61,8 @@ @RunWith(Parameterized.class) public class FlowStorageSpillbackTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); private final boolean isUsingFastCapacityUpdate; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimEventsIntegrationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimEventsIntegrationTest.java index 09c873c3f2c..e7ec111bd4b 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimEventsIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimEventsIntegrationTest.java @@ -22,9 +22,9 @@ package org.matsim.core.mobsim.qsim; import org.assertj.core.api.Assertions; -import org.junit.Rule; +import org.junit.jupiter.api.Timeout; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; -import org.junit.rules.Timeout; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.handler.LinkLeaveEventHandler; import org.matsim.core.api.experimental.events.EventsManager; @@ -35,12 +35,10 @@ import org.matsim.core.scenario.ScenarioUtils; import org.matsim.testcases.MatsimTestUtils; +@Timeout(10) public class QSimEventsIntegrationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); - - @Rule - public Timeout globalTimeout = new Timeout(10000); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void netsimEngineHandlesExceptionCorrectly() { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TeleportationEngineWDistanceCheckTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TeleportationEngineWDistanceCheckTest.java index 9e722b5eaa6..0af1d61514c 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TeleportationEngineWDistanceCheckTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TeleportationEngineWDistanceCheckTest.java @@ -20,7 +20,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -56,7 +56,7 @@ public class TeleportationEngineWDistanceCheckTest { private static final Logger log = LogManager.getLogger( TeleportationEngineWDistanceCheckTest.class ) ; - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test public final void test() { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java index 069f22b616b..5ffc5e3b6af 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java @@ -19,7 +19,7 @@ package org.matsim.core.mobsim.qsim; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -100,7 +100,7 @@ public static Collection parameterObjects () { ); } - @Rule public MatsimTestUtils helper = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils helper = new MatsimTestUtils(); private Scenario scenario ; private final String[] transportModes = new String[]{"bike", "car"}; private Link link1; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/jdeqsimengine/JDEQSimPluginTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/jdeqsimengine/JDEQSimPluginTest.java index 8be6ddce8a9..af6cfbc3aa3 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/jdeqsimengine/JDEQSimPluginTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/jdeqsimengine/JDEQSimPluginTest.java @@ -21,7 +21,7 @@ package org.matsim.core.mobsim.qsim.jdeqsimengine; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.api.experimental.events.EventsManager; @@ -38,8 +38,8 @@ */ public class JDEQSimPluginTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private QSim prepareQSim(Scenario scenario, EventsManager eventsManager) { return new QSimBuilder(scenario.getConfig()) // diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java index b7bd85628a1..a30dfcc609f 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java @@ -29,7 +29,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -74,8 +74,8 @@ */ public class UmlaufDriverTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(UmlaufDriverTest.class); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java index a73e82a5b3e..7f1d04bc347 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java @@ -23,7 +23,7 @@ import jakarta.inject.Inject; import jakarta.inject.Provider; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -58,7 +58,7 @@ */ public class LinkSpeedCalculatorIntegrationTest { - @Rule public MatsimTestUtils helper = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils helper = new MatsimTestUtils(); @Test public void testIntegration_Default() { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java index 78f85f000a2..554b88b3059 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java @@ -21,7 +21,7 @@ import java.util.*; import jakarta.inject.Inject; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -63,7 +63,7 @@ */ public class PassingTest { - @Rule public MatsimTestUtils helper = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils helper = new MatsimTestUtils(); /** * A bike enters at t=0; and a car at t=5sec link length = 1000m diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java index 0577d703827..064025f4fe1 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -53,8 +53,8 @@ */ public class QLinkLanesTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static void initNetwork(Network network) { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java index 63e11d2c30d..bb83c11c1d8 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -88,8 +88,8 @@ @RunWith(Parameterized.class) public final class QLinkTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger logger = LogManager.getLogger( QLinkTest.class ); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QSimComponentsTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QSimComponentsTest.java index 8915e730af2..28f2c1bd0dd 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QSimComponentsTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QSimComponentsTest.java @@ -4,7 +4,7 @@ import com.google.inject.ProvisionException; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -30,7 +30,7 @@ public class QSimComponentsTest{ private final static String MY_NETSIM_ENGINE = "MyNetsimEngine"; private static final Logger log = LogManager.getLogger( QSimComponentsTest.class ); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test(expected = RuntimeException.class) public void testRemoveNetsimEngine() { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java index 62966d8493f..01ee89e122e 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java @@ -27,7 +27,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -69,8 +69,8 @@ */ public class SimulatedLaneFlowCapacityTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** * create this network: diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java index cea3d9d7d25..dcef567b287 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java @@ -1,7 +1,7 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; import com.google.inject.Singleton; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -33,7 +33,7 @@ public class SpeedCalculatorTest{ // This originally comes from the bicycle contrib. One now needs access to AbstractQLink to properly test this functionality. In contrast, the // specific bicycle material should not be necessary. kai, jun'23 - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); private final Config config = ConfigUtils.createConfig(); private final Network unusedNetwork = NetworkUtils.createNetwork(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java index 48bf9fbc37a..6919f8f020c 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java @@ -24,7 +24,7 @@ import java.util.Arrays; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -57,8 +57,8 @@ public class VehicleHandlerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testVehicleHandler() { diff --git a/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java b/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java index 90b73184eee..7391d0b4d2f 100644 --- a/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java @@ -34,7 +34,7 @@ import java.util.Set; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -57,8 +57,8 @@ */ public abstract class AbstractNetworkWriterReaderTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java index 1cb653a1421..f48d85ecc6b 100644 --- a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java +++ b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java @@ -2,13 +2,15 @@ import java.io.File; import java.io.IOException; +import java.nio.file.Path; import java.util.Collections; import java.util.List; import java.util.Map; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; +import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -21,8 +23,8 @@ public class DisallowedNextLinksTest { - @Rule - public TemporaryFolder tempFolder = new TemporaryFolder(); + @TempDir + public File tempFolder; @Test public void testEquals() { @@ -135,7 +137,7 @@ public void testNetworkWritingAndReading() throws IOException { DisallowedNextLinks dnl0 = NetworkUtils.getOrCreateDisallowedNextLinks(l1); dnl0.addDisallowedLinkSequence("car", List.of(l1.getId(), Id.createLinkId("2"))); - File tempFile = tempFolder.newFile("network.xml"); + File tempFile = new File(tempFolder, "network.xml"); new NetworkWriter(n).write(tempFile.toString()); Network network = NetworkUtils.createNetwork(); new MatsimNetworkReader(network).readFile(tempFile.toString()); diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java index f02fcc531dc..44479f38383 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java @@ -21,7 +21,7 @@ package org.matsim.core.network; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -43,8 +43,8 @@ public class NetworkChangeEventsParserWriterTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils() ; @Test public void testChangeEventsParserWriter() { @@ -227,4 +227,4 @@ public void testNegativeOffsetChangeEvents() { Assert.assertEquals(event.getFreespeedChange().getValue(), event2.getFreespeedChange().getValue(), 1e-10); } -} \ No newline at end of file +} diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java index 1b54bdee4ce..28008eaa50c 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -46,9 +46,9 @@ */ public class NetworkUtilsTest { private static final Logger log = LogManager.getLogger( NetworkUtilsTest.class ) ; - - @Rule - public MatsimTestUtils utils = new MatsimTestUtils() ; + + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils() ; /** * Test method for {@link org.matsim.core.network.NetworkUtils#isMultimodal(org.matsim.api.core.v01.network.Network)}. @@ -58,13 +58,13 @@ public final void testIsMultimodal() { Config config = utils.createConfigWithInputResourcePathAsContext(); config.network().setInputFile("network.xml" ); - + Scenario scenario = ScenarioUtils.loadScenario(config) ; - + Network network = scenario.getNetwork() ; - + Assert.assertTrue( NetworkUtils.isMultimodal( network ) ); - + } @@ -73,11 +73,11 @@ public final void testIsMultimodal() { public final void getOutLinksSortedByAngleTest() { final Network network = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); // (we need the network to properly connect the links) - + NetworkFactory nf = network.getFactory() ; - + // a number of potentially outgoing links: - + Node nd0 = nf.createNode(Id.createNodeId("0"), new Coord(0.,0.) ) ; Node ndN = nf.createNode(Id.createNodeId("N"), new Coord(0.,100.) ) ; Node ndNE = nf.createNode(Id.createNodeId("NE"), new Coord(100.,100.) ) ; @@ -87,7 +87,7 @@ public final void getOutLinksSortedByAngleTest() { Node ndSW = nf.createNode(Id.createNodeId("SW"), new Coord(-100.,-100.) ) ; Node ndW = nf.createNode(Id.createNodeId("W"), new Coord(-100.,0.) ) ; Node ndNW = nf.createNode(Id.createNodeId("NW"), new Coord(-100.,+100.) ) ; - + network.addNode( nd0 ); network.addNode( ndN ); network.addNode( ndNE ); @@ -97,7 +97,7 @@ public final void getOutLinksSortedByAngleTest() { network.addNode( ndSW ); network.addNode( ndW ); network.addNode( ndNW ); - + Link liN = nf.createLink( Id.createLinkId("N"), nd0, ndN ) ; Link liNE = nf.createLink( Id.createLinkId("NE"), nd0, ndNE ) ; Link liE = nf.createLink( Id.createLinkId("E"), nd0, ndE ) ; @@ -106,7 +106,7 @@ public final void getOutLinksSortedByAngleTest() { Link liSW = nf.createLink( Id.createLinkId("SW"), nd0, ndSW ) ; Link liW = nf.createLink( Id.createLinkId("W"), nd0, ndW ) ; Link liNW = nf.createLink( Id.createLinkId("NW"), nd0, ndNW ) ; - + network.addLink( liN ); network.addLink( liNE ); network.addLink( liE ); @@ -115,7 +115,7 @@ public final void getOutLinksSortedByAngleTest() { network.addLink( liSW ); network.addLink( liW ); network.addLink( liNW ); - + log.info("==="); // a link coming north to south: { @@ -124,11 +124,11 @@ public final void getOutLinksSortedByAngleTest() { for ( Link outLink : result.values() ) { log.info( outLink ); } - + Link[] actuals = result.values().toArray( new Link[result.size()] ) ; Link[] expecteds = {liNE,liE,liSE,liS,liSW,liW,liNW} ; Assert.assertArrayEquals(expecteds, actuals); - + } log.info("==="); // a link coming south to north: diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java index ed49b59785d..589ec99ba16 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java @@ -22,7 +22,7 @@ package org.matsim.core.network; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -37,8 +37,8 @@ * @author thibautd */ public class NetworkV2IOTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testNetworkAttributes() { diff --git a/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java b/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java index 9b6c6f109d9..5b84ddb4263 100644 --- a/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java +++ b/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -39,8 +39,8 @@ */ public class TimeVariantLinkImplTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final double TIME_BEFORE_FIRST_CHANGE_EVENTS = -99999;//when base (default) link properties are used diff --git a/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java b/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java index 3ab5af3cff8..8a886da7975 100644 --- a/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -43,8 +43,8 @@ */ public class TravelTimeCalculatorIntegrationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testTravelTimeCalculatorArray() { diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java index 733a8ed14cf..8d8e0f6639c 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java @@ -25,7 +25,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -41,7 +41,7 @@ import org.matsim.testcases.MatsimTestUtils; public class IntersectionSimplifierTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testComplexIntersection() { @@ -116,7 +116,7 @@ public void testSimplifyOne() { Cluster c2 = findCluster(clusters, CoordUtils.createCoord(225.0, 85.0)); Assert.assertNotNull("Could not find cluster with centroid (225.0,85.0)", c2); Assert.assertEquals("Wrong number of points", 4, c2.getPoints().size()); - + /* Write the cleaned network to file. */ new NetworkWriter(simpleNetwork).write(utils.getOutputDirectory() + "cleanNetwork.xml"); } @@ -138,13 +138,13 @@ public void testSimplifyTwo() { Cluster c2 = findCluster(clusters, CoordUtils.createCoord(225.0, 85.0)); Assert.assertNotNull("Could not find cluster with centroid (225.0,85.0)", c2); Assert.assertEquals("Wrong number of points", 12, c2.getPoints().size()); - + /* Write the cleaned network to file. */ new NetworkWriter(simpleNetwork).write(utils.getOutputDirectory() + "cleanNetwork.xml"); } /** - * The network cleaner will/should ensure that full connectivity remains. + * The network cleaner will/should ensure that full connectivity remains. */ @Test public void testNetworkCleaner() { @@ -194,7 +194,7 @@ public void testNetworkSimplifier() { ns.run(simpleNetwork); new NetworkCleaner().run(simpleNetwork); new NetworkWriter(simpleNetwork).write(utils.getOutputDirectory() + "network.xml"); - + Assert.assertEquals("Wrong number of nodes.", 12l, simpleNetwork.getNodes().size()); Assert.assertNotNull("Should find node '1'", simpleNetwork.getNodes().get(Id.createNodeId("1"))); @@ -219,7 +219,7 @@ public void testNetworkSimplifier() { Assert.assertNotNull("Should find simplified node '23-24'", simpleNetwork.getNodes().get(Id.createNodeId("23-24"))); } - + private Cluster findCluster(List clusters, Coord c) { Cluster cluster = null; Iterator iterator = clusters.iterator(); @@ -234,7 +234,7 @@ private Cluster findCluster(List clusters, Coord c) { /** - * The following layout is not according to scale, but shows the structure + * The following layout is not according to scale, but shows the structure * of the two 'complex' intersections. * 11 * | @@ -242,7 +242,7 @@ private Cluster findCluster(List clusters, Coord c) { * 12 * 3 / \ * | / \ - * | .__ 13 14 __. + * | .__ 13 14 __. * 4 / | | \ * / \ | | | | * .____ 5 ___ 6 _____________> 110m ______________ 15 ___ 16 ___ 17 ___ 18 ___. @@ -352,4 +352,4 @@ private Network buildComplexIntersection() { return network; } -} \ No newline at end of file +} diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java index 2a8be041b68..8fdde25b9eb 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java @@ -20,7 +20,7 @@ package org.matsim.core.network.algorithms.intersectionSimplifier.containers; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; @@ -30,33 +30,33 @@ import org.matsim.testcases.MatsimTestUtils; public class ConcaveHullTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + - /** Test whether duplicate input points are removed. **/ @Test public void testConstructor(){ GeometryCollection gcIncorrect = setupWithDuplicates(); ConcaveHull ch1 = new ConcaveHull(gcIncorrect, 2); Assert.assertEquals("Duplicates not removed.", 8, ch1.getInputPoints()); - + GeometryCollection gcCorrect = setup(); ConcaveHull ch2 = new ConcaveHull(gcCorrect, 2); Assert.assertEquals("Wrong number of input points.", 8, ch2.getInputPoints()); } - - + + public void testGetConcaveHull(){ GeometryCollection gc = setup(); ConcaveHull ch = new ConcaveHull(gc, 1.0); Geometry g = ch.getConcaveHull(); Assert.assertTrue("Wrong geometry created.", g instanceof Polygon); } - + /** * Set up a small test case: - * + * * ^ * | * 3 4 @@ -64,7 +64,7 @@ public void testGetConcaveHull(){ * | 8 6 * | 5 * 1_________2___> - * + * */ private GeometryCollection setup(){ GeometryFactory gf = new GeometryFactory(); @@ -79,7 +79,7 @@ private GeometryCollection setup(){ ga[7] = gf.createPoint(new Coordinate(1, 2)); return new GeometryCollection(ga, gf); } - + /** * Creates a similar {@link GeometryCollection} as in setup() but have * triplicates of points 7 & 8. @@ -96,10 +96,10 @@ private GeometryCollection setupWithDuplicates(){ ga[5] = gf.createPoint(new Coordinate(3, 2)); // 6 ga[6] = gf.createPoint(new Coordinate(2, 3)); // 7 ga[7] = gf.createPoint(new Coordinate(1, 2)); // 8 - + ga[8] = gf.createPoint(new Coordinate(2, 3)); // 7 ga[9] = gf.createPoint(new Coordinate(2, 3)); // 7 - + ga[10] = gf.createPoint(new Coordinate(1, 2)); // 8 ga[11] = gf.createPoint(new Coordinate(1, 2)); // 8 return new GeometryCollection(ga, gf); diff --git a/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java b/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java index cdb701228af..e122adda402 100644 --- a/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java @@ -22,7 +22,7 @@ package org.matsim.core.network.io; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; @@ -35,7 +35,7 @@ import java.util.function.Consumer; public class NetworkAttributeConversionTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java b/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java index f69ec1a456b..33517747af2 100644 --- a/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java +++ b/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java @@ -25,7 +25,7 @@ import java.util.Set; import java.util.Stack; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -42,8 +42,8 @@ public class NetworkReaderMatsimV1Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java b/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java index 3fe86ebe824..980cddcc1eb 100644 --- a/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java @@ -22,7 +22,7 @@ package org.matsim.core.network.io; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -51,7 +51,7 @@ public class NetworkReprojectionIOTest { INITIAL_CRS, TARGET_CRS); - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java b/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java index b8a84df5797..732657460e2 100644 --- a/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java +++ b/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -41,8 +41,8 @@ */ public class PersonImplTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private final static Logger log = LogManager.getLogger(PersonImplTest.class); diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java index c418f5179a2..8fe0bef6f34 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java @@ -22,7 +22,7 @@ package org.matsim.core.population.io; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -39,7 +39,7 @@ import java.util.function.Consumer; public class PopulationAttributeConversionTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java index 853af4157eb..7518db2c084 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java @@ -28,7 +28,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -66,7 +66,7 @@ public class PopulationReprojectionIOIT { private static final String NET_FILE = "network.xml.gz"; private static final String BASE_FILE = "plans_hwh_1pct.xml.gz"; - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java index 1228ac4736a..07e7629c7cb 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java @@ -22,7 +22,7 @@ package org.matsim.core.population.io; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -58,7 +58,7 @@ * @author thibautd */ public class PopulationV6IOTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java index 32feb12bf34..7a242e6ab54 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -45,8 +45,8 @@ public class PopulationWriterHandlerImplV4Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteGenericRoute() { diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java index 0853ed74581..a0e79a87e89 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java @@ -24,7 +24,7 @@ import java.util.Stack; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -52,7 +52,7 @@ */ public class PopulationWriterHandlerImplV5Test { - @Rule public MatsimTestUtils util = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test public void test_writeNetworkRoute_sameStartEndLink() { diff --git a/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java b/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java index b66d311c8b8..de959287f47 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java @@ -26,7 +26,7 @@ import java.util.function.Consumer; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -40,7 +40,7 @@ public class StreamingPopulationAttributeConversionTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java b/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java index 6b50d8c8ea8..d0025c9bb74 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java @@ -21,7 +21,7 @@ package org.matsim.core.population.routes; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -36,8 +36,8 @@ */ public class NetworkFactoryTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /*package*/ static class CarRouteMock extends AbstractRoute implements Cloneable { diff --git a/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java b/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java index bcecf3f052a..e72eb1ecde7 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java @@ -21,7 +21,7 @@ package org.matsim.core.population.routes; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.*; @@ -43,7 +43,7 @@ */ public class RouteFactoryIntegrationTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java b/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java index 3e3afa3ca65..8e4407f56e8 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.population.Plan; import org.matsim.api.core.v01.replanning.PlanStrategyModule; @@ -31,8 +31,8 @@ public class PlanStrategyTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java b/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java index 1a04ffdf6cb..e741f3d3066 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java @@ -5,7 +5,7 @@ import java.util.List; import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -20,8 +20,8 @@ public class ReplanningAnnealerTest { private static final String FILENAME_ANNEAL = "annealingRates.txt"; - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); private Scenario scenario; private Config config; private ReplanningAnnealerConfigGroup saConfig; diff --git a/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java b/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java index d7dcef44001..66db3fd7806 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java @@ -2,7 +2,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -38,8 +38,8 @@ * @author Sebastian Hörl (sebhoerl), IRT SystemX */ public class ReplanningWithConflictsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testModeRestriction() { @@ -52,10 +52,10 @@ public void testModeRestriction() { * BestScore, so if selection is chosen, a plan with "restricted" will be chosen * if it exists in the agent memory. For innovation, we use ChangeTripMode, so * we choose a new random mode. - * + * * Without conflicts, this will lead to all agents choosing the "restricted" * mode eventually, only 10% will choose "unrestricted" because they innovate. - * + * * However, we introduce a conflict logic that ensures that we never have more * than 40 agents using the "restricted" mode. In our simple logic, we iterate * through the agents and "accept" plans as long as we don't go over this @@ -63,10 +63,10 @@ public void testModeRestriction() { * and let our ConflictResolver return their IDs. The conflict logic will then * *reject* the plans generated by replanning and switch the agents back to a * non-conflicting plan (in that case the ones with the "unrestricted" mode). - * + * * To make sure that every agent always has a non-conflicting plan in memory, we * use WorstPlanForRemovalSelectorWithConflicts as the planRemovalSelector. - * + * * Running the simulation will make the agents replan and soon we hit the mark * of 40 agents using the "restricted" mode. After that, the conflict logic will * start rejecting plans. Note that in this particular logic as a side effect, @@ -75,7 +75,7 @@ public void testModeRestriction() { * logic we would make sure that, for instance, agents that didn't change their * plan or were already using initially the restricted mode are treated with * priority. - * + * * This is the most simple set-up of a conflict resolution process. It can be * adapted to all kind of use cases, for instance, managing parking space, * matching agents for car-pooling or implementing peer-to-peer car-sharing. diff --git a/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java b/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java index d7a8f260215..6612877c0f1 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java @@ -24,7 +24,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -41,8 +41,8 @@ public class ExternalModuleTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); private Scenario scenario; private OutputDirectoryHierarchy outputDirectoryHierarchy; diff --git a/matsim/src/test/java/org/matsim/core/replanning/planInheritance/PlanInheritanceTest.java b/matsim/src/test/java/org/matsim/core/replanning/planInheritance/PlanInheritanceTest.java index c15436d3391..e6ca4326678 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/planInheritance/PlanInheritanceTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/planInheritance/PlanInheritanceTest.java @@ -7,7 +7,7 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.List; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -30,8 +30,7 @@ public class PlanInheritanceTest { * @author alex94263 */ - - @Rule + @RegisterExtension public MatsimTestUtils util = new MatsimTestUtils(); @Test @@ -48,7 +47,7 @@ public void testPlanInheritanceEnabled() throws IOException { File csv = new File(outputDirectory, "planInheritanceRecords.csv.gz"); assertThat(csv).exists(); - + List personList = new ArrayList(); final Scenario scenario = ScenarioUtils.createScenario(config); @@ -66,9 +65,9 @@ public void run(Person person) { assert(p.getAttributes().getAsMap().keySet().contains(PlanInheritanceModule.ITERATION_CREATED)); assert(p.getAttributes().getAsMap().keySet().contains(PlanInheritanceModule.PLAN_ID)); } - + } - + PlanInheritanceRecordReader reader = new PlanInheritanceRecordReader(outputDirectory+"planInheritanceRecords.csv.gz"); List records = reader.read(); assert(records.size()==2); @@ -79,7 +78,7 @@ public void run(Person person) { assert( ((PlanInheritanceRecord) records.get(0)).getIterationRemoved() == -1); assert( ((PlanInheritanceRecord) records.get(0)).getPlanId().equals(Id.create("1",Plan.class))); assert( ((PlanInheritanceRecord) records.get(0)).getIterationsSelected().equals(Arrays.asList(0, 1, 2, 3, 4, 6, 7, 8, 9, 10))); - + assert( ((PlanInheritanceRecord) records.get(1)).getAgentId().equals(Id.createPersonId("1"))); assert( ((PlanInheritanceRecord) records.get(1)).getAncestorId().equals(Id.create("1",Plan.class))); assert( ((PlanInheritanceRecord) records.get(1)).getMutatedBy().equals("RandomPlanSelector_ReRoute")); @@ -87,11 +86,11 @@ public void run(Person person) { assert( ((PlanInheritanceRecord) records.get(1)).getIterationRemoved() == -1); assert( ((PlanInheritanceRecord) records.get(1)).getPlanId().equals(Id.create("2",Plan.class))); assert( ((PlanInheritanceRecord) records.get(1)).getIterationsSelected().equals(Arrays.asList(5))); - - + + } - + @Test public void testPlanInheritanceDisabled() throws IOException { String outputDirectory = util.getOutputDirectory(); @@ -106,7 +105,7 @@ public void testPlanInheritanceDisabled() throws IOException { File csv = new File(outputDirectory, "planInheritanceRecords.csv.gz"); assertThat(csv).doesNotExist(); - + List personList = new ArrayList(); final Scenario scenario = ScenarioUtils.createScenario(config); StreamingPopulationReader spr = new StreamingPopulationReader(scenario); @@ -123,7 +122,7 @@ public void run(Person person) { assert(!p.getAttributes().getAsMap().keySet().contains(PlanInheritanceModule.ITERATION_CREATED)); assert(!p.getAttributes().getAsMap().keySet().contains(PlanInheritanceModule.PLAN_ID)); } - + } } } diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java index 30e576431ff..d6c414c47ee 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java @@ -23,7 +23,7 @@ import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNull; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.HasPlansAndId; @@ -43,7 +43,7 @@ */ public abstract class AbstractPlanSelectorTest { - @Rule + @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); diff --git a/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java b/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java index 122f9acc428..bbf1f35fa4f 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java +++ b/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java @@ -23,7 +23,7 @@ import com.google.inject.Singleton; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -58,8 +58,8 @@ */ public class DeterministicMultithreadedReplanningIT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); /** * Tests that the {@link TimeAllocationMutatorModule} generates always the same results diff --git a/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java b/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java index 9c81aee55f2..62aa5944e92 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java @@ -26,7 +26,7 @@ import org.junit.Assert; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.config.Config; @@ -55,8 +55,8 @@ public class InnovationSwitchOffTest { private static final Logger log = LogManager.getLogger(InnovationSwitchOffTest.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** * Integration test for testing if switching off of innovative strategies works. diff --git a/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java b/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java index 00e5fa6b164..c27cf25f777 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java @@ -23,7 +23,7 @@ import static org.junit.Assert.assertTrue; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -52,8 +52,8 @@ */ public class TimeAllocationMutatorModuleTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testSimplifiedMutation() { diff --git a/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java b/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java index f87838e068b..ecad20f4e9b 100644 --- a/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java @@ -26,7 +26,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -46,8 +46,8 @@ */ public abstract class AbstractLeastCostPathCalculatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); protected abstract LeastCostPathCalculator getLeastCostPathCalculator(final Network network); diff --git a/matsim/src/test/java/org/matsim/core/router/FallbackRoutingModuleTest.java b/matsim/src/test/java/org/matsim/core/router/FallbackRoutingModuleTest.java index 2357da20138..97d039dd334 100644 --- a/matsim/src/test/java/org/matsim/core/router/FallbackRoutingModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/FallbackRoutingModuleTest.java @@ -2,7 +2,7 @@ import java.util.List; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -27,7 +27,7 @@ import org.matsim.testcases.MatsimTestUtils; public class FallbackRoutingModuleTest{ - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void calcRoute(){ diff --git a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java index 6f53a8f7363..4883342c79d 100644 --- a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java @@ -1,6 +1,6 @@ package org.matsim.core.router; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.util.Assert; import org.matsim.api.core.v01.Coord; @@ -49,8 +49,8 @@ public class NetworkRoutingInclAccessEgressModuleTest { private static final String SLOW_BUT_DIRECT_LINK = "slow-but-direct-link"; private static final String FAST_BUT_LONGER_LINK = "fast-but-longer-link"; - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); private static Scenario createScenario(Config config) { diff --git a/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java b/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java index eeb366c2f68..9061316cef6 100644 --- a/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java @@ -22,7 +22,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -57,8 +57,8 @@ public class PseudoTransitRoutingModuleTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRouteLeg() { diff --git a/matsim/src/test/java/org/matsim/core/router/RoutingIT.java b/matsim/src/test/java/org/matsim/core/router/RoutingIT.java index 0d1fc62702e..33bf594d4c5 100644 --- a/matsim/src/test/java/org/matsim/core/router/RoutingIT.java +++ b/matsim/src/test/java/org/matsim/core/router/RoutingIT.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; @@ -55,7 +55,7 @@ public class RoutingIT { /*package*/ static final Logger log = LogManager.getLogger(RoutingIT.class); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); private interface RouterProvider { public String getName(); diff --git a/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java b/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java index 4bb4c1df8ed..20447170bcd 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java @@ -23,7 +23,7 @@ package org.matsim.core.router; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -38,8 +38,8 @@ public class TripRouterModuleTest { - @Rule - public MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); @Test public void testRouterCreation() { diff --git a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java index 511a141c8a2..395299f5f62 100644 --- a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java +++ b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java @@ -23,7 +23,7 @@ package org.matsim.core.router.old; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -55,8 +55,8 @@ public class PlanRouterTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test public void passesVehicleFromOldPlan() { diff --git a/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java b/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java index d77d2dfe4f1..bc7cc4793ed 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java +++ b/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -47,7 +47,7 @@ */ public class ScenarioByConfigInjectionTest { private static final Logger log = LogManager.getLogger( ScenarioByConfigInjectionTest.class ); - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java b/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java index ed651429022..bca2d701757 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java +++ b/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java @@ -21,7 +21,7 @@ import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -46,7 +46,7 @@ */ public class ScenarioLoaderImplTest { - @Rule public MatsimTestUtils util = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test public void testLoadScenario_loadTransitData() { diff --git a/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java b/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java index 48fabecebed..4873a3759ec 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java @@ -21,7 +21,7 @@ package org.matsim.core.scoring; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -44,8 +44,8 @@ */ public class EventsToScoreTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java index 336f4dc2273..5e87ef5bf27 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java @@ -24,7 +24,7 @@ import org.junit.After; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -46,8 +46,8 @@ public class CharyparNagelOpenTimesScoringFunctionTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private Person person = null; diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java index 2b5e3db5a5a..179a9254981 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -40,8 +40,8 @@ public class LinkToLinkTravelTimeCalculatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java index 7a1b22936cc..00654aa914e 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java @@ -24,7 +24,7 @@ import com.google.inject.Key; import com.google.inject.Singleton; import com.google.inject.name.Names; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -54,8 +54,8 @@ public class TravelTimeCalculatorModuleTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testOneTravelTimeCalculatorForAll() { diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java index a7bc3c003af..45c0595a509 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java @@ -33,7 +33,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -70,8 +70,8 @@ */ public class TravelTimeCalculatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private final static Logger log = LogManager.getLogger(TravelTimeCalculatorTest.class); diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeDataArrayTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeDataArrayTest.java index 1e0e4e3dca7..e56a8cb3a51 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeDataArrayTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeDataArrayTest.java @@ -2,7 +2,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -13,7 +13,7 @@ public class TravelTimeDataArrayTest{ private static final Logger log = LogManager.getLogger( TravelTimeDataArrayTest.class ); - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void test() { diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java index dd069338304..b13c9fd28a8 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java @@ -29,7 +29,7 @@ import javax.imageio.ImageIO; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -40,8 +40,8 @@ */ public class BarChartTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java index 91a272f1b37..4c70f43a26d 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java @@ -29,7 +29,7 @@ import javax.imageio.ImageIO; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -40,8 +40,8 @@ */ public class LineChartTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java index 69379559860..1410b27b202 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java @@ -29,7 +29,7 @@ import javax.imageio.ImageIO; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -40,8 +40,8 @@ */ public class XYLineChartTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java index cfda39f43b5..03c60398659 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java @@ -29,7 +29,7 @@ import javax.imageio.ImageIO; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -40,8 +40,8 @@ */ public class XYScatterChartTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java index dbb81fd3c2d..4e4a7495248 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java @@ -21,7 +21,7 @@ package org.matsim.core.utils.geometry; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.GeometryFactory; @@ -46,13 +46,13 @@ */ public class GeometryUtilsTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test public final void testIntersectingLinks() { - + Config config = ConfigUtils.loadConfig( IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL("equil"), "config.xml" ) ) ; - + final Network network = ScenarioUtils.loadScenario(config).getNetwork(); { @@ -86,7 +86,7 @@ public final void testIntersectingLinks() { Assert.assertTrue("expected link " + id, intersectingLinkIds.contains(id)); } } - + } } diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java index 64666c2fa55..65265390b9f 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java @@ -21,7 +21,7 @@ package org.matsim.core.utils.geometry.geotools; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Point; @@ -35,8 +35,8 @@ */ public class MGCTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testCoord2CoordinateAndViceVersa(){ diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java index 41a7275bb2a..7fd2cacc8df 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java @@ -20,7 +20,7 @@ package org.matsim.core.utils.geometry.transformations; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.geometry.CoordinateTransformation; @@ -32,8 +32,8 @@ */ public class GeotoolsTransformationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testTransform(){ diff --git a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java index 30c9f350ffc..155a9f62128 100644 --- a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java @@ -25,7 +25,7 @@ import org.geotools.data.FeatureSource; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -34,8 +34,8 @@ */ public class ShapeFileReaderTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + /** * Based on message on users-mailing list from 20Dec2012) * @throws IOException diff --git a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java index b20f713473e..bf9b3ee2a90 100644 --- a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java @@ -33,7 +33,7 @@ import org.geotools.feature.simple.SimpleFeatureTypeBuilder; import org.geotools.referencing.crs.DefaultGeographicCRS; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; @@ -46,15 +46,15 @@ import org.opengis.feature.simple.SimpleFeatureType; public class ShapeFileWriterTest { - - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testShapeFileWriter() throws IOException{ - + String inFile = "src/test/resources/" + utils.getInputDirectory() + "test.shp"; - - String outFile = utils.getOutputDirectory() + "/test.shp"; + + String outFile = utils.getOutputDirectory() + "/test.shp"; SimpleFeatureSource s = ShapeFileReader.readDataFile(inFile); SimpleFeatureCollection fts = s.getFeatures(); SimpleFeatureIterator it = fts.features(); @@ -63,133 +63,133 @@ public void testShapeFileWriter() throws IOException{ List fc = new ArrayList<>(); fc.add(ft); ShapeFileWriter.writeGeometries(fc, outFile); - + SimpleFeatureSource s1 = ShapeFileReader.readDataFile(outFile); SimpleFeatureCollection fts1 = s1.getFeatures(); SimpleFeatureIterator it1 = fts1.features(); SimpleFeature ft1 = it1.next(); Geometry g1 = (Geometry) ft1.getDefaultGeometry(); - + Assert.assertEquals(g.getCoordinates().length, g1.getCoordinates().length); - + } - + @Test public void testShapeFileWriterWithSelfCreatedContent() throws IOException { - String outFile = utils.getOutputDirectory() + "/test.shp"; + String outFile = utils.getOutputDirectory() + "/test.shp"; SimpleFeatureTypeBuilder b = new SimpleFeatureTypeBuilder(); b.setName("EvacuationArea"); b.setCRS(DefaultGeographicCRS.WGS84); b.add("the_geom", MultiPolygon.class); b.add("name", String.class); SimpleFeatureType ft = b.buildFeatureType(); - + GeometryFactory geofac = new GeometryFactory(); LinearRing lr = geofac.createLinearRing(new Coordinate[]{new Coordinate(0,0),new Coordinate(0,1),new Coordinate(1,1),new Coordinate(0,0)}); Polygon p = geofac.createPolygon(lr,null); - MultiPolygon mp = geofac.createMultiPolygon(new Polygon[]{p}); + MultiPolygon mp = geofac.createMultiPolygon(new Polygon[]{p}); Collection features = new ArrayList(); features.add(SimpleFeatureBuilder.build(ft, new Object[]{mp,"test_name"},"fid")); - - + + Geometry g0 = (Geometry) features.iterator().next().getDefaultGeometry(); - + ShapeFileWriter.writeGeometries(features, outFile); - + SimpleFeatureSource s1 = ShapeFileReader.readDataFile(outFile); SimpleFeatureCollection fts1 = s1.getFeatures(); SimpleFeatureIterator it1 = fts1.features(); SimpleFeature ft1 = it1.next(); Geometry g1 = (Geometry) ft1.getDefaultGeometry(); - + Assert.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); - - + + } - + @Test public void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Polygon() throws IOException { String outFile = utils.getOutputDirectory() + "test.shp"; - + PolygonFeatureFactory ff = new PolygonFeatureFactory.Builder() .setName("EvacuationArea") .setCrs(DefaultGeographicCRS.WGS84) .addAttribute("name", String.class) .create(); - + Coordinate[] coordinates = new Coordinate[]{new Coordinate(0,0),new Coordinate(0,1),new Coordinate(1,1),new Coordinate(0,0)}; SimpleFeature f = ff.createPolygon(coordinates); - + Collection features = new ArrayList(); features.add(f); - + Geometry g0 = (Geometry) f.getDefaultGeometry(); - + ShapeFileWriter.writeGeometries(features, outFile); - + SimpleFeatureSource s1 = ShapeFileReader.readDataFile(outFile); SimpleFeatureCollection fts1 = s1.getFeatures(); SimpleFeatureIterator it1 = fts1.features(); SimpleFeature ft1 = it1.next(); Geometry g1 = (Geometry) ft1.getDefaultGeometry(); - + Assert.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); } @Test public void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Polyline() throws IOException { String outFile = utils.getOutputDirectory() + "test.shp"; - + PolylineFeatureFactory ff = new PolylineFeatureFactory.Builder() .setName("EvacuationArea") .setCrs(DefaultGeographicCRS.WGS84) .addAttribute("name", String.class) .create(); - + Coordinate[] coordinates = new Coordinate[]{new Coordinate(0,0),new Coordinate(0,1),new Coordinate(1,1),new Coordinate(0,0)}; SimpleFeature f = ff.createPolyline(coordinates); - + Collection features = new ArrayList(); features.add(f); - + Geometry g0 = (Geometry) f.getDefaultGeometry(); - + ShapeFileWriter.writeGeometries(features, outFile); - + SimpleFeatureSource s1 = ShapeFileReader.readDataFile(outFile); SimpleFeatureCollection fts1 = s1.getFeatures(); SimpleFeatureIterator it1 = fts1.features(); SimpleFeature ft1 = it1.next(); Geometry g1 = (Geometry) ft1.getDefaultGeometry(); - + Assert.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); } @Test public void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Point() throws IOException { String outFile = utils.getOutputDirectory() + "test.shp"; - + PointFeatureFactory ff = new PointFeatureFactory.Builder() .setName("EvacuationArea") .setCrs(DefaultGeographicCRS.WGS84) .addAttribute("name", String.class) .create(); - + SimpleFeature f = ff.createPoint(new Coordinate(10, 20)); - + Collection features = new ArrayList(); features.add(f); - + Geometry g0 = (Geometry) f.getDefaultGeometry(); - + ShapeFileWriter.writeGeometries(features, outFile); - + SimpleFeatureSource s1 = ShapeFileReader.readDataFile(outFile); SimpleFeatureCollection fts1 = s1.getFeatures(); SimpleFeatureIterator it1 = fts1.features(); SimpleFeature ft1 = it1.next(); Geometry g1 = (Geometry) ft1.getDefaultGeometry(); - + Assert.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java index 58c03dc4f5e..db3784f59e6 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java @@ -20,7 +20,7 @@ package org.matsim.core.utils.io; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.controler.OutputDirectoryLogging; import org.matsim.core.utils.misc.CRCChecksum; @@ -39,7 +39,7 @@ */ public class IOUtilsTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testInitOutputDirLogging() throws IOException { diff --git a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java index d7006b7ce1d..972b0a99be4 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java @@ -20,8 +20,9 @@ package org.matsim.core.utils.io; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; +import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.xml.sax.Attributes; import org.xml.sax.SAXParseException; @@ -43,8 +44,8 @@ */ public class MatsimXmlParserTest { - @Rule - public TemporaryFolder tempFolder = new TemporaryFolder(); + @TempDir + public File tempFolder; @Test public void testParsingReservedEntities_AttributeValue() { @@ -302,7 +303,7 @@ public void testParse_preventXEEattack_woodstox() throws IOException { String secretValue = "S3CR3T"; - File secretsFile = this.tempFolder.newFile("file-with-secrets.txt"); + File secretsFile = new File(this.tempFolder,"file-with-secrets.txt"); try (OutputStream out = new FileOutputStream(secretsFile)) { out.write(secretValue.getBytes(StandardCharsets.UTF_8)); } @@ -349,7 +350,7 @@ public void testParse_preventXEEattack_xerces() throws IOException { String secretValue = "S3CR3T"; - File secretsFile = this.tempFolder.newFile("file-with-secrets.txt"); + File secretsFile = new File(this.tempFolder, "file-with-secrets.txt"); try (OutputStream out = new FileOutputStream(secretsFile)) { out.write(secretValue.getBytes(StandardCharsets.UTF_8)); } diff --git a/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java b/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java index aa0f362a2a4..a43441e5c8f 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java @@ -20,7 +20,7 @@ package org.matsim.core.utils.io; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -41,7 +41,7 @@ */ public class OsmNetworkReaderTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testConversion() { @@ -198,13 +198,13 @@ public void testConversion_MissingNodeRef() { Assert.assertEquals("incomplete ways should not be converted.", 0, net.getNodes().size()); Assert.assertEquals("incomplete ways should not be converted.", 0, net.getLinks().size()); } - + @Test public void testConversion_maxspeeds() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network net = sc.getNetwork(); CoordinateTransformation ct = new IdentityTransformation(); - + OsmNetworkReader reader = new OsmNetworkReader(net, ct); reader.setKeepPaths(true); reader.setHighwayDefaults(1, "motorway", 1, 50.0/3.6, 1.0, 2000.0); @@ -242,7 +242,7 @@ public void testConversion_maxspeeds() { * - links 3 & 4: for way 2, in both directions * - links 5 & 6: for way 3, in both directions */ - + Link link1 = net.getLinks().get(Id.create("1", Link.class)); Link link3 = net.getLinks().get(Id.create("3", Link.class)); Link link5 = net.getLinks().get(Id.create("5", Link.class)); @@ -256,20 +256,20 @@ public void testConversion_maxspeeds() { /** * Tests that the conversion does not fail if a way does not contain any node. This might - * happen if the osm-file was edited, e.g. with JOSM, and a link was deleted. Then, the way + * happen if the osm-file was edited, e.g. with JOSM, and a link was deleted. Then, the way * still exists, but marked as deleted, and all nodes removed from it. - * Reported by jjoubert,15nov2012. + * Reported by jjoubert,15nov2012. */ @Test public void testConversion_emptyWay() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network net = sc.getNetwork(); CoordinateTransformation ct = new IdentityTransformation(); - + OsmNetworkReader reader = new OsmNetworkReader(net, ct); reader.setKeepPaths(true); reader.setHighwayDefaults(1, "motorway", 1, 50.0/3.6, 1.0, 2000.0); - + String str = "\n" + "\n" + " \n" + @@ -293,12 +293,12 @@ public void testConversion_emptyWay() { " \n" + ""; reader.parse(() -> new ByteArrayInputStream(str.getBytes())); - + /* this creates 4 links: * - links 1 & 2: for way 1, in both directions * - links 3 & 4: for way 2, in both directions */ - + Link link1 = net.getLinks().get(Id.create("1", Link.class)); Link link3 = net.getLinks().get(Id.create("3", Link.class)); Assert.assertNotNull("Could not find converted link 1.", link1); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java index 5d322e5fd0e..8b30ecbdf30 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java @@ -26,7 +26,7 @@ import java.util.Iterator; import java.util.NoSuchElementException; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -37,8 +37,8 @@ */ public class ArgumentParserTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java index 70ff5573005..8741b572cd5 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java @@ -26,7 +26,7 @@ import java.io.Serializable; import java.nio.ByteBuffer; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -35,8 +35,8 @@ */ public class ByteBufferUtilsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java index 2b0e176d0bb..cf2e00940eb 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -40,8 +40,8 @@ public class ConfigUtilsTest { private static final Logger log = LogManager.getLogger( ConfigUtilsTest.class ) ; - @Rule - public MatsimTestUtils util = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils util = new MatsimTestUtils(); @Test public void testLoadConfig_filenameOnly() throws IOException { diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java index dc35c4d2bf9..6e5a02f746e 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java @@ -21,7 +21,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -47,8 +47,8 @@ * */ public class PopulationUtilsTest { - - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test public void testLegOverlap() { @@ -56,28 +56,28 @@ public void testLegOverlap() { List legs1 = PopulationUtils.getLegs(f.plan1) ; List legs2 = PopulationUtils.getLegs(f.plan2); List legs3 = PopulationUtils.getLegs(f.plan3); - + // Assert.assertEquals( 2., PopulationUtils.calculateSimilarity( legs1, legs2, null, 1., 1. ) , 0.001 ) ; Assert.assertEquals( 4., PopulationUtils.calculateSimilarity( legs1, legs2, null, 1., 1. ) , 0.001 ) ; // (no route is now counted as "same route" and thus reaps the reward. kai, jul'18) - + // Assert.assertEquals( 1., PopulationUtils.calculateSimilarity( legs1, legs3, null, 1., 1. ) , 0.001 ) ; Assert.assertEquals( 2., PopulationUtils.calculateSimilarity( legs1, legs3, null, 1., 1. ) , 0.001 ) ; // (no route is now counted as "same route" and thus reaps the reward. kai, jul'18) } - + @Test public void testActivityOverlap() { Fixture f = new Fixture() ; List acts1 = PopulationUtils.getActivities(f.plan1, StageActivityHandling.StagesAsNormalActivities ) ; List acts2 = PopulationUtils.getActivities(f.plan2, StageActivityHandling.StagesAsNormalActivities ) ; List acts3 = PopulationUtils.getActivities(f.plan3, StageActivityHandling.StagesAsNormalActivities ) ; - + Assert.assertEquals( 6., PopulationUtils.calculateSimilarity( acts1, acts2 , 1., 1., 0. ) , 0.001 ) ; Assert.assertEquals( 5., PopulationUtils.calculateSimilarity( acts1, acts3 , 1., 1., 0. ) , 0.001 ) ; } - + private static class Fixture { Plan plan1, plan2, plan3 ; Fixture() { @@ -85,13 +85,13 @@ private static class Fixture { Scenario scenario = ScenarioUtils.createScenario(config) ; Population pop = scenario.getPopulation() ; PopulationFactory pf = pop.getFactory() ; - + { Plan plan = pf.createPlan() ; Activity act1 = pf.createActivityFromCoord("h", new Coord(0., 0.)) ; plan.addActivity(act1); - + Leg leg1 = pf.createLeg( TransportMode.car ) ; plan.addLeg( leg1 ) ; @@ -103,7 +103,7 @@ private static class Fixture { Activity act3 = pf.createActivityFromCoord("h", new Coord(0., 0.)) ; plan.addActivity(act3) ; - + plan1 = plan ; } { @@ -111,7 +111,7 @@ private static class Fixture { Activity act1 = pf.createActivityFromCoord("h", new Coord(0., 0.)) ; plan.addActivity(act1); - + Leg leg1 = pf.createLeg( TransportMode.car ) ; plan.addLeg( leg1 ) ; @@ -123,7 +123,7 @@ private static class Fixture { Activity act3 = pf.createActivityFromCoord("h", new Coord(0., 0.)) ; plan.addActivity(act3) ; - + plan2 = plan ; } { @@ -131,7 +131,7 @@ private static class Fixture { Activity act1 = pf.createActivityFromCoord("h", new Coord(0., 0.)) ; plan.addActivity(act1); - + Leg leg1 = pf.createLeg( TransportMode.car ) ; plan.addLeg( leg1 ) ; @@ -143,19 +143,19 @@ private static class Fixture { Activity act3 = pf.createActivityFromCoord("h", new Coord(0., 0.)) ; plan.addActivity(act3) ; - + plan3 = plan ; } } } - + @Test public void testEmptyPopulation() { Scenario s1 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario s2 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Assert.assertTrue(PopulationUtils.equalPopulation(s1.getPopulation(), s2.getPopulation())); } - + @Test public void testEmptyPopulationVsOnePerson() { Scenario s1 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -165,7 +165,7 @@ public void testEmptyPopulationVsOnePerson() { Assert.assertFalse(PopulationUtils.equalPopulation(s1.getPopulation(), s2.getPopulation())); Assert.assertFalse(PopulationUtils.equalPopulation(s2.getPopulation(), s1.getPopulation())); } - + @Test public void testCompareBigPopulationWithItself() { Scenario s1 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java index c5c19f6a232..873fad98d90 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -33,8 +33,8 @@ */ public class StringUtilsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java b/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java index e8ef70e3ccd..58e06bfdf21 100644 --- a/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java @@ -24,7 +24,7 @@ import java.util.List; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -48,8 +48,8 @@ public class TimeInterpretationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testIgnoreDelays() { diff --git a/matsim/src/test/java/org/matsim/counts/CountTest.java b/matsim/src/test/java/org/matsim/counts/CountTest.java index 3ea7868ec61..7575c4bd529 100644 --- a/matsim/src/test/java/org/matsim/counts/CountTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountTest.java @@ -25,7 +25,7 @@ import java.util.Iterator; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -33,8 +33,8 @@ public class CountTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private Counts counts; diff --git a/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java b/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java index 07f36ef8d6f..ecefd40d4b1 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java @@ -24,15 +24,15 @@ import java.util.List; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.counts.algorithms.CountsComparisonAlgorithm; import org.matsim.testcases.MatsimTestUtils; public class CountsComparisonAlgorithmTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testCompare() { diff --git a/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java b/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java index 45f5d661b93..21b0939f3d8 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java @@ -27,7 +27,7 @@ import jakarta.inject.Singleton; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -59,7 +59,7 @@ */ public class CountsControlerListenerTest { - @Rule public MatsimTestUtils util = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test public void testUseVolumesOfIteration() { diff --git a/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java b/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java index 6320634482c..dd1627a5c0e 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java @@ -22,15 +22,15 @@ import static org.junit.Assert.assertNotNull; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.counts.algorithms.graphs.BoxPlotErrorGraph; import org.matsim.testcases.MatsimTestUtils; public class CountsErrorGraphTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testCreateChart() { diff --git a/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java b/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java index 5a1d0617691..50dac9c7a41 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertTrue; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.counts.algorithms.CountsComparisonAlgorithm; import org.matsim.counts.algorithms.CountsHtmlAndGraphsWriter; @@ -38,8 +38,8 @@ */ public class CountsHtmlAndGraphsWriterTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testGraphCreation() { diff --git a/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java b/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java index 376c36a1732..63a2002b7af 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java @@ -22,15 +22,15 @@ import static org.junit.Assert.assertNotNull; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.counts.algorithms.graphs.CountsLoadCurveGraph; import org.matsim.testcases.MatsimTestUtils; public class CountsLoadCurveGraphTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testCreateChart() { diff --git a/matsim/src/test/java/org/matsim/counts/CountsParserTest.java b/matsim/src/test/java/org/matsim/counts/CountsParserTest.java index 1f3f4201cd8..804c0be2f33 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsParserTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsParserTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.*; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -31,8 +31,8 @@ public class CountsParserTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testSEElementCounts() throws SAXException { diff --git a/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java b/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java index 0d9c6b0dd34..e548ece2bd0 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java @@ -27,7 +27,7 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import org.xml.sax.SAXException; @@ -39,7 +39,7 @@ */ public class CountsParserWriterTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); /** * @author ahorni diff --git a/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java b/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java index cee54eff284..70f99f38dd9 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java +++ b/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -30,8 +30,8 @@ public class CountsReaderHandlerImplV1Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testSECounts() { diff --git a/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java b/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java index 55e42f43d49..627d918b98d 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java @@ -24,7 +24,7 @@ import com.google.inject.Key; import com.google.inject.TypeLiteral; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -42,7 +42,7 @@ * @author thibautd */ public class CountsReprojectionIOTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java b/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java index 624940acd73..93d404cbe68 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java @@ -22,15 +22,15 @@ import static org.junit.Assert.assertNotNull; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.counts.algorithms.graphs.CountsSimRealPerHourGraph; import org.matsim.testcases.MatsimTestUtils; public class CountsSimRealPerHourGraphTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testCreateChart() { diff --git a/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java b/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java index 320df997d40..f869f6edaa3 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java @@ -25,7 +25,7 @@ import java.io.File; import java.util.Locale; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.counts.algorithms.CountSimComparisonTableWriter; import org.matsim.counts.algorithms.CountsComparisonAlgorithm; @@ -34,8 +34,8 @@ public class CountsTableWriterTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testTableCreation() { diff --git a/matsim/src/test/java/org/matsim/counts/CountsTest.java b/matsim/src/test/java/org/matsim/counts/CountsTest.java index 28e76bfcaf0..af9ae2d6249 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -30,8 +30,8 @@ public class CountsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testGetCounts() { diff --git a/matsim/src/test/java/org/matsim/counts/CountsV2Test.java b/matsim/src/test/java/org/matsim/counts/CountsV2Test.java index 696aa521795..46e306ae4d5 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsV2Test.java +++ b/matsim/src/test/java/org/matsim/counts/CountsV2Test.java @@ -2,7 +2,7 @@ import org.assertj.core.api.Assertions; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -26,8 +26,8 @@ public class CountsV2Test { private final SplittableRandom random = new SplittableRandom(1234); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void test_general_handling() throws IOException { diff --git a/matsim/src/test/java/org/matsim/counts/OutputDelegateTest.java b/matsim/src/test/java/org/matsim/counts/OutputDelegateTest.java index b8fb853dce1..7928c29c482 100644 --- a/matsim/src/test/java/org/matsim/counts/OutputDelegateTest.java +++ b/matsim/src/test/java/org/matsim/counts/OutputDelegateTest.java @@ -27,7 +27,7 @@ import java.util.List; import java.util.Vector; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -38,8 +38,8 @@ public class OutputDelegateTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testOutputHtml() { diff --git a/matsim/src/test/java/org/matsim/examples/EquilTest.java b/matsim/src/test/java/org/matsim/examples/EquilTest.java index c884bf4b3a5..64e3bcdc062 100644 --- a/matsim/src/test/java/org/matsim/examples/EquilTest.java +++ b/matsim/src/test/java/org/matsim/examples/EquilTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -51,7 +51,7 @@ public class EquilTest { private static final Logger log = LogManager.getLogger( EquilTest.class ) ; - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); private final boolean isUsingFastCapacityUpdate; diff --git a/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java b/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java index 92e9431f0c5..48c7bb036f8 100644 --- a/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java +++ b/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.api.experimental.events.EventsManager; @@ -44,8 +44,8 @@ public class OnePercentBerlin10sIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(OnePercentBerlin10sIT.class); diff --git a/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java b/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java index 43c8378d326..781f3587b01 100644 --- a/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java +++ b/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -52,7 +52,8 @@ public class PtTutorialIT { private final static Logger log = LogManager.getLogger(PtTutorialIT.class); - public @Rule MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test public void ensure_tutorial_runs() throws MalformedURLException { diff --git a/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java b/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java index 3789e469a25..0c63dacd949 100644 --- a/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java +++ b/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java @@ -22,7 +22,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -61,7 +61,7 @@ public static Object[] testParameters() { return new Object[] {TypicalDurationScoreComputation.relative, TypicalDurationScoreComputation.uniform}; } - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void test_PtScoringLineswitch() { diff --git a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java index 30d0e5a0a6e..25b4d5a96ed 100644 --- a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java +++ b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java @@ -20,7 +20,7 @@ package org.matsim.facilities; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -53,7 +53,7 @@ @RunWith(Parameterized.class) public class ActivityFacilitiesSourceTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; // private static final String outDir = "test/output/"+ActivityFacilitiesSourceTest.class.getCanonicalName().replace('.','/')+"/"; diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java index 04225385284..9120b176773 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java @@ -22,7 +22,7 @@ package org.matsim.facilities; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.ConfigUtils; @@ -35,7 +35,7 @@ import java.util.function.Consumer; public class FacilitiesAttributeConvertionTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java index 65fca6d624d..90bde039ca5 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java @@ -21,7 +21,7 @@ package org.matsim.facilities; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -42,7 +42,7 @@ */ public class FacilitiesParserWriterTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testParserWriter1() { diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java index e3ad1e04478..f4154bb23d4 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java @@ -22,7 +22,7 @@ package org.matsim.facilities; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -50,7 +50,7 @@ public class FacilitiesReprojectionIOTest { INITIAL_CRS, TARGET_CRS); - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java b/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java index 5296c8c4440..99083e55eb7 100644 --- a/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java +++ b/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -32,8 +32,8 @@ public class AbstractFacilityAlgorithmTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRunAlgorithms() { diff --git a/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java b/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java index 10257ac5867..14d81eb0be3 100644 --- a/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java @@ -24,7 +24,7 @@ import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -40,7 +40,7 @@ import java.util.function.Consumer; public class HouseholdAttributeConversionTest { - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java b/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java index e5137aa72cb..83f7d596c35 100644 --- a/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java +++ b/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java @@ -22,15 +22,15 @@ import static org.junit.Assert.*; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; public class HouseholdImplTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java b/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java index 0f158b4494e..28f68261192 100644 --- a/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java +++ b/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java @@ -27,7 +27,7 @@ import java.util.Collections; import java.util.List; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -41,8 +41,8 @@ */ public class HouseholdsIoTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final String TESTHOUSEHOLDSINPUT = "testHouseholds.xml"; diff --git a/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java b/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java index 3d2df7affd6..d458b8af9a5 100644 --- a/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java +++ b/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -69,8 +69,8 @@ */ public class EquilTwoAgentsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /*package*/ final static Logger log = LogManager.getLogger(EquilTwoAgentsTest.class); diff --git a/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java b/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java index 9d70490fc42..a7235c552d9 100644 --- a/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java +++ b/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java @@ -24,7 +24,7 @@ import java.util.Arrays; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -82,8 +82,8 @@ public class SimulateAndScoreTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRealPtScore() { diff --git a/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java index 6236bd93fbb..d255daabe55 100644 --- a/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java @@ -26,7 +26,7 @@ import java.io.BufferedWriter; import java.io.IOException; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonMoneyEvent; @@ -44,8 +44,8 @@ */ public class PersonMoneyEventIntegrationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteReadXxml() { diff --git a/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java b/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java index 7373f84c106..acf0bf75e71 100644 --- a/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java +++ b/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java @@ -21,7 +21,7 @@ import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.controler.Controler; import org.matsim.core.controler.events.StartupEvent; @@ -30,8 +30,8 @@ public class InvertedNetworkRoutingIT { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public final void testLanesInvertedNetworkRouting() { diff --git a/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java b/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java index f31ec3a810e..e3f49875139 100644 --- a/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java +++ b/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkEnterEvent; @@ -56,8 +56,8 @@ public class LanesIT { private static final Logger log = LogManager.getLogger(LanesIT.class); - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test public void testLanes(){ diff --git a/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java b/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java index 5c317f24862..9e4952cb95a 100644 --- a/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java +++ b/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java @@ -23,7 +23,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -60,7 +60,7 @@ */ public class NonAlternatingPlanElementsIT { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void test_Controler_QSim_Routechoice_acts() { diff --git a/matsim/src/test/java/org/matsim/integration/pt/TransitIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/pt/TransitIntegrationTest.java index b6caa9f2372..7f957b6bf4e 100644 --- a/matsim/src/test/java/org/matsim/integration/pt/TransitIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/pt/TransitIntegrationTest.java @@ -19,7 +19,7 @@ package org.matsim.integration.pt; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -31,7 +31,7 @@ public class TransitIntegrationTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test(expected = RuntimeException.class) public void testPtInteractionParams() { diff --git a/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java index 7672fd7769b..8dc31bb2b98 100644 --- a/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java @@ -23,7 +23,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -70,8 +70,8 @@ */ public class ChangeTripModeIntegrationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testStrategyManagerConfigLoaderIntegration() { diff --git a/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java b/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java index 19a67fdd437..eeba73759b9 100644 --- a/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java +++ b/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.PopulationWriter; @@ -44,8 +44,8 @@ public class ReRoutingIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private Scenario loadScenario() { Config config = utils.loadConfig(utils.getClassInputDirectory() +"config.xml"); diff --git a/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java b/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java index ee859ca7b41..feb4b69ff3c 100644 --- a/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java +++ b/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java @@ -21,7 +21,7 @@ package org.matsim.integration.replanning; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -46,8 +46,8 @@ */ public class ResumableRunsIT { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** * Runs a first simulation for 11 iteration, then restarts at iteration 10. diff --git a/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java index 32c05ba9629..9808f4b5f2c 100644 --- a/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java @@ -26,7 +26,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -75,8 +75,8 @@ */ public class QSimIntegrationTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testFreespeed() { diff --git a/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java b/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java index 9ba9fcade74..c032d3409c9 100644 --- a/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java +++ b/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -49,8 +49,8 @@ */ public class LanesReaderWriterTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(LanesReaderWriterTest.class); diff --git a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java index 4951ffdf3c7..caf4baac619 100644 --- a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java +++ b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java @@ -29,7 +29,7 @@ import jakarta.inject.Inject; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -48,8 +48,8 @@ public class ScoreStatsModuleTest { public static final double DELTA = 0.0000000001; - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private final boolean isUsingFastCapacityUpdate; private final boolean isInsertingAccessEgressWalk; diff --git a/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java b/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java index 9508314fd5c..883aa930f3a 100644 --- a/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java +++ b/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java @@ -21,7 +21,7 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; @@ -31,15 +31,15 @@ import org.matsim.testcases.MatsimTestUtils; /** - * + * * Tests downloading and reading in xml files from our public svn. - * + * * @author gleich */ public class DownloadAndReadXmlTest { - - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Ignore @Test @@ -47,43 +47,43 @@ public class DownloadAndReadXmlTest { * Http downloads from the SVN server will be forbidden soon, according to jwilk. */ public final void testHttpFromSvn() { - + Config config = ConfigUtils.createConfig(); System.out.println(utils.getInputDirectory() + "../../"); config.network().setInputFile("http://svn.vsp.tu-berlin.de/repos/public-svn/matsim/scenarios/countries/atlantis/minibus/input/network.xml"); - + // See whether the file can be downloaded and read Scenario scenario = ScenarioUtils.loadScenario(config); - + // Check whether all nodes and links were read Network network = scenario.getNetwork(); - + // 3 pt nodes and 4 x 4 car nodes Assert.assertEquals(3 + 4 * 4, network.getNodes().size()); - + // 6 pt links and 3 links * 2 directions * 4 times in parallel * 2 (horizontally and vertically) Assert.assertEquals(6 + 3 * 2 * 4 * 2, network.getLinks().size()); } - + @Test public final void testHttpsFromSvn() { - + Config config = ConfigUtils.createConfig(); System.out.println(utils.getInputDirectory() + "../../"); config.network().setInputFile("https://svn.vsp.tu-berlin.de/repos/public-svn/matsim/scenarios/countries/atlantis/minibus/input/network.xml"); - + // See whether the file can be downloaded and read Scenario scenario = ScenarioUtils.loadScenario(config); - + // Check whether all nodes and links were read Network network = scenario.getNetwork(); - + // 3 pt nodes and 4 x 4 car nodes Assert.assertEquals(3 + 4 * 4, network.getNodes().size()); - + // 6 pt links and 3 links * 2 directions * 4 times in parallel * 2 (horizontally and vertically) Assert.assertEquals(6 + 3 * 2 * 4 * 2, network.getLinks().size()); } - + } diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java index 8511013b329..68c8df6fd01 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java @@ -30,7 +30,7 @@ import java.util.List; import java.util.Random; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -65,9 +65,9 @@ */ @RunWith(Parameterized.class) public class ChooseRandomLegModeForSubtourTest { - + private double probaForRandomSingleTripMode; - + private static class AllowTheseModesForEveryone implements PermissibleModesCalculator { @@ -79,18 +79,18 @@ public AllowTheseModesForEveryone(String[] availableModes) { @Override public Collection getPermissibleModes(Plan plan) { - return availableModes; + return availableModes; } } - - @Rule + + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); public static enum TripStructureAnalysisLayerOption {facility,link} private static final String CONFIGFILE = "test/scenarios/equil/config.xml"; - private static final String[] CHAIN_BASED_MODES = new String[] { TransportMode.car }; + private static final String[] CHAIN_BASED_MODES = new String[] { TransportMode.car }; private static final Collection activityChainStrings = Arrays.asList( "1 2 1", "1 2 20 1", @@ -108,7 +108,7 @@ public static enum TripStructureAnalysisLayerOption {facility,link} "1 2 1 1", "1 2 2 3 2 2 2 1 4 1", "1 2 3 4 3 1"); - + @Parameterized.Parameters(name = "{index}: probaForRandomSingleTripMode == {0}") public static Collection createTests() { return Arrays.asList(0., 0.5); @@ -116,8 +116,8 @@ public static Collection createTests() { public ChooseRandomLegModeForSubtourTest( double proba ) { this.probaForRandomSingleTripMode = proba ; } - - + + @Test public void testHandleEmptyPlan() { String[] modes = new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}; @@ -175,7 +175,7 @@ public void testCarDoesntTeleportFromHome() { @Test public void testSingleTripSubtourHandling() { String[] modes = new String[] {"car", "pt", "walk"}; - + ChooseRandomLegModeForSubtour testee = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, new Random(15102011), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); Person person = PopulationUtils.getFactory().createPerson(Id.create("1000", Person.class)); Plan plan = PopulationUtils.createPlan(); @@ -187,12 +187,12 @@ public void testSingleTripSubtourHandling() { plan.addActivity(home1); plan.addLeg(leg); plan.addActivity(home2); - + { // test default boolean hasCar = false; boolean hasPt = false; boolean hasWalk = false; - + for (int i = 0; i < 50; i++) { testee.run(plan); @@ -225,7 +225,7 @@ public void testSingleTripSubtourHandling() { boolean hasCar = false; boolean hasPt = false; boolean hasWalk = false; - + for (int i = 0; i < 50; i++) { testee.run(plan); @@ -302,7 +302,7 @@ private void testSubTourMutationToCar(Network network) { assertSubTourMutated(plan, originalPlan, expectedMode, false); } } - + private void testSubTourMutationToCar(ActivityFacilities facilities) { String expectedMode = TransportMode.car; String originalMode = TransportMode.pt; @@ -318,7 +318,7 @@ private void testSubTourMutationToCar(ActivityFacilities facilities) { assertSubTourMutated(plan, originalPlan, expectedMode, true); } } - + private void testUnknownModeDoesntMutate(Network network) { String originalMode = TransportMode.walk; String[] modes = new String[] {TransportMode.car, TransportMode.pt}; @@ -333,7 +333,7 @@ private void testUnknownModeDoesntMutate(Network network) { assertTrue(TestsUtil.equals(plan.getPlanElements(), originalPlan.getPlanElements())); } } - + private void testUnknownModeDoesntMutate(ActivityFacilities facilities) { String originalMode = TransportMode.walk; String[] modes = new String[] {TransportMode.car, TransportMode.pt}; @@ -364,7 +364,7 @@ private void testSubTourMutationToPt(ActivityFacilities facilities) { assertSubTourMutated(plan, originalPlan, expectedMode, true); } } - + private void testSubTourMutationToPt(Network network) { String expectedMode = TransportMode.pt; String originalMode = TransportMode.car; @@ -380,7 +380,7 @@ private void testSubTourMutationToPt(Network network) { assertSubTourMutated(plan, originalPlan, expectedMode, false); } } - + private void testCarDoesntTeleport(Network network, String originalMode, String otherMode) { String[] modes = new String[] {originalMode, otherMode}; ChooseRandomLegModeForSubtour testee = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, MatsimRandom.getRandom(), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); @@ -414,7 +414,7 @@ private void testCarDoesntTeleport(Network network, String originalMode, String carLocation); } } - + private void testCarDoesntTeleport(ActivityFacilities facilities, String originalMode, String otherMode) { String[] modes = new String[] {originalMode, otherMode}; ChooseRandomLegModeForSubtour testee = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, MatsimRandom.getRandom(), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java index dce12c298ec..e52d56eca60 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java @@ -24,7 +24,7 @@ import java.util.Random; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -43,8 +43,8 @@ */ public class ChooseRandomLegModeTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRandomChoice() { diff --git a/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java b/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java index 298664f0f7f..8e43b745d0a 100644 --- a/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java @@ -20,7 +20,7 @@ package org.matsim.pt.analysis; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -41,7 +41,7 @@ */ public class TransitLoadIntegrationTest { - @Rule public MatsimTestUtils util = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test public void testIntegration() { diff --git a/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java b/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java index 196ff84dc0c..7d573d29ed8 100644 --- a/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java +++ b/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java @@ -3,7 +3,7 @@ import ch.sbb.matsim.routing.pt.raptor.SwissRailRaptor; import com.google.inject.Injector; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.controler.AbstractModule; import org.matsim.core.controler.Controler; @@ -16,7 +16,7 @@ */ public class TransitRouterModuleTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testTransitRoutingAlgorithm_DependencyInjection_Raptor() { diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java index a178e71fc8b..d79bcd590e4 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java @@ -23,7 +23,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNull; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.pt.transitSchedule.api.Departure; @@ -35,8 +35,8 @@ */ public class DepartureTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java index b4a9c097c47..05c4b721b6d 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.pt.transitSchedule.api.TransitLine; @@ -39,8 +39,8 @@ */ public class TransitLineTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(TransitLineTest.class); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java index 1bc7999d263..176ac89d5c3 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.*; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -35,8 +35,8 @@ */ public class TransitRouteStopTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); protected TransitRouteStop createTransitRouteStop(final TransitStopFacility stop, final double arrivalDelay, final double departureDelay) { diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java index ac7d811dd0f..d55881a2542 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -46,8 +46,8 @@ */ public class TransitRouteTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(TransitRouteTest.class); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java index b4f4c0afe95..665f560b7db 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java @@ -28,7 +28,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -61,8 +61,8 @@ */ public class TransitScheduleFormatV1Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteRead() throws IOException, SAXException, ParserConfigurationException { diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java index 305de6e3cec..a634df0d228 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java @@ -29,7 +29,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -56,8 +56,8 @@ */ public class TransitScheduleReaderTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final String INPUT_TEST_FILE_TRANSITSCHEDULE = "transitSchedule.xml"; diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java index 526fefcb1d2..460bb4930b3 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -62,7 +62,7 @@ public class TransitScheduleReprojectionIOTest { INITIAL_CRS, TARGET_CRS); - @Rule + @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @Test diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java index 2bd2ef73e58..c628d33117e 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java @@ -25,7 +25,7 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.population.routes.RouteFactories; @@ -41,8 +41,8 @@ */ public class TransitScheduleWriterTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); - + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + /** * Tests that the default format written is in v2 format. * @@ -67,20 +67,20 @@ public void testDefaultV2() throws IOException, SAXException, ParserConfiguratio new TransitScheduleReaderV2(schedule2, new RouteFactories()).readFile(filename); Assert.assertEquals(1, schedule2.getTransitLines().size()); } - + @Test public void testTransitLineName() { String filename = this.utils.getOutputDirectory() + "schedule.xml"; - + TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitSchedule schedule = builder.createTransitSchedule(); TransitLine line = builder.createTransitLine(Id.create(1, TransitLine.class)); line.setName("Blue line"); schedule.addTransitLine(line); - + TransitScheduleWriter writer = new TransitScheduleWriter(schedule); writer.writeFile(filename); - + TransitScheduleFactory builder2 = new TransitScheduleFactoryImpl(); TransitSchedule schedule2 = builder2.createTransitSchedule(); new TransitScheduleReaderV1(schedule2, new RouteFactories()).readFile(filename); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java index dd2889e872f..5f8cd61b7b1 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.*; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -36,8 +36,8 @@ */ public class TransitStopFacilityTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** diff --git a/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java b/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java index fba104c3f3d..cf324a220c0 100644 --- a/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java +++ b/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -35,7 +35,7 @@ public class CreateFullConfigTest { private final static Logger log = LogManager.getLogger(CreateFullConfigTest.class); - @Rule public MatsimTestUtils helper = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils helper = new MatsimTestUtils(); @Test public void testMain() { diff --git a/matsim/src/test/java/org/matsim/run/InitRoutesTest.java b/matsim/src/test/java/org/matsim/run/InitRoutesTest.java index ecc5c4b1d8b..b44932b7cf4 100644 --- a/matsim/src/test/java/org/matsim/run/InitRoutesTest.java +++ b/matsim/src/test/java/org/matsim/run/InitRoutesTest.java @@ -24,7 +24,7 @@ import java.io.File; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -57,8 +57,8 @@ */ public class InitRoutesTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testMain() throws Exception { diff --git a/matsim/src/test/java/org/matsim/run/XY2LinksTest.java b/matsim/src/test/java/org/matsim/run/XY2LinksTest.java index bab46ae2286..b403682c30a 100644 --- a/matsim/src/test/java/org/matsim/run/XY2LinksTest.java +++ b/matsim/src/test/java/org/matsim/run/XY2LinksTest.java @@ -24,7 +24,7 @@ import java.io.File; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -54,8 +54,8 @@ */ public class XY2LinksTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testMain() throws Exception { diff --git a/matsim/src/test/java/org/matsim/testcases/MatsimJunit5Test.java b/matsim/src/test/java/org/matsim/testcases/MatsimJunit5Test.java deleted file mode 100644 index 0581a3d58d0..00000000000 --- a/matsim/src/test/java/org/matsim/testcases/MatsimJunit5Test.java +++ /dev/null @@ -1,344 +0,0 @@ -/* *********************************************************************** * - * project: org.matsim.* - * * - * *********************************************************************** * - * * - * copyright : (C) 2010 by the members listed in the COPYING, * - * LICENSE and WARRANTY file. * - * email : info at matsim dot org * - * * - * *********************************************************************** * - * * - * This program is free software; you can redistribute it and/or modify * - * it under the terms of the GNU General Public License as published by * - * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * - * See also COPYING, LICENSE and WARRANTY file * - * * - * *********************************************************************** */ - -package org.matsim.testcases; - -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; -import org.junit.Assert; -import org.junit.jupiter.api.AfterEach; -import org.junit.jupiter.api.BeforeEach; -import org.junit.jupiter.api.TestInfo; -import org.junit.rules.TestWatcher; -import org.junit.runner.Description; -import org.matsim.core.config.Config; -import org.matsim.core.config.ConfigGroup; -import org.matsim.core.config.ConfigUtils; -import org.matsim.core.gbl.MatsimRandom; -import org.matsim.core.utils.io.IOUtils; -import org.matsim.core.utils.misc.CRCChecksum; -import org.matsim.utils.eventsfilecomparison.EventsFileComparator; - -import java.io.BufferedReader; -import java.io.File; -import java.io.IOException; -import java.io.UncheckedIOException; -import java.lang.reflect.Method; -import java.net.MalformedURLException; -import java.net.URL; -import java.util.Objects; -import java.util.regex.Matcher; -import java.util.regex.Pattern; - -import static org.junit.Assert.assertEquals; - -/** - * //TODO - * - * @author pheinrich - */ -public abstract class MatsimJunit5Test { - private static final Logger log = LogManager.getLogger(MatsimJunit5Test.class); - - /** - * A constant for the exactness when comparing doubles. - */ - public static final double EPSILON = 1e-10; - - /** The default output directory, where files of this test should be written to. - * Includes the trailing '/' to denote a directory. */ - private String outputDirectory = null; - - /** The default input directory, where files of this test should be read from. - * Includes the trailing '/' to denote a directory. */ - private String inputDirectory = null; - - /** - * The input directory one level above the default input directory. If files are - * used by several test methods of a testcase they have to be stored in this directory. - */ - private String classInputDirectory = null; - /** - * The input directory two levels above the default input directory. If files are used - * by several test classes of a package they have to be stored in this directory. - */ - private String packageInputDirectory; - - private boolean outputDirCreated = false; - - private Class testClass = null; - private String testMethodName = null; - private String testParameterSetIndex = null; - - public MatsimJunit5Test() { - MatsimRandom.reset(); - } - - @BeforeEach - public void initEach(TestInfo testInfo) { - this.testClass = testInfo.getTestClass().orElseThrow(); - - Matcher matcher = METHOD_PARAMETERS_WITH_INDEX_PATTERN.matcher(testInfo.getTestMethod().orElseThrow().getName()); - if (!matcher.matches()) { - throw new RuntimeException("The name of the test parameter set must start with {index}"); - } - this.testMethodName = matcher.group(1); - this.testParameterSetIndex = matcher.group(2); // null for non-parametrised tests - } - - @AfterEach - public void finish() { - this.testClass = null; - this.testMethodName = null; - } - - public Config createConfigWithInputResourcePathAsContext() { - Config config = ConfigUtils.createConfig(); - config.setContext(inputResourcePath()); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - public Config createConfigWithClassInputResourcePathAsContext() { - Config config = ConfigUtils.createConfig(); - config.setContext(classInputResourcePath()); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - public Config createConfigWithPackageInputResourcePathAsContext() { - Config config = ConfigUtils.createConfig(); - config.setContext(packageInputResourcePath()); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - public URL inputResourcePath() { - return getResourceNotNull("/" + getClassInputDirectory() + getMethodName() + "/."); - } - - /** - * @return class input directory as URL - */ - public URL classInputResourcePath() { - return getResourceNotNull("/" + getClassInputDirectory() + "/."); - } - - public URL packageInputResourcePath() { - return getResourceNotNull("/" + getPackageInputDirectory() + "/."); - } - - private URL getResourceNotNull(String pathString) { - URL resource = this.testClass.getResource(pathString); - if (resource == null) { - throw new UncheckedIOException(new IOException("Not found: "+pathString)); - } - return resource; - } - - public Config createConfigWithTestInputFilePathAsContext() { - try { - Config config = ConfigUtils.createConfig(); - config.setContext(new File(this.getInputDirectory()).toURI().toURL()); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } catch (MalformedURLException e) { - throw new RuntimeException(e); - } - } - - public Config createConfig(URL context) { - Config config = ConfigUtils.createConfig(); - config.setContext(context); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - - /** - * Loads a configuration from file (or the default config if configfile is null). - * - * @param configfile The path/filename of a configuration file, or null to load the default configuration. - * @return The loaded configuration. - */ - public Config loadConfig(final String configfile, final ConfigGroup... customGroups) { - Config config; - if (configfile != null) { - config = ConfigUtils.loadConfig(configfile, customGroups); - } else { - config = ConfigUtils.createConfig( customGroups ); - } - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - public Config loadConfig(final URL configfile, final ConfigGroup... customGroups) { - Config config; - if (configfile != null) { - config = ConfigUtils.loadConfig(configfile, customGroups); - } else { - config = ConfigUtils.createConfig( customGroups ); - } - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - public Config createConfig(final ConfigGroup... customGroups) { - Config config = ConfigUtils.createConfig( customGroups ); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - private void createOutputDirectory() { - if ((!this.outputDirCreated) && (this.outputDirectory != null)) { - File directory = new File(this.outputDirectory); - if (directory.exists()) { - IOUtils.deleteDirectoryRecursively(directory.toPath()); - } - this.outputDirCreated = directory.mkdirs(); - Assert.assertTrue("Could not create the output directory " + this.outputDirectory, this.outputDirCreated); - } - } - - /** - * Returns the path to the output directory for this test including a trailing slash as directory delimiter. - * - * @return path to the output directory for this test - */ - public String getOutputDirectory() { - if (this.outputDirectory == null) { - String subDirectoryForParametrisedTests = testParameterSetIndex == null ? "" : testParameterSetIndex + "/"; - this.outputDirectory = "test/output/" + this.testClass.getCanonicalName().replace('.', '/') + "/" + getMethodName()+ "/" - + subDirectoryForParametrisedTests; - } - createOutputDirectory(); - return this.outputDirectory; - } - - /** - * Returns the path to the input directory for this test including a trailing slash as directory delimiter. - * - * @return path to the input directory for this test - */ - public String getInputDirectory() { - if (this.inputDirectory == null) { - this.inputDirectory = getClassInputDirectory() + getMethodName() + "/"; - } - return this.inputDirectory; - } - /** - * Returns the path to the input directory one level above the default input directory for this test including a trailing slash as directory delimiter. - * - * @return path to the input directory for this test - */ - public String getClassInputDirectory() { - if (this.classInputDirectory == null) { - - LogManager.getLogger(this.getClass()).info( "user.dir = " + System.getProperty("user.dir") ) ; - - this.classInputDirectory = "test/input/" + - this.testClass.getCanonicalName().replace('.', '/') + "/"; -// this.classInputDirectory = System.getProperty("user.dir") + "/test/input/" + -// this.testClass.getCanonicalName().replace('.', '/') + "/"; - // (this used to be relative, i.e. ... = "test/input/" + ... . Started failing when - // this was used in tests to read a second config file when I made the path of that - // relative to the root of the initial config file. Arghh. kai, feb'18) - // yyyyyy needs to be discussed, see MATSIM-776 and MATSIM-777. kai, feb'18 - } - return this.classInputDirectory; - } - /** - * Returns the path to the input directory two levels above the default input directory for this test including a trailing slash as directory delimiter. - * - * @return path to the input directory for this test - */ - public String getPackageInputDirectory() { - if (this.packageInputDirectory == null) { - String classDirectory = getClassInputDirectory(); - this.packageInputDirectory = classDirectory.substring(0, classDirectory.lastIndexOf('/')); - this.packageInputDirectory = this.packageInputDirectory.substring(0, this.packageInputDirectory.lastIndexOf('/') + 1); - } - return this.packageInputDirectory; - } - - /** - * @return the name of the currently-running test method - */ - public String getMethodName() { - if (this.testMethodName == null) { - throw new RuntimeException("MatsimTestUtils.getMethodName() can only be used in actual test, not in constructor or elsewhere!"); - } - return this.testMethodName; - } - - /** - * Initializes MatsimTestUtils without requiring the method of a class to be a JUnit test. - * This should be used for "fixtures" only that provide a scenario common to several - * test cases. - */ - public void initWithoutJUnitForFixture(Class fixture, Method method){ - this.testClass = fixture; - this.testMethodName = method.getName(); - } - - //captures the method name (group 1) and optionally the index of the parameter set (group 2; only if the test is parametrised) - //The matching may fail if the parameter set name does not start with {index} (at least one digit is required at the beginning) - private static final Pattern METHOD_PARAMETERS_WITH_INDEX_PATTERN = Pattern.compile( - "([\\S]*)(?:\\[(\\d+)[\\s\\S]*\\])?"); - - public static void assertEqualEventsFiles( String filename1, String filename2 ) { - Assert.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL ,EventsFileComparator.compare(filename1, filename2) ); - } - - public static void assertEqualFilesBasedOnCRC( String filename1, String filename2 ) { - long checksum1 = CRCChecksum.getCRCFromFile(filename1) ; - long checksum2 = CRCChecksum.getCRCFromFile(filename2) ; - Assert.assertEquals( "different file checksums", checksum1, checksum2 ); - } - - public static void assertEqualFilesLineByLine(String inputFilename, String outputFilename) { - try (BufferedReader readerV1Input = IOUtils.getBufferedReader(inputFilename); - BufferedReader readerV1Output = IOUtils.getBufferedReader(outputFilename)) { - - String lineInput; - String lineOutput; - - while( ((lineInput = readerV1Input.readLine()) != null) && ((lineOutput = readerV1Output.readLine()) != null) ){ - if ( !Objects.equals( lineInput.trim(), lineOutput.trim() ) ){ - log.info( "Reading line... " ); - log.info( lineInput ); - log.info( lineOutput ); - log.info( "" ); - } - assertEquals( "Lines have different content: ", lineInput.trim(), lineOutput.trim() ); - } - } catch (IOException e) { - throw new UncheckedIOException(e); - } - } - -} diff --git a/matsim/src/test/java/org/matsim/testcases/MatsimJunit5TestExtension.java b/matsim/src/test/java/org/matsim/testcases/MatsimJunit5TestExtension.java deleted file mode 100644 index 1e4e87367c9..00000000000 --- a/matsim/src/test/java/org/matsim/testcases/MatsimJunit5TestExtension.java +++ /dev/null @@ -1,344 +0,0 @@ -/* *********************************************************************** * - * project: org.matsim.* - * * - * *********************************************************************** * - * * - * copyright : (C) 2010 by the members listed in the COPYING, * - * LICENSE and WARRANTY file. * - * email : info at matsim dot org * - * * - * *********************************************************************** * - * * - * This program is free software; you can redistribute it and/or modify * - * it under the terms of the GNU General Public License as published by * - * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * - * See also COPYING, LICENSE and WARRANTY file * - * * - * *********************************************************************** */ - -package org.matsim.testcases; - -import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; -import org.junit.Assert; -import org.junit.jupiter.api.AfterEach; -import org.junit.jupiter.api.BeforeEach; -import org.junit.jupiter.api.TestInfo; -import org.junit.jupiter.api.extension.AfterEachCallback; -import org.junit.jupiter.api.extension.BeforeEachCallback; -import org.junit.jupiter.api.extension.ExtensionContext; -import org.matsim.core.config.Config; -import org.matsim.core.config.ConfigGroup; -import org.matsim.core.config.ConfigUtils; -import org.matsim.core.gbl.MatsimRandom; -import org.matsim.core.utils.io.IOUtils; -import org.matsim.core.utils.misc.CRCChecksum; -import org.matsim.utils.eventsfilecomparison.EventsFileComparator; - -import java.io.BufferedReader; -import java.io.File; -import java.io.IOException; -import java.io.UncheckedIOException; -import java.lang.reflect.Method; -import java.net.MalformedURLException; -import java.net.URL; -import java.util.Objects; -import java.util.regex.Matcher; -import java.util.regex.Pattern; - -import static org.junit.Assert.assertEquals; - -/** - * //TODO - * - * @author pheinrich - */ -public class MatsimJunit5TestExtension implements BeforeEachCallback, AfterEachCallback { - private static final Logger log = LogManager.getLogger(MatsimJunit5TestExtension.class); - - /** - * A constant for the exactness when comparing doubles. - */ - public static final double EPSILON = 1e-10; - - /** The default output directory, where files of this test should be written to. - * Includes the trailing '/' to denote a directory. */ - private String outputDirectory = null; - - /** The default input directory, where files of this test should be read from. - * Includes the trailing '/' to denote a directory. */ - private String inputDirectory = null; - - /** - * The input directory one level above the default input directory. If files are - * used by several test methods of a testcase they have to be stored in this directory. - */ - private String classInputDirectory = null; - /** - * The input directory two levels above the default input directory. If files are used - * by several test classes of a package they have to be stored in this directory. - */ - private String packageInputDirectory; - - private boolean outputDirCreated = false; - - private Class testClass = null; - private String testMethodName = null; - private String testParameterSetIndex = null; - - public MatsimJunit5TestExtension() { - MatsimRandom.reset(); - } - - @Override - public void beforeEach(ExtensionContext extensionContext) throws Exception { - this.testClass = extensionContext.getTestClass().orElseThrow(); - - Matcher matcher = METHOD_PARAMETERS_WITH_INDEX_PATTERN.matcher(extensionContext.getTestMethod().orElseThrow().getName()); - if (!matcher.matches()) { - throw new RuntimeException("The name of the test parameter set must start with {index}"); - } - this.testMethodName = matcher.group(1); - this.testParameterSetIndex = matcher.group(2); // null for non-parametrised tests - } - - @Override - public void afterEach(ExtensionContext extensionContext) throws Exception { - this.testClass = null; - this.testMethodName = null; - } - - public Config createConfigWithInputResourcePathAsContext() { - Config config = ConfigUtils.createConfig(); - config.setContext(inputResourcePath()); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - public Config createConfigWithClassInputResourcePathAsContext() { - Config config = ConfigUtils.createConfig(); - config.setContext(classInputResourcePath()); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - public Config createConfigWithPackageInputResourcePathAsContext() { - Config config = ConfigUtils.createConfig(); - config.setContext(packageInputResourcePath()); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - public URL inputResourcePath() { - return getResourceNotNull("/" + getClassInputDirectory() + getMethodName() + "/."); - } - - /** - * @return class input directory as URL - */ - public URL classInputResourcePath() { - return getResourceNotNull("/" + getClassInputDirectory() + "/."); - } - - public URL packageInputResourcePath() { - return getResourceNotNull("/" + getPackageInputDirectory() + "/."); - } - - private URL getResourceNotNull(String pathString) { - URL resource = this.testClass.getResource(pathString); - if (resource == null) { - throw new UncheckedIOException(new IOException("Not found: "+pathString)); - } - return resource; - } - - public Config createConfigWithTestInputFilePathAsContext() { - try { - Config config = ConfigUtils.createConfig(); - config.setContext(new File(this.getInputDirectory()).toURI().toURL()); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } catch (MalformedURLException e) { - throw new RuntimeException(e); - } - } - - public Config createConfig(URL context) { - Config config = ConfigUtils.createConfig(); - config.setContext(context); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - - /** - * Loads a configuration from file (or the default config if configfile is null). - * - * @param configfile The path/filename of a configuration file, or null to load the default configuration. - * @return The loaded configuration. - */ - public Config loadConfig(final String configfile, final ConfigGroup... customGroups) { - Config config; - if (configfile != null) { - config = ConfigUtils.loadConfig(configfile, customGroups); - } else { - config = ConfigUtils.createConfig( customGroups ); - } - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - public Config loadConfig(final URL configfile, final ConfigGroup... customGroups) { - Config config; - if (configfile != null) { - config = ConfigUtils.loadConfig(configfile, customGroups); - } else { - config = ConfigUtils.createConfig( customGroups ); - } - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - public Config createConfig(final ConfigGroup... customGroups) { - Config config = ConfigUtils.createConfig( customGroups ); - this.outputDirectory = getOutputDirectory(); - config.controller().setOutputDirectory(this.outputDirectory); - return config; - } - - private void createOutputDirectory() { - if ((!this.outputDirCreated) && (this.outputDirectory != null)) { - File directory = new File(this.outputDirectory); - if (directory.exists()) { - IOUtils.deleteDirectoryRecursively(directory.toPath()); - } - this.outputDirCreated = directory.mkdirs(); - Assert.assertTrue("Could not create the output directory " + this.outputDirectory, this.outputDirCreated); - } - } - - /** - * Returns the path to the output directory for this test including a trailing slash as directory delimiter. - * - * @return path to the output directory for this test - */ - public String getOutputDirectory() { - if (this.outputDirectory == null) { - String subDirectoryForParametrisedTests = testParameterSetIndex == null ? "" : testParameterSetIndex + "/"; - this.outputDirectory = "test/output/" + this.testClass.getCanonicalName().replace('.', '/') + "/" + getMethodName()+ "/" - + subDirectoryForParametrisedTests; - } - createOutputDirectory(); - return this.outputDirectory; - } - - /** - * Returns the path to the input directory for this test including a trailing slash as directory delimiter. - * - * @return path to the input directory for this test - */ - public String getInputDirectory() { - if (this.inputDirectory == null) { - this.inputDirectory = getClassInputDirectory() + getMethodName() + "/"; - } - return this.inputDirectory; - } - /** - * Returns the path to the input directory one level above the default input directory for this test including a trailing slash as directory delimiter. - * - * @return path to the input directory for this test - */ - public String getClassInputDirectory() { - if (this.classInputDirectory == null) { - - LogManager.getLogger(this.getClass()).info( "user.dir = " + System.getProperty("user.dir") ) ; - - this.classInputDirectory = "test/input/" + - this.testClass.getCanonicalName().replace('.', '/') + "/"; -// this.classInputDirectory = System.getProperty("user.dir") + "/test/input/" + -// this.testClass.getCanonicalName().replace('.', '/') + "/"; - // (this used to be relative, i.e. ... = "test/input/" + ... . Started failing when - // this was used in tests to read a second config file when I made the path of that - // relative to the root of the initial config file. Arghh. kai, feb'18) - // yyyyyy needs to be discussed, see MATSIM-776 and MATSIM-777. kai, feb'18 - } - return this.classInputDirectory; - } - /** - * Returns the path to the input directory two levels above the default input directory for this test including a trailing slash as directory delimiter. - * - * @return path to the input directory for this test - */ - public String getPackageInputDirectory() { - if (this.packageInputDirectory == null) { - String classDirectory = getClassInputDirectory(); - this.packageInputDirectory = classDirectory.substring(0, classDirectory.lastIndexOf('/')); - this.packageInputDirectory = this.packageInputDirectory.substring(0, this.packageInputDirectory.lastIndexOf('/') + 1); - } - return this.packageInputDirectory; - } - - /** - * @return the name of the currently-running test method - */ - public String getMethodName() { - if (this.testMethodName == null) { - throw new RuntimeException("MatsimTestUtils.getMethodName() can only be used in actual test, not in constructor or elsewhere!"); - } - return this.testMethodName; - } - - /** - * Initializes MatsimTestUtils without requiring the method of a class to be a JUnit test. - * This should be used for "fixtures" only that provide a scenario common to several - * test cases. - */ - public void initWithoutJUnitForFixture(Class fixture, Method method){ - this.testClass = fixture; - this.testMethodName = method.getName(); - } - - //captures the method name (group 1) and optionally the index of the parameter set (group 2; only if the test is parametrised) - //The matching may fail if the parameter set name does not start with {index} (at least one digit is required at the beginning) - private static final Pattern METHOD_PARAMETERS_WITH_INDEX_PATTERN = Pattern.compile( - "([\\S]*)(?:\\[(\\d+)[\\s\\S]*\\])?"); - - public static void assertEqualEventsFiles( String filename1, String filename2 ) { - Assert.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL ,EventsFileComparator.compare(filename1, filename2) ); - } - - public static void assertEqualFilesBasedOnCRC( String filename1, String filename2 ) { - long checksum1 = CRCChecksum.getCRCFromFile(filename1) ; - long checksum2 = CRCChecksum.getCRCFromFile(filename2) ; - Assert.assertEquals( "different file checksums", checksum1, checksum2 ); - } - - public static void assertEqualFilesLineByLine(String inputFilename, String outputFilename) { - try (BufferedReader readerV1Input = IOUtils.getBufferedReader(inputFilename); - BufferedReader readerV1Output = IOUtils.getBufferedReader(outputFilename)) { - - String lineInput; - String lineOutput; - - while( ((lineInput = readerV1Input.readLine()) != null) && ((lineOutput = readerV1Output.readLine()) != null) ){ - if ( !Objects.equals( lineInput.trim(), lineOutput.trim() ) ){ - log.info( "Reading line... " ); - log.info( lineInput ); - log.info( lineOutput ); - log.info( "" ); - } - assertEquals( "Lines have different content: ", lineInput.trim(), lineOutput.trim() ); - } - } catch (IOException e) { - throw new UncheckedIOException(e); - } - } -} diff --git a/matsim/src/test/java/org/matsim/testcases/MatsimTestUtils.java b/matsim/src/test/java/org/matsim/testcases/MatsimTestUtils.java index b568268cbae..8b34bea7c10 100644 --- a/matsim/src/test/java/org/matsim/testcases/MatsimTestUtils.java +++ b/matsim/src/test/java/org/matsim/testcases/MatsimTestUtils.java @@ -21,9 +21,10 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; -import org.junit.rules.TestWatcher; -import org.junit.runner.Description; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.extension.AfterEachCallback; +import org.junit.jupiter.api.extension.BeforeEachCallback; +import org.junit.jupiter.api.extension.ExtensionContext; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigGroup; import org.matsim.core.config.ConfigUtils; @@ -43,15 +44,12 @@ import java.util.regex.Matcher; import java.util.regex.Pattern; -import static org.junit.Assert.assertEquals; - /** - * Some helper methods for writing JUnit 4 tests in MATSim. - * Inspired by JUnit's rule TestName + * Some helper methods for writing JUnit 5 tests in MATSim. * * @author mrieser */ -public final class MatsimTestUtils extends TestWatcher { +public final class MatsimTestUtils implements BeforeEachCallback, AfterEachCallback { private static final Logger log = LogManager.getLogger(MatsimTestUtils.class); /** @@ -59,27 +57,6 @@ public final class MatsimTestUtils extends TestWatcher { */ public static final double EPSILON = 1e-10; - public static void assertEqualFilesLineByLine(String inputFilename, String outputFilename) { - try (BufferedReader readerV1Input = IOUtils.getBufferedReader(inputFilename); - BufferedReader readerV1Output = IOUtils.getBufferedReader(outputFilename)) { - - String lineInput; - String lineOutput; - - while( ((lineInput = readerV1Input.readLine()) != null) && ((lineOutput = readerV1Output.readLine()) != null) ){ - if ( !Objects.equals( lineInput.trim(), lineOutput.trim() ) ){ - log.info( "Reading line... " ); - log.info( lineInput ); - log.info( lineOutput ); - log.info( "" ); - } - assertEquals( "Lines have different content: ", lineInput.trim(), lineOutput.trim() ); - } - } catch (IOException e) { - throw new UncheckedIOException(e); - } - } - /** The default output directory, where files of this test should be written to. * Includes the trailing '/' to denote a directory. */ private String outputDirectory = null; @@ -105,10 +82,34 @@ public static void assertEqualFilesLineByLine(String inputFilename, String outpu private String testMethodName = null; private String testParameterSetIndex = null; + //captures the method name (group 1) and optionally the index of the parameter set (group 2; only if the test is parametrised) + //The matching may fail if the parameter set name does not start with {index} (at least one digit is required at the beginning) + private static final Pattern METHOD_PARAMETERS_WITH_INDEX_PATTERN = Pattern.compile( + "([\\S]*)(?:\\[(\\d+)[\\s\\S]*\\])?"); + + public MatsimTestUtils() { MatsimRandom.reset(); } + @Override + public void beforeEach(ExtensionContext extensionContext) { + this.testClass = extensionContext.getTestClass().orElseThrow(); + + Matcher matcher = METHOD_PARAMETERS_WITH_INDEX_PATTERN.matcher(extensionContext.getTestMethod().orElseThrow().getName()); + if (!matcher.matches()) { + throw new RuntimeException("The name of the test parameter set must start with {index}"); + } + this.testMethodName = matcher.group(1); + this.testParameterSetIndex = matcher.group(2); // null for non-parametrised tests + } + + @Override + public void afterEach(ExtensionContext extensionContext) { + this.testClass = null; + this.testMethodName = null; + } + public Config createConfigWithInputResourcePathAsContext() { Config config = ConfigUtils.createConfig(); config.setContext(inputResourcePath()); @@ -221,7 +222,7 @@ private void createOutputDirectory() { IOUtils.deleteDirectoryRecursively(directory.toPath()); } this.outputDirCreated = directory.mkdirs(); - Assert.assertTrue("Could not create the output directory " + this.outputDirectory, this.outputDirCreated); + Assertions.assertTrue(this.outputDirCreated, "Could not create the output directory " + this.outputDirectory); } } @@ -306,41 +307,34 @@ public void initWithoutJUnitForFixture(Class fixture, Method method){ this.testMethodName = method.getName(); } - //captures the method name (group 1) and optionally the index of the parameter set (group 2; only if the test is parametrised) - //The matching may fail if the parameter set name does not start with {index} (at least one digit is required at the beginning) - private static final Pattern METHOD_PARAMETERS_WITH_INDEX_PATTERN = Pattern.compile( - "([\\S]*)(?:\\[(\\d+)[\\s\\S]*\\])?"); + public static void assertEqualFilesLineByLine(String inputFilename, String outputFilename) { + try (BufferedReader readerV1Input = IOUtils.getBufferedReader(inputFilename); + BufferedReader readerV1Output = IOUtils.getBufferedReader(outputFilename)) { - /* inspired by - * @see org.junit.rules.TestName#starting(org.junit.runners.model.FrameworkMethod) - */ - @Override - public void starting(Description description) { - super.starting(description); - this.testClass = description.getTestClass(); + String lineInput; + String lineOutput; - Matcher matcher = METHOD_PARAMETERS_WITH_INDEX_PATTERN.matcher(description.getMethodName()); - if (!matcher.matches()) { - throw new RuntimeException("The name of the test parameter set must start with {index}"); + while( ((lineInput = readerV1Input.readLine()) != null) && ((lineOutput = readerV1Output.readLine()) != null) ){ + if ( !Objects.equals( lineInput.trim(), lineOutput.trim() ) ){ + log.info( "Reading line... " ); + log.info( lineInput ); + log.info( lineOutput ); + log.info( "" ); + } + Assertions.assertEquals(lineInput.trim(), lineOutput.trim(), "Lines have different content: " ); + } + } catch (IOException e) { + throw new UncheckedIOException(e); } - this.testMethodName = matcher.group(1); - this.testParameterSetIndex = matcher.group(2); // null for non-parametrised tests - } - - @Override - public void finished(Description description) { - super.finished(description); - this.testClass = null; - this.testMethodName = null; } public static void assertEqualEventsFiles( String filename1, String filename2 ) { - Assert.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL ,EventsFileComparator.compare(filename1, filename2) ); + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL ,EventsFileComparator.compare(filename1, filename2) ); } public static void assertEqualFilesBasedOnCRC( String filename1, String filename2 ) { long checksum1 = CRCChecksum.getCRCFromFile(filename1) ; long checksum2 = CRCChecksum.getCRCFromFile(filename2) ; - Assert.assertEquals( "different file checksums", checksum1, checksum2 ); + Assertions.assertEquals( checksum1, checksum2, "different file checksums" ); } } diff --git a/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java b/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java index b11f3b6128f..76c4b86140b 100644 --- a/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java +++ b/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; import static org.matsim.utils.eventsfilecomparison.EventsFileComparator.Result.*; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -32,8 +32,8 @@ */ public class EventsFileComparatorTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRetCode0() { diff --git a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java index 93d111619ea..298f06bcbb0 100755 --- a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java +++ b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java @@ -23,7 +23,7 @@ import java.util.Collection; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; @@ -38,8 +38,8 @@ public class Network2ESRIShapeTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testPolygonCapacityShape() { String netFileName = "test/scenarios/equil/network.xml"; diff --git a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java index 10db54d1fef..eb8441dce27 100755 --- a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java +++ b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java @@ -25,7 +25,7 @@ import java.util.zip.GZIPInputStream; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; @@ -41,8 +41,8 @@ public class SelectedPlans2ESRIShapeTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testSelectedPlansActsShape() throws IOException { diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java index ce57926282c..8cbc027a81b 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java @@ -24,7 +24,7 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import org.xml.sax.SAXException; @@ -34,7 +34,8 @@ */ public class ObjectAttributesXmlIOTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + public MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testReadWrite() throws IOException, SAXException, ParserConfigurationException { @@ -52,7 +53,7 @@ public void testReadWrite() throws IOException, SAXException, ParserConfiguratio Assert.assertEquals(Double.valueOf(1.5), oa2.getAttribute("two", "c")); Assert.assertEquals(Boolean.TRUE, oa2.getAttribute("two", "d")); } - + @Test public void testReadWrite_CustomAttribute() { ObjectAttributes oa1 = new ObjectAttributes(); @@ -62,14 +63,14 @@ public void testReadWrite_CustomAttribute() { MyTuple.MyTupleConverter converter = new MyTuple.MyTupleConverter(); writer.putAttributeConverter(MyTuple.class, converter); writer.writeFile(this.utils.getOutputDirectory() + "oa.xml"); - + Assert.assertFalse("toString() should return something different from converter to test functionality.", t.toString().equals(converter.convertToString(t))); ObjectAttributes oa2 = new ObjectAttributes(); ObjectAttributesXmlReader reader = new ObjectAttributesXmlReader(oa2); reader.putAttributeConverter(MyTuple.class, new MyTuple.MyTupleConverter()); reader.readFile(this.utils.getOutputDirectory() + "oa.xml"); - + Object o = oa2.getAttribute("1", "A"); Assert.assertNotNull(o); Assert.assertEquals(MyTuple.class, o.getClass()); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java index d0c298be179..b02914eaada 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java @@ -25,7 +25,7 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import org.xml.sax.SAXException; @@ -35,7 +35,7 @@ */ public class ObjectAttributesXmlReaderTest { - @Rule public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testParse_customConverter() throws SAXException, ParserConfigurationException, IOException { diff --git a/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java b/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java index 2357c18ec49..6c0b4d9858e 100644 --- a/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java +++ b/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java @@ -29,7 +29,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -39,8 +39,8 @@ */ public class MatsimVehicleWriterTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(MatsimVehicleWriterTest.class); diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java index deaecd70c10..4ff191bfbfc 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java @@ -24,7 +24,7 @@ import java.util.Map; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -34,8 +34,8 @@ */ public class VehicleReaderV1Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final String TESTXML = "testVehicles_v1.xml"; diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java index fa989c663d1..5e2208a4a88 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java @@ -24,7 +24,7 @@ import java.util.Map; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -34,8 +34,8 @@ */ public class VehicleReaderV2Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final String TESTXML2 = "testVehicles_v2.xml"; diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java index c31cbd923c9..ea13e5dd1b4 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java @@ -6,14 +6,14 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class VehicleWriteReadTest{ private static final Logger log = LogManager.getLogger( VehicleWriteReadTest.class ) ; - @Rule public MatsimTestUtils utils = new MatsimTestUtils() ; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; private static final String TESTXML_v1 = "testVehicles_v1_withDefaultValues.xml"; diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java index cc87af6eacd..7625ba85319 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -38,8 +38,8 @@ */ public class VehicleWriterV1Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(VehicleWriterV1Test.class); diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java index e4a4818a335..d7242617d79 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -38,8 +38,8 @@ */ public class VehicleWriterV2Test { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final Logger log = LogManager.getLogger(VehicleWriterV2Test.class); diff --git a/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java b/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java index dea73c1d5b7..84d11f60338 100644 --- a/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java +++ b/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -34,8 +34,8 @@ public class PositionInfoTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); private static final double epsilon = 1e-8; // accuracy of double-comparisons diff --git a/matsim/src/test/java/org/matsim/withinday/controller/ExampleWithinDayControllerTest.java b/matsim/src/test/java/org/matsim/withinday/controller/ExampleWithinDayControllerTest.java index 01a9e44a166..4512cfea7e0 100644 --- a/matsim/src/test/java/org/matsim/withinday/controller/ExampleWithinDayControllerTest.java +++ b/matsim/src/test/java/org/matsim/withinday/controller/ExampleWithinDayControllerTest.java @@ -22,7 +22,7 @@ package org.matsim.withinday.controller; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Leg; @@ -39,8 +39,8 @@ public class ExampleWithinDayControllerTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testRun() { diff --git a/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java b/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java index a9290886cb9..c1b95aa5670 100644 --- a/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java +++ b/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -73,8 +73,8 @@ public class ExperiencedPlansWriterTest { private static final Logger log = LogManager.getLogger(ExperiencedPlansWriterTest.class); - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testWriteFile() { diff --git a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java index 4aebdd6bb91..59c2ed7e244 100644 --- a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java +++ b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java @@ -27,7 +27,7 @@ import jakarta.inject.Inject; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; @@ -54,8 +54,8 @@ public class ActivityReplanningMapTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); @Test public void testGetTimeBin() { diff --git a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java index 7dddab430db..4f5157fb784 100644 --- a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java +++ b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java @@ -24,7 +24,7 @@ import jakarta.inject.Inject; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.groups.ControllerConfigGroup; @@ -45,8 +45,8 @@ */ public class LinkReplanningMapTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); diff --git a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/TtmobsimListener.java b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/TtmobsimListener.java index 61a87f4d6cc..7d8dab36738 100644 --- a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/TtmobsimListener.java +++ b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/TtmobsimListener.java @@ -20,7 +20,7 @@ package org.matsim.withinday.trafficmonitoring; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.network.Link; import org.matsim.core.mobsim.framework.events.MobsimAfterSimStepEvent; import org.matsim.core.mobsim.framework.listeners.MobsimAfterSimStepListener; @@ -35,22 +35,22 @@ */ public class TtmobsimListener implements MobsimAfterSimStepListener { - - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); @Inject private TravelTime travelTime; - + private boolean case1 = false; private boolean case2 = false; - + private Link link; private double networkChangeEventTime; private double reducedFreespeed; public TtmobsimListener(NetworkChangeEvent nce) { - + if (nce.getLinks().size() > 1) { throw new RuntimeException("Expecting only one network change event for a single link. Aborting..."); } else { @@ -58,22 +58,22 @@ public TtmobsimListener(NetworkChangeEvent nce) { this.link = link; this.networkChangeEventTime = nce.getStartTime(); this.reducedFreespeed = nce.getFreespeedChange().getValue(); - + Assert.assertEquals(true, this.reducedFreespeed < this.link.getFreespeed()); } - } + } } @Override public void notifyMobsimAfterSimStep(MobsimAfterSimStepEvent e) { - + if (e.getSimulationTime() <= networkChangeEventTime) { - + Assert.assertEquals("Wrong travel time at time step " + e.getSimulationTime() + ". Should be the freespeed travel time.", Math.ceil(link.getLength()/link.getFreespeed()), Math.ceil(travelTime.getLinkTravelTime(link, e.getSimulationTime(), null, null)), testUtils.EPSILON); - + case1 = true; } else { @@ -81,10 +81,10 @@ public void notifyMobsimAfterSimStep(MobsimAfterSimStepEvent e) { Math.ceil(link.getLength() / reducedFreespeed), Math.ceil(travelTime.getLinkTravelTime(link, e.getSimulationTime(), null, null)), testUtils.EPSILON); - + case2 = true; } - + } public boolean isCase1() { diff --git a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java index 8a1e15db1f4..7af481f6af8 100644 --- a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java +++ b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -55,8 +55,8 @@ */ public class WithinDayTravelTimeTest { - @Rule - public MatsimTestUtils helper = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils helper = new MatsimTestUtils(); private Link link22; private double originalFreeSpeed22; diff --git a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java index ef68744005b..25f5076e8b9 100644 --- a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java +++ b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java @@ -25,7 +25,7 @@ import java.util.Set; import org.junit.Assert; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -64,8 +64,8 @@ */ public class WithinDayTravelTimeWithNetworkChangeEventsTest { - @Rule - public MatsimTestUtils testUtils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils testUtils = new MatsimTestUtils(); private Id link01 = Id.createLinkId("link_0_1"); private Id link12 = Id.createLinkId("link_1_2"); diff --git a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java index d6d29521b27..8c87bda545e 100644 --- a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java +++ b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -68,8 +68,8 @@ public class EditRoutesTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); // yyyy This test relies heavily on position counting in plans. With the introduction of intermediate walk legs the positions changed. // I tried to guess the correct indices, but it would be more honest to change this to TripStructureUtils. kai, feb'16 diff --git a/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java b/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java index f938263629a..23c69bdc66d 100644 --- a/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java +++ b/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Rule; +import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -37,8 +37,8 @@ public class ReplacePlanElementsTest { - @Rule - public MatsimTestUtils utils = new MatsimTestUtils(); + @RegisterExtension + private MatsimTestUtils utils = new MatsimTestUtils(); /** From cc1c2b59cf8a71ec54294b3150be070efa59b08e Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 16:46:40 +0100 Subject: [PATCH 27/43] removed build failures --- .../freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java | 1 + .../src/test/java/org/matsim/modechoice/ScenarioTest.java | 2 +- .../contrib/multimodal/MultiModalControlerListenerTest.java | 1 + .../matsim/freight/carriers/analysis/RunFreightAnalysisIT.java | 1 + .../planmodification/PlanFileModifierTest.java | 1 + ...ncomeDependentUtilityOfMoneyPersonScoringParametersTest.java | 1 + 6 files changed, 6 insertions(+), 1 deletion(-) diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java index 1732949b629..00d92714dc3 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java @@ -22,6 +22,7 @@ package org.matsim.freight.carriers; import org.junit.*; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.core.gbl.Gbl; import org.matsim.freight.carriers.*; diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java index 4e38c743ab9..2042b6c03a0 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java @@ -16,7 +16,7 @@ public class ScenarioTest { protected Injector injector; @RegisterExtension - private MatsimTestUtils utils = new MatsimTestUtils(); + public MatsimTestUtils utils = new MatsimTestUtils(); @Before public void setUp() throws Exception { diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java index e94aeb5073c..f64a3d0d57c 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java @@ -26,6 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.*; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; diff --git a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java index 54d9471758b..6ef803c9a77 100644 --- a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java +++ b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java @@ -22,6 +22,7 @@ package org.matsim.freight.carriers.analysis; import org.junit.*; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Network; import org.matsim.api.core.v01.population.Person; diff --git a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java index 594390f486c..f8dedea8aa3 100644 --- a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java @@ -3,6 +3,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.*; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.*; diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java index 247e54a45e5..d94fa19d64d 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java @@ -1,6 +1,7 @@ package playground.vsp.scoring; import org.junit.*; +import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Population; From 429ffdf6895971fb0b15e138a67295ee14ba017d Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 19:25:17 +0100 Subject: [PATCH 28/43] Migrate JUnit 4 @Test annotations to JUnit 5 --- .../accessibility/LeastCostPathTreeTest.java | 6 +- .../accessibility/grid/SpatialGridTest.java | 5 +- .../CompareLogsumFormulas2Test.java | 6 +- .../CompareLogsumFormulasTest.java | 5 +- .../ComputeLogsumFormulas3Test.java | 5 +- .../run/AccessibilityIntegrationTest.java | 18 +- .../accessibility/run/NetworkUtilTest.java | 4 +- .../run/TinyAccessibilityTest.java | 6 +- .../run/TinyMultimodalAccessibilityTest.java | 7 +- .../BvwpAccidentsCostComputationTest.java | 16 +- .../org/matsim/contrib/accidents/RunTest.java | 4 +- .../contrib/accidents/RunTestEquil.java | 16 +- .../PersonIntersectAreaFilterTest.java | 5 +- .../population/RouteLinkFilterTest.java | 5 +- .../kai/KNAnalysisEventsHandlerTest.java | 14 +- .../contrib/analysis/spatial/GridTest.java | 34 +- .../spatial/SpatialInterpolationTest.java | 49 +-- .../contrib/analysis/time/TimeBinMapTest.java | 45 ++- .../GoogleMapRouteValidatorTest.java | 4 +- .../HereMapsRouteValidatorTest.java | 6 +- .../RunEventsToTravelDiariesIT.java | 8 +- .../application/ApplicationUtilsTest.java | 4 +- .../matsim/application/CommandRunnerTest.java | 4 +- .../application/MATSimApplicationTest.java | 16 +- .../analysis/LogFileAnalysisTest.java | 4 +- .../application/options/CsvOptionsTest.java | 4 +- .../options/SampleOptionsTest.java | 6 +- .../application/options/ShpOptionsTest.java | 8 +- .../prepare/CreateLandUseShpTest.java | 4 +- .../prepare/ShapeFileTextLookupTest.java | 6 +- .../counts/CreateCountsFromBAStDataTest.java | 10 +- .../prepare/counts/NetworkIndexTest.java | 4 +- .../population/CloseTrajectoriesTest.java | 4 +- .../population/FixSubtourModesTest.java | 8 +- .../SplitActivityTypesDurationTest.java | 4 +- .../pt/CreateTransitScheduleFromGtfsTest.java | 4 +- .../CarrierReaderFromCSVTest.java | 6 +- .../DemandReaderFromCSVTest.java | 8 +- .../FreightDemandGenerationTest.java | 4 +- .../FreightDemandGenerationUtilsTest.java | 44 ++- .../LanduseBuildingAnalysisTest.java | 6 +- ...nerateSmallScaleCommercialTrafficTest.java | 4 +- .../SmallScaleCommercialTrafficUtilsTest.java | 4 +- .../TrafficVolumeGenerationTest.java | 17 +- .../TripDistributionMatrixTest.java | 6 +- .../contrib/av/flow/RunAvExampleIT.java | 4 +- .../contrib/av/flow/TestAvFlowFactor.java | 4 +- .../RunTaxiPTIntermodalExampleIT.java | 4 +- .../run/RunDrtAndTaxiExampleTest.java | 4 +- .../av/robotaxi/run/RunRobotaxiExampleIT.java | 4 +- .../BicycleLinkSpeedCalculatorTest.java | 34 +- .../bicycle/BicycleUtilityUtilsTest.java | 12 +- .../contrib/bicycle/run/BicycleTest.java | 28 +- .../contrib/cadyts/car/CadytsCarIT.java | 6 +- .../cadyts/car/CadytsCarWithPtScenarioIT.java | 7 +- .../utils/CalibrationStatReaderTest.java | 4 +- .../runExample/RunCarsharingIT.java | 4 +- .../ChangeCommercialJobOperatorTest.java | 6 +- .../CommercialTrafficIntegrationTest.java | 6 +- .../DefaultCommercialServiceScoreTest.java | 6 +- .../IsTheRightCustomerScoredTest.java | 6 +- ...unJointDemandCarExampleSkipIntervalIT.java | 4 +- .../examples/RunJointDemandCarExampleIT.java | 4 +- .../examples/RunJointDemandDRTExampleIT.java | 4 +- .../common/collections/PartialSortTest.java | 16 +- .../DiversityGeneratingPlansRemoverTest.java | 10 +- .../util/WeightedRandomSelectionTest.java | 12 +- .../always/BetaTravelTest66IT.java | 7 +- .../integration/always/BetaTravelTest6IT.java | 7 +- .../DecongestionPricingTestIT.java | 16 +- .../SubtourModeChoiceReplacementTest.java | 8 +- .../VehicleTourConstraintTest.java | 8 +- .../components/readers/ApolloTest.java | 4 +- .../tour_finder/ActivityTourFinderTest.java | 6 +- .../ScheduleWaitingTimeEstimatorTest.java | 12 +- .../examples/TestSiouxFalls.java | 4 +- .../models/MaximumUtilityTest.java | 4 +- .../models/MultinomialLogitTest.java | 4 +- .../models/NestedLogitTest.java | 4 +- .../models/RandomUtilityTest.java | 4 +- .../models/nested/NestCalculatorTest.java | 10 +- .../modules/config/ConfigTest.java | 8 +- .../replanning/TestDepartureTimes.java | 8 +- .../DrtWithExtensionsConfigGroupTest.java | 6 +- .../RunDrtWithCompanionExampleIT.java | 4 +- .../extension/dashboards/DashboardTests.java | 4 +- .../extension/edrt/run/RunEDrtScenarioIT.java | 8 +- .../MultiModaFixedDrtLegEstimatorTest.java | 4 +- .../MultiModalDrtLegEstimatorTest.java | 4 +- .../extension/fiss/RunFissDrtScenarioIT.java | 4 +- .../insertion/DrtInsertionExtensionIT.java | 22 +- .../eshifts/run/RunEShiftDrtScenarioIT.java | 4 +- .../OperationFacilitiesIOTest.java | 6 +- .../operations/shifts/ShiftsIOTest.java | 5 +- .../efficiency/ShiftEfficiencyTest.java | 4 +- .../run/RunMultiHubShiftDrtScenarioIT.java | 4 +- .../shifts/run/RunShiftDrtScenarioIT.java | 4 +- .../optimizer/RunPreplannedDrtExampleIT.java | 4 +- .../drt/analysis/zonal/DrtGridUtilsTest.java | 4 +- .../analysis/zonal/DrtZonalSystemTest.java | 10 +- .../RandomDrtZoneTargetLinkSelectorTest.java | 4 +- .../drt/config/ConfigBehaviorTest.java | 10 +- .../contrib/drt/fare/DrtFareHandlerTest.java | 4 +- .../DrtRequestInsertionRetryQueueTest.java | 12 +- .../VehicleDataEntryFactoryImplTest.java | 14 +- .../insertion/BestInsertionFinderTest.java | 16 +- .../CostCalculationStrategyTest.java | 14 +- .../DefaultUnplannedRequestInserterTest.java | 12 +- .../insertion/DetourTimeEstimatorTest.java | 6 +- .../insertion/DrtPoolingParameterTest.java | 22 +- .../InsertionCostCalculatorTest.java | 4 +- .../InsertionDetourTimeCalculatorTest.java | 19 +- ...imeCalculatorWithVariableDurationTest.java | 19 +- .../insertion/InsertionGeneratorTest.java | 42 +- .../extensive/DetourPathDataCacheTest.java | 15 +- .../ExtensiveInsertionProviderTest.java | 8 +- .../KNearestInsertionsAtEndFilterTest.java | 15 +- ...ultiInsertionDetourPathCalculatorTest.java | 8 +- ...ngleInsertionDetourPathCalculatorTest.java | 8 +- ...eviousIterationDrtDemandEstimatorTest.java | 14 +- ...ualVehicleDensityTargetCalculatorTest.java | 8 +- ...ToPopulationRatioTargetCalculatorTest.java | 10 +- .../drt/prebooking/AbandonAndCancelTest.java | 12 +- .../prebooking/ComplexUnschedulerTest.java | 18 +- .../prebooking/PersonStuckPrebookingTest.java | 6 +- .../drt/prebooking/PrebookingTest.java | 24 +- .../drt/routing/DrtRoutingModuleTest.java | 6 +- .../MultiModeDrtMainModeIdentifierTest.java | 4 +- .../drt/run/examples/RunDrtExampleIT.java | 21 +- .../examples/RunMultiModeDrtExampleIT.java | 4 +- .../examples/RunOneSharedTaxiExampleIT.java | 4 +- .../contrib/drt/speedup/DrtSpeedUpTest.java | 13 +- .../drt/util/DrtEventsReadersTest.java | 4 +- .../DvrpBenchmarkQSimModuleTest.java | 4 +- .../examples/onetaxi/RunOneTaxiExampleIT.java | 4 +- .../RunOneTaxiWithPrebookingExampleIT.java | 4 +- .../RunOneTaxiOneTruckExampleIT.java | 4 +- .../onetruck/RunOneTruckExampleIT.java | 4 +- .../passenger/DefaultPassengerEngineTest.java | 9 +- .../passenger/GroupPassengerEngineTest.java | 4 +- .../TeleportingPassengerEngineTest.java | 6 +- .../LeastCostPathTreeStopCriteriaTest.java | 24 +- .../path/OneToManyPathCalculatorTest.java | 24 +- .../contrib/dvrp/router/DiversionTest.java | 10 +- .../dvrp/router/RoutingTimeStructureTest.java | 6 +- .../DvrpOfflineTravelTimeEstimatorTest.java | 9 +- .../DvrpOfflineTravelTimesTest.java | 11 +- .../dvrp/util/DvrpEventsReadersTest.java | 4 +- .../dvrp/vrpagent/VrpAgentLogicTest.java | 16 +- .../random/RunRandomDynAgentExampleTest.java | 4 +- .../matsim/contrib/zone/SquareGridTest.java | 12 +- .../skims/FreeSpeedTravelTimeMatrixTest.java | 6 +- .../matsim/contrib/zone/skims/MatrixTest.java | 12 +- .../contrib/zone/skims/SparseMatrixTest.java | 9 +- .../zone/skims/TravelTimeMatricesTest.java | 8 +- .../SpeedyMultiSourceALTBackwardTest.java | 10 +- .../SpeedyMultiSourceALTForwardTest.java | 10 +- .../contrib/emissions/EmissionModuleTest.java | 63 +-- .../emissions/OsmHbefaMappingTest.java | 47 +-- .../TestColdEmissionAnalysisModule.java | 6 +- .../TestColdEmissionAnalysisModuleCase1.java | 4 +- .../TestColdEmissionAnalysisModuleCase2.java | 4 +- .../TestColdEmissionAnalysisModuleCase3.java | 4 +- .../TestColdEmissionAnalysisModuleCase4.java | 6 +- .../TestColdEmissionAnalysisModuleCase6.java | 6 +- .../TestColdEmissionsFallbackBehaviour.java | 64 ++-- .../TestHbefaColdEmissionFactorKey.java | 16 +- .../emissions/TestHbefaVehicleAttributes.java | 16 +- .../TestHbefaWarmEmissionFactorKey.java | 28 +- .../emissions/TestPositionEmissionModule.java | 12 +- .../TestWarmEmissionAnalysisModule.java | 15 +- .../TestWarmEmissionAnalysisModuleCase1.java | 21 +- .../TestWarmEmissionAnalysisModuleCase2.java | 6 +- .../TestWarmEmissionAnalysisModuleCase3.java | 6 +- .../TestWarmEmissionAnalysisModuleCase4.java | 6 +- .../TestWarmEmissionAnalysisModuleCase5.java | 4 +- .../TestWarmEmissionsFallbackBehaviour.java | 54 +-- .../VspHbefaRoadTypeMappingTest.java | 6 +- .../analysis/EmissionGridAnalyzerTest.java | 61 +-- .../analysis/EmissionsByPollutantTest.java | 26 +- .../EmissionsOnLinkEventHandlerTest.java | 22 +- .../FastEmissionGridAnalyzerTest.java | 26 +- .../emissions/analysis/RasterTest.java | 20 +- .../analysis/RawEmissionEventsReaderTest.java | 18 +- .../events/TestColdEmissionEventImpl.java | 8 +- .../events/TestWarmEmissionEventImpl.java | 6 +- .../events/VehicleLeavesTrafficEventTest.java | 6 +- ...unAverageEmissionToolOfflineExampleIT.java | 10 +- ...nDetailedEmissionToolOfflineExampleIT.java | 14 +- ...EmissionToolOnlineExampleIT_vehTypeV1.java | 4 +- ...eExampleIT_vehTypeV1FallbackToAverage.java | 4 +- ...EmissionToolOnlineExampleIT_vehTypeV2.java | 4 +- ...eExampleIT_vehTypeV2FallbackToAverage.java | 4 +- .../emissions/utils/EmissionUtilsTest.java | 46 ++- .../ev/charging/FastThenSlowChargingTest.java | 16 +- .../charging/VariableSpeedChargingTest.java | 4 +- ...nEvExampleWithLTHConsumptionModelTest.java | 5 +- ...emperatureChangeModuleIntegrationTest.java | 4 +- .../carriers/CarrierEventsReadersTest.java | 12 +- .../freight/carriers/CarrierModuleTest.java | 12 +- .../carriers/CarrierPlanReaderV1Test.java | 10 +- .../carriers/CarrierPlanXmlReaderV2Test.java | 32 +- .../CarrierPlanXmlReaderV2WithDtdTest.java | 56 +-- .../carriers/CarrierPlanXmlWriterV1Test.java | 4 +- .../carriers/CarrierPlanXmlWriterV2Test.java | 28 +- .../CarrierPlanXmlWriterV2_1Test.java | 37 +- .../carriers/CarrierReadWriteV2_1Test.java | 6 +- .../CarrierVehicleTypeLoaderTest.java | 6 +- .../CarrierVehicleTypeReaderTest.java | 18 +- .../carriers/CarrierVehicleTypeTest.java | 32 +- .../CarrierVehicleTypeWriterTest.java | 4 +- .../freight/carriers/CarriersUtilsTest.java | 10 +- .../FreightCarriersConfigGroupTest.java | 6 +- .../EquilWithCarrierWithPersonsIT.java | 4 +- .../EquilWithCarrierWithoutPersonsIT.java | 66 ++-- ...istanceConstraintFromVehiclesFileTest.java | 10 +- .../jsprit/DistanceConstraintTest.java | 14 +- .../carriers/jsprit/FixedCostsTest.java | 8 +- .../carriers/jsprit/IntegrationIT.java | 4 +- .../jsprit/MatsimTransformerTest.java | 48 +-- .../NetworkBasedTransportCostsTest.java | 8 +- .../freight/carriers/jsprit/SkillsIT.java | 6 +- .../usecases/chessboard/RunChessboardIT.java | 4 +- .../RunPassengerAlongWithCarriersIT.java | 6 +- .../utils/CarrierControlerUtilsIT.java | 12 +- .../utils/CarrierControlerUtilsTest.java | 92 +++-- .../ReceiverCostAllocationFixedTest.java | 4 +- .../freightreceiver/ReceiverPlanTest.java | 5 +- .../freightreceiver/ReceiversReaderTest.java | 6 +- .../freightreceiver/ReceiversTest.java | 42 +- .../freightreceiver/ReceiversWriterTest.java | 6 +- .../freightreceiver/SSReorderPolicyTest.java | 4 +- .../hybridsim/utils/IdIntMapperTest.java | 26 +- .../matsim/modechoice/EstimateRouterTest.java | 4 +- .../ModeChoiceWeightSchedulerTest.java | 6 +- .../commands/GenerateChoiceSetTest.java | 4 +- ...RelaxedMassConservationConstraintTest.java | 8 +- .../RelaxedSubtourConstraintTest.java | 8 +- .../estimators/ComplexEstimatorTest.java | 4 +- .../DefaultActivityEstimatorTest.java | 4 +- .../MultinomialLogitSelectorTest.java | 18 +- .../RandomSubtourModeStrategyTest.java | 4 +- .../SelectSingleTripModeStrategyTest.java | 6 +- .../SelectSubtourModeStrategyTest.java | 8 +- .../search/BestChoiceGeneratorTest.java | 4 +- .../modechoice/search/DifferentModesTest.java | 4 +- .../search/ModeChoiceSearchTest.java | 8 +- .../SingleTripChoicesGeneratorTest.java | 8 +- .../search/TopKChoicesGeneratorTest.java | 12 +- .../modechoice/search/TopKMinMaxTest.java | 6 +- .../search/TopKSubtourGeneratorTest.java | 4 +- .../integration/daily/SomeDailyTest.java | 4 +- .../integration/weekly/SomeWeeklyTest.java | 4 +- .../CreateAutomatedFDTest.java | 10 +- ...stReplyLocationChoicePlanStrategyTest.java | 5 +- .../locationchoice/LocationChoiceIT.java | 7 +- .../frozenepsilons/BestReplyIT.java | 4 +- .../frozenepsilons/FacilityPenaltyTest.java | 8 +- .../FrozenEpsilonLocaChoiceIT.java | 9 +- .../frozenepsilons/SamplerTest.java | 6 +- .../frozenepsilons/ScoringPenaltyTest.java | 4 +- .../LocationMutatorwChoiceSetTest.java | 11 +- .../timegeography/ManageSubchainsTest.java | 5 +- .../RandomLocationMutatorTest.java | 5 +- .../timegeography/SubChainTest.java | 5 +- .../router/BackwardFastMultiNodeTest.java | 8 +- .../matsim/core/router/FastMultiNodeTest.java | 8 +- .../core/router/MultiNodeDijkstraTest.java | 28 +- .../MatrixBasedPtRouterIT.java | 4 +- .../matrixbasedptrouter/PtMatrixTest.java | 6 +- .../matrixbasedptrouter/TestQuadTree.java | 5 +- .../genericUtils/TerminusStopFinderTest.java | 7 +- .../minibus/integration/PControlerTestIT.java | 4 +- .../integration/SubsidyContextTestIT.java | 6 +- .../minibus/integration/SubsidyTestIT.java | 4 +- .../replanning/EndRouteExtensionTest.java | 6 +- .../MaxRandomEndTimeAllocatorTest.java | 4 +- .../MaxRandomStartTimeAllocatorTest.java | 4 +- .../SidewaysRouteExtensionTest.java | 4 +- .../minibus/replanning/TimeProviderTest.java | 8 +- .../WeightedEndTimeExtensionTest.java | 4 +- .../WeightedStartTimeExtensionTest.java | 4 +- .../ComplexCircleScheduleProviderTest.java | 10 +- .../SimpleCircleScheduleProviderTest.java | 8 +- ...tionApproachesAndBetweenJunctionsTest.java | 6 +- .../CreateStopsForAllCarLinksTest.java | 4 +- ...eaBtwLinksVsTerminiBeelinePenaltyTest.java | 6 +- .../RouteDesignScoringManagerTest.java | 6 +- .../StopServedMultipleTimesPenaltyTest.java | 6 +- .../RecursiveStatsApproxContainerTest.java | 4 +- .../stats/RecursiveStatsContainerTest.java | 4 +- .../MultiModalControlerListenerTest.java | 16 +- .../multimodal/MultiModalTripRouterTest.java | 4 +- .../multimodal/RunMultimodalExampleTest.java | 4 +- .../pt/MultiModalPTCombinationTest.java | 4 +- .../router/util/BikeTravelTimeTest.java | 8 +- .../router/util/WalkTravelTimeTest.java | 8 +- .../multimodal/simengine/StuckAgentTest.java | 4 +- .../contrib/noise/NoiseConfigGroupIT.java | 24 +- .../org/matsim/contrib/noise/NoiseIT.java | 19 +- .../contrib/noise/NoiseOnlineExampleIT.java | 8 +- .../matsim/contrib/noise/NoiseRLS19IT.java | 12 +- .../osm/networkReader/LinkPropertiesTest.java | 30 +- .../osm/networkReader/OsmBicycleReaderIT.java | 4 +- .../networkReader/OsmBicycleReaderTest.java | 18 +- .../networkReader/OsmNetworkParserTest.java | 10 +- .../networkReader/OsmSignalsParserTest.java | 14 +- .../SupersonicOsmNetworkReaderIT.java | 4 +- .../SupersonicOsmNetworkReaderTest.java | 44 +-- ...SupersonicOsmNetworkReaderBuilderTest.java | 4 +- .../org/matsim/contrib/otfvis/OTFVisIT.java | 6 +- .../contrib/parking/lib/GeneralLibTest.java | 8 +- .../lib/obj/DoubleValueHashMapTest.java | 5 +- .../lib/obj/LinkedListValueHashMapTest.java | 11 +- .../ParkingCostVehicleTrackerTest.java | 4 +- .../RideParkingCostTrackerTest.java | 4 +- .../RunParkingCostsExampleTest.java | 4 +- .../run/RunWithParkingProxyIT.java | 8 +- .../run/RunParkingChoiceExampleIT.java | 4 +- .../run/RunParkingSearchScenarioIT.java | 10 +- .../contrib/protobuf/EventWriterPBTest.java | 14 +- .../contrib/pseudosimulation/RunPSimTest.java | 6 +- .../integration/RailsimIntegrationTest.java | 48 +-- .../railsim/qsimengine/RailsimCalcTest.java | 14 +- .../railsim/qsimengine/RailsimEngineTest.java | 18 +- .../roadpricing/AvoidTolledRouteTest.java | 16 +- .../contrib/roadpricing/CalcPaidTollTest.java | 8 +- .../contrib/roadpricing/ModuleTest.java | 36 +- .../PlansCalcRouteWithTollOrNotTest.java | 10 +- .../RoadPricingConfigGroupTest.java | 10 +- .../roadpricing/RoadPricingControlerIT.java | 4 +- .../roadpricing/RoadPricingIOTest.java | 5 +- .../TollTravelCostCalculatorTest.java | 11 +- .../run/RoadPricingByConfigfileTest.java | 4 +- .../run/RunRoadPricingExampleIT.java | 4 +- .../run/RunRoadPricingFromCodeIT.java | 4 +- ...unRoadPricingUsingTollFactorExampleIT.java | 4 +- .../analysis/skims/FloatMatrixIOTest.java | 6 +- .../analysis/skims/RooftopUtilsTest.java | 70 ++-- .../config/SBBTransitConfigGroupTest.java | 6 +- .../matsim/mobsim/qsim/SBBQSimModuleTest.java | 8 +- .../SBBTransitQSimEngineIntegrationTest.java | 10 +- .../qsim/pt/SBBTransitQSimEngineTest.java | 76 ++-- .../matsim/contrib/shared_mobility/RunIT.java | 4 +- .../AdaptiveSignalsExampleTest.java | 4 +- .../CreateIntergreensExampleTest.java | 16 +- .../CreateSignalInputExampleTest.java | 16 +- ...CreateSignalInputExampleWithLanesTest.java | 16 +- .../RunSignalSystemsExampleTest.java | 6 +- ...sualizeSignalScenarioWithLanesGUITest.java | 10 +- .../FixResponsiveSignalResultsIT.java | 18 +- .../io/MatsimFileTypeGuesserSignalsTest.java | 12 +- .../contrib/signals/CalculateAngleTest.java | 38 +- .../contrib/signals/SignalUtilsTest.java | 19 +- .../analysis/DelayAnalysisToolTest.java | 6 +- .../signals/builder/QSimSignalTest.java | 70 ++-- .../builder/TravelTimeFourWaysTest.java | 6 +- .../builder/TravelTimeOneWayTestIT.java | 10 +- ...aultPlanbasedSignalSystemControllerIT.java | 40 +- .../controller/laemmerFix/LaemmerIT.java | 18 +- .../signals/controller/sylvia/SylviaIT.java | 8 +- .../v10/AmberTimesData10ReaderWriterTest.java | 6 +- .../SignalConflictDataReaderWriterTest.java | 4 +- .../UnprotectedLeftTurnLogicTest.java | 4 +- ...IntergreenTimesData10ReaderWriterTest.java | 6 +- .../SignalControlData20ReaderWriterTest.java | 8 +- .../v20/SignalGroups20ReaderWriterTest.java | 6 +- .../SignalSystemsData20ReaderWriterTest.java | 11 +- .../signals/integration/SignalSystemsIT.java | 6 +- .../InvertedNetworksSignalsIT.java | 6 +- .../SignalsAndLanesOsmNetworkReaderTest.java | 19 +- .../signals/oneagent/ControlerTest.java | 5 +- .../signals/sensor/LaneSensorTest.java | 20 +- .../signals/sensor/LinkSensorTest.java | 30 +- .../DefaultAnnealingAcceptorTest.java | 4 +- .../SimulatedAnnealingConfigGroupTest.java | 6 +- .../SimulatedAnnealingIT.java | 4 +- .../SimulatedAnnealingTest.java | 4 +- .../simwrapper/SimWrapperConfigGroupTest.java | 4 +- .../simwrapper/SimWrapperModuleTest.java | 4 +- .../org/matsim/simwrapper/SimWrapperTest.java | 4 +- .../simwrapper/dashboard/DashboardTests.java | 14 +- .../dashboard/EmissionsDashboardTest.java | 4 +- .../dashboard/TrafficCountsDashboardTest.java | 4 +- .../simwrapper/viz/PlotlyExamplesTest.java | 12 +- .../org/matsim/simwrapper/viz/PlotlyTest.java | 8 +- .../framework/events/CourtesyEventsTest.java | 12 +- .../population/JointPlanFactoryTest.java | 6 +- .../framework/population/JointPlanIOTest.java | 6 +- .../framework/population/JointPlansTest.java | 18 +- .../population/SocialNetworkIOTest.java | 6 +- .../population/SocialNetworkTest.java | 20 +- .../grouping/DynamicGroupIdentifierTest.java | 10 +- .../replanning/grouping/FixedGroupsIT.java | 4 +- .../replanning/grouping/GroupPlansTest.java | 8 +- .../ActivitySequenceMutatorAlgorithmTest.java | 10 +- .../replanning/modules/MergingTest.java | 6 +- .../modules/TourModeUnifierAlgorithmTest.java | 8 +- .../removers/LexicographicRemoverTest.java | 8 +- .../FullExplorationVsCuttoffTest.java | 10 +- .../selectors/HighestWeightSelectorTest.java | 10 +- .../selectors/RandomSelectorsTest.java | 9 +- .../CoalitionSelectorTest.java | 4 +- ...ghtJointPlanPruningConflictSolverTest.java | 4 +- ...tPointedPlanPruningConflictSolverTest.java | 5 +- .../WhoIsTheBossSelectorTest.java | 8 +- .../GroupCompositionPenalizerTest.java | 14 +- .../RecomposeJointPlanAlgorithmTest.java | 10 +- .../RandomJointLocationChoiceTest.java | 6 +- .../jointtrips/JointTravelUtilsTest.java | 6 +- ...intTravelingSimulationIntegrationTest.java | 26 +- ...InsertionRemovalIgnoranceBehaviorTest.java | 6 +- .../InsertionRemovalIterativeActionTest.java | 10 +- ...intTripInsertionWithSocialNetworkTest.java | 4 +- .../JointTripRemoverAlgorithmTest.java | 4 +- ...nchronizeCoTravelerPlansAlgorithmTest.java | 4 +- .../router/JointPlanRouterTest.java | 6 +- .../router/JointTripRouterFactoryTest.java | 6 +- .../HouseholdBasedVehicleRessourcesTest.java | 4 +- .../PlanRouterWithVehicleRessourcesTest.java | 4 +- ...PopulationAgentSourceWithVehiclesTest.java | 8 +- ...ehicleToPlansInGroupPlanAlgorithmTest.java | 10 +- ...imizeVehicleAllocationAtTourLevelTest.java | 8 +- .../replanning/GroupPlanStrategyTest.java | 10 +- ...nableActivitiesPlanLinkIdentifierTest.java | 24 +- .../VehicularPlanLinkIdentifierTest.java | 8 +- .../utils/JointScenarioUtilsTest.java | 4 +- .../socnetsim/utils/ObjectPoolTest.java | 6 +- .../utils/QuadTreeRebuilderTest.java | 4 +- .../sumo/SumoNetworkConverterTest.java | 6 +- .../contrib/sumo/SumoNetworkHandlerTest.java | 6 +- .../etaxi/run/RunETaxiBenchmarkTest.java | 4 +- .../contrib/etaxi/run/RunETaxiScenarioIT.java | 8 +- .../taxi/benchmark/RunTaxiBenchmarkTest.java | 4 +- .../assignment/AssignmentTaxiOptimizerIT.java | 10 +- .../optimizer/fifo/FifoTaxiOptimizerIT.java | 4 +- .../rules/RuleBasedTaxiOptimizerIT.java | 8 +- .../optimizer/zonal/ZonalTaxiOptimizerIT.java | 6 +- .../contrib/taxi/run/RunTaxiScenarioTest.java | 4 +- .../taxi/run/RunTaxiScenarioTestIT.java | 6 +- .../RunMultiModeTaxiExampleTestIT.java | 4 +- .../run/examples/RunTaxiExampleTestIT.java | 4 +- .../taxi/util/TaxiEventsReadersTest.java | 4 +- .../taxi/util/stats/DurationStatsTest.java | 8 +- .../taxi/util/stats/TimeBinSamplesTest.java | 10 +- ...oringParametersFromPersonAttributesIT.java | 8 +- ...omPersonAttributesNoSubpopulationTest.java | 16 +- ...ingParametersFromPersonAttributesTest.java | 20 +- .../FreightAnalysisEventBasedTest.java | 4 +- .../analysis/RunFreightAnalysisIT.java | 10 +- .../RunFreightAnalysisWithShipmentTest.java | 6 +- .../drtAndPt/PtAlongALine2Test.java | 11 +- .../drtAndPt/PtAlongALineTest.java | 10 +- .../EmissionCostFactorsTest.java | 17 +- .../emissions/TestColdEmissionHandler.java | 4 +- .../emissions/TestWarmEmissionHandler.java | 4 +- ...entId2DepartureDelayAtStopMapDataTest.java | 7 +- .../AgentId2DepartureDelayAtStopMapTest.java | 4 +- ...tId2EnterLeaveVehicleEventHandlerTest.java | 13 +- .../AgentId2PtTripTravelTimeMapDataTest.java | 4 +- .../AgentId2PtTripTravelTimeMapTest.java | 5 +- .../level1/StopId2LineId2PulkDataTest.java | 6 +- .../bvgAna/level1/StopId2LineId2PulkTest.java | 7 +- .../StopId2RouteId2DelayAtStopMapTest.java | 4 +- .../level1/VehId2DelayAtStopMapDataTest.java | 4 +- .../level1/VehId2DelayAtStopMapTest.java | 4 +- .../level1/VehId2OccupancyHandlerTest.java | 5 +- .../VehId2PersonEnterLeaveVehicleMapTest.java | 4 +- .../osmBB/PTCountsNetworkSimplifierTest.java | 20 +- .../ModalDistanceAndCountsCadytsIT.java | 5 +- ...odalDistanceCadytsMultipleDistancesIT.java | 5 +- .../ModalDistanceCadytsSingleDistanceIT.java | 17 +- .../marginals/TripEventHandlerTest.java | 4 +- .../AdvancedMarginalCongestionPricingIT.java | 16 +- .../CombinedFlowAndStorageDelayTest.java | 4 +- .../vsp/congestion/CorridorNetworkTest.java | 6 +- ...nalCongestionHandlerFlowQueueQsimTest.java | 8 +- ...tionHandlerFlowSpillbackQueueQsimTest.java | 36 +- .../MarginalCongestionHandlerV3Test.java | 4 +- .../MarginalCongestionPricingTest.java | 4 +- .../MultipleSpillbackCausingLinksTest.java | 4 +- .../vsp/congestion/TestForEmergenceTime.java | 4 +- .../ev/TransferFinalSocToNextIterTest.java | 4 +- .../java/playground/vsp/ev/UrbanEVIT.java | 5 +- .../java/playground/vsp/ev/UrbanEVTests.java | 26 +- ...rarchicalFLowEfficiencyCalculatorTest.java | 4 +- .../cemdap/input/SynPopCreatorTest.java | 4 +- .../PlanFileModifierTest.java | 52 +-- .../vsp/pt/fare/PtTripFareEstimatorTest.java | 8 +- .../vsp/pt/ptdisturbances/EditTripsTest.java | 19 +- .../TransitRouteTrimmerTest.java | 360 +++++++++--------- ...nScoringParametersNoSubpopulationTest.java | 14 +- ...ityOfMoneyPersonScoringParametersTest.java | 20 +- .../vsp/zzArchive/bvwpOld/BvwpTest.java | 6 +- .../SwissRailRaptorConfigGroupTest.java | 22 +- .../raptor/CapacityDependentScoringTest.java | 4 +- .../pt/raptor/OccupancyTrackerTest.java | 6 +- .../pt/raptor/RaptorStopFinderTest.java | 134 ++++--- .../routing/pt/raptor/RaptorUtilsTest.java | 6 +- .../raptor/SwissRailRaptorCapacitiesTest.java | 4 +- .../pt/raptor/SwissRailRaptorDataTest.java | 6 +- .../SwissRailRaptorInVehicleCostTest.java | 14 +- .../raptor/SwissRailRaptorIntermodalTest.java | 150 ++++---- .../pt/raptor/SwissRailRaptorModuleTest.java | 30 +- .../pt/raptor/SwissRailRaptorTest.java | 165 ++++---- .../pt/raptor/SwissRailRaptorTreeTest.java | 34 +- .../analysis/CalcAverageTripLengthTest.java | 17 +- .../org/matsim/analysis/CalcLegTimesTest.java | 8 +- .../matsim/analysis/CalcLinkStatsTest.java | 8 +- ...ationTravelStatsControlerListenerTest.java | 4 +- .../org/matsim/analysis/LegHistogramTest.java | 11 +- .../LinkStatsControlerListenerTest.java | 10 +- ...deChoiceCoverageControlerListenerTest.java | 14 +- .../ModeStatsControlerListenerTest.java | 4 +- .../analysis/OutputTravelStatsTest.java | 4 +- .../analysis/PHbyModeCalculatorTest.java | 16 +- .../analysis/PKMbyModeCalculatorTest.java | 4 +- .../ScoreStatsControlerListenerTest.java | 4 +- ...ansportPlanningMainModeIdentifierTest.java | 16 +- .../analysis/TravelDistanceStatsTest.java | 4 +- .../org/matsim/analysis/TripsAnalysisIT.java | 4 +- .../analysis/TripsAndLegsCSVWriterTest.java | 4 +- .../matsim/analysis/VolumesAnalyzerTest.java | 16 +- .../LinkPaxVolumesAnalysisTest.java | 12 +- .../PersonMoneyEventAggregatorTest.java | 4 +- .../pt/stop2stop/PtStop2StopAnalysisTest.java | 16 +- .../org/matsim/api/core/v01/CoordTest.java | 16 +- .../api/core/v01/DemandGenerationTest.java | 5 +- .../api/core/v01/IdAnnotationsTest.java | 10 +- .../matsim/api/core/v01/IdCollectorsTest.java | 10 +- .../core/v01/IdDeSerializationModuleTest.java | 6 +- .../org/matsim/api/core/v01/IdMapTest.java | 32 +- .../org/matsim/api/core/v01/IdSetTest.java | 20 +- .../java/org/matsim/api/core/v01/IdTest.java | 44 +-- .../api/core/v01/NetworkCreationTest.java | 5 +- .../core/v01/network/AbstractNetworkTest.java | 6 +- .../matsim/core/config/CommandLineTest.java | 61 +-- .../core/config/ConfigReaderMatsimV2Test.java | 22 +- .../org/matsim/core/config/ConfigTest.java | 6 +- .../core/config/MaterializeConfigTest.java | 4 +- .../config/ReflectiveConfigGroupTest.java | 46 +-- .../java/org/matsim/core/config/URLTest.java | 8 +- ...alidationConfigConsistencyCheckerTest.java | 12 +- .../ConfigConsistencyCheckerImplTest.java | 16 +- .../groups/ControllerConfigGroupTest.java | 12 +- .../config/groups/CountsConfigGroupTest.java | 14 +- .../groups/LinkStatsConfigGroupTest.java | 14 +- .../groups/ReplanningConfigGroupTest.java | 8 +- .../config/groups/RoutingConfigGroupTest.java | 77 ++-- .../config/groups/ScoringConfigGroupTest.java | 21 +- .../SubtourModeChoiceConfigGroupTest.java | 8 +- .../VspExperimentalConfigGroupTest.java | 5 +- .../core/controler/AbstractModuleTest.java | 4 +- .../core/controler/ControlerEventsTest.java | 8 +- .../matsim/core/controler/ControlerIT.java | 121 +++--- .../ControlerListenerManagerImplTest.java | 12 +- .../ControlerMobsimIntegrationTest.java | 30 +- .../controler/MatsimServicesImplTest.java | 10 +- .../core/controler/MobsimListenerTest.java | 45 ++- .../core/controler/NewControlerTest.java | 8 +- .../OutputDirectoryHierarchyTest.java | 8 +- .../core/controler/PrepareForSimImplTest.java | 16 +- .../core/controler/TerminationTest.java | 14 +- .../TransitControlerIntegrationTest.java | 5 +- .../corelisteners/ListenersInjectionTest.java | 12 +- .../corelisteners/PlansDumpingIT.java | 8 +- .../matsim/core/events/ActEndEventTest.java | 5 +- .../matsim/core/events/ActStartEventTest.java | 5 +- .../core/events/AgentMoneyEventTest.java | 5 +- .../events/AgentWaitingForPtEventTest.java | 4 +- .../core/events/BasicEventsHandlerTest.java | 5 +- .../matsim/core/events/CustomEventTest.java | 6 +- .../events/EventsHandlerHierarchyTest.java | 8 +- .../core/events/EventsManagerImplTest.java | 6 +- .../matsim/core/events/EventsReadersTest.java | 8 +- .../matsim/core/events/GenericEventTest.java | 5 +- .../core/events/LinkEnterEventTest.java | 5 +- .../core/events/LinkLeaveEventTest.java | 5 +- .../events/MobsimScopeEventHandlingTest.java | 8 +- .../events/ParallelEventsManagerTest.java | 10 +- .../core/events/PersonArrivalEventTest.java | 5 +- .../core/events/PersonDepartureEventTest.java | 5 +- .../events/PersonEntersVehicleEventTest.java | 5 +- .../events/PersonLeavesVehicleEventTest.java | 5 +- .../core/events/PersonStuckEventTest.java | 8 +- .../SimStepParallelEventsManagerImplTest.java | 8 +- .../events/TransitDriverStartsEventTest.java | 4 +- .../core/events/VehicleAbortsEventTest.java | 5 +- ...VehicleArrivesAtFacilityEventImplTest.java | 5 +- ...VehicleDepartsAtFacilityEventImplTest.java | 5 +- .../events/VehicleEntersTrafficEventTest.java | 5 +- .../events/VehicleLeavesTrafficEventTest.java | 5 +- .../algorithms/EventWriterJsonTest.java | 6 +- .../events/algorithms/EventWriterXMLTest.java | 6 +- .../org/matsim/core/gbl/MatsimRandomTest.java | 17 +- .../matsim/core/gbl/MatsimResourceTest.java | 5 +- .../core/mobsim/AbstractMobsimModuleTest.java | 8 +- .../matsim/core/mobsim/hermes/AgentTest.java | 24 +- .../core/mobsim/hermes/FlowCapacityTest.java | 14 +- .../mobsim/hermes/HermesRoundaboutTest.java | 5 +- .../matsim/core/mobsim/hermes/HermesTest.java | 32 +- .../core/mobsim/hermes/HermesTransitTest.java | 20 +- .../mobsim/hermes/StorageCapacityTest.java | 12 +- .../core/mobsim/hermes/TravelTimeTest.java | 10 +- .../mobsim/jdeqsim/ConfigParameterTest.java | 5 +- .../core/mobsim/jdeqsim/EmptyCarLegTest.java | 18 +- .../core/mobsim/jdeqsim/EquilPlans1Test.java | 18 +- .../core/mobsim/jdeqsim/NonCarLegTest.java | 18 +- .../mobsim/jdeqsim/TestDESStarter_Berlin.java | 20 +- ...tarter_EquilPopulationPlans1Modified1.java | 18 +- .../jdeqsim/TestDESStarter_equilPlans100.java | 18 +- .../core/mobsim/jdeqsim/TestEventLog.java | 8 +- .../mobsim/jdeqsim/TestMessageFactory.java | 29 +- .../core/mobsim/jdeqsim/TestMessageQueue.java | 29 +- .../core/mobsim/jdeqsim/TestScheduler.java | 42 +- .../mobsim/jdeqsim/util/TestEventLibrary.java | 10 +- .../mobsim/qsim/AbstractQSimModuleTest.java | 20 +- .../mobsim/qsim/AgentNotificationTest.java | 10 +- .../mobsim/qsim/FlowStorageSpillbackTest.java | 4 +- .../qsim/MobsimListenerManagerTest.java | 6 +- .../qsim/NetsimRoutingConsistencyTest.java | 128 +++---- .../core/mobsim/qsim/NodeTransitionTest.java | 16 +- .../qsim/QSimEventsIntegrationTest.java | 8 +- .../org/matsim/core/mobsim/qsim/QSimTest.java | 62 +-- ...TeleportationEngineWDistanceCheckTest.java | 4 +- .../mobsim/qsim/TransitQueueNetworkTest.java | 151 ++++---- .../core/mobsim/qsim/TravelTimeTest.java | 12 +- .../core/mobsim/qsim/VehicleSourceTest.java | 4 +- .../NetworkChangeEventsEngineTest.java | 16 +- .../qsim/components/QSimComponentsTest.java | 135 +++---- .../guice/ExplicitBindingsRequiredTest.java | 9 +- .../guice/MultipleBindingsTest.java | 9 +- .../qsim/jdeqsimengine/JDEQSimPluginTest.java | 10 +- .../mobsim/qsim/pt/QSimIntegrationTest.java | 12 +- .../core/mobsim/qsim/pt/TransitAgentTest.java | 8 +- .../mobsim/qsim/pt/TransitDriverTest.java | 20 +- .../qsim/pt/TransitQueueSimulationTest.java | 187 ++++----- .../qsim/pt/TransitStopAgentTrackerTest.java | 11 +- .../mobsim/qsim/pt/TransitVehicleTest.java | 20 +- .../core/mobsim/qsim/pt/UmlaufDriverTest.java | 29 +- .../DeparturesOnSameLinkSameTimeTest.java | 4 +- .../EquiDistAgentSnapshotInfoBuilderTest.java | 10 +- .../FlowCapacityVariationTest.java | 16 +- .../FlowEfficiencyCalculatorTest.java | 4 +- .../JavaRoundingErrorInQsimTest.java | 8 +- .../LinkSpeedCalculatorIntegrationTest.java | 8 +- .../qsim/qnetsimengine/PassingTest.java | 4 +- .../qsim/qnetsimengine/QLinkLanesTest.java | 15 +- .../mobsim/qsim/qnetsimengine/QLinkTest.java | 26 +- .../qnetsimengine/QSimComponentsTest.java | 96 ++--- .../QueueAgentSnapshotInfoBuilderTest.java | 26 +- ...onfigurableQNetworkFactoryExampleTest.java | 4 +- .../qsim/qnetsimengine/SeepageTest.java | 8 +- .../SimulatedLaneFlowCapacityTest.java | 14 +- .../qnetsimengine/SpeedCalculatorTest.java | 17 +- .../qnetsimengine/VehVsLinkSpeedTest.java | 8 +- .../qnetsimengine/VehicleHandlerTest.java | 4 +- .../qnetsimengine/VehicleWaitingTest.java | 10 +- .../AbstractNetworkWriterReaderTest.java | 29 +- .../core/network/DisallowedNextLinksTest.java | 22 +- .../network/DisallowedNextLinksUtilsTest.java | 10 +- .../org/matsim/core/network/LinkImplTest.java | 18 +- .../matsim/core/network/LinkQuadTreeTest.java | 36 +- .../NetworkChangeEventsParserWriterTest.java | 40 +- .../core/network/NetworkCollectorTest.java | 14 +- .../matsim/core/network/NetworkImplTest.java | 28 +- .../matsim/core/network/NetworkUtilsTest.java | 14 +- .../matsim/core/network/NetworkV2IOTest.java | 24 +- .../matsim/core/network/ReadFromURLIT.java | 4 +- .../core/network/TimeVariantLinkImplTest.java | 20 +- .../TravelTimeCalculatorIntegrationTest.java | 8 +- .../algorithms/CalcBoundingBoxTest.java | 7 +- .../MultimodalNetworkCleanerTest.java | 45 ++- .../algorithms/NetworkCleanerTest.java | 14 +- .../algorithms/NetworkExpandNodeTest.java | 17 +- .../NetworkMergeDoubleLinksTest.java | 9 +- .../NetworkSimplifierPass2WayTest.java | 7 +- .../algorithms/NetworkSimplifierTest.java | 12 +- .../TransportModeNetworkFilterTest.java | 21 +- .../DensityClusterTest.java | 8 +- .../HullConverterTest.java | 12 +- .../IntersectionSimplifierTest.java | 16 +- .../containers/ConcaveHullTest.java | 4 +- .../filter/NetworkFilterManagerTest.java | 4 +- .../io/NetworkAttributeConversionTest.java | 12 +- .../network/io/NetworkReaderMatsimV1Test.java | 11 +- .../network/io/NetworkReprojectionIOTest.java | 20 +- .../core/population/PersonImplTest.java | 26 +- .../matsim/core/population/PlanImplTest.java | 30 +- .../core/population/PopulationUtilsTest.java | 8 +- .../io/CompressedRoutesIntegrationTest.java | 4 +- .../io/MatsimPopulationReaderTest.java | 18 +- .../io/ParallelPopulationReaderTest.java | 6 +- .../io/PopulationAttributeConversionTest.java | 20 +- .../io/PopulationReaderMatsimV4Test.java | 16 +- .../io/PopulationReaderMatsimV5Test.java | 22 +- .../io/PopulationReprojectionIOIT.java | 28 +- .../population/io/PopulationV6IOTest.java | 56 +-- .../io/PopulationWriterHandlerImplV4Test.java | 5 +- .../io/PopulationWriterHandlerImplV5Test.java | 10 +- ...mingPopulationAttributeConversionTest.java | 4 +- .../routes/AbstractNetworkRouteTest.java | 48 +-- .../routes/LinkNetworkRouteTest.java | 4 +- .../population/routes/NetworkFactoryTest.java | 5 +- .../routes/RouteFactoryImplTest.java | 11 +- .../routes/RouteFactoryIntegrationTest.java | 4 +- .../HeavyCompressedNetworkRouteTest.java | 20 +- .../MediumCompressedNetworkRouteTest.java | 20 +- .../core/replanning/PlanStrategyTest.java | 5 +- .../StrategyManagerSubpopulationsTest.java | 4 +- .../core/replanning/StrategyManagerTest.java | 35 +- .../annealing/ReplanningAnnealerTest.java | 42 +- .../ForceInnovationStrategyChooserTest.java | 6 +- .../ReplanningWithConflictsTest.java | 4 +- .../AbstractMultithreadedModuleTest.java | 6 +- .../replanning/modules/ChangeLegModeTest.java | 14 +- .../modules/ChangeSingleLegModeTest.java | 12 +- .../modules/ExternalModuleTest.java | 10 +- .../planInheritance/PlanInheritanceTest.java | 12 +- .../selectors/AbstractPlanSelectorTest.java | 14 +- .../selectors/BestPlanSelectorTest.java | 5 +- .../selectors/ExpBetaPlanSelectorTest.java | 11 +- .../selectors/KeepSelectedTest.java | 5 +- .../selectors/PathSizeLogitSelectorTest.java | 5 +- .../selectors/RandomPlanSelectorTest.java | 5 +- .../WorstPlanForRemovalSelectorTest.java | 8 +- ...eterministicMultithreadedReplanningIT.java | 10 +- .../strategies/InnovationSwitchOffTest.java | 4 +- .../TimeAllocationMutatorModuleTest.java | 12 +- .../AbstractLeastCostPathCalculatorTest.java | 8 +- ...DefaultAnalysisMainModeIdentifierTest.java | 8 +- .../router/FallbackRoutingModuleTest.java | 4 +- .../router/InvertertedNetworkRoutingTest.java | 5 +- .../router/MultimodalLinkChooserTest.java | 6 +- ...workRoutingInclAccessEgressModuleTest.java | 93 ++--- .../core/router/NetworkRoutingModuleTest.java | 6 +- ...rsonalizableDisutilityIntegrationTest.java | 8 +- .../PseudoTransitRoutingModuleTest.java | 4 +- .../org/matsim/core/router/RoutingIT.java | 18 +- .../TeleportationRoutingModuleTest.java | 4 +- .../router/TestActivityWrapperFacility.java | 4 +- .../router/TripRouterFactoryImplTest.java | 6 +- .../core/router/TripRouterModuleTest.java | 6 +- .../matsim/core/router/TripRouterTest.java | 8 +- .../TripStructureUtilsSubtoursTest.java | 26 +- .../core/router/TripStructureUtilsTest.java | 57 +-- ...izingTimeDistanceTravelDisutilityTest.java | 4 +- .../core/router/old/PlanRouterTest.java | 10 +- .../priorityqueue/BinaryMinHeapTest.java | 48 +-- .../core/router/speedy/DAryMinHeapTest.java | 8 +- .../core/router/speedy/SpeedyGraphTest.java | 6 +- .../core/scenario/LoadScenarioByHTTPIT.java | 4 +- .../ScenarioByConfigInjectionTest.java | 8 +- .../core/scenario/ScenarioImplTest.java | 8 +- .../core/scenario/ScenarioLoaderImplTest.java | 12 +- .../core/scenario/ScenarioUtilsTest.java | 4 +- .../core/scoring/EventsToActivitiesTest.java | 10 +- .../matsim/core/scoring/EventsToLegsTest.java | 16 +- .../core/scoring/EventsToScoreTest.java | 8 +- ...ScoringFunctionsForPopulationStressIT.java | 76 ++-- .../ScoringFunctionsForPopulationTest.java | 12 +- ...yparNagelLegScoringDailyConstantsTest.java | 4 +- .../CharyparNagelLegScoringPtChangeTest.java | 4 +- ...yparNagelOpenTimesScoringFunctionTest.java | 5 +- .../CharyparNagelScoringFunctionTest.java | 46 +-- .../CharyparNagelWithSubpopulationsTest.java | 6 +- .../LinkToLinkTravelTimeCalculatorTest.java | 5 +- .../TravelTimeCalculatorModuleTest.java | 28 +- .../TravelTimeCalculatorTest.java | 38 +- .../TravelTimeDataArrayTest.java | 4 +- .../core/utils/charts/BarChartTest.java | 5 +- .../core/utils/charts/LineChartTest.java | 5 +- .../core/utils/charts/XYLineChartTest.java | 5 +- .../core/utils/charts/XYScatterChartTest.java | 5 +- .../core/utils/collections/ArrayMapTest.java | 36 +- .../collections/CollectionUtilsTest.java | 16 +- .../collections/IdentifiableArrayMapTest.java | 68 ++-- .../utils/collections/IntArrayMapTest.java | 34 +- .../PseudoRemovePriorityQueueTest.java | 38 +- .../core/utils/collections/QuadTreeTest.java | 44 +-- .../core/utils/collections/TupleTest.java | 14 +- .../core/utils/geometry/CoordImplTest.java | 4 +- .../core/utils/geometry/CoordUtilsTest.java | 37 +- .../utils/geometry/GeometryUtilsTest.java | 4 +- .../core/utils/geometry/geotools/MGCTest.java | 16 +- .../CH1903LV03PlustoWGS84Test.java | 4 +- .../CH1903LV03PlustofromCH1903LV03Test.java | 6 +- .../CH1903LV03toWGS84Test.java | 5 +- .../GeotoolsTransformationTest.java | 5 +- .../TransformationFactoryTest.java | 32 +- .../WGS84toCH1903LV03PlusTest.java | 4 +- .../WGS84toCH1903LV03Test.java | 5 +- .../core/utils/gis/ShapeFileReaderTest.java | 4 +- .../core/utils/gis/ShapeFileWriterTest.java | 12 +- .../org/matsim/core/utils/io/IOUtilsTest.java | 140 +++---- .../utils/io/MatsimFileTypeGuesserTest.java | 30 +- .../core/utils/io/MatsimXmlParserTest.java | 22 +- .../core/utils/io/MatsimXmlWriterTest.java | 6 +- .../core/utils/io/OsmNetworkReaderTest.java | 20 +- .../matsim/core/utils/io/XmlUtilsTest.java | 6 +- .../core/utils/misc/ArgumentParserTest.java | 14 +- .../core/utils/misc/ByteBufferUtilsTest.java | 8 +- .../core/utils/misc/ClassUtilsTest.java | 24 +- .../core/utils/misc/ConfigUtilsTest.java | 17 +- .../core/utils/misc/NetworkUtilsTest.java | 45 ++- .../core/utils/misc/OptionalTimeTest.java | 32 +- .../core/utils/misc/OptionalTimesTest.java | 4 +- .../core/utils/misc/PopulationUtilsTest.java | 12 +- .../core/utils/misc/RouteUtilsTest.java | 32 +- .../core/utils/misc/StringUtilsTest.java | 8 +- .../org/matsim/core/utils/misc/TimeTest.java | 23 +- .../utils/timing/TimeInterpretationTest.java | 8 +- .../java/org/matsim/counts/CountTest.java | 11 +- .../counts/CountsComparisonAlgorithmTest.java | 8 +- .../counts/CountsControlerListenerTest.java | 10 +- .../matsim/counts/CountsErrorGraphTest.java | 5 +- .../counts/CountsHtmlAndGraphsWriterTest.java | 5 +- .../counts/CountsLoadCurveGraphTest.java | 5 +- .../org/matsim/counts/CountsParserTest.java | 14 +- .../matsim/counts/CountsParserWriterTest.java | 6 +- .../counts/CountsReaderHandlerImplV1Test.java | 11 +- .../counts/CountsReprojectionIOTest.java | 16 +- .../counts/CountsSimRealPerHourGraphTest.java | 5 +- .../matsim/counts/CountsTableWriterTest.java | 5 +- .../java/org/matsim/counts/CountsTest.java | 5 +- .../java/org/matsim/counts/CountsV2Test.java | 24 +- .../org/matsim/counts/MatsimCountsIOTest.java | 32 +- .../org/matsim/counts/OutputDelegateTest.java | 5 +- .../java/org/matsim/examples/EquilTest.java | 4 +- .../examples/OnePercentBerlin10sIT.java | 8 +- .../org/matsim/examples/PtTutorialIT.java | 4 +- .../matsim/examples/simple/PtScoringTest.java | 12 +- .../ActivityFacilitiesFactoryImplTest.java | 6 +- .../ActivityFacilitiesImplTest.java | 10 +- .../ActivityFacilitiesSourceTest.java | 4 +- .../ActivityWithOnlyFacilityIdTest.java | 18 +- .../FacilitiesAttributeConvertionTest.java | 16 +- .../FacilitiesFromPopulationTest.java | 8 +- .../FacilitiesParserWriterTest.java | 10 +- .../FacilitiesReprojectionIOTest.java | 20 +- .../facilities/FacilitiesWriterTest.java | 24 +- .../MatsimFacilitiesReaderTest.java | 12 +- .../StreamingActivityFacilitiesTest.java | 4 +- .../AbstractFacilityAlgorithmTest.java | 5 +- .../HouseholdAttributeConversionTest.java | 8 +- .../matsim/households/HouseholdImplTest.java | 8 +- .../matsim/households/HouseholdsIoTest.java | 5 +- .../integration/EquilTwoAgentsTest.java | 4 +- .../integration/SimulateAndScoreTest.java | 8 +- .../PersonMoneyEventIntegrationTest.java | 8 +- .../events/PersonScoreEventTest.java | 8 +- ...iverStartsEventHandlerIntegrationTest.java | 4 +- .../InvertedNetworkRoutingIT.java | 9 +- .../integration/invertednetworks/LanesIT.java | 4 +- .../NonAlternatingPlanElementsIT.java | 6 +- .../pt/TransitIntegrationTest.java | 66 ++-- .../ChangeTripModeIntegrationTest.java | 5 +- .../integration/replanning/ReRoutingIT.java | 8 +- .../replanning/ResumableRunsIT.java | 4 +- .../QSimIntegrationTest.java | 11 +- .../java/org/matsim/lanes/LanesUtilsTest.java | 6 +- .../lanes/data/LanesReaderWriterTest.java | 8 +- .../matsim/modules/ScoreStatsModuleTest.java | 4 +- .../matsim/other/DownloadAndReadXmlTest.java | 9 +- ...ndomLegModeForSubtourComplexTripsTest.java | 8 +- ...eRandomLegModeForSubtourDiffModesTest.java | 6 +- .../ChooseRandomLegModeForSubtourTest.java | 16 +- .../algorithms/ChooseRandomLegModeTest.java | 30 +- .../ChooseRandomSingleLegModeTest.java | 23 +- .../ParallelPersonAlgorithmRunnerTest.java | 8 +- .../PermissibleModesCalculatorImplTest.java | 6 +- .../algorithms/PersonPrepareForSimTest.java | 24 +- .../algorithms/TripsToLegsAlgorithmTest.java | 10 +- .../analysis/TransitLoadIntegrationTest.java | 4 +- .../matsim/pt/analysis/TransitLoadTest.java | 4 +- .../pt/config/TransitConfigGroupTest.java | 11 +- .../pt/router/TransitActsRemoverTest.java | 17 +- .../pt/router/TransitRouterConfigTest.java | 5 +- .../pt/router/TransitRouterModuleTest.java | 4 +- .../DefaultTransitPassengerRouteTest.java | 26 +- .../routes/ExperimentalTransitRouteTest.java | 23 +- .../pt/transitSchedule/DepartureTest.java | 8 +- .../MinimalTransferTimesImplTest.java | 18 +- .../pt/transitSchedule/TransitLineTest.java | 17 +- .../transitSchedule/TransitRouteStopTest.java | 14 +- .../pt/transitSchedule/TransitRouteTest.java | 32 +- .../TransitScheduleFactoryTest.java | 14 +- .../TransitScheduleFormatV1Test.java | 5 +- .../TransitScheduleIOTest.java | 4 +- .../TransitScheduleReaderTest.java | 8 +- .../TransitScheduleReaderV1Test.java | 46 +-- .../TransitScheduleReprojectionIOTest.java | 20 +- .../transitSchedule/TransitScheduleTest.java | 22 +- .../TransitScheduleWriterTest.java | 6 +- .../TransitStopFacilityTest.java | 14 +- .../utils/TransitScheduleValidatorTest.java | 10 +- .../org/matsim/run/CreateFullConfigTest.java | 4 +- .../java/org/matsim/run/InitRoutesTest.java | 5 +- .../java/org/matsim/run/XY2LinksTest.java | 5 +- .../testcases/utils/LogCounterTest.java | 6 +- .../EventsFileComparatorTest.java | 17 +- .../matsim/utils/geometry/CoordUtilsTest.java | 12 +- .../LanesBasedWidthCalculatorTest.java | 4 +- .../network/Network2ESRIShapeTest.java | 17 +- .../plans/SelectedPlans2ESRIShapeTest.java | 8 +- .../ObjectAttributesConverterTest.java | 32 +- .../ObjectAttributesTest.java | 4 +- .../ObjectAttributesUtilsTest.java | 8 +- .../ObjectAttributesXmlIOTest.java | 6 +- .../ObjectAttributesXmlReaderTest.java | 10 +- .../attributable/AttributesTest.java | 20 +- .../attributable/AttributesUtilsTest.java | 6 +- .../CoordArrayConverterTest.java | 7 +- .../CoordConverterTest.java | 6 +- .../DoubleArrayConverterTest.java | 8 +- .../EnumConverterTest.java | 12 +- .../StringCollectionConverterTest.java | 6 +- .../StringStringMapConverterTest.java | 6 +- .../vehicles/MatsimVehicleWriterTest.java | 5 +- .../matsim/vehicles/VehicleReaderV1Test.java | 17 +- .../matsim/vehicles/VehicleReaderV2Test.java | 23 +- .../matsim/vehicles/VehicleWriteReadTest.java | 6 +- .../matsim/vehicles/VehicleWriterV1Test.java | 5 +- .../matsim/vehicles/VehicleWriterV2Test.java | 24 +- .../org/matsim/vehicles/VehiclesImplTest.java | 14 +- .../vis/snapshotwriters/PositionInfoTest.java | 8 +- .../ExampleWithinDayControllerTest.java | 4 +- .../ExperiencedPlansWriterTest.java | 4 +- .../tools/ActivityReplanningMapTest.java | 9 +- .../tools/LinkReplanningMapTest.java | 7 +- .../WithinDayTravelTimeTest.java | 6 +- ...TravelTimeWithNetworkChangeEventsTest.java | 4 +- .../withinday/utils/EditRoutesTest.java | 47 ++- .../utils/ReplacePlanElementsTest.java | 8 +- 934 files changed, 6756 insertions(+), 6186 deletions(-) diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/LeastCostPathTreeTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/LeastCostPathTreeTest.java index fcd995bd7b7..0de803d1434 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/LeastCostPathTreeTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/LeastCostPathTreeTest.java @@ -6,7 +6,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Node; @@ -24,9 +24,9 @@ public class LeastCostPathTreeTest { Scenario scenario; - + @Test - public void testRouteChoiceTestSpanningTree(){ + void testRouteChoiceTestSpanningTree(){ this.scenario = new ScenarioBuilder(ConfigUtils.createConfig()).setNetwork(CreateTestNetwork.createTriangularNetwork()).build() ; compareRouteChoices(); } diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java index 3b1ea9c2c9b..0a43df9c1b6 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java @@ -1,8 +1,8 @@ package org.matsim.contrib.accessibility.grid; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.network.Network; import org.matsim.contrib.accessibility.SpatialGrid; import org.matsim.contrib.matrixbasedptrouter.utils.BoundingBox; @@ -17,7 +17,8 @@ public class SpatialGridTest { private double cellSize = 10.; - @Test public void testSpatialGrid() { + @Test + void testSpatialGrid() { // get network Network network = CreateTestNetwork.createTestNetwork(); diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java index 046d187a965..8d4c324a49a 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java @@ -23,8 +23,8 @@ package org.matsim.contrib.accessibility.logsumComputations; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -37,8 +37,8 @@ public class CompareLogsumFormulas2Test { private MatsimTestUtils utils = new MatsimTestUtils(); - - @Test public void testLogsumFormulas(){ + @Test + void testLogsumFormulas(){ double walkTravelTime2Network = 2.; // 2min double travelTimeOnNetwork = 6.; // 6min diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java index 3c25e7c59d0..95517505f79 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java @@ -23,8 +23,8 @@ package org.matsim.contrib.accessibility.logsumComputations; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -47,7 +47,8 @@ public class CompareLogsumFormulasTest { * cjk3 */ - @Test public void testLogsumFormulas(){ + @Test + void testLogsumFormulas(){ double betaWalkTT = -2.; double betaWalkTD = -1.; diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java index 0b358229465..a746fd57137 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java @@ -23,8 +23,8 @@ package org.matsim.contrib.accessibility.logsumComputations; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -48,7 +48,8 @@ public class ComputeLogsumFormulas3Test { */ @SuppressWarnings("static-method") - @Test public void testLogsumFormulas(){ + @Test + void testLogsumFormulas(){ double betaWalkTT = -10. / 3600.0; // [util/sec] double betaWalkTD = -10.; // [util/meter] diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java index c4835291ee3..0b3aa1ebf8c 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java @@ -29,8 +29,8 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.geom.Envelope; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -78,7 +78,7 @@ public class AccessibilityIntegrationTest { @Ignore @Test - public void testRunAccessibilityExample() { + void testRunAccessibilityExample() { Config config = ConfigUtils.loadConfig("./examples/RunAccessibilityExample/config.xml"); AccessibilityConfigGroup accConfig = ConfigUtils.addOrGetModule(config, AccessibilityConfigGroup.class); @@ -119,7 +119,7 @@ public void startRow(String[] row) { @Test - public void testWithBoundingBoxConfigFile() { + void testWithBoundingBoxConfigFile() { Config config = ConfigUtils.loadConfig(utils.getInputDirectory() + "config.xml"); AccessibilityConfigGroup acg = ConfigUtils.addOrGetModule(config, AccessibilityConfigGroup.class) ; @@ -159,7 +159,7 @@ public void install() { @Test - public void testWithBoundingBox() { + void testWithBoundingBox() { final Config config = createTestConfig(); double min = 0.; // Values for bounding box usually come from a config file @@ -197,7 +197,7 @@ public void install() { @Test - public void testWithBoundingBoxUsingOpportunityWeights() { + void testWithBoundingBoxUsingOpportunityWeights() { final Config config = createTestConfig(); double min = 0.; // Values for bounding box usually come from a config file @@ -237,7 +237,7 @@ public void install() { @Test - public void testWithExtentDeterminedByNetwork() { + void testWithExtentDeterminedByNetwork() { final Config config = createTestConfig() ; config.routing().setRoutingRandomness(0.); @@ -264,7 +264,7 @@ public void install() { @Test - public void testWithExtentDeterminedShapeFile() { + void testWithExtentDeterminedShapeFile() { Config config = createTestConfig() ; File f = new File(this.utils.getInputDirectory() + "shapefile.shp"); // shape file completely covers the road network @@ -304,7 +304,7 @@ public void install() { @Test - public void testWithPredefinedMeasuringPoints() { + void testWithPredefinedMeasuringPoints() { Config config = createTestConfig() ; File f = new File(this.utils.getInputDirectory() + "measuringPoints.xml"); @@ -352,7 +352,7 @@ public void install() { @Ignore @Test - public void testWithFile(){ + void testWithFile(){ /*TODO Complete - JWJ, Dec'16 */ Config config = createTestConfig(); diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java index aa9360e8013..e131507e5ad 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java @@ -22,8 +22,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -46,7 +46,7 @@ public class NetworkUtilTest { @Test - public void testNetworkUtil() { + void testNetworkUtil() { /* create a sample network: * * (e) (f) diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java index a0a2f6548f7..9e7a6eb30f1 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -60,7 +60,7 @@ public class TinyAccessibilityTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void runFromEvents() { + void runFromEvents() { final Config config = createTestConfig(); double min = 0.; // Values for bounding box usually come from a config file @@ -86,7 +86,7 @@ public void runFromEvents() { } @Test - public void testWithBoundingBox() { + void testWithBoundingBox() { final Config config = createTestConfig(); double min = 0.; // Values for bounding box usually come from a config file diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java index 51081fd61b1..3f407b42ffb 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java @@ -23,8 +23,8 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -67,9 +67,10 @@ public class TinyMultimodalAccessibilityTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + // non-deterministic presumably because of multi-threading. kai, sep'19 @Test - @Ignore // non-deterministic presumably because of multi-threading. kai, sep'19 - public void testWithBoundingBox() { + @Ignore + void testWithBoundingBox() { final Config config = createTestConfig(); double min = 0.; // Values for bounding box usually come from a config file diff --git a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/BvwpAccidentsCostComputationTest.java b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/BvwpAccidentsCostComputationTest.java index 9acd427bef7..5e6bd4a91d0 100644 --- a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/BvwpAccidentsCostComputationTest.java +++ b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/BvwpAccidentsCostComputationTest.java @@ -3,7 +3,7 @@ import java.util.ArrayList; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -12,7 +12,7 @@ import org.matsim.api.core.v01.network.Node; import org.matsim.core.network.NetworkUtils; import org.matsim.testcases.MatsimTestUtils; -; + /** * @author ikaddoura, mmayobre @@ -20,9 +20,9 @@ * */ public class BvwpAccidentsCostComputationTest { - + @Test - public void test1() { + void test1() { Network network = NetworkUtils.createNetwork(); NetworkFactory factory = network.getFactory(); @@ -42,9 +42,9 @@ public void test1() { double costs = AccidentCostComputationBVWP.computeAccidentCosts(4820, link1, list); Assert.assertEquals("wrong cost", 1772.13863066011, costs, MatsimTestUtils.EPSILON); } - + @Test - public void test2() { + void test2() { Network network = NetworkUtils.createNetwork(); NetworkFactory factory = network.getFactory(); @@ -64,9 +64,9 @@ public void test2() { double costs = AccidentCostComputationBVWP.computeAccidentCosts(1000, link1, list); Assert.assertEquals("wrong cost", 23.165, costs, MatsimTestUtils.EPSILON); } - + @Test - public void test3() { + void test3() { Network network = NetworkUtils.createNetwork(); NetworkFactory factory = network.getFactory(); diff --git a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java index bd0daad8082..b087e316b5b 100644 --- a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java +++ b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java @@ -4,8 +4,8 @@ import java.io.IOException; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.accidents.AccidentsConfigGroup.AccidentsComputationMethod; @@ -27,7 +27,7 @@ public class RunTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void test1() { + void test1() { String configFile = utils.getPackageInputDirectory() + "/trial_scenario/trial_scenario_config.xml"; String outputDirectory = utils.getOutputDirectory(); diff --git a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java index de2a0923944..94e8df01123 100644 --- a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java +++ b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java @@ -2,9 +2,9 @@ import java.io.BufferedReader; import java.io.IOException; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -15,14 +15,14 @@ import org.matsim.core.controler.OutputDirectoryHierarchy.OverwriteFileSetting; import org.matsim.core.scenario.ScenarioUtils; import org.matsim.core.utils.io.IOUtils; -import org.matsim.testcases.MatsimTestUtils; - +import org.matsim.testcases.MatsimTestUtils; + public class RunTestEquil { - @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - - @Test - public void test1() { + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + + @Test + void test1() { String configFile = utils.getPackageInputDirectory() + "/equil_scenario/config.xml"; String outputDirectory = utils.getOutputDirectory(); String runId = "run1"; diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java index 848a370fb01..53501436d54 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java @@ -25,8 +25,8 @@ import java.util.HashMap; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -55,7 +55,8 @@ public class PersonIntersectAreaFilterTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testFilter() throws Exception { + @Test + void testFilter() throws Exception { /* create a simple network where agents can drive from the lower left * to the upper right */ Network network = NetworkUtils.createNetwork(); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java index 206f1a7c2a9..4f5b186f055 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java @@ -23,8 +23,8 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertTrue; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -54,7 +54,8 @@ public class RouteLinkFilterTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testRouteLinkFilter() { + @Test + void testRouteLinkFilter() { // used to set the default dtd-location utils.loadConfig((String)null); Population population = getTestPopulation(); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java index ee36629cfc1..f474729f527 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java @@ -26,8 +26,8 @@ import org.junit.Assert; import org.junit.Before; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -107,9 +107,9 @@ public void tearDown() throws Exception { this.network = null; } - @Test - @Ignore - public void testNoEvents() { + @Test + @Ignore + void testNoEvents() { KNAnalysisEventsHandler testee = new KNAnalysisEventsHandler(this.scenario); @@ -121,9 +121,9 @@ public void testNoEvents() { this.runTest(testee); } - @Test - @Ignore - public void testAveraging() { + @Test + @Ignore + void testAveraging() { // yy this test is probably not doing anything with respect to some of the newer statistics, such as money. kai, mar'14 KNAnalysisEventsHandler testee = new KNAnalysisEventsHandler(this.scenario); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/GridTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/GridTest.java index a3253515666..1b223b21821 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/GridTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/GridTest.java @@ -4,14 +4,14 @@ import java.util.Collection; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.GeometryFactory; public class GridTest { - @Test - public void initializeSquareGrid() { + @Test + void initializeSquareGrid() { final String testValue = "Test-value"; Grid grid = new SquareGrid<>(2, () -> testValue, SpatialTestUtils.createRect(10, 10)); @@ -23,8 +23,8 @@ public void initializeSquareGrid() { values.forEach(value -> assertEquals(testValue, value.getValue())); } - @Test - public void initializeHexagonalGrid() { + @Test + void initializeHexagonalGrid() { final String testValue = "test-value"; Grid grid = new HexagonalGrid<>(2, () -> testValue, SpatialTestUtils.createRect(10, 10)); @@ -38,8 +38,8 @@ public void initializeHexagonalGrid() { values.forEach(value -> assertEquals(testValue, value.getValue())); } - @Test - public void getArea_squareGrid() { + @Test + void getArea_squareGrid() { final double horizontalDistance = 2; final double expected = 2 * 2; // area of square is d^2 @@ -49,8 +49,8 @@ public void getArea_squareGrid() { assertEquals(expected, grid.getCellArea(), 0.0001); } - @Test - public void getArea_HexagonalGrid() { + @Test + void getArea_HexagonalGrid() { // actually area of hexagon is r^2 * sqrt(3)/2 final double horizontalDistance = 2; @@ -65,8 +65,8 @@ public void getArea_HexagonalGrid() { assertEquals(expected5, grid5.getCellArea(), 0.0001); } - @Test - public void getValue_withExactCoord() { + @Test + void getValue_withExactCoord() { final String testValue = "initialValue"; final Coordinate expectedCoordinate = new Coordinate(2, 1+Math.sqrt(3)); @@ -77,8 +77,8 @@ public void getValue_withExactCoord() { assertEquals(expectedCoordinate, result.getCoordinate()); } - @Test - public void getValue_closeCoordinate() { + @Test + void getValue_closeCoordinate() { final String testValue = "initialValue"; Grid grid = new HexagonalGrid<>(2, () -> testValue, SpatialTestUtils.createRect(10, 10)); @@ -89,8 +89,8 @@ public void getValue_closeCoordinate() { assertEquals(new Coordinate(2, 1+Math.sqrt(3)), result.getCoordinate()); } - @Test - public void getValue_coordOutsideOfGrid() { + @Test + void getValue_coordOutsideOfGrid() { final String testValue = "initialValue"; Grid grid = new HexagonalGrid<>(2, () -> testValue, SpatialTestUtils.createRect(10, 10)); @@ -100,8 +100,8 @@ public void getValue_coordOutsideOfGrid() { assertEquals(new Coordinate(8, 1 + 5*Math.sqrt(3)), result.getCoordinate()); } - @Test - public void getValues() { + @Test + void getValues() { final String testValue = "initialValue"; Grid grid = new HexagonalGrid<>(2, () -> testValue, SpatialTestUtils.createRect(10, 10)); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/SpatialInterpolationTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/SpatialInterpolationTest.java index 49e3f8e4a8a..e739ab2b847 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/SpatialInterpolationTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/SpatialInterpolationTest.java @@ -2,14 +2,15 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.assertThrows; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.Coordinate; public class SpatialInterpolationTest { - @Test - public void calculateWeightFromLine() { + @Test + void calculateWeightFromLine() { final Coordinate from = new Coordinate(1, 1); final Coordinate to = new Coordinate(4, 5); @@ -22,33 +23,37 @@ public void calculateWeightFromLine() { assertEquals(0.0011109434390476694, weight, 0.001); } - @Test(expected = IllegalArgumentException.class) - public void calculateWeightFromLine_invalidSmoothingRadius() { + @Test + void calculateWeightFromLine_invalidSmoothingRadius() { + assertThrows(IllegalArgumentException.class, () -> { - final Coordinate from = new Coordinate(0, 1); - final Coordinate to = new Coordinate(10, 1); - final Coordinate cellCentroid = new Coordinate(5, 1); - final double smoothingRadius = 0; + final Coordinate from = new Coordinate(0, 1); + final Coordinate to = new Coordinate(10, 1); + final Coordinate cellCentroid = new Coordinate(5, 1); + final double smoothingRadius = 0; - double weight = SpatialInterpolation.calculateWeightFromLine(from, to, cellCentroid, smoothingRadius); + double weight = SpatialInterpolation.calculateWeightFromLine(from, to, cellCentroid, smoothingRadius); - fail("smoothing radius <= 0 should cause exception"); - } + fail("smoothing radius <= 0 should cause exception"); + }); + } - @Test(expected = IllegalArgumentException.class) - public void calculateWeightFromPoint_invalidSmoothingRadius() { + @Test + void calculateWeightFromPoint_invalidSmoothingRadius() { + assertThrows(IllegalArgumentException.class, () -> { - final Coordinate source = new Coordinate(10, 10); - final Coordinate centroid = new Coordinate(10, 10); - final double smoothingRadius = 0; + final Coordinate source = new Coordinate(10, 10); + final Coordinate centroid = new Coordinate(10, 10); + final double smoothingRadius = 0; - double weight = SpatialInterpolation.calculateWeightFromPoint(source, centroid, smoothingRadius); + double weight = SpatialInterpolation.calculateWeightFromPoint(source, centroid, smoothingRadius); - fail("smoothing radius <= 0 should cause exception"); - } + fail("smoothing radius <= 0 should cause exception"); + }); + } - @Test - public void calculateWeightFromPoint() { + @Test + void calculateWeightFromPoint() { final Coordinate point = new Coordinate(5, 5); final Coordinate cell = new Coordinate (9, 5); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/time/TimeBinMapTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/time/TimeBinMapTest.java index a15b076f567..3acb0feeec5 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/time/TimeBinMapTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/time/TimeBinMapTest.java @@ -1,15 +1,16 @@ package org.matsim.contrib.analysis.time; -import org.junit.Test; - import java.util.Map; import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.assertThrows; + +import org.junit.jupiter.api.Test; public class TimeBinMapTest { - @Test - public void getTimeBin() { + @Test + void getTimeBin() { TimeBinMap> map = new TimeBinMap<>(10); @@ -18,8 +19,8 @@ public void getTimeBin() { assertEquals(10, bin.getStartTime(), 0.001); } - @Test - public void getTimeBinWithStartTime() { + @Test + void getTimeBinWithStartTime() { TimeBinMap> map = new TimeBinMap<>(10, 20); @@ -28,18 +29,20 @@ public void getTimeBinWithStartTime() { assertEquals(20, bin.getStartTime(), 0.001); } - @Test(expected = IllegalArgumentException.class) - public void getTimeInvalidTime_exception() { + @Test + void getTimeInvalidTime_exception() { + assertThrows(IllegalArgumentException.class, () -> { - TimeBinMap> map = new TimeBinMap<>(10, 20); + TimeBinMap> map = new TimeBinMap<>(10, 20); - TimeBinMap.TimeBin> bin = map.getTimeBin(19); + TimeBinMap.TimeBin> bin = map.getTimeBin(19); - assertEquals(20, bin.getStartTime(), 0.001); - } + assertEquals(20, bin.getStartTime(), 0.001); + }); + } - @Test - public void getMultipleTimeBins() { + @Test + void getMultipleTimeBins() { TimeBinMap> map = new TimeBinMap<>(10); @@ -55,8 +58,8 @@ public void getMultipleTimeBins() { assertEquals(30, fourth.getStartTime(), 0.001); } - @Test - public void getEndOfLastTimeBucket() { + @Test + void getEndOfLastTimeBucket() { TimeBinMap> map = new TimeBinMap<>(10); @@ -68,8 +71,8 @@ public void getEndOfLastTimeBucket() { assertEquals(120, map.getEndTimeOfLastBin(), 0.0001); } - @Test - public void getAllTimeBins() { + @Test + void getAllTimeBins() { TimeBinMap> map = new TimeBinMap<>(10); @@ -81,8 +84,8 @@ public void getAllTimeBins() { assertEquals(4, map.getTimeBins().size()); } - @Test - public void timeBin_setEntry() { + @Test + void timeBin_setEntry() { final String testValue = "some-value"; @@ -97,7 +100,7 @@ public void timeBin_setEntry() { } @Test - public void timeBin_getValue() { + void timeBin_getValue() { final String testValue = "some-value"; diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java index 0b8723a704b..3d322dec849 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.analysis.vsp.traveltimedistance; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.utils.collections.Tuple; import org.matsim.testcases.MatsimTestUtils; @@ -16,7 +16,7 @@ public class GoogleMapRouteValidatorTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testReadJson() throws IOException { + void testReadJson() throws IOException { GoogleMapRouteValidator googleMapRouteValidator = getDummyValidator(); BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(utils.getClassInputDirectory() + "route.json"))); Optional> result = googleMapRouteValidator.readFromJson(reader); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java index e08bf8c5b00..72ec7f44e30 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.analysis.vsp.traveltimedistance; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.utils.collections.Tuple; import org.matsim.testcases.MatsimTestUtils; @@ -15,7 +15,7 @@ public class HereMapsRouteValidatorTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testReadJson() throws IOException { + void testReadJson() throws IOException { HereMapsRouteValidator hereMapsRouteValidator = getDummyValidator(false); BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(utils.getClassInputDirectory() + "route.json"))); Optional> result = hereMapsRouteValidator.readFromJson(reader, null); @@ -25,7 +25,7 @@ public void testReadJson() throws IOException { } @Test - public void testWriteFile() throws IOException { + void testWriteFile() throws IOException { HereMapsRouteValidator hereMapsRouteValidator = getDummyValidator(true); BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(utils.getClassInputDirectory() + "route.json"))); hereMapsRouteValidator.readFromJson(reader, "tripId"); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/travelsummary/events2traveldiaries/RunEventsToTravelDiariesIT.java b/contribs/analysis/src/test/java/org/matsim/contrib/travelsummary/events2traveldiaries/RunEventsToTravelDiariesIT.java index 58ee087e1fe..c3a4f24d7fd 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/travelsummary/events2traveldiaries/RunEventsToTravelDiariesIT.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/travelsummary/events2traveldiaries/RunEventsToTravelDiariesIT.java @@ -18,8 +18,8 @@ * *********************************************************************** */ package org.matsim.contrib.travelsummary.events2traveldiaries; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -29,9 +29,9 @@ public class RunEventsToTravelDiariesIT { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @SuppressWarnings("static-method") - @Test - public final void test() { + @SuppressWarnings("static-method") + @Test + final void test() { String[] str = {"../../examples/scenarios/equil/config.xml", "../../examples/scenarios/equil/output_events.xml.gz", "_test", utils.getOutputDirectory()}; // This goes through the file system (nothing to do with resource paths etc.) diff --git a/contribs/application/src/test/java/org/matsim/application/ApplicationUtilsTest.java b/contribs/application/src/test/java/org/matsim/application/ApplicationUtilsTest.java index edb2bcdbba6..85a1f820674 100644 --- a/contribs/application/src/test/java/org/matsim/application/ApplicationUtilsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/ApplicationUtilsTest.java @@ -1,6 +1,6 @@ package org.matsim.application; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.application.analysis.TestAnalysis; import org.matsim.application.analysis.TestDependentAnalysis; import org.matsim.application.options.ShpOptions; @@ -10,7 +10,7 @@ public class ApplicationUtilsTest { @Test - public void shp() { + void shp() { assertTrue(ApplicationUtils.acceptsOptions(TestAnalysis.class, ShpOptions.class)); diff --git a/contribs/application/src/test/java/org/matsim/application/CommandRunnerTest.java b/contribs/application/src/test/java/org/matsim/application/CommandRunnerTest.java index 3f3cff914d1..bd7f228964f 100644 --- a/contribs/application/src/test/java/org/matsim/application/CommandRunnerTest.java +++ b/contribs/application/src/test/java/org/matsim/application/CommandRunnerTest.java @@ -1,8 +1,8 @@ package org.matsim.application; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.application.analysis.TestDependentAnalysis; import org.matsim.application.analysis.TestOtherAnalysis; import org.matsim.application.analysis.TestOtherDependentAnalysis; @@ -16,7 +16,7 @@ public class CommandRunnerTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void runner() { + void runner() { Path path = Path.of(utils.getOutputDirectory()); diff --git a/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java b/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java index 4decf8ec93b..1abf0991cf0 100644 --- a/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java +++ b/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java @@ -2,8 +2,8 @@ import org.junit.Assume; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.application.options.SampleOptions; import org.matsim.application.prepare.freight.tripExtraction.ExtractRelevantFreightTrips; import org.matsim.application.prepare.population.GenerateShortDistanceTrips; @@ -32,7 +32,7 @@ public class MATSimApplicationTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void help() { + void help() { int ret = MATSimApplication.execute(TestScenario.class, "--help"); @@ -40,7 +40,7 @@ public void help() { } @Test - public void config() { + void config() { Controler controler = MATSimApplication.prepare(TestScenario.class, ConfigUtils.createConfig(), "-c:controler.runId=Test123", "--config:global.numberOfThreads=4", "--config:plans.inputCRS", "EPSG:1234"); @@ -54,7 +54,7 @@ public void config() { } @Test - public void yaml() { + void yaml() { Path yml = Path.of(utils.getClassInputDirectory(), "specs.yml"); @@ -76,7 +76,7 @@ public void yaml() { } @Test - public void sample() { + void sample() { Controler controler = MATSimApplication.prepare(TestScenario.class, ConfigUtils.createConfig(), "--10pct"); @@ -92,7 +92,7 @@ public void sample() { } @Test - public void population() throws MalformedURLException { + void population() throws MalformedURLException { Path input = Path.of(utils.getClassInputDirectory()); Path output = Path.of(utils.getOutputDirectory()); @@ -128,7 +128,7 @@ public void population() throws MalformedURLException { @Test @Ignore("Class is deprecated") - public void freight() { + void freight() { Path input = Path.of("..", "..", "..", "..", "shared-svn", "komodnext", "data", "freight", "original_data").toAbsolutePath().normalize(); @@ -161,7 +161,7 @@ public void freight() { } @Test - public void run() { + void run() { Config config = ConfigUtils.createConfig(); Path out = Path.of(utils.getOutputDirectory()).resolve("out"); diff --git a/contribs/application/src/test/java/org/matsim/application/analysis/LogFileAnalysisTest.java b/contribs/application/src/test/java/org/matsim/application/analysis/LogFileAnalysisTest.java index 043845b921f..5309e1585b5 100644 --- a/contribs/application/src/test/java/org/matsim/application/analysis/LogFileAnalysisTest.java +++ b/contribs/application/src/test/java/org/matsim/application/analysis/LogFileAnalysisTest.java @@ -1,8 +1,8 @@ package org.matsim.application.analysis; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.application.ApplicationUtils; import org.matsim.application.MATSimApplication; import org.matsim.application.MATSimApplicationTest; @@ -20,7 +20,7 @@ public class LogFileAnalysisTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void output() throws IOException { + void output() throws IOException { Config config = ConfigUtils.createConfig(); diff --git a/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java b/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java index 8fd5097116a..da166a7ea88 100644 --- a/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java @@ -2,8 +2,8 @@ import org.apache.commons.csv.CSVFormat; import org.apache.commons.csv.CSVPrinter; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; @@ -19,7 +19,7 @@ public class CsvOptionsTest { public Path f; @Test - public void output() throws IOException { + void output() throws IOException { CsvOptions csv = new CsvOptions(CSVFormat.Predefined.TDF); diff --git a/contribs/application/src/test/java/org/matsim/application/options/SampleOptionsTest.java b/contribs/application/src/test/java/org/matsim/application/options/SampleOptionsTest.java index 545e30560a2..cc7f4469b2b 100644 --- a/contribs/application/src/test/java/org/matsim/application/options/SampleOptionsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/options/SampleOptionsTest.java @@ -2,7 +2,7 @@ import com.google.common.util.concurrent.AtomicDouble; import org.assertj.core.api.Assertions; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.application.MATSimAppCommand; import picocli.CommandLine; @@ -11,7 +11,7 @@ public class SampleOptionsTest { @Test - public void flexible() { + void flexible() { AtomicInteger size = new AtomicInteger(); AtomicDouble dSize = new AtomicDouble(); @@ -39,7 +39,7 @@ public Integer call() throws Exception { } @Test - public void fixed() { + void fixed() { AtomicInteger size = new AtomicInteger(); diff --git a/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java b/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java index 48c70be2e1b..ca5a7785d4b 100644 --- a/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java @@ -2,8 +2,8 @@ import org.junit.Assert; import org.junit.Assume; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.geom.Geometry; import org.locationtech.jts.geom.GeometryFactory; import org.matsim.testcases.MatsimTestUtils; @@ -23,7 +23,7 @@ public class ShpOptionsTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void readZip() { + void readZip() { // use same shape file as for land-use Path input = Path.of(utils.getClassInputDirectory() @@ -43,7 +43,7 @@ public void readZip() { } @Test - public void all() { + void all() { // use same shape file as for land-use Path input = Path.of(utils.getClassInputDirectory() @@ -66,7 +66,7 @@ public void all() { } @Test - public void testGetGeometry() { + void testGetGeometry() { Path input = Path.of(utils.getClassInputDirectory() .replace("ShpOptionsTest", "CreateLandUseShpTest") diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java index 7830166223f..38747c0fbc7 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java @@ -1,8 +1,8 @@ package org.matsim.application.prepare; import org.junit.Assume; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import java.nio.file.Files; @@ -16,7 +16,7 @@ public class CreateLandUseShpTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void convert() { + void convert() { Path input = Path.of(utils.getClassInputDirectory(), "andorra-latest-free.shp.zip"); diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java index 0fb5fe666c5..0ff988f14cf 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java @@ -1,8 +1,8 @@ package org.matsim.application.prepare; import org.junit.Assume; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import picocli.CommandLine; @@ -17,8 +17,8 @@ public class ShapeFileTextLookupTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void main() { + @Test + void main() { Path input = Path.of(utils.getClassInputDirectory(), "verkehrszellen.csv"); Path output = Path.of(utils.getOutputDirectory(), "output.csv"); diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java index 6706676043b..4c35b94c282 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java @@ -1,8 +1,8 @@ package org.matsim.application.prepare.counts; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -36,7 +36,7 @@ public class CreateCountsFromBAStDataTest { String shpCrs = "EPSG:3857"; @Test - public void testCreateCountsFromBAStData() { + void testCreateCountsFromBAStData() { String version = "normal-"; String out = utils.getOutputDirectory() + version + countsOutput; @@ -74,7 +74,7 @@ public void testCreateCountsFromBAStData() { } @Test - public void testWithIgnoredStations() { + void testWithIgnoredStations() { String version = "with-ignored-"; String out1 = utils.getOutputDirectory() + version + countsOutput; @@ -123,7 +123,7 @@ public void testWithIgnoredStations() { } @Test - public void testManualMatchedCounts() { + void testManualMatchedCounts() { String out = utils.getOutputDirectory() + "manual-matched-" + countsOutput; @@ -164,7 +164,7 @@ public void testManualMatchedCounts() { } @Test - public void testManualMatchingWithWrongInput() { + void testManualMatchingWithWrongInput() { String out = utils.getOutputDirectory() + "manual-matched-" + countsOutput; diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/counts/NetworkIndexTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/counts/NetworkIndexTest.java index a342fbac29c..74d0a5e356a 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/counts/NetworkIndexTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/counts/NetworkIndexTest.java @@ -2,7 +2,7 @@ import org.assertj.core.data.Offset; import org.geotools.geometry.jts.JTSFactoryFinder; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.GeometryFactory; @@ -11,7 +11,7 @@ public class NetworkIndexTest { @Test - public void angle() { + void angle() { GeometryFactory f = JTSFactoryFinder.getGeometryFactory(); diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/population/CloseTrajectoriesTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/population/CloseTrajectoriesTest.java index b3db595cfb0..5c45ddefdb3 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/population/CloseTrajectoriesTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/population/CloseTrajectoriesTest.java @@ -1,8 +1,8 @@ package org.matsim.application.prepare.population; import org.assertj.core.api.Condition; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.population.Activity; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Population; @@ -21,7 +21,7 @@ public class CloseTrajectoriesTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void main() { + void main() { Path input = Path.of(utils.getPackageInputDirectory(), "persons.xml"); diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/population/FixSubtourModesTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/population/FixSubtourModesTest.java index cbd4d0bd400..6f65537c5bf 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/population/FixSubtourModesTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/population/FixSubtourModesTest.java @@ -1,6 +1,6 @@ package org.matsim.application.prepare.population; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -19,7 +19,7 @@ public class FixSubtourModesTest { private PopulationFactory fact = PopulationUtils.getFactory(); @Test - public void unclosed() { + void unclosed() { Person person = fact.createPerson(Id.create("1000", Person.class)); final Plan plan = fact.createPlan(); @@ -43,7 +43,7 @@ public void unclosed() { } @Test - public void complex() { + void complex() { Person person = fact.createPerson(Id.create("1000", Person.class)); final Plan plan = fact.createPlan(); @@ -72,7 +72,7 @@ public void complex() { @Test - public void correct() { + void correct() { Person person = fact.createPerson(Id.create("1000", Person.class)); final Plan plan = fact.createPlan(); diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/population/SplitActivityTypesDurationTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/population/SplitActivityTypesDurationTest.java index 0e3e98374a1..3c87f29a3c8 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/population/SplitActivityTypesDurationTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/population/SplitActivityTypesDurationTest.java @@ -1,8 +1,8 @@ package org.matsim.application.prepare.population; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.population.Activity; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Population; @@ -21,7 +21,7 @@ public class SplitActivityTypesDurationTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void split() { + void split() { Path input = Path.of(utils.getPackageInputDirectory(), "persons.xml"); diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/pt/CreateTransitScheduleFromGtfsTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/pt/CreateTransitScheduleFromGtfsTest.java index 89ce36a5691..5b3732f6347 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/pt/CreateTransitScheduleFromGtfsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/pt/CreateTransitScheduleFromGtfsTest.java @@ -1,8 +1,8 @@ package org.matsim.application.prepare.pt; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; @@ -16,7 +16,7 @@ public class CreateTransitScheduleFromGtfsTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void run() { + void run() { String input = utils.getClassInputDirectory(); String output = utils.getOutputDirectory(); diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java index b067e5e2a43..e66b63d3dd1 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java @@ -10,8 +10,8 @@ import java.util.Set; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -43,7 +43,7 @@ public class CarrierReaderFromCSVTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void carrierCreation() throws IOException { + void carrierCreation() throws IOException { Config config = ConfigUtils.createConfig(); config.network().setInputFile( "https://raw.githubusercontent.com/matsim-org/matsim/master/examples/scenarios/freight-chessboard-9x9/grid9x9.xml"); @@ -160,7 +160,7 @@ public void carrierCreation() throws IOException { } @Test - public void csvCarrierReader() throws IOException { + void csvCarrierReader() throws IOException { Path carrierCSVLocation = Path.of(utils.getPackageInputDirectory() + "testCarrierCSV.csv"); Set allNewCarrierInformation = CarrierReaderFromCSV diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java index a8b19900587..7db97056e79 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java @@ -9,8 +9,8 @@ import java.util.Set; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -41,7 +41,7 @@ public class DemandReaderFromCSVTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testLinkForPerson() throws IOException { + void testLinkForPerson() throws IOException { Config config = ConfigUtils.createConfig(); config.network().setInputFile( "https://raw.githubusercontent.com/matsim-org/matsim-libs/master/examples/scenarios/freight-chessboard-9x9/grid9x9.xml"); @@ -67,7 +67,7 @@ public void testLinkForPerson() throws IOException { } @Test - public void demandCreation() throws IOException { + void demandCreation() throws IOException { // read inputs Config config = ConfigUtils.createConfig(); config.network().setInputFile( @@ -239,7 +239,7 @@ public void demandCreation() throws IOException { } @Test - public void csvDemandReader() throws IOException { + void csvDemandReader() throws IOException { Path demandCSVLocation = Path.of(utils.getPackageInputDirectory() + "testDemandCSV.csv"); Set demandInformation = DemandReaderFromCSV.readDemandInformation(demandCSVLocation); diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java index 5d42bcd5ab3..f1285ff809a 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java @@ -2,8 +2,8 @@ import org.apache.logging.log4j.LogManager; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import java.nio.file.Path; @@ -19,7 +19,7 @@ public class FreightDemandGenerationTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testMain() { + void testMain() { try { Path output = Path.of(utils.getOutputDirectory()); Path vehicleFilePath = Path.of(utils.getPackageInputDirectory() + "testVehicleTypes.xml"); diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java index ea14e21ad6b..cedeccd9dfb 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java @@ -3,9 +3,9 @@ import java.nio.file.Path; import java.util.Collection; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.geom.Point; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -18,8 +18,8 @@ import org.matsim.core.population.PopulationUtils; import org.matsim.core.utils.geometry.geotools.MGC; import org.matsim.testcases.MatsimTestUtils; -import org.opengis.feature.simple.SimpleFeature; - +import org.opengis.feature.simple.SimpleFeature; + /** * @author Ricardo Ewert * @@ -27,10 +27,10 @@ public class FreightDemandGenerationUtilsTest { @RegisterExtension - private MatsimTestUtils utils = new MatsimTestUtils(); - - @Test - public void testPreparePopulation() { + private MatsimTestUtils utils = new MatsimTestUtils(); + + @Test + void testPreparePopulation() { String populationLocation = utils.getPackageInputDirectory() + "testPopulation.xml"; Population population = PopulationUtils.readPopulation(populationLocation); FreightDemandGenerationUtils.preparePopulation(population, 1.0, 1.0, "changeNumberOfLocationsWithDemand"); @@ -78,9 +78,10 @@ public void testPreparePopulation() { Assert.assertEquals(5200.0,person.getAttributes().getAttribute("homeY")); Assert.assertEquals(0, person.getPlans().size()); Assert.assertNull(person.getSelectedPlan()); - } - @Test - public void testCoordOfMiddlePointOfLink() { + } + + @Test + void testCoordOfMiddlePointOfLink() { Network network = NetworkUtils.readNetwork("https://raw.githubusercontent.com/matsim-org/matsim-libs/master/examples/scenarios/freight-chessboard-9x9/grid9x9.xml"); Link link = network.getLinks().get(Id.createLinkId("i(8,8)")); Coord middlePoint = FreightDemandGenerationUtils.getCoordOfMiddlePointOfLink(link); @@ -90,9 +91,10 @@ public void testCoordOfMiddlePointOfLink() { Coord middlePoint2 = FreightDemandGenerationUtils.getCoordOfMiddlePointOfLink(link2); Assert.assertEquals(5000, middlePoint2.getX(), MatsimTestUtils.EPSILON); Assert.assertEquals(7500, middlePoint2.getY(), MatsimTestUtils.EPSILON); - } - @Test - public void testReducePopulationToShapeArea() { + } + + @Test + void testReducePopulationToShapeArea() { String populationLocation = utils.getPackageInputDirectory() + "testPopulation.xml"; Population population = PopulationUtils.readPopulation(populationLocation); FreightDemandGenerationUtils.preparePopulation(population, 1.0, 1.0, "changeNumberOfLocationsWithDemand"); @@ -103,9 +105,10 @@ public void testReducePopulationToShapeArea() { Assert.assertEquals(6, population.getPersons().size()); Assert.assertFalse(population.getPersons().containsKey(Id.createPersonId("person2"))); Assert.assertFalse(population.getPersons().containsKey(Id.createPersonId("person4"))); - } - @Test - public void testCheckPositionInShape_link() { + } + + @Test + void testCheckPositionInShape_link() { Network network = NetworkUtils.readNetwork("https://raw.githubusercontent.com/matsim-org/matsim-libs/master/examples/scenarios/freight-chessboard-9x9/grid9x9.xml"); Link link = network.getLinks().get(Id.createLinkId("i(8,8)")); Path shapeFilePath = Path.of(utils.getPackageInputDirectory() + "testShape/testShape.shp"); @@ -119,9 +122,10 @@ public void testCheckPositionInShape_link() { Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area1"}, null)); Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area2"}, null)); - } - @Test - public void testCheckPositionInShape_point() { + } + + @Test + void testCheckPositionInShape_point() { Path shapeFilePath = Path.of(utils.getPackageInputDirectory() + "testShape/testShape.shp"); ShpOptions shp = new ShpOptions(shapeFilePath,"WGS84", null); Collection polygonsInShape = shp.readFeatures(); diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java index 5ad5e0de362..4255b694d0e 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java @@ -21,8 +21,8 @@ import it.unimi.dsi.fastutil.objects.Object2DoubleMap; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.application.options.ShpOptions; import org.matsim.application.options.ShpOptions.Index; import org.matsim.testcases.MatsimTestUtils; @@ -46,7 +46,7 @@ public class LanduseBuildingAnalysisTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testReadOfDataDistributionPerZoneAndBuildingAnalysis() throws IOException { + void testReadOfDataDistributionPerZoneAndBuildingAnalysis() throws IOException { HashMap> landuseCategoriesAndDataConnection = new HashMap>(); HashMap>> buildingsPerZone = new HashMap<>(); @@ -239,7 +239,7 @@ public void testReadOfDataDistributionPerZoneAndBuildingAnalysis() throws IOExce } @Test - public void testLanduseDistribution() throws IOException { + void testLanduseDistribution() throws IOException { HashMap> landuseCategoriesAndDataConnection = new HashMap>(); HashMap>> buildingsPerZone = new HashMap<>(); diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java index a916ccae961..43fa34e8a5d 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java @@ -20,8 +20,8 @@ package org.matsim.smallScaleCommercialTrafficGeneration; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Population; @@ -47,7 +47,7 @@ public class RunGenerateSmallScaleCommercialTrafficTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testMainRunAndResults() { + void testMainRunAndResults() { String inputDataDirectory = utils.getPackageInputDirectory() + "config_demand.xml"; String output = utils.getOutputDirectory(); String sample = "0.1"; diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java index fab0c22abc4..f73b0698099 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java @@ -20,8 +20,8 @@ package org.matsim.smallScaleCommercialTrafficGeneration; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -50,7 +50,7 @@ public class SmallScaleCommercialTrafficUtilsTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void findZoneOfLinksTest() throws IOException, URISyntaxException { + void findZoneOfLinksTest() throws IOException, URISyntaxException { Path inputDataDirectory = Path.of(utils.getPackageInputDirectory()); Path shapeFileZonePath = inputDataDirectory.resolve("shp/testZones.shp"); diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java index 05d4e824089..c2e7ff89bd0 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java @@ -21,8 +21,8 @@ import it.unimi.dsi.fastutil.objects.Object2DoubleMap; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -53,7 +53,7 @@ public class TrafficVolumeGenerationTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testTrafficVolumeGenerationCommercialPersonTraffic() throws IOException { + void testTrafficVolumeGenerationCommercialPersonTraffic() throws IOException { HashMap> landuseCategoriesAndDataConnection = new HashMap<>(); HashMap>> buildingsPerZone = new HashMap<>(); @@ -183,7 +183,7 @@ public void testTrafficVolumeGenerationCommercialPersonTraffic() throws IOExcept } @Test - public void testTrafficVolumeGenerationGoodsTraffic() throws IOException { + void testTrafficVolumeGenerationGoodsTraffic() throws IOException { HashMap> landuseCategoriesAndDataConnection = new HashMap<>(); HashMap>> buildingsPerZone = new HashMap<>(); @@ -386,7 +386,7 @@ public void testTrafficVolumeGenerationGoodsTraffic() throws IOException { } @Test - public void testAddingExistingScenarios() throws Exception { + void testAddingExistingScenarios() throws Exception { Path inputDataDirectory = Path.of(utils.getPackageInputDirectory()); Path shapeFileZonePath = inputDataDirectory.resolve("shp/testZones.shp"); @@ -452,7 +452,7 @@ public void testAddingExistingScenarios() throws Exception { } @Test - public void testAddingExistingScenariosWithSample() throws Exception { + void testAddingExistingScenariosWithSample() throws Exception { Path inputDataDirectory = Path.of(utils.getPackageInputDirectory()); Path shapeFileZonePath = inputDataDirectory.resolve("shp/testZones.shp"); @@ -503,7 +503,7 @@ public void testAddingExistingScenariosWithSample() throws Exception { } @Test - public void testReducingDemandAfterAddingExistingScenarios_goods() throws Exception { + void testReducingDemandAfterAddingExistingScenarios_goods() throws Exception { HashMap> landuseCategoriesAndDataConnection = new HashMap<>(); HashMap>> buildingsPerZone = new HashMap<>(); @@ -663,7 +663,7 @@ public void testReducingDemandAfterAddingExistingScenarios_goods() throws Except } @Test - public void testReducingDemandAfterAddingExistingScenarios_commercialPersonTraffic() throws Exception { + void testReducingDemandAfterAddingExistingScenarios_commercialPersonTraffic() throws Exception { HashMap> landuseCategoriesAndDataConnection = new HashMap<>(); HashMap>> buildingsPerZone = new HashMap<>(); @@ -754,9 +754,8 @@ public void testReducingDemandAfterAddingExistingScenarios_commercialPersonTraff } - @Test - public void testTrafficVolumeKeyGeneration() { + void testTrafficVolumeKeyGeneration() { String zone = "zone1"; String mode = "modeA"; diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java index 9694505cbf2..5d439e96bc9 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java @@ -21,8 +21,8 @@ import it.unimi.dsi.fastutil.objects.Object2DoubleMap; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -47,7 +47,7 @@ public class TripDistributionMatrixTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testTripDistributionCommercialPersonTrafficTraffic() throws IOException { + void testTripDistributionCommercialPersonTrafficTraffic() throws IOException { HashMap> landuseCategoriesAndDataConnection = new HashMap>(); HashMap>> buildingsPerZone = new HashMap<>(); @@ -137,7 +137,7 @@ public void testTripDistributionCommercialPersonTrafficTraffic() throws IOExcept } @Test - public void testTripDistributionGoodsTraffic() throws IOException { + void testTripDistributionGoodsTraffic() throws IOException { HashMap> landuseCategoriesAndDataConnection = new HashMap>(); HashMap>> buildingsPerZone = new HashMap<>(); diff --git a/contribs/av/src/test/java/org/matsim/contrib/av/flow/RunAvExampleIT.java b/contribs/av/src/test/java/org/matsim/contrib/av/flow/RunAvExampleIT.java index ed3476fc8ea..ddc697ee825 100644 --- a/contribs/av/src/test/java/org/matsim/contrib/av/flow/RunAvExampleIT.java +++ b/contribs/av/src/test/java/org/matsim/contrib/av/flow/RunAvExampleIT.java @@ -26,8 +26,8 @@ import java.net.MalformedURLException; import java.net.URL; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -38,7 +38,7 @@ public class RunAvExampleIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testAvFlowExample() throws MalformedURLException { + void testAvFlowExample() throws MalformedURLException { URL configUrl = new File(utils.getPackageInputDirectory() + "config.xml").toURI().toURL(); new RunAvExample().run(configUrl, false); } diff --git a/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java b/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java index 916bd3c9e12..2fe06af31f4 100644 --- a/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java +++ b/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java @@ -27,8 +27,8 @@ import java.net.URL; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.LinkEnterEvent; @@ -48,7 +48,7 @@ public class TestAvFlowFactor { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testAvFlowFactor() throws MalformedURLException { + void testAvFlowFactor() throws MalformedURLException { URL configUrl = new File(utils.getPackageInputDirectory() + "config.xml").toURI().toURL(); Config config = ConfigUtils.loadConfig(configUrl, new OTFVisConfigGroup()); Scenario scenario = ScenarioUtils.loadScenario(config); diff --git a/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java b/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java index d9573384ef0..5d7aae5a4e5 100644 --- a/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java +++ b/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java @@ -30,8 +30,8 @@ import java.util.Map; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Leg; @@ -52,7 +52,7 @@ public class RunTaxiPTIntermodalExampleIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testIntermodalExample() throws MalformedURLException { + void testIntermodalExample() throws MalformedURLException { URL configUrl = new File(utils.getClassInputDirectory() + "config.xml").toURI().toURL(); new RunTaxiPTIntermodalExample().run(configUrl, false); diff --git a/contribs/av/src/test/java/org/matsim/contrib/av/robotaxi/run/RunDrtAndTaxiExampleTest.java b/contribs/av/src/test/java/org/matsim/contrib/av/robotaxi/run/RunDrtAndTaxiExampleTest.java index 2a85956ae3f..aa513d2a9e5 100644 --- a/contribs/av/src/test/java/org/matsim/contrib/av/robotaxi/run/RunDrtAndTaxiExampleTest.java +++ b/contribs/av/src/test/java/org/matsim/contrib/av/robotaxi/run/RunDrtAndTaxiExampleTest.java @@ -22,13 +22,13 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; public class RunDrtAndTaxiExampleTest { @Test - public void run() { + void run() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "one_taxi_and_one_shared_taxi_config.xml"); RunDrtAndTaxiExample.run(configUrl, false); diff --git a/contribs/av/src/test/java/org/matsim/contrib/av/robotaxi/run/RunRobotaxiExampleIT.java b/contribs/av/src/test/java/org/matsim/contrib/av/robotaxi/run/RunRobotaxiExampleIT.java index 9c56af75336..a256bd46e52 100644 --- a/contribs/av/src/test/java/org/matsim/contrib/av/robotaxi/run/RunRobotaxiExampleIT.java +++ b/contribs/av/src/test/java/org/matsim/contrib/av/robotaxi/run/RunRobotaxiExampleIT.java @@ -22,7 +22,7 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; @@ -31,7 +31,7 @@ */ public class RunRobotaxiExampleIT { @Test - public void testRun() { + void testRun() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_taxi_config.xml"); RunRobotaxiExample.run(configUrl, false); } diff --git a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java index 8ee7bcdc13d..9bba0878b85 100644 --- a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java +++ b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java @@ -1,8 +1,8 @@ package org.matsim.contrib.bicycle; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -59,8 +59,8 @@ private static Vehicle createVehicle(double maxVelocity, long id) { return VehicleUtils.createVehicle(Id.createVehicleId(id), type); } - @Test - public void getMaximumVelocity_bike() { + @Test + void getMaximumVelocity_bike() { Link link = createLinkWithNoGradientAndNoSpecialSurface(); QVehicle vehicle = new QVehicleImpl(createVehicle(link.getFreespeed() * 0.5, 1)); // higher speed than the default @@ -71,8 +71,8 @@ public void getMaximumVelocity_bike() { assertEquals(vehicle.getMaximumVelocity(), speed, 0.0); } - @Test - public void getMaximumVelocity_bike_fasterThanFreespeed() { + @Test + void getMaximumVelocity_bike_fasterThanFreespeed() { Link link = createLinkWithNoGradientAndNoSpecialSurface(); QVehicle vehicle = new QVehicleImpl(createVehicle(link.getFreespeed() * 2, 1)); @@ -83,8 +83,8 @@ public void getMaximumVelocity_bike_fasterThanFreespeed() { assertEquals(link.getFreespeed(), speed, 0.0); } - @Test - public void getMaximumVelocityForLink_bikeIsNull() { + @Test + void getMaximumVelocityForLink_bikeIsNull() { Link link = createLinkWithNoGradientAndNoSpecialSurface(); BicycleLinkSpeedCalculatorDefaultImpl calculator = new BicycleLinkSpeedCalculatorDefaultImpl(config); @@ -94,8 +94,8 @@ public void getMaximumVelocityForLink_bikeIsNull() { assertEquals(configGroup.getMaxBicycleSpeedForRouting(), speed, 0.001); } - @Test - public void getMaximumVelocityForLink_withGradient() { + @Test + void getMaximumVelocityForLink_withGradient() { Link linkForComparison = createLinkWithNoGradientAndNoSpecialSurface(); Link linkWithGradient = createLink(100, "paved", "not-a-cycle-way", 1.0); @@ -109,8 +109,8 @@ public void getMaximumVelocityForLink_withGradient() { assertTrue(comparisonSpeed > gradientSpeed); } - @Test - public void getMaximumVelocityForLink_withReducedSpeedFactor() { + @Test + void getMaximumVelocityForLink_withReducedSpeedFactor() { Link linkForComparison = createLinkWithNoGradientAndNoSpecialSurface(); Link linkWithReducedSpeed = createLink(0, "paved", "not-a-cycle-way", 0.5); @@ -124,8 +124,8 @@ public void getMaximumVelocityForLink_withReducedSpeedFactor() { assertTrue(comparisonSpeed > gradientSpeed); } - @Test - public void getMaximumVelocityForLink_noSpeedFactor() { + @Test + void getMaximumVelocityForLink_noSpeedFactor() { var link = createLinkWithNoGradientAndNoSpecialSurface(); var vehicle = createVehicle(link.getFreespeed() + 1, 1); @@ -136,8 +136,8 @@ public void getMaximumVelocityForLink_noSpeedFactor() { assertEquals(link.getFreespeed(), speed, 0.001); } - @Test - public void getMaximumVelocityForLink_withRoughSurface() { + @Test + void getMaximumVelocityForLink_withRoughSurface() { Link linkForComparison = createLinkWithNoGradientAndNoSpecialSurface(); Link linkWithCobbleStone = createLink(0, "cobblestone", "not-a-cycle-way", 1.0); @@ -178,8 +178,8 @@ private Link createLink(double elevation, String surfaceType, String wayType, do return link; } - @Test - public void getMaximumVelocityForLink_withCycleWay() { + @Test + void getMaximumVelocityForLink_withCycleWay() { Link linkForComparison = createLinkWithNoGradientAndNoSpecialSurface(); Link linkWithCobbleStone = createLink(0, "some-surface", BicycleUtils.CYCLEWAY, 1.0); diff --git a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleUtilityUtilsTest.java b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleUtilityUtilsTest.java index 19697a3afaf..5e8ebb2f5d9 100644 --- a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleUtilityUtilsTest.java +++ b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleUtilityUtilsTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.bicycle; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -11,31 +11,31 @@ public class BicycleUtilityUtilsTest { @Test - public void getGradientNoFromZ() { + void getGradientNoFromZ() { var link = createLink(new Coord(0, 0), new Coord(100, 0, 100)); assertEquals(0., BicycleUtils.getGradient(link ), 0.00001 ); } @Test - public void getGradientNoToZ() { + void getGradientNoToZ() { var link = createLink(new Coord(0, 0, 100), new Coord(100, 0)); assertEquals(0., BicycleUtils.getGradient(link ), 0.00001 ); } @Test - public void getGradientFlat() { + void getGradientFlat() { var link = createLink(new Coord(0, 0, 100), new Coord(100, 0, 100)); assertEquals(0., BicycleUtils.getGradient(link ), 0.00001 ); } @Test - public void getGradientUphill() { + void getGradientUphill() { var link = createLink(new Coord(0, 0, 0), new Coord(100, 0, 100)); assertEquals(1., BicycleUtils.getGradient(link ), 0.00001 ); } @Test - public void getGradientDownhill() { + void getGradientDownhill() { var link = createLink(new Coord(0, 0, 100), new Coord(100, 0, 0)); assertEquals(0., BicycleUtils.getGradient(link ), 0.00001 ); } diff --git a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java index e3a50e711df..e14c9e48b76 100644 --- a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java +++ b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -79,7 +79,7 @@ public class BicycleTest { public MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testNormal() { + void testNormal() { Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -113,7 +113,7 @@ public void testNormal() { } @Test - public void testCobblestone() { + void testCobblestone() { Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -146,7 +146,7 @@ public void testCobblestone() { } @Test - public void testPedestrian() { + void testPedestrian() { Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -175,7 +175,7 @@ public void testPedestrian() { } @Test - public void testLane() { + void testLane() { Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -204,7 +204,7 @@ public void testLane() { } @Test - public void testGradient() { + void testGradient() { Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -233,7 +233,7 @@ public void testGradient() { } @Test - public void testGradientLane() { + void testGradientLane() { Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -263,7 +263,7 @@ public void testGradientLane() { } @Test - public void testNormal10It() { + void testNormal10It() { Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); RunBicycleExample.fillConfigWithBicycleStandardValues(config); @@ -294,7 +294,8 @@ public void testNormal10It() { assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } - @Test public void testLinkBasedScoring() { + @Test + void testLinkBasedScoring() { // { // Config config = createConfig( 0 ); // BicycleConfigGroup bicycleConfigGroup = (BicycleConfigGroup) config.getModules().get( "bicycle" ); @@ -325,7 +326,9 @@ public void testNormal10It() { } // assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } - @Test public void testLinkVsLegMotorizedScoring() { + + @Test + void testLinkVsLegMotorizedScoring() { // --- withOUT additional car traffic: // { // Config config2 = createConfig( 0 ); @@ -411,6 +414,7 @@ public void testNormal10It() { } // assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } + // @Test public void testMotorizedInteraction() { //// Config config = ConfigUtils.createConfig("./src/main/resources/bicycle_example/"); // Config config = createConfig( 10 ); @@ -441,7 +445,7 @@ public void testNormal10It() { // } @Test - public void testInfrastructureSpeedFactor() { + void testInfrastructureSpeedFactor() { Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); config.addModule(new BicycleConfigGroup()); @@ -536,7 +540,7 @@ public void install() { } @Test - public void testInfrastructureSpeedFactorDistanceMoreRelevantThanTravelTime() { + void testInfrastructureSpeedFactorDistanceMoreRelevantThanTravelTime() { Config config = ConfigUtils.createConfig(utils.getClassInputDirectory() ); BicycleConfigGroup bicycleConfigGroup = ConfigUtils.addOrGetModule( config, BicycleConfigGroup.class ); diff --git a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java index 815fc250dc3..85c1d6f6e88 100644 --- a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java +++ b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java @@ -24,8 +24,8 @@ import cadyts.utilities.io.tabularFileParser.TabularFileParser; import cadyts.utilities.misc.DynamicData; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -82,7 +82,7 @@ public class CadytsCarIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testInitialization() { + final void testInitialization() { final String CADYTS_STRATEGY_NAME = "ccc"; String inputDir = this.utils.getClassInputDirectory(); @@ -154,7 +154,7 @@ public PlanStrategy get() { //-------------------------------------------------------------- @Test - public final void testCalibrationAsScoring() throws IOException { + final void testCalibrationAsScoring() throws IOException { final double beta=30. ; final int lastIteration = 20 ; diff --git a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java index 58f3b81fb2f..08ccf453ef9 100644 --- a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java +++ b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java @@ -5,7 +5,7 @@ import java.util.concurrent.atomic.AtomicInteger; import org.junit.Ignore; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.handler.LinkLeaveEventHandler; @@ -22,8 +22,9 @@ public class CadytsCarWithPtScenarioIT { - @Test @Ignore - public void testCadytsWithPtVehicles() { + @Test + @Ignore + void testCadytsWithPtVehicles() { final Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("siouxfalls-2014"), "config_default.xml")); config.controller().setOverwriteFileSetting(OutputDirectoryHierarchy.OverwriteFileSetting.overwriteExistingFiles); config.controller().setLastIteration(0); diff --git a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java index f8512146bf5..1da4d65881a 100644 --- a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java +++ b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java @@ -22,8 +22,8 @@ import java.io.IOException; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import cadyts.utilities.io.tabularFileParser.TabularFileParser; @@ -34,7 +34,7 @@ public class CalibrationStatReaderTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testReader() throws IOException { + void testReader() throws IOException { TabularFileParser tabularFileParser = new TabularFileParser(); String calibStatFile = this.utils.getInputDirectory() + "calibration-stats.txt"; CalibrationStatReader calibrationStatReader = new CalibrationStatReader(); diff --git a/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java b/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java index 6b95a948fbe..4f862921469 100644 --- a/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java +++ b/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java @@ -26,8 +26,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.analysis.LegHistogram; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -58,7 +58,7 @@ public class RunCarsharingIT { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void test() { + final void test() { Config config = ConfigUtils.loadConfig(utils.getClassInputDirectory() + "/config.xml", new FreeFloatingConfigGroup(), new OneWayCarsharingConfigGroup(), diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/ChangeCommercialJobOperatorTest.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/ChangeCommercialJobOperatorTest.java index 18de26d446d..6fb30f6b0b7 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/ChangeCommercialJobOperatorTest.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/ChangeCommercialJobOperatorTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.commercialTrafficApplications.jointDemand; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -17,8 +17,8 @@ public class ChangeCommercialJobOperatorTest { - @Test - public void getPlanAlgoInstance() { + @Test + void getPlanAlgoInstance() { Carriers carriers = TestScenarioGeneration.generateCarriers(); diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/CommercialTrafficIntegrationTest.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/CommercialTrafficIntegrationTest.java index 27b59b0d621..c0132d8903c 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/CommercialTrafficIntegrationTest.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/CommercialTrafficIntegrationTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.commercialTrafficApplications.jointDemand; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.freight.carriers.FreightCarriersConfigGroup; import org.matsim.freight.carriers.CarriersUtils; @@ -12,8 +12,8 @@ public class CommercialTrafficIntegrationTest { - @Test - public void runCommercialTrafficIT() { + @Test + void runCommercialTrafficIT() { Config config = ConfigUtils.loadConfig("./scenarios/grid/jointDemand_config.xml"); config.controller().setLastIteration(5); ConfigUtils.addOrGetModule(config, JointDemandConfigGroup.class); diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/DefaultCommercialServiceScoreTest.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/DefaultCommercialServiceScoreTest.java index b96b3e5ca86..051e97829e9 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/DefaultCommercialServiceScoreTest.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/DefaultCommercialServiceScoreTest.java @@ -1,13 +1,13 @@ package org.matsim.contrib.commercialTrafficApplications.jointDemand; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.commercialTrafficApplications.jointDemand.DefaultCommercialServiceScore; public class DefaultCommercialServiceScoreTest { - @Test - public void calcScore() { + @Test + void calcScore() { DefaultCommercialServiceScore serviceScore = new DefaultCommercialServiceScore(6, -6, 1800); Assert.assertEquals(serviceScore.calcScore(0), 6., 0.001); diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java index b9f40a81c5d..f71e9a3a3ed 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java @@ -20,7 +20,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Activity; @@ -98,8 +98,8 @@ private void preparePopulation(Scenario scenario) { } - @Test - public void testIfTheRightPersonIsScoredForReceivingAJob() { + @Test + void testIfTheRightPersonIsScoredForReceivingAJob() { Plan partyPizzaPlan = scenario.getPopulation().getPersons().get(Id.createPersonId("customerOrderingForParty")).getSelectedPlan(); Plan lonelyPizzaPlan = scenario.getPopulation().getPersons().get(Id.createPersonId("customerOrderingJustForItself")).getSelectedPlan(); Plan nonCustomerPlan = scenario.getPopulation().getPersons().get(Id.createPersonId("nonCustomer")).getSelectedPlan(); diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/RunJointDemandCarExampleSkipIntervalIT.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/RunJointDemandCarExampleSkipIntervalIT.java index 5ec00c316dc..884319ca6ef 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/RunJointDemandCarExampleSkipIntervalIT.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/RunJointDemandCarExampleSkipIntervalIT.java @@ -1,13 +1,13 @@ package org.matsim.contrib.commercialTrafficApplications.jointDemand; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.io.IOException; public class RunJointDemandCarExampleSkipIntervalIT { @Test - public void main() throws IOException { + void main() throws IOException { RunJointDemandCarToggleJspritExample.main(new String[0]); } } \ No newline at end of file diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/examples/RunJointDemandCarExampleIT.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/examples/RunJointDemandCarExampleIT.java index 5d07acb7686..663f68d69e2 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/examples/RunJointDemandCarExampleIT.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/examples/RunJointDemandCarExampleIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.commercialTrafficApplications.jointDemand.examples; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.commercialTrafficApplications.jointDemand.examples.RunJointDemandCarExample; import java.io.IOException; @@ -8,7 +8,7 @@ public class RunJointDemandCarExampleIT { @Test - public void main() throws IOException { + void main() throws IOException { RunJointDemandCarExample.main(new String[0]); } } \ No newline at end of file diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/examples/RunJointDemandDRTExampleIT.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/examples/RunJointDemandDRTExampleIT.java index 30fbe9ef2c0..e62b15cc0ba 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/examples/RunJointDemandDRTExampleIT.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/examples/RunJointDemandDRTExampleIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.commercialTrafficApplications.jointDemand.examples; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.commercialTrafficApplications.jointDemand.examples.RunJointDemandDRTExample; import java.io.IOException; @@ -8,7 +8,7 @@ public class RunJointDemandDRTExampleIT { @Test - public void main() throws IOException { + void main() throws IOException { RunJointDemandDRTExample.main(new String[0]); } } \ No newline at end of file diff --git a/contribs/common/src/test/java/org/matsim/contrib/common/collections/PartialSortTest.java b/contribs/common/src/test/java/org/matsim/contrib/common/collections/PartialSortTest.java index 84371963d61..2609969dd8c 100644 --- a/contribs/common/src/test/java/org/matsim/contrib/common/collections/PartialSortTest.java +++ b/contribs/common/src/test/java/org/matsim/contrib/common/collections/PartialSortTest.java @@ -24,9 +24,9 @@ import static org.matsim.contrib.common.collections.PartialSort.kSmallestElements; import java.util.Comparator; -import java.util.stream.Stream; -import org.junit.Test; +import org.junit.jupiter.api.Test; +import java.util.stream.Stream; /** * @author Michal Maciejewski (michalm) @@ -35,36 +35,36 @@ public class PartialSortTest { private final Comparator comparator = Integer::compareTo; @Test - public void k0_noneSelected() { + void k0_noneSelected() { assertThat(kSmallestElements(0, Stream.of(), comparator)).isEmpty(); assertThat(kSmallestElements(0, Stream.of(7, 1, 4, 9, 8), comparator)).isEmpty(); } @Test - public void reversedComparator_largestElementsSelected() { + void reversedComparator_largestElementsSelected() { assertThat(kSmallestElements(1, Stream.of(7, 1, 4, 9, 8), comparator.reversed())).containsExactly(9); assertThat(kSmallestElements(3, Stream.of(7, 1, 4, 9, 8), comparator.reversed())).containsExactly(9, 8, 7); } @Test - public void allElementsPairwiseNonEqual_inputOrderNotImportant() { + void allElementsPairwiseNonEqual_inputOrderNotImportant() { assertThat(kSmallestElements(3, Stream.of(1, 7, 9, 8), comparator)).containsExactly(1, 7, 8); assertThat(kSmallestElements(3, Stream.of(9, 8, 7, 1), comparator)).containsExactly(1, 7, 8); } @Test - public void exactlyKElementsProvided() { + void exactlyKElementsProvided() { assertThat(kSmallestElements(3, Stream.of(7, 1, 4), comparator)).containsExactly(1, 4, 7); } @Test - public void moreThenKElementsProvided() { + void moreThenKElementsProvided() { assertThat(kSmallestElements(3, Stream.of(7, 1, 4, 9, 8), comparator)).containsExactly(1, 4, 7); assertThat(kSmallestElements(3, Stream.of(13, 7, 1, 55, 4, 9, 8, 11), comparator)).containsExactly(1, 4, 7); } @Test - public void lessThenKElementsProvided() { + void lessThenKElementsProvided() { assertThat(kSmallestElements(3, Stream.of(7, 1), comparator)).containsExactly(1, 7); assertThat(kSmallestElements(3, Stream.of(13), comparator)).containsExactly(13); assertThat(kSmallestElements(3, Stream.of(), comparator)).isEmpty(); diff --git a/contribs/common/src/test/java/org/matsim/contrib/common/diversitygeneration/planselectors/DiversityGeneratingPlansRemoverTest.java b/contribs/common/src/test/java/org/matsim/contrib/common/diversitygeneration/planselectors/DiversityGeneratingPlansRemoverTest.java index a0025ce5638..a2b73e1657d 100644 --- a/contribs/common/src/test/java/org/matsim/contrib/common/diversitygeneration/planselectors/DiversityGeneratingPlansRemoverTest.java +++ b/contribs/common/src/test/java/org/matsim/contrib/common/diversitygeneration/planselectors/DiversityGeneratingPlansRemoverTest.java @@ -5,7 +5,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -45,9 +45,9 @@ public class DiversityGeneratingPlansRemoverTest { private final Id link0_1 = Id.createLinkId( "dummy0-1" ); private final Id link1_2 = Id.createLinkId( "dummy1-2" ); private final Id link2_3 = Id.createLinkId( "dummyN" ); - + @Test - public void calcWeights() { + void calcWeights() { // yy This is not really a strong test. Rather something I wrote for debugging. Would be a good // starting point for a fuller test. kai, jul'18 @@ -221,8 +221,8 @@ private Plan createHwhPlan( final PopulationFactory pf ) { plan.setScore(90.) ; return plan; } - + @Test - public void selectPlan() { + void selectPlan() { } } diff --git a/contribs/common/src/test/java/org/matsim/contrib/common/util/WeightedRandomSelectionTest.java b/contribs/common/src/test/java/org/matsim/contrib/common/util/WeightedRandomSelectionTest.java index f96b4468202..fb30100ab83 100644 --- a/contribs/common/src/test/java/org/matsim/contrib/common/util/WeightedRandomSelectionTest.java +++ b/contribs/common/src/test/java/org/matsim/contrib/common/util/WeightedRandomSelectionTest.java @@ -27,7 +27,7 @@ import org.apache.commons.lang3.mutable.MutableDouble; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author michalm @@ -48,7 +48,7 @@ public double nextDouble(double from, double to) { } @Test - public void testIncorrectInput() { + void testIncorrectInput() { assertIncorrectWeight(-Double.MIN_VALUE); assertIncorrectWeight(-1); assertIncorrectWeight(-Double.MAX_VALUE); @@ -71,7 +71,7 @@ private void assertIncorrectWeight(double weight) { } @Test - public void testEmptyList() { + void testEmptyList() { assertThat(weightedRandomSelection.size()).isEqualTo(0); assertThatThrownBy(() -> weightedRandomSelection.select())// .isExactlyInstanceOf(IllegalStateException.class)// @@ -79,7 +79,7 @@ public void testEmptyList() { } @Test - public void testZeroTotalWeight() { + void testZeroTotalWeight() { weightedRandomSelection.add("A", 0.); weightedRandomSelection.add("B", 0.); assertThatThrownBy(() -> weightedRandomSelection.select())// @@ -88,7 +88,7 @@ public void testZeroTotalWeight() { } @Test - public void testSingleValueList() { + void testSingleValueList() { weightedRandomSelection.add("A", 1); assertThat(weightedRandomSelection.size()).isEqualTo(1); @@ -100,7 +100,7 @@ public void testSingleValueList() { } @Test - public void testThreeValuesList() { + void testThreeValuesList() { weightedRandomSelection.add("A", 1); weightedRandomSelection.add("B", 0.5); weightedRandomSelection.add("C", 1.5); diff --git a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java index 4e6afb73afd..09772d843d3 100644 --- a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java +++ b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java @@ -32,8 +32,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -94,7 +94,7 @@ public class BetaTravelTest66IT { private MatsimTestUtils utils = new MatsimTestUtils(); - /* This TestCase uses a custom Controler, named TestControler, to load + /*This TestCase uses a custom Controler, named TestControler, to load * specific strategies. The strategies make use of a test-specific * TimeAllocationMutator, the TimeAllocationMutatorBottleneck. * LinkAnalyzer, an event handler, collects some statistics on the @@ -130,7 +130,8 @@ public class BetaTravelTest66IT { * * @author mrieser */ - @Test public void testBetaTravel_66() { + @Test + void testBetaTravel_66() { Config config = utils.loadConfig("../../examples/scenarios/equil/config.xml"); ConfigUtils.loadConfig(config, utils.getInputDirectory() + "config.xml"); config.controller().setWritePlansInterval(0); diff --git a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java index de0ecae4685..da2037aa8cd 100644 --- a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java +++ b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java @@ -32,8 +32,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -95,7 +95,7 @@ public class BetaTravelTest6IT { private MatsimTestUtils utils = new MatsimTestUtils(); - /* This TestCase uses a custom Controler, named TestControler, to load + /*This TestCase uses a custom Controler, named TestControler, to load * specific strategies. The strategies make use of a test-specific * TimeAllocationMutator, the TimeAllocationMutatorBottleneck. * LinkAnalyzer, an event handler, collects some statistics on the @@ -130,7 +130,8 @@ public class BetaTravelTest6IT { * * @author mrieser */ - @Test public void testBetaTravel_6() { + @Test + void testBetaTravel_6() { Config config = utils.loadConfig("../../examples/scenarios/equil/config.xml"); // default config ConfigUtils.loadConfig(config, utils.getInputDirectory() + "config.xml"); // specific setting for this test config.controller().setWritePlansInterval(0); diff --git a/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java b/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java index a59cc8f2027..7ff2403f49b 100644 --- a/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java +++ b/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java @@ -23,8 +23,8 @@ package org.matsim.contrib.decongestion; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.analysis.ScoreStatsControlerListener.ScoreItem; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -62,7 +62,7 @@ public class DecongestionPricingTestIT { * */ @Test - public final void test0a() { + final void test0a() { System.out.println(testUtils.getPackageInputDirectory()); @@ -151,7 +151,7 @@ public void install() { * */ @Test - public final void test0amodified() { + final void test0amodified() { System.out.println(testUtils.getPackageInputDirectory()); @@ -211,7 +211,7 @@ public void install() { * */ @Test - public final void test0b() { + final void test0b() { System.out.println(testUtils.getPackageInputDirectory()); @@ -299,7 +299,7 @@ public void install() { * */ @Test - public final void test0bmodified() { + final void test0bmodified() { System.out.println(testUtils.getPackageInputDirectory()); @@ -359,7 +359,7 @@ public void install() { * */ @Test - public final void test0c() { + final void test0c() { System.out.println(testUtils.getPackageInputDirectory()); @@ -440,7 +440,7 @@ public void install() { * */ @Test - public final void test1() { + final void test1() { System.out.println(testUtils.getPackageInputDirectory()); @@ -501,7 +501,7 @@ public void install() { * */ @Test - public final void test2() { + final void test2() { System.out.println(testUtils.getPackageInputDirectory()); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/SubtourModeChoiceReplacementTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/SubtourModeChoiceReplacementTest.java index 2abbf28777c..b9cab362620 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/SubtourModeChoiceReplacementTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/SubtourModeChoiceReplacementTest.java @@ -9,7 +9,7 @@ import java.util.Random; import java.util.Set; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Plan; import org.matsim.contrib.discrete_mode_choice.test_utils.PlanBuilder; import org.matsim.contrib.discrete_mode_choice.test_utils.PlanTester; @@ -51,7 +51,7 @@ public class SubtourModeChoiceReplacementTest { @Test - public void testChoiceSet() throws NoFeasibleChoiceException { + void testChoiceSet() throws NoFeasibleChoiceException { List modes = Arrays.asList("walk", "pt"); List constrainedModes = Arrays.asList(); boolean considerCarAvailability = true; @@ -140,7 +140,7 @@ public void testChoiceSet() throws NoFeasibleChoiceException { } @Test - public void testConstrainedChoiceSet() throws NoFeasibleChoiceException { + void testConstrainedChoiceSet() throws NoFeasibleChoiceException { List modes = Arrays.asList("walk", "car"); List constrainedModes = Arrays.asList("car"); boolean considerCarAvailability = true; @@ -229,7 +229,7 @@ public void testConstrainedChoiceSet() throws NoFeasibleChoiceException { } @Test - public void testLargerCase() throws NoFeasibleChoiceException { + void testLargerCase() throws NoFeasibleChoiceException { List modes = Arrays.asList("walk", "car", "pt", "bike"); List constrainedModes = Arrays.asList("car", "bike"); boolean considerCarAvailability = true; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/constraints/VehicleTourConstraintTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/constraints/VehicleTourConstraintTest.java index 24bc7e6ceb5..a95458ffdf4 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/constraints/VehicleTourConstraintTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/constraints/VehicleTourConstraintTest.java @@ -7,7 +7,7 @@ import java.util.Collection; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.contrib.discrete_mode_choice.test_utils.PlanBuilder; @@ -20,7 +20,7 @@ public class VehicleTourConstraintTest { @Test - public void testWithHome() { + void testWithHome() { // PREPARATION HomeFinder homeFinder = (List trips) -> Id.create("A", ActivityFacility.class); Collection availableModes = Arrays.asList("car", "walk"); @@ -69,7 +69,7 @@ public void testWithHome() { } @Test - public void testWithoutHome() { + void testWithoutHome() { // PREPARATION HomeFinder homeFinder = (List trips) -> null; Collection availableModes = Arrays.asList("car", "walk"); @@ -107,7 +107,7 @@ public void testWithoutHome() { } @Test - public void testTour() { + void testTour() { // PREPARATION HomeFinder homeFinder = (List trips) -> Id.create("A", ActivityFacility.class); Collection availableModes = Arrays.asList("car", "walk"); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/readers/ApolloTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/readers/ApolloTest.java index b58abaf6f80..3e396542e5f 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/readers/ApolloTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/readers/ApolloTest.java @@ -5,13 +5,13 @@ import java.io.IOException; import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contribs.discrete_mode_choice.components.readers.ApolloParameterReader; import org.matsim.contribs.discrete_mode_choice.components.readers.ApolloParameters; public class ApolloTest { @Test - public void testApolloReader() throws IOException { + void testApolloReader() throws IOException { URL fixtureUrl = getClass().getClassLoader().getResource("Model_13_12_Zurich_output.txt"); ApolloParameters parameters = new ApolloParameterReader().read(fixtureUrl); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/tour_finder/ActivityTourFinderTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/tour_finder/ActivityTourFinderTest.java index af9610761ca..8fd14c7f09a 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/tour_finder/ActivityTourFinderTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/tour_finder/ActivityTourFinderTest.java @@ -6,7 +6,7 @@ import java.util.LinkedList; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Plan; import org.matsim.contribs.discrete_mode_choice.components.tour_finder.ActivityTourFinder; import org.matsim.contribs.discrete_mode_choice.model.DiscreteModeChoiceTrip; @@ -42,7 +42,7 @@ private List createFixture(String... activityTypes) { } @Test - public void testActivityTourFinder() { + void testActivityTourFinder() { ActivityTourFinder finder = new ActivityTourFinder(Arrays.asList("home")); List trips; @@ -84,7 +84,7 @@ public void testActivityTourFinder() { } @Test - public void testActivityTourFinderMultiple() { + void testActivityTourFinderMultiple() { ActivityTourFinder finder = new ActivityTourFinder(Arrays.asList("home1", "home2", "home3", "home4")); List trips; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/utils/ScheduleWaitingTimeEstimatorTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/utils/ScheduleWaitingTimeEstimatorTest.java index 4d19508ad24..2e69210fff1 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/utils/ScheduleWaitingTimeEstimatorTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/utils/ScheduleWaitingTimeEstimatorTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.discrete_mode_choice.components.utils; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; @@ -29,7 +29,7 @@ public class ScheduleWaitingTimeEstimatorTest { @Test - public void testValidSingleCase() throws IOException { + void testValidSingleCase() throws IOException { TransitSchedule schedule = createSchedule(); ScheduleWaitingTimeEstimator estimator = new ScheduleWaitingTimeEstimator(schedule); @@ -53,9 +53,9 @@ public void testValidSingleCase() throws IOException { waitingTime = estimator.estimateWaitingTime(elements); assertEquals(995.0, waitingTime, 1e-6); } - + @Test - public void testValidMultiCase() throws IOException { + void testValidMultiCase() throws IOException { TransitSchedule schedule = createSchedule(); ScheduleWaitingTimeEstimator estimator = new ScheduleWaitingTimeEstimator(schedule); @@ -72,10 +72,10 @@ public void testValidMultiCase() throws IOException { waitingTime = estimator.estimateWaitingTime(elements); assertEquals(20.0 + 995.0, waitingTime, 1e-6); } - + @Test - public void testInvalidCase() throws IOException { + void testInvalidCase() throws IOException { TransitSchedule schedule = createSchedule(); ScheduleWaitingTimeEstimator estimator = new ScheduleWaitingTimeEstimator(schedule); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/examples/TestSiouxFalls.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/examples/TestSiouxFalls.java index 1780065a3fe..5a1edb6623e 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/examples/TestSiouxFalls.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/examples/TestSiouxFalls.java @@ -6,7 +6,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.PersonArrivalEvent; import org.matsim.api.core.v01.events.handler.PersonArrivalEventHandler; @@ -24,7 +24,7 @@ public class TestSiouxFalls { @Test - public void testSiouxFallsWithSubtourModeChoiceReplacement() { + void testSiouxFallsWithSubtourModeChoiceReplacement() { URL scenarioURL = ExamplesUtils.getTestScenarioURL("siouxfalls-2014"); Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(scenarioURL, "config_default.xml")); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MaximumUtilityTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MaximumUtilityTest.java index 347139ac155..31bff842634 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MaximumUtilityTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MaximumUtilityTest.java @@ -7,7 +7,7 @@ import java.util.List; import java.util.Random; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.population.Activity; import org.matsim.contribs.discrete_mode_choice.model.DiscreteModeChoiceModel.FallbackBehaviour; @@ -31,7 +31,7 @@ public class MaximumUtilityTest { @Test - public void testMaximumUtility() throws NoFeasibleChoiceException { + void testMaximumUtility() throws NoFeasibleChoiceException { TripFilter tripFilter = new CompositeTripFilter(Collections.emptySet()); ModeAvailability modeAvailability = new DefaultModeAvailability(Arrays.asList("car", "pt", "walk")); TripConstraintFactory constraintFactory = new CompositeTripConstraintFactory(); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MultinomialLogitTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MultinomialLogitTest.java index 71bcf10e76b..dbe32f1e8a3 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MultinomialLogitTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MultinomialLogitTest.java @@ -9,7 +9,7 @@ import java.util.Map; import java.util.Random; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.population.Activity; import org.matsim.contribs.discrete_mode_choice.model.DiscreteModeChoiceModel.FallbackBehaviour; @@ -33,7 +33,7 @@ public class MultinomialLogitTest { @Test - public void testMultinomialLogit() throws NoFeasibleChoiceException { + void testMultinomialLogit() throws NoFeasibleChoiceException { TripFilter tripFilter = new CompositeTripFilter(Collections.emptySet()); ModeAvailability modeAvailability = new DefaultModeAvailability(Arrays.asList("car", "pt", "walk")); TripConstraintFactory constraintFactory = new CompositeTripConstraintFactory(); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/NestedLogitTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/NestedLogitTest.java index 84489c34c7c..38e7b54df7d 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/NestedLogitTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/NestedLogitTest.java @@ -9,7 +9,7 @@ import java.util.Map; import java.util.Random; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.population.Activity; import org.matsim.contribs.discrete_mode_choice.model.DiscreteModeChoiceModel.FallbackBehaviour; @@ -35,7 +35,7 @@ public class NestedLogitTest { @Test - public void testRedBusBlueBus() throws NoFeasibleChoiceException { + void testRedBusBlueBus() throws NoFeasibleChoiceException { TripFilter tripFilter = new CompositeTripFilter(Collections.emptySet()); ModeAvailability modeAvailability = new DefaultModeAvailability(Arrays.asList("car", "redbus", "bluebus")); TripConstraintFactory constraintFactory = new CompositeTripConstraintFactory(); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/RandomUtilityTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/RandomUtilityTest.java index e0f3e7dd619..e69eae5ee23 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/RandomUtilityTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/RandomUtilityTest.java @@ -9,7 +9,7 @@ import java.util.Map; import java.util.Random; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.population.Activity; import org.matsim.contribs.discrete_mode_choice.components.estimators.UniformTripEstimator; @@ -35,7 +35,7 @@ public class RandomUtilityTest { @Test - public void testRandomUtility() throws NoFeasibleChoiceException { + void testRandomUtility() throws NoFeasibleChoiceException { TripFilter tripFilter = new CompositeTripFilter(Collections.emptySet()); ModeAvailability modeAvailability = new DefaultModeAvailability(Arrays.asList("car", "pt", "walk")); TripConstraintFactory constraintFactory = new CompositeTripConstraintFactory(); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/nested/NestCalculatorTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/nested/NestCalculatorTest.java index 499a955392a..5c344aabd51 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/nested/NestCalculatorTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/nested/NestCalculatorTest.java @@ -2,7 +2,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contribs.discrete_mode_choice.model.DiscreteModeChoiceModel.NoFeasibleChoiceException; import org.matsim.contribs.discrete_mode_choice.model.nested.DefaultNest; import org.matsim.contribs.discrete_mode_choice.model.nested.DefaultNestStructure; @@ -12,7 +12,7 @@ public class NestCalculatorTest { @Test - public void testNoNesting() throws NoFeasibleChoiceException { + void testNoNesting() throws NoFeasibleChoiceException { DefaultNestStructure structure = new DefaultNestStructure(); NestCalculator calculator = new NestCalculator(structure); @@ -28,7 +28,7 @@ public void testNoNesting() throws NoFeasibleChoiceException { } @Test - public void testNoNestingRedBlue() throws NoFeasibleChoiceException { + void testNoNestingRedBlue() throws NoFeasibleChoiceException { DefaultNestStructure structure = new DefaultNestStructure(); NestCalculator calculator = new NestCalculator(structure); @@ -49,7 +49,7 @@ public void testNoNestingRedBlue() throws NoFeasibleChoiceException { } @Test - public void testNestedBalancedRedBlue() throws NoFeasibleChoiceException { + void testNestedBalancedRedBlue() throws NoFeasibleChoiceException { DefaultNestStructure structure = new DefaultNestStructure(); DefaultNest busNest = new DefaultNest("bus", 1.0); structure.addNest(structure.getRoot(), busNest); @@ -96,7 +96,7 @@ public void testNestedBalancedRedBlue() throws NoFeasibleChoiceException { } @Test - public void testNestedUnbalancedRedBlue() throws NoFeasibleChoiceException { + void testNestedUnbalancedRedBlue() throws NoFeasibleChoiceException { DefaultNestStructure structure = new DefaultNestStructure(); DefaultNest busNest = new DefaultNest("bus", 1.0); structure.addNest(structure.getRoot(), busNest); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java index 32697f90a8d..4090739bcd5 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java @@ -11,8 +11,8 @@ import java.util.Arrays; import java.util.HashSet; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contribs.discrete_mode_choice.modules.config.DiscreteModeChoiceConfigGroup; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigReader; @@ -25,7 +25,7 @@ public class ConfigTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testReadWriteConfig() { + void testReadWriteConfig() { // Create config DiscreteModeChoiceConfigGroup dmcConfig = new DiscreteModeChoiceConfigGroup(); Config config = ConfigUtils.createConfig(dmcConfig); @@ -46,7 +46,7 @@ public void testReadWriteConfig() { } @Test - public void testReadWriteConfigMultipleTimes() throws IOException { + void testReadWriteConfigMultipleTimes() throws IOException { DiscreteModeChoiceConfigGroup dmcConfig = new DiscreteModeChoiceConfigGroup(); Config config1 = ConfigUtils.createConfig(dmcConfig); @@ -85,7 +85,7 @@ public void testReadWriteConfigMultipleTimes() throws IOException { } @Test - public void testSetTripConstraints() { + void testSetTripConstraints() { DiscreteModeChoiceConfigGroup dmcConfig1 = new DiscreteModeChoiceConfigGroup(); dmcConfig1.setTripConstraints(Arrays.asList("A", "B", "C")); diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/replanning/TestDepartureTimes.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/replanning/TestDepartureTimes.java index cfdef620689..c3e744e0880 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/replanning/TestDepartureTimes.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/replanning/TestDepartureTimes.java @@ -8,7 +8,7 @@ import java.util.List; import java.util.Random; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Leg; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -49,7 +49,7 @@ public class TestDepartureTimes { @Test - public void testTripBasedModelDepartureTimes() throws NoFeasibleChoiceException { + void testTripBasedModelDepartureTimes() throws NoFeasibleChoiceException { TripBasedModel model = createTripBasedModel(); // Case 1: Only activity end times, and trips fall well between the end times @@ -130,7 +130,7 @@ public void testTripBasedModelDepartureTimes() throws NoFeasibleChoiceException } @Test - public void testPushDepartureTimeToNextTour() throws NoFeasibleChoiceException { + void testPushDepartureTimeToNextTour() throws NoFeasibleChoiceException { TourBasedModel model = createTourBasedModel(); Plan plan = new PlanBuilder() // @@ -150,7 +150,7 @@ public void testPushDepartureTimeToNextTour() throws NoFeasibleChoiceException { } @Test - public void testAccumulateAndPushDepartureTimeToNextTour() throws NoFeasibleChoiceException { + void testAccumulateAndPushDepartureTimeToNextTour() throws NoFeasibleChoiceException { TourBasedModel model = createTourBasedModel(); Plan plan = new PlanBuilder() // diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java index 8790d1a5341..8ca27490ae3 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java @@ -25,8 +25,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.matsim.contrib.drt.extension.DrtWithExtensionsConfigGroup; @@ -77,8 +77,8 @@ private static Path writeConfig(final File tempFolder, List weights) thr return configFile; } - @Test - public void loadConfigGroupTest() throws IOException { + @Test + void loadConfigGroupTest() throws IOException { /* Test that exported values are correct imported again */ Path configFile = writeConfig(tempFolder, List.of(WEIGHT_1,WEIGHT_2,WEIGHT_3)); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/companions/RunDrtWithCompanionExampleIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/companions/RunDrtWithCompanionExampleIT.java index 749cc23e8ea..3529d2fcd04 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/companions/RunDrtWithCompanionExampleIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/companions/RunDrtWithCompanionExampleIT.java @@ -28,8 +28,8 @@ import java.util.stream.Collectors; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.drt.extension.DrtWithExtensionsConfigGroup; import org.matsim.contrib.drt.run.MultiModeDrtConfigGroup; @@ -52,7 +52,7 @@ public class RunDrtWithCompanionExampleIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testRunDrtWithCompanions() { + void testRunDrtWithCompanions() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_drt_config.xml"); Config config = ConfigUtils.loadConfig(configUrl, new OTFVisConfigGroup(), new MultiModeDrtConfigGroup(DrtWithExtensionsConfigGroup::new), new DvrpConfigGroup()); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/dashboards/DashboardTests.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/dashboards/DashboardTests.java index f078e00e07b..78e7ccbeb5e 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/dashboards/DashboardTests.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/dashboards/DashboardTests.java @@ -1,8 +1,8 @@ package org.matsim.contrib.drt.extension.dashboards; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.application.MATSimApplication; import org.matsim.contrib.drt.extension.DrtTestScenario; import org.matsim.contrib.drt.run.DrtConfigGroup; @@ -45,7 +45,7 @@ private void run() { } @Test - public void drtDefaults() { + void drtDefaults() { run(); // TODO: add test headers!? diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/edrt/run/RunEDrtScenarioIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/edrt/run/RunEDrtScenarioIT.java index 3a3471007fd..370304d1bdb 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/edrt/run/RunEDrtScenarioIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/edrt/run/RunEDrtScenarioIT.java @@ -22,7 +22,7 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.drt.prebooking.PrebookingParams; import org.matsim.contrib.drt.prebooking.logic.ProbabilityBasedPrebookingLogic; import org.matsim.contrib.drt.run.DrtConfigGroup; @@ -46,13 +46,13 @@ */ public class RunEDrtScenarioIT { @Test - public void test() { + void test() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_edrt_config.xml"); RunEDrtScenario.run(configUrl, false); } - + @Test - public void testWithPrebooking() { + void testWithPrebooking() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_edrt_config.xml"); Config config = ConfigUtils.loadConfig(configUrl, new MultiModeDrtConfigGroup(), new DvrpConfigGroup(), diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java index 1a149837266..cb93757590c 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java @@ -1,8 +1,8 @@ package org.matsim.contrib.drt.extension.estimator; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.application.MATSimApplication; import org.matsim.contrib.drt.extension.DrtTestScenario; import org.matsim.contrib.drt.extension.estimator.impl.ConstantDrtEstimator; @@ -78,7 +78,7 @@ public void setUp() throws Exception { } @Test - public void run() { + void run() { String out = utils.getOutputDirectory(); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java index c35ac36af49..4f57b22744e 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java @@ -1,8 +1,8 @@ package org.matsim.contrib.drt.extension.estimator; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.application.MATSimApplication; import org.matsim.contrib.drt.extension.DrtTestScenario; import org.matsim.contrib.drt.extension.estimator.run.DrtEstimatorConfigGroup; @@ -75,7 +75,7 @@ private static void prepare(Config config) { } @Test - public void run() { + void run() { String out = utils.getOutputDirectory(); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/fiss/RunFissDrtScenarioIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/fiss/RunFissDrtScenarioIT.java index c5ea83cbce9..52da0c3199a 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/fiss/RunFissDrtScenarioIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/fiss/RunFissDrtScenarioIT.java @@ -1,7 +1,7 @@ package org.matsim.contrib.drt.extension.fiss; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.LinkLeaveEvent; import org.matsim.api.core.v01.events.handler.LinkLeaveEventHandler; @@ -37,7 +37,7 @@ public class RunFissDrtScenarioIT { @Test - public void test() { + void test() { MultiModeDrtConfigGroup multiModeDrtConfigGroup = new MultiModeDrtConfigGroup(DrtWithOperationsConfigGroup::new); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java index 7f7f76fe71c..91d5699623d 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java @@ -9,8 +9,8 @@ import java.util.List; import java.util.Set; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; import org.matsim.api.core.v01.IdSet; @@ -68,7 +68,7 @@ private Controler createController() { } @Test - public void testExclusivityContraint() { + void testExclusivityContraint() { IdSet exclusiveRequestIds = new IdSet<>(Request.class); for (int i = 100; i <= 200; i++) { @@ -173,7 +173,7 @@ public void install() { } @Test - public void testSkillsConstraint() { + void testSkillsConstraint() { IdSet restrictedRequestIds = new IdSet<>(Request.class); for (int i = 100; i <= 200; i++) { restrictedRequestIds.add(Id.create("drt_" + i, Request.class)); @@ -239,7 +239,7 @@ public void install() { } @Test - public void testRangeConstraint() { + void testRangeConstraint() { Controler controller = createController(); DrtConfigGroup drtConfig = DrtConfigGroup.getSingleModeDrtConfig(controller.getConfig()); @@ -259,7 +259,7 @@ public void testRangeConstraint() { } @Test - public void testRangeConstraintWithCustomInstances() { + void testRangeConstraintWithCustomInstances() { Controler controller = createController(); DrtConfigGroup drtConfig = DrtConfigGroup.getSingleModeDrtConfig(controller.getConfig()); @@ -287,7 +287,7 @@ public void testRangeConstraintWithCustomInstances() { } @Test - public void testRangeConstraintWithCustomInjection() { + void testRangeConstraintWithCustomInjection() { Controler controller = createController(); DrtConfigGroup drtConfig = DrtConfigGroup.getSingleModeDrtConfig(controller.getConfig()); @@ -365,7 +365,7 @@ public void install() { } @Test - public void testCustomConstraint() { + void testCustomConstraint() { Controler controller = createController(); DrtConfigGroup drtConfig = DrtConfigGroup.getSingleModeDrtConfig(controller.getConfig()); @@ -409,7 +409,7 @@ public void install() { } @Test - public void testDefaults() { + void testDefaults() { Controler controller = createController(); DrtConfigGroup drtConfig = DrtConfigGroup.getSingleModeDrtConfig(controller.getConfig()); @@ -428,7 +428,7 @@ public void testDefaults() { } @Test - public void testVehicleActiveTimeObjective() { + void testVehicleActiveTimeObjective() { Controler controller = createController(); DrtConfigGroup drtConfig = DrtConfigGroup.getSingleModeDrtConfig(controller.getConfig()); @@ -449,7 +449,7 @@ public void testVehicleActiveTimeObjective() { } @Test - public void testVehicleDistanceObjective() { + void testVehicleDistanceObjective() { Controler controller = createController(); DrtConfigGroup drtConfig = DrtConfigGroup.getSingleModeDrtConfig(controller.getConfig()); @@ -470,7 +470,7 @@ public void testVehicleDistanceObjective() { } @Test - public void testPassengerPassengerDelayObjective() { + void testPassengerPassengerDelayObjective() { Controler controller = createController(); DrtConfigGroup drtConfig = DrtConfigGroup.getSingleModeDrtConfig(controller.getConfig()); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/eshifts/run/RunEShiftDrtScenarioIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/eshifts/run/RunEShiftDrtScenarioIT.java index 4abe57ba415..05e08557722 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/eshifts/run/RunEShiftDrtScenarioIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/eshifts/run/RunEShiftDrtScenarioIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.drt.extension.operations.eshifts.run; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.contrib.drt.analysis.zonal.DrtZonalSystemParams; import org.matsim.contrib.drt.extension.operations.DrtOperationsParams; @@ -38,7 +38,7 @@ public class RunEShiftDrtScenarioIT { private static final double TEMPERATURE = 20;// oC @Test - public void test() { + void test() { MultiModeDrtConfigGroup multiModeDrtConfigGroup = new MultiModeDrtConfigGroup(DrtWithOperationsConfigGroup::new); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java index 3afc583589b..427416b3b4b 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java @@ -1,8 +1,8 @@ package org.matsim.contrib.drt.extension.operations.operationFacilities; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -16,8 +16,8 @@ public class OperationFacilitiesIOTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void test() { + @Test + void test() { OperationFacilitiesSpecification operationFacilities = new OperationFacilitiesSpecificationImpl(); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java index d7ff41c3846..d2f4c3e27f2 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java @@ -5,8 +5,8 @@ import java.io.File; import java.util.Optional; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.drt.extension.operations.operationFacilities.OperationFacility; import org.matsim.contrib.drt.extension.operations.shifts.io.DrtShiftsReader; @@ -36,7 +36,8 @@ public class ShiftsIOTest { private final Id oid2 = Id.create("op2", OperationFacility.class); - @Test public void testBasicReaderWriter() { + @Test + void testBasicReaderWriter() { DrtShiftsSpecification shiftsSpecification = new DrtShiftsSpecificationImpl(); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyTest.java index e40e1331388..d3b4dfb001c 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyTest.java @@ -10,7 +10,7 @@ package org.matsim.contrib.drt.extension.operations.shifts.analysis.efficiency; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonMoneyEvent; import org.matsim.api.core.v01.network.Link; @@ -38,7 +38,7 @@ public class ShiftEfficiencyTest { * Test method for {@link ShiftEfficiencyTracker}. */ @Test - public void testDrtShiftEfficiency() { + void testDrtShiftEfficiency() { EventsManager events = new EventsManagerImpl(); ShiftEfficiencyTracker shiftEfficiencyTracker = new ShiftEfficiencyTracker(); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/run/RunMultiHubShiftDrtScenarioIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/run/RunMultiHubShiftDrtScenarioIT.java index 91c2dd16be9..5b3f79ea7dd 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/run/RunMultiHubShiftDrtScenarioIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/run/RunMultiHubShiftDrtScenarioIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.drt.extension.operations.shifts.run; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.contrib.drt.analysis.zonal.DrtZonalSystemParams; import org.matsim.contrib.drt.extension.operations.DrtOperationsControlerCreator; @@ -29,7 +29,7 @@ public class RunMultiHubShiftDrtScenarioIT { @Test - public void test() { + void test() { MultiModeDrtConfigGroup multiModeDrtConfigGroup = new MultiModeDrtConfigGroup(DrtWithOperationsConfigGroup::new); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/run/RunShiftDrtScenarioIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/run/RunShiftDrtScenarioIT.java index e6b9caf51af..28034b937c6 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/run/RunShiftDrtScenarioIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/run/RunShiftDrtScenarioIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.drt.extension.operations.shifts.run; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.contrib.drt.analysis.zonal.DrtZonalSystemParams; import org.matsim.contrib.drt.extension.operations.DrtOperationsControlerCreator; @@ -30,7 +30,7 @@ public class RunShiftDrtScenarioIT { @Test - public void test() { + void test() { MultiModeDrtConfigGroup multiModeDrtConfigGroup = new MultiModeDrtConfigGroup(DrtWithOperationsConfigGroup::new); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/preplanned/optimizer/RunPreplannedDrtExampleIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/preplanned/optimizer/RunPreplannedDrtExampleIT.java index cd0b743f9f2..e5477142a92 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/preplanned/optimizer/RunPreplannedDrtExampleIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/preplanned/optimizer/RunPreplannedDrtExampleIT.java @@ -29,7 +29,7 @@ import java.util.stream.Collectors; import java.util.stream.Stream; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.drt.extension.preplanned.optimizer.PreplannedDrtOptimizer.PreplannedRequestKey; import org.matsim.contrib.drt.extension.preplanned.optimizer.PreplannedDrtOptimizer.PreplannedSchedules; @@ -43,7 +43,7 @@ */ public class RunPreplannedDrtExampleIT { @Test - public void testRun() { + void testRun() { // scenario with 1 shared taxi (max 2 pax) and 10 requests URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "one_shared_taxi_config.xml"); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtGridUtilsTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtGridUtilsTest.java index 110d6bc9852..0d73adba5c6 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtGridUtilsTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtGridUtilsTest.java @@ -4,7 +4,7 @@ import java.util.Map; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; import org.locationtech.jts.geom.prep.PreparedGeometry; @@ -18,7 +18,7 @@ public class DrtGridUtilsTest { @Test - public void test() { + void test() { Network network = createNetwork(); Map grid = DrtGridUtils.createGridFromNetwork(network, 100); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtZonalSystemTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtZonalSystemTest.java index af5b0be555e..6e58adfdbe5 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtZonalSystemTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtZonalSystemTest.java @@ -25,7 +25,7 @@ import static org.matsim.contrib.drt.analysis.zonal.DrtGridUtilsTest.createNetwork; import static org.matsim.contrib.drt.analysis.zonal.DrtZonalSystem.createFromPreparedGeometries; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.GeometryFactory; import org.locationtech.jts.geom.Polygon; @@ -44,21 +44,21 @@ public class DrtZonalSystemTest { @Test - public void test_cellSize100() { + void test_cellSize100() { DrtZonalSystem drtZonalSystem = createFromPreparedGeometries(createNetwork(), DrtGridUtils.createGridFromNetwork(createNetwork(), 100)); assertThat(drtZonalSystem.getZoneForLinkId(Id.createLinkId("ab")).getId()).isEqualTo("10"); } @Test - public void test_cellSize700() { + void test_cellSize700() { DrtZonalSystem drtZonalSystem = createFromPreparedGeometries(createNetwork(), DrtGridUtils.createGridFromNetwork(createNetwork(), 700)); assertThat(drtZonalSystem.getZoneForLinkId(Id.createLinkId("ab")).getId()).isEqualTo("2"); } @Test - public void test_gridWithinServiceArea(){ + void test_gridWithinServiceArea(){ Coordinate min = new Coordinate(-500, 500); Coordinate max = new Coordinate(1500, 1500); List serviceArea = createServiceArea(min,max); @@ -74,7 +74,7 @@ public void test_gridWithinServiceArea(){ } @Test - public void test_noZonesWithoutLinks(){ + void test_noZonesWithoutLinks(){ Coordinate min = new Coordinate(1500, 1500); Coordinate max = new Coordinate(2500, 2500); List serviceArea = createServiceArea(min,max); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/RandomDrtZoneTargetLinkSelectorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/RandomDrtZoneTargetLinkSelectorTest.java index 3251579a09e..fa38b72749b 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/RandomDrtZoneTargetLinkSelectorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/RandomDrtZoneTargetLinkSelectorTest.java @@ -27,7 +27,7 @@ import java.util.List; import java.util.function.IntUnaryOperator; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.testcases.fakes.FakeLink; @@ -44,7 +44,7 @@ public class RandomDrtZoneTargetLinkSelectorTest { private final Link link3 = new FakeLink(Id.createLinkId("3")); @Test - public void testSelectTargetLink_fourLinks() { + void testSelectTargetLink_fourLinks() { DrtZone zone = DrtZone.createDummyZone("zone", List.of(link0, link1, link2, link3), null); //fake random sequence diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java index 38880db6bcb..791902fbf14 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java @@ -3,8 +3,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.drt.run.DrtConfigGroup; import org.matsim.contrib.drt.run.MultiModeDrtConfigGroup; import org.matsim.contrib.dvrp.run.DvrpConfigGroup; @@ -19,8 +19,8 @@ public class ConfigBehaviorTest{ @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; - @Test - public final void testMaterializeAfterReadParameterSets() { + @Test + final void testMaterializeAfterReadParameterSets() { { // generate a test config that sets two values away from their defaults, and write it to file: Config config = ConfigUtils.createConfig(); @@ -60,8 +60,8 @@ public final void testMaterializeAfterReadParameterSets() { } } - @Test - public final void testMaterializeAfterReadStandardParams() { + @Test + final void testMaterializeAfterReadStandardParams() { { // generate a test config that sets two values away from their defaults, and write it to file: Config config = ConfigUtils.createConfig(); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/fare/DrtFareHandlerTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/fare/DrtFareHandlerTest.java index e586e1a9dda..fc3c85c6c57 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/fare/DrtFareHandlerTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/fare/DrtFareHandlerTest.java @@ -22,7 +22,7 @@ import org.apache.commons.lang3.mutable.MutableDouble; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonMoneyEvent; import org.matsim.api.core.v01.events.handler.PersonMoneyEventHandler; @@ -42,7 +42,7 @@ public class DrtFareHandlerTest { * Test method for {@link DrtFareHandler}. */ @Test - public void testDrtFareHandler() { + void testDrtFareHandler() { String mode = "mode_0"; DrtFareParams fareParams = new DrtFareParams(); fareParams.baseFare = 1; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/DrtRequestInsertionRetryQueueTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/DrtRequestInsertionRetryQueueTest.java index 208e652d1dc..8989aa90855 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/DrtRequestInsertionRetryQueueTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/DrtRequestInsertionRetryQueueTest.java @@ -22,7 +22,7 @@ import static org.assertj.core.api.Assertions.assertThat; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.drt.passenger.DrtRequest; import org.matsim.contrib.dvrp.optimizer.Request; @@ -43,21 +43,21 @@ public class DrtRequestInsertionRetryQueueTest { .build(); @Test - public void maxRequestAgeZero_noRetry() { + void maxRequestAgeZero_noRetry() { var queue = new DrtRequestInsertionRetryQueue(params(10, 0)); assertThat(queue.tryAddFailedRequest(request, SUBMISSION_TIME)).isFalse(); assertThat(queue.getRequestsToRetryNow(9999)).isEmpty(); } @Test - public void requestMaxAgeExceeded_noRetry() { + void requestMaxAgeExceeded_noRetry() { var queue = new DrtRequestInsertionRetryQueue(params(2, 10)); assertThat(queue.tryAddFailedRequest(request, SUBMISSION_TIME + 10)).isFalse(); assertThat(queue.getRequestsToRetryNow(9999)).isEmpty(); } @Test - public void requestMaxAgeNotExceeded_retry() { + void requestMaxAgeNotExceeded_retry() { var queue = new DrtRequestInsertionRetryQueue(params(2, 10)); assertThat(queue.tryAddFailedRequest(request, SUBMISSION_TIME)).isTrue(); @@ -77,7 +77,7 @@ public void requestMaxAgeNotExceeded_retry() { } @Test - public void requestMaxAgeNotExceeded_lateRetry() { + void requestMaxAgeNotExceeded_lateRetry() { var queue = new DrtRequestInsertionRetryQueue(params(2, 10)); assertThat(queue.tryAddFailedRequest(request, SUBMISSION_TIME)).isTrue(); @@ -91,7 +91,7 @@ public void requestMaxAgeNotExceeded_lateRetry() { } @Test - public void queueOrderMaintained() { + void queueOrderMaintained() { var queue = new DrtRequestInsertionRetryQueue(params(2, 10)); assertThat(queue.tryAddFailedRequest(DrtRequest.newBuilder(request).id(Id.create("a", Request.class)).build(), SUBMISSION_TIME)).isTrue(); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/VehicleDataEntryFactoryImplTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/VehicleDataEntryFactoryImplTest.java index 035367e15fc..e74e3334a71 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/VehicleDataEntryFactoryImplTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/VehicleDataEntryFactoryImplTest.java @@ -26,7 +26,7 @@ import java.util.Arrays; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.drt.optimizer.Waypoint.Stop; @@ -50,7 +50,7 @@ public class VehicleDataEntryFactoryImplTest { private final Stop stop1 = stop(300, 340, 400, 430); @Test - public void computeSlackTimes_withStops() { + void computeSlackTimes_withStops() { final List precedingStayTimes = Arrays.asList(0.0, 0.0); //final stay task not started - vehicle slack time is 50 @@ -64,7 +64,7 @@ public void computeSlackTimes_withStops() { } @Test - public void computeSlackTimes_withoutStops() { + void computeSlackTimes_withoutStops() { final List precedingStayTimes = Arrays.asList(); //final stay task not started yet - vehicle slack time is 10 @@ -85,9 +85,9 @@ public void computeSlackTimes_withoutStops() { //final stay task planned after vehicle end time - vehicle slack time is 0s assertThat(computeSlackTimes(vehicle(500, 510), 300, new Stop[] {}, null, precedingStayTimes)).containsExactly(0, 0); } - + @Test - public void computeSlackTimes_withStart() { + void computeSlackTimes_withStart() { final List noPrecedingStayTimes = Arrays.asList(); final List onePrecedingStayTime = Arrays.asList(0.0); @@ -100,9 +100,9 @@ public void computeSlackTimes_withStart() { //start with stop assertThat(computeSlackTimes(vehicle(500, 450), 100, new Stop[] { stop1 }, stop0, onePrecedingStayTime)).containsExactly(30, 30, 50); } - + @Test - public void computeSlackTimes_withPrecedingStayTimes() { + void computeSlackTimes_withPrecedingStayTimes() { final List precedingStayTimes = Arrays.asList( // 0.0, // 33.0 // second stop is a prebooked pickup, so slack for insertion after first stop is longer diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/BestInsertionFinderTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/BestInsertionFinderTest.java index 32b44c82f2f..bf42ede62a7 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/BestInsertionFinderTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/BestInsertionFinderTest.java @@ -30,7 +30,7 @@ import java.util.Arrays; import java.util.Optional; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.drt.optimizer.VehicleEntry; import org.matsim.contrib.drt.passenger.DrtRequest; @@ -48,19 +48,19 @@ public class BestInsertionFinderTest { private final BestInsertionFinder bestInsertionFinder = new BestInsertionFinder(insertionCostCalculator); @Test - public void noInsertions_empty() { + void noInsertions_empty() { assertThat(findBestInsertion()).isEmpty(); } @Test - public void noFeasibleInsertions_empty() { + void noFeasibleInsertions_empty() { when(insertionCostCalculator.calculate(eq(request), any(), any())).thenReturn(INFEASIBLE_SOLUTION_COST); assertThat(findBestInsertion(insertion("v1", 0, 0), insertion("v1", 0, 1))).isEmpty(); } @Test - public void oneFeasibleInsertion_oneInfeasibleInsertion_chooseFeasible() { + void oneFeasibleInsertion_oneInfeasibleInsertion_chooseFeasible() { var feasibleInsertion = insertion("v1", 0, 0); whenInsertionThenCost(feasibleInsertion, 12345); @@ -72,7 +72,7 @@ public void oneFeasibleInsertion_oneInfeasibleInsertion_chooseFeasible() { } @Test - public void twoFeasibleInsertions_chooseBetter() { + void twoFeasibleInsertions_chooseBetter() { var insertion1 = insertion("v1", 0, 0); whenInsertionThenCost(insertion1, 123); @@ -84,7 +84,7 @@ public void twoFeasibleInsertions_chooseBetter() { } @Test - public void twoEqualInsertions_chooseLowerVehicleId() { + void twoEqualInsertions_chooseLowerVehicleId() { var insertion1 = insertion("v1", 0, 0); whenInsertionThenCost(insertion1, 123); @@ -96,7 +96,7 @@ public void twoEqualInsertions_chooseLowerVehicleId() { } @Test - public void twoEqualInsertions_sameVehicle_chooseLowerPickupIdx() { + void twoEqualInsertions_sameVehicle_chooseLowerPickupIdx() { var insertion1 = insertion("v1", 0, 1); whenInsertionThenCost(insertion1, 123); @@ -108,7 +108,7 @@ public void twoEqualInsertions_sameVehicle_chooseLowerPickupIdx() { } @Test - public void twoEqualInsertions_sameVehicle_samePickupIdx_chooseLowerDropoffIdx() { + void twoEqualInsertions_sameVehicle_samePickupIdx_chooseLowerDropoffIdx() { var insertion1 = insertion("v1", 0, 0); whenInsertionThenCost(insertion1, 123); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/CostCalculationStrategyTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/CostCalculationStrategyTest.java index 569f4e7d708..cc52e2a3dbf 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/CostCalculationStrategyTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/CostCalculationStrategyTest.java @@ -27,7 +27,7 @@ import static org.matsim.contrib.drt.optimizer.insertion.InsertionDetourTimeCalculator.DropoffDetourInfo; import static org.matsim.contrib.drt.optimizer.insertion.InsertionDetourTimeCalculator.PickupDetourInfo; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.drt.optimizer.insertion.InsertionDetourTimeCalculator.DetourTimeInfo; import org.matsim.contrib.drt.passenger.DrtRequest; @@ -36,20 +36,20 @@ */ public class CostCalculationStrategyTest { @Test - public void RejectSoftConstraintViolations_tooLongWaitTime() { + void RejectSoftConstraintViolations_tooLongWaitTime() { assertRejectSoftConstraintViolations(10, 9999, new DetourTimeInfo(new PickupDetourInfo(11, 0), new DropoffDetourInfo(22, 0)), INFEASIBLE_SOLUTION_COST); } @Test - public void RejectSoftConstraintViolations_tooLongTravelTime() { + void RejectSoftConstraintViolations_tooLongTravelTime() { assertRejectSoftConstraintViolations(9999, 10, new DetourTimeInfo(new PickupDetourInfo(0, 0), new DropoffDetourInfo(11, 0)), INFEASIBLE_SOLUTION_COST); } @Test - public void RejectSoftConstraintViolations_allConstraintSatisfied() { + void RejectSoftConstraintViolations_allConstraintSatisfied() { assertRejectSoftConstraintViolations(9999, 9999, new DetourTimeInfo(new PickupDetourInfo(11, 33), new DropoffDetourInfo(22, 44)), 33 + 44); } @@ -65,21 +65,21 @@ private void assertRejectSoftConstraintViolations(double latestStartTime, double } @Test - public void DiscourageSoftConstraintViolations_tooLongWaitTime() { + void DiscourageSoftConstraintViolations_tooLongWaitTime() { assertDiscourageSoftConstraintViolations(10, 9999, new DetourTimeInfo(new PickupDetourInfo(11, 0), new DropoffDetourInfo(22, 0)), MAX_WAIT_TIME_VIOLATION_PENALTY); } @Test - public void DiscourageSoftConstraintViolations_tooLongTravelTime() { + void DiscourageSoftConstraintViolations_tooLongTravelTime() { assertDiscourageSoftConstraintViolations(9999, 10, new DetourTimeInfo(new PickupDetourInfo(0, 0), new DropoffDetourInfo(11, 0)), MAX_TRAVEL_TIME_VIOLATION_PENALTY); } @Test - public void DiscourageSoftConstraintViolations_allConstraintSatisfied() { + void DiscourageSoftConstraintViolations_allConstraintSatisfied() { assertDiscourageSoftConstraintViolations(9999, 9999, new DetourTimeInfo(new PickupDetourInfo(11, 33), new DropoffDetourInfo(22, 44)), 33 + 44); } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DefaultUnplannedRequestInserterTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DefaultUnplannedRequestInserterTest.java index 2f33a567b87..58637acaddc 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DefaultUnplannedRequestInserterTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DefaultUnplannedRequestInserterTest.java @@ -32,8 +32,8 @@ import java.util.*; import org.apache.commons.lang3.mutable.MutableInt; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; -import org.junit.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Identifiable; @@ -74,7 +74,7 @@ public class DefaultUnplannedRequestInserterTest { public final ForkJoinPoolExtension forkJoinPoolExtension = new ForkJoinPoolExtension(); @Test - public void nothingToSchedule() { + void nothingToSchedule() { var fleet = fleet(vehicle("1")); var unplannedRequests = requests(); double now = 15; @@ -89,7 +89,7 @@ public void nothingToSchedule() { } @Test - public void notScheduled_rejected() { + void notScheduled_rejected() { var fleet = fleet();//no vehicles -> impossible to schedule var unplannedRequests = requests(request1); double now = 15; @@ -122,7 +122,7 @@ public void notScheduled_rejected() { } @Test - public void notScheduled_addedToRetry() { + void notScheduled_addedToRetry() { var fleet = fleet();//no vehicles -> impossible to schedule var unplannedRequests = requests(request1); double now = 15; @@ -159,7 +159,7 @@ public void notScheduled_addedToRetry() { } @Test - public void firstRetryOldRequest_thenHandleNewRequest() { + void firstRetryOldRequest_thenHandleNewRequest() { var fleet = fleet();//no vehicles -> impossible to schedule var unplannedRequests = requests(request1); double now = 15; @@ -194,7 +194,7 @@ public void firstRetryOldRequest_thenHandleNewRequest() { } @Test - public void acceptedRequest() { + void acceptedRequest() { var vehicle1 = vehicle("1"); var fleet = fleet(vehicle1); var unplannedRequests = requests(request1); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DetourTimeEstimatorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DetourTimeEstimatorTest.java index 85caff1ca6c..d11094a9fd1 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DetourTimeEstimatorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DetourTimeEstimatorTest.java @@ -25,7 +25,7 @@ import static org.mockito.Mockito.when; import org.assertj.core.api.Assertions; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.dvrp.trafficmonitoring.QSimFreeSpeedTravelTime; import org.matsim.contrib.zone.skims.TravelTimeMatrix; import org.matsim.testcases.fakes.FakeLink; @@ -37,14 +37,14 @@ public class DetourTimeEstimatorTest { @Test - public void freeSpeedZonalTimeEstimator_fromLinkToLinkSame() { + void freeSpeedZonalTimeEstimator_fromLinkToLinkSame() { var link = new FakeLink(null); var estimator = DetourTimeEstimator.createMatrixBasedEstimator(1, null, null); Assertions.assertThat(estimator.estimateTime(link, link, 345)).isZero(); } @Test - public void freeSpeedZonalTimeEstimator_fromLinkToLinkDifferent() { + void freeSpeedZonalTimeEstimator_fromLinkToLinkDifferent() { var linkA = new FakeLink(null, null, new FakeNode(null)); var linkB = new FakeLink(null, new FakeNode(null), null); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java index 26c4c3f6f7d..6b01f318098 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java @@ -4,8 +4,8 @@ import java.util.*; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.*; @@ -64,7 +64,7 @@ public class DrtPoolingParameterTest { * With a low maxWaitTime of 100s, no DRT vehicle should have time to any agents. */ @Test - public void testMaxWaitTimeNoVehicles() { + void testMaxWaitTimeNoVehicles() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(50, 10.0, 10000.); Assert.assertEquals("There should be no vehicle used", 0, handler.getVehRequestCount().size()); @@ -76,7 +76,7 @@ public void testMaxWaitTimeNoVehicles() { * too far away to reach those agents. */ @Test - public void testMaxWaitTimeTwoVehiclesForTwoAgents() { + void testMaxWaitTimeTwoVehiclesForTwoAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(121, 10.0, 10000.); Assert.assertEquals("There should two vehicle used", 2, handler.getVehRequestCount().size()); @@ -97,7 +97,7 @@ public void testMaxWaitTimeTwoVehiclesForTwoAgents() { * With a maxWaitTime of 250s, both drt vehicles should have time to each pick up two passengers. */ @Test - public void testMaxWaitTimeTwoVehiclesForFourAgents() { + void testMaxWaitTimeTwoVehiclesForFourAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(250, 10.0, 10000.); Assert.assertEquals("There should two vehicle used", 2, handler.getVehRequestCount().size()); @@ -118,7 +118,7 @@ public void testMaxWaitTimeTwoVehiclesForFourAgents() { * With a high maxWaitTime of 500s, a single DRT vehicle should be able to pick up all four agents. */ @Test - public void testMaxWaitTimeOneVehicleForFourAgents() { + void testMaxWaitTimeOneVehicleForFourAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(500, 10.0, 10000.); System.out.println(handler.getVehRequestCount()); @@ -132,15 +132,15 @@ public void testMaxWaitTimeOneVehicleForFourAgents() { } /* - The following tests vary the maxTravelTimeBeta parameter. maxTravelTimeAlpha is fixed to 1.0, while maxWaitTime is - fixed to a high value: 5000s. + e following tests vary the maxTravelTimeBeta parameter. maxTravelTimeAlpha is fixed to 1.0, while maxWaitTime is + ixed to a high value: 5000s. */ /** * With a low Beta of 0s, no DRT vehicles should be assigned to the agents. */ @Test - public void testBetaNoVehicles() { + void testBetaNoVehicles() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(5000, 1.0, 0.); Assert.assertEquals("There should only be zero vehicles used", 0, handler.getVehRequestCount().size()); @@ -152,7 +152,7 @@ public void testBetaNoVehicles() { * the remaining two agents will be left stranded */ @Test - public void testBetaTwoVehiclesForTwoAgents() { + void testBetaTwoVehiclesForTwoAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(5000, 1.0, 150); Assert.assertEquals("There should two vehicle used", 2, handler.getVehRequestCount().size()); @@ -173,7 +173,7 @@ public void testBetaTwoVehiclesForTwoAgents() { * With a Beta value of 250s, two DRT vehicles should have enough time to pick up two passengers each. */ @Test - public void testBetaTwoVehiclesForFourAgents() { + void testBetaTwoVehiclesForFourAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(5000, 1.0, 250); Assert.assertEquals("There should two vehicle used", 2, handler.getVehRequestCount().size()); @@ -193,7 +193,7 @@ public void testBetaTwoVehiclesForFourAgents() { * With a high Beta of 400s, one DRT vehicle should be used to pick up all four agents */ @Test - public void testBetaOneVehicleForFourAgents() { + void testBetaOneVehicleForFourAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(5000, 1.0, 400); Assert.assertEquals("There should only be one vehicle used", 1, handler.getVehRequestCount().size()); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionCostCalculatorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionCostCalculatorTest.java index 563788c0f5c..0d617d9fc9f 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionCostCalculatorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionCostCalculatorTest.java @@ -24,7 +24,7 @@ import static org.matsim.contrib.drt.optimizer.insertion.InsertionCostCalculator.INFEASIBLE_SOLUTION_COST; import static org.matsim.contrib.drt.optimizer.insertion.InsertionDetourTimeCalculator.*; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.drt.optimizer.VehicleEntry; @@ -41,7 +41,7 @@ public class InsertionCostCalculatorTest { private final DrtRequest drtRequest = DrtRequest.newBuilder().fromLink(fromLink).toLink(toLink).build(); @Test - public void testCalculate() { + void testCalculate() { VehicleEntry entry = entry(new double[] { 20, 20, 50 }); var insertion = insertion(entry, 0, 1); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionDetourTimeCalculatorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionDetourTimeCalculatorTest.java index 3489c5ee854..756682854b0 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionDetourTimeCalculatorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionDetourTimeCalculatorTest.java @@ -24,8 +24,7 @@ import java.util.Collections; import java.util.List; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.drt.optimizer.VehicleEntry; @@ -57,7 +56,7 @@ public class InsertionDetourTimeCalculatorTest { private final DrtRequest drtRequest = DrtRequest.newBuilder().fromLink(fromLink).toLink(toLink).build(); @Test - public void detourTimeLoss_start_pickup_dropoff() { + void detourTimeLoss_start_pickup_dropoff() { Waypoint.Start start = start(null, 10, link("start")); VehicleEntry entry = entry(start); var detour = detourData(100., 15., Double.NaN, 0.); @@ -74,7 +73,7 @@ public void detourTimeLoss_start_pickup_dropoff() { } @Test - public void detourTimeLoss_ongoingStopAsStart_pickup_dropoff() { + void detourTimeLoss_ongoingStopAsStart_pickup_dropoff() { //similar to detourTmeLoss_start_pickup_dropoff(), but the pickup is appended to the ongoing STOP task // sh 03/08/23: Changed this test, according to VehicleDataEntryFactoryImpl the start time should be end time of stop task Waypoint.Start start = start(new DefaultDrtStopTask(20, 20 + STOP_DURATION, fromLink), 20 + STOP_DURATION, fromLink); @@ -91,7 +90,7 @@ public void detourTimeLoss_ongoingStopAsStart_pickup_dropoff() { } @Test - public void detourTimeLoss_start_pickup_dropoff_stop() { + void detourTimeLoss_start_pickup_dropoff_stop() { Waypoint.Start start = start(null, 5, link("start")); Waypoint.Stop stop0 = stop(10, link("stop0")); VehicleEntry entry = entry(start, stop0); @@ -109,7 +108,7 @@ public void detourTimeLoss_start_pickup_dropoff_stop() { } @Test - public void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff() { + void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff() { Waypoint.Start start = start(null, 5, link("start")); Waypoint.Stop stop0 = stop(10, link("stop0")); VehicleEntry entry = entry(start, stop0); @@ -127,7 +126,7 @@ public void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff() { } @Test - public void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff_stop() { + void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff_stop() { Waypoint.Start start = start(null, 5, link("start")); Waypoint.Stop stop0 = stop(10, link("stop0")); Waypoint.Stop stop1 = stop(200, link("stop1")); @@ -148,7 +147,7 @@ public void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff_stop() { } @Test - public void calculatePickupDetourTimeLoss_start_pickupNotAppended_stop_dropoffAppended_stop() { + void calculatePickupDetourTimeLoss_start_pickupNotAppended_stop_dropoffAppended_stop() { Waypoint.Start start = start(null, 5, fromLink);//not a STOP -> pickup cannot be appended Waypoint.Stop stop0 = stop(10, toLink); Waypoint.Stop stop1 = stop(200, link("stop1")); @@ -165,7 +164,7 @@ public void calculatePickupDetourTimeLoss_start_pickupNotAppended_stop_dropoffAp } @Test - public void calculatePickupDetourTimeLoss_start_stop_pickupAppended_stop_dropoffAppended() { + void calculatePickupDetourTimeLoss_start_stop_pickupAppended_stop_dropoffAppended() { Waypoint.Start start = start(null, 5, link("start")); Waypoint.Stop stop0 = stop(10, fromLink); Waypoint.Stop stop1 = stop(200, toLink); @@ -182,7 +181,7 @@ public void calculatePickupDetourTimeLoss_start_stop_pickupAppended_stop_dropoff } @Test - public void replacedDriveTimeEstimator() { + void replacedDriveTimeEstimator() { Waypoint.Start start = start(null, 0, link("start")); Waypoint.Stop stop0 = stop(10, link("stop0")); Waypoint.Stop stop1 = stop(200, link("stop1")); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionDetourTimeCalculatorWithVariableDurationTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionDetourTimeCalculatorWithVariableDurationTest.java index 461a598d874..fcfa03962bd 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionDetourTimeCalculatorWithVariableDurationTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionDetourTimeCalculatorWithVariableDurationTest.java @@ -24,8 +24,7 @@ import java.util.Collections; import java.util.List; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.drt.optimizer.VehicleEntry; @@ -91,7 +90,7 @@ public double calcDropoffDuration(DvrpVehicle vehicle, DrtRequest request) { new CumulativeStopTimeCalculator(STOP_DURATION_PROVIDER); @Test - public void detourTimeLoss_start_pickup_dropoff() { + void detourTimeLoss_start_pickup_dropoff() { Waypoint.Start start = start(null, 10, link("start")); VehicleEntry entry = entry(start); var detour = new Detour(100., 15., 0., 0.); @@ -109,7 +108,7 @@ public void detourTimeLoss_start_pickup_dropoff() { } @Test - public void detourTimeLoss_ongoingStopAsStart_pickup_dropoff() { + void detourTimeLoss_ongoingStopAsStart_pickup_dropoff() { //similar to detourTmeLoss_start_pickup_dropoff(), but the pickup is appended to the ongoing STOP task DrtStopTask stopTask = new DefaultDrtStopTask(20, 20 + STOP_DURATION_INITIAL, fromLink); stopTask.addDropoffRequest(AcceptedDrtRequest.createFromOriginalRequest(drtRequestInitial)); @@ -129,7 +128,7 @@ public void detourTimeLoss_ongoingStopAsStart_pickup_dropoff() { } @Test - public void detourTimeLoss_start_pickup_dropoff_stop() { + void detourTimeLoss_start_pickup_dropoff_stop() { Waypoint.Start start = start(null, 5, link("start")); Waypoint.Stop stop0 = stop(10, link("stop0")); VehicleEntry entry = entry(start, stop0); @@ -146,7 +145,7 @@ public void detourTimeLoss_start_pickup_dropoff_stop() { } @Test - public void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff() { + void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff() { Waypoint.Start start = start(null, 5, link("start")); Waypoint.Stop stop0 = stop(10, link("stop0")); VehicleEntry entry = entry(start, stop0); @@ -163,7 +162,7 @@ public void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff() { } @Test - public void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff_stop() { + void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff_stop() { Waypoint.Start start = start(null, 5, link("start")); Waypoint.Stop stop0 = stop(10, link("stop0")); Waypoint.Stop stop1 = stop(200, link("stop1")); @@ -181,7 +180,7 @@ public void calculatePickupDetourTimeLoss_start_pickup_stop_dropoff_stop() { } @Test - public void calculatePickupDetourTimeLoss_start_pickupNotAppended_stop_dropoffAppended_stop() { + void calculatePickupDetourTimeLoss_start_pickupNotAppended_stop_dropoffAppended_stop() { Waypoint.Start start = start(null, 5, fromLink);//not a STOP -> pickup cannot be appended Waypoint.Stop stop0 = stop(10, toLink); Waypoint.Stop stop1 = stop(200, link("stop1")); @@ -199,7 +198,7 @@ public void calculatePickupDetourTimeLoss_start_pickupNotAppended_stop_dropoffAp } @Test - public void calculatePickupDetourTimeLoss_start_stop_pickupAppended_stop_dropoffAppended() { + void calculatePickupDetourTimeLoss_start_stop_pickupAppended_stop_dropoffAppended() { Waypoint.Start start = start(null, 5, link("start")); Waypoint.Stop stop0 = stop(10, fromLink); Waypoint.Stop stop1 = stop(200, toLink); @@ -217,7 +216,7 @@ public void calculatePickupDetourTimeLoss_start_stop_pickupAppended_stop_dropoff } @Test - public void replacedDriveTimeEstimator() { + void replacedDriveTimeEstimator() { Waypoint.Start start = start(null, 0, link("start")); Waypoint.Stop stop0 = stop(10, link("stop0")); Waypoint.Stop stop1 = stop(200, link("stop1")); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionGeneratorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionGeneratorTest.java index 18bb57661f2..53c6aa2d5ae 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionGeneratorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/InsertionGeneratorTest.java @@ -28,7 +28,7 @@ import java.util.List; import com.google.common.collect.Sets; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.drt.optimizer.VehicleEntry; @@ -94,7 +94,7 @@ public class InsertionGeneratorTest { private final DvrpVehicle vehicle = new DvrpVehicleImpl(vehicleSpecification, depotLink); @Test - public void startEmpty_noStops() { + void startEmpty_noStops() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); //no stops => must be empty VehicleEntry entry = entry(start); @@ -110,7 +110,7 @@ public void startEmpty_noStops() { } @Test - public void startNotFull_oneStop() { + void startNotFull_oneStop() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 1); // 1 pax aboard Waypoint.Stop stop0 = stop(start.time + TIME_REPLACED_DRIVE, link("stop0"), 0);//drop off 1 pax VehicleEntry entry = entry(start, stop0); @@ -143,7 +143,7 @@ public void startNotFull_oneStop() { } @Test - public void startFull_oneStop() { + void startFull_oneStop() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, CAPACITY); //full Waypoint.Stop stop0 = stop(start.time + TIME_REPLACED_DRIVE, link("stop0"), 0);//drop off 4 pax VehicleEntry entry = entry(start, stop0); @@ -160,7 +160,7 @@ public void startFull_oneStop() { } @Test - public void startEmpty_twoStops_notFullBetweenStops() { + void startEmpty_twoStops_notFullBetweenStops() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); //empty Waypoint.Stop stop0 = stop(start.time + TIME_REPLACED_DRIVE, link("stop0"), 1);//pick up 1 pax Waypoint.Stop stop1 = stop(stop0.getDepartureTime() + TIME_REPLACED_DRIVE, link("stop1"), 0);//drop off 1 pax @@ -218,7 +218,7 @@ public void startEmpty_twoStops_notFullBetweenStops() { } @Test - public void startEmpty_twoStops_notFullBetweenStops_tightSlackTimes() { + void startEmpty_twoStops_notFullBetweenStops_tightSlackTimes() { //same as startEmpty_twoStops_notFullBetweenStops() but with different slack times Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); //empty Waypoint.Stop stop0 = stop(start.time + TIME_REPLACED_DRIVE, link("stop0"), 1);//pick up 1 pax @@ -252,7 +252,7 @@ public void startEmpty_twoStops_notFullBetweenStops_tightSlackTimes() { } @Test - public void startEmpty_twoStops_fullBetweenStops() { + void startEmpty_twoStops_fullBetweenStops() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); //empty Waypoint.Stop stop0 = stop(0, link("stop0"), CAPACITY);//pick up 4 pax (full) Waypoint.Stop stop1 = stop(0, link("stop1"), 0);//drop off 4 pax @@ -266,7 +266,7 @@ public void startEmpty_twoStops_fullBetweenStops() { } @Test - public void startFull_twoStops_notFullBetweenStops() { + void startFull_twoStops_notFullBetweenStops() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, CAPACITY); //full Waypoint.Stop stop0 = stop(0, link("stop0"), 2);//drop off 2 pax Waypoint.Stop stop1 = stop(0, link("stop1"), 0);//drop off 2 pax @@ -281,7 +281,7 @@ public void startFull_twoStops_notFullBetweenStops() { } @Test - public void startFull_twoStops_fullBetweenStops() { + void startFull_twoStops_fullBetweenStops() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, CAPACITY); //full Waypoint.Stop stop0 = stop(0, link("stop0"), CAPACITY);//drop off 1 pax, pickup 1 pax (full) Waypoint.Stop stop1 = stop(0, link("stop1"), 0);//drop off 4 pax @@ -294,7 +294,7 @@ public void startFull_twoStops_fullBetweenStops() { } @Test - public void startNotFull_threeStops_emptyBetweenStops01_fullBetweenStops12() { + void startNotFull_threeStops_emptyBetweenStops01_fullBetweenStops12() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 1); //empty Waypoint.Stop stop0 = stop(0, link("stop0"), 0);// dropoff 1 pax Waypoint.Stop stop1 = stop(0, link("stop1"), CAPACITY);// pickup 4 pax @@ -312,7 +312,7 @@ public void startNotFull_threeStops_emptyBetweenStops01_fullBetweenStops12() { } @Test - public void startFull_threeStops_emptyBetweenStops01_fullBetweenStops12() { + void startFull_threeStops_emptyBetweenStops01_fullBetweenStops12() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, CAPACITY); //full Waypoint.Stop stop0 = stop(0, link("stop0"), 0);// dropoff 4 pax Waypoint.Stop stop1 = stop(0, link("stop1"), CAPACITY);// pickup 4 pax @@ -328,7 +328,7 @@ public void startFull_threeStops_emptyBetweenStops01_fullBetweenStops12() { } @Test - public void noDetourForPickup_noDuplicatedInsertions() { + void noDetourForPickup_noDuplicatedInsertions() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 1); // 1 pax Waypoint.Stop stop0 = stop(0, fromLink, 0);//dropoff 1 pax VehicleEntry entry = entry(start, stop0); @@ -339,7 +339,7 @@ public void noDetourForPickup_noDuplicatedInsertions() { } @Test - public void noDetourForDropoff_noDuplicatedInsertions() { + void noDetourForDropoff_noDuplicatedInsertions() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 1); // 1 pax Waypoint.Stop stop0 = stop(0, toLink, 0);//dropoff 1 pax VehicleEntry entry = entry(start, stop0); @@ -351,7 +351,7 @@ public void noDetourForDropoff_noDuplicatedInsertions() { } @Test - public void noDetourForDropoff_vehicleOutgoingFullAfterDropoff_insertionPossible() { + void noDetourForDropoff_vehicleOutgoingFullAfterDropoff_insertionPossible() { // a special case where we allow inserting the dropoff after a stop despite outgoingOccupancy == maxCapacity // this is only because the the dropoff happens exactly at (not after) the stop Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 1); // 1 pax @@ -366,7 +366,7 @@ public void noDetourForDropoff_vehicleOutgoingFullAfterDropoff_insertionPossible } @Test - public void startEmpty_prebookedRequest() { + void startEmpty_prebookedRequest() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); VehicleEntry entry = entry(start); assertInsertionsOnly(prebookedRequest, entry, @@ -374,7 +374,7 @@ public void startEmpty_prebookedRequest() { } @Test - public void startEmpty_onlineRequest_beforeAlreadyPrebookedOtherRequest() { + void startEmpty_onlineRequest_beforeAlreadyPrebookedOtherRequest() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); Waypoint.Stop stop0 = stop(200, fromLink, 1); Waypoint.Stop stop1 = stop(400, link("stop"), 0); @@ -390,7 +390,7 @@ public void startEmpty_onlineRequest_beforeAlreadyPrebookedOtherRequest() { } @Test - public void startEmpty_prebookedRequest_inMiddleOfAlreadyPrebookedOtherRequest() { + void startEmpty_prebookedRequest_inMiddleOfAlreadyPrebookedOtherRequest() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); Waypoint.Stop stop0 = stop(50, fromLink, 1); Waypoint.Stop stop1 = stop(300, link("stop"), 0); @@ -402,7 +402,7 @@ public void startEmpty_prebookedRequest_inMiddleOfAlreadyPrebookedOtherRequest() } @Test - public void startEmpty_prebookedRequest_afterAlreadyPrebookedOtherRequest() { + void startEmpty_prebookedRequest_afterAlreadyPrebookedOtherRequest() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); Waypoint.Stop stop0 = stop(20, fromLink, 1); Waypoint.Stop stop1 = stop(70, link("stop"), 0); @@ -413,7 +413,7 @@ public void startEmpty_prebookedRequest_afterAlreadyPrebookedOtherRequest() { @Test - public void startEmpty_smallGroup() { + void startEmpty_smallGroup() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); //empty VehicleEntry entry = entry(start); assertInsertionsOnly(drtRequest2Pax, entry, @@ -422,7 +422,7 @@ public void startEmpty_smallGroup() { } @Test - public void startEmpty_groupExceedsCapacity() { + void startEmpty_groupExceedsCapacity() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); //empty VehicleEntry entry = entry(start); assertInsertionsOnly(drtRequest5Pax, entry @@ -431,7 +431,7 @@ public void startEmpty_groupExceedsCapacity() { } @Test - public void startEmpty_twoStops_groupExceedsCapacityAtFirstStop() { + void startEmpty_twoStops_groupExceedsCapacityAtFirstStop() { Waypoint.Start start = new Waypoint.Start(null, link("start"), 0, 0); //empty Waypoint.Stop stop0 = stop(0, toLink, 3);//dropoff 1 pax Waypoint.Stop stop1 = stop(0, link("stop1"), 0);//dropoff 1 pax diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/DetourPathDataCacheTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/DetourPathDataCacheTest.java index af7c0c331f2..fcc8928de9c 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/DetourPathDataCacheTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/DetourPathDataCacheTest.java @@ -24,8 +24,7 @@ import static org.mockito.Mockito.mock; import java.util.Arrays; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.drt.optimizer.VehicleEntry; @@ -86,32 +85,32 @@ public class DetourPathDataCacheTest { pathToDropoffMap, pathFromDropoffMap, ZERO_DETOUR); @Test - public void insertion_0_0() { + void insertion_0_0() { assertInsertion(0, 0, start_pickup, pickup_dropoff, null, dropoff_stop0); } @Test - public void insertion_0_1() { + void insertion_0_1() { assertInsertion(0, 1, start_pickup, pickup_stop0, stop0_dropoff, dropoff_stop1); } @Test - public void insertion_0_2() { + void insertion_0_2() { assertInsertion(0, 2, start_pickup, pickup_stop0, stop1_dropoff, ZERO_DETOUR); } @Test - public void insertion_1_1() { + void insertion_1_1() { assertInsertion(1, 1, stop0_pickup, pickup_dropoff, null, dropoff_stop1); } @Test - public void insertion_1_2() { + void insertion_1_2() { assertInsertion(1, 2, stop0_pickup, pickup_stop1, stop1_dropoff, ZERO_DETOUR); } @Test - public void insertion_2_2() { + void insertion_2_2() { assertInsertion(2, 2, stop1_pickup, pickup_dropoff, null, ZERO_DETOUR); } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/ExtensiveInsertionProviderTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/ExtensiveInsertionProviderTest.java index 4d05fbc2397..c6dc35ebdf6 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/ExtensiveInsertionProviderTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/ExtensiveInsertionProviderTest.java @@ -29,7 +29,7 @@ import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.drt.optimizer.VehicleEntry; import org.matsim.contrib.drt.optimizer.Waypoint; @@ -47,21 +47,21 @@ public class ExtensiveInsertionProviderTest { public final ForkJoinPoolExtension rule = new ForkJoinPoolExtension(); @Test - public void getInsertions_noInsertionsGenerated() { + void getInsertions_noInsertionsGenerated() { var insertionProvider = new ExtensiveInsertionProvider(null, null, new InsertionGenerator(new DefaultStopTimeCalculator(120), null), rule.forkJoinPool); assertThat(insertionProvider.getInsertions(null, List.of())).isEmpty(); } @Test - public void getInsertions_twoAtEndInsertionsGenerated_zeroNearestInsertionsAtEndLimit() { + void getInsertions_twoAtEndInsertionsGenerated_zeroNearestInsertionsAtEndLimit() { //the infeasible solution gets discarded in the first stage //the feasible solution gets discarded in the second stage (KNearestInsertionsAtEndFilter) getInsertions_twoInsertionsGenerated(0); } @Test - public void getInsertions_twoAtEndInsertionsGenerated_tenNearestInsertionsAtEndLimit() { + void getInsertions_twoAtEndInsertionsGenerated_tenNearestInsertionsAtEndLimit() { //the infeasible solution gets discarded in the first stage //the feasible solution is NOT discarded in the second stage (KNearestInsertionsAtEndFilter) getInsertions_twoInsertionsGenerated(10); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/KNearestInsertionsAtEndFilterTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/KNearestInsertionsAtEndFilterTest.java index 77fc80cf388..02a92a9588b 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/KNearestInsertionsAtEndFilterTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/KNearestInsertionsAtEndFilterTest.java @@ -25,8 +25,7 @@ import static org.mockito.Mockito.when; import java.util.List; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.drt.optimizer.VehicleEntry; import org.matsim.contrib.drt.optimizer.Waypoint; @@ -46,7 +45,7 @@ public class KNearestInsertionsAtEndFilterTest { @Test - public void k0_atEndInsertionsNotReturned() { + void k0_atEndInsertionsNotReturned() { var vehicleEntry = vehicleEntry("v1", start(0), stop(100)); var insertion = insertion(vehicleEntry, 1, 10); var filteredInsertions = KNearestInsertionsAtEndFilter.filterInsertionsAtEnd(0, List.of(insertion)); @@ -54,13 +53,13 @@ public void k0_atEndInsertionsNotReturned() { } @Test - public void noInsertions_emptyList() { + void noInsertions_emptyList() { var filteredInsertions = filterOneInsertionAtEnd(); assertThat(filteredInsertions).isEmpty(); } @Test - public void noAtEndInsertions_allReturned() { + void noAtEndInsertions_allReturned() { var vehicleEntry = vehicleEntry("v1", start(0), stop(100)); var insertion1 = insertion(vehicleEntry, 0, 11); var insertion2 = insertion(vehicleEntry, 0, 22); @@ -70,7 +69,7 @@ public void noAtEndInsertions_allReturned() { } @Test - public void onlyAtEndInsertions_theEarliestReturned() { + void onlyAtEndInsertions_theEarliestReturned() { var vehicleEntry1 = vehicleEntry("v1", start(0), stop(100)); var insertion1 = insertion(vehicleEntry1, 1, 110); @@ -83,7 +82,7 @@ public void onlyAtEndInsertions_theEarliestReturned() { } @Test - public void onlyAtEndInsertions_equalArrivalTime_useVehicleIdAsTieBreaker() { + void onlyAtEndInsertions_equalArrivalTime_useVehicleIdAsTieBreaker() { var vehicleEntry1 = vehicleEntry("v1", start(0), stop(100)); var insertion1 = insertion(vehicleEntry1, 1, 110); @@ -96,7 +95,7 @@ public void onlyAtEndInsertions_equalArrivalTime_useVehicleIdAsTieBreaker() { } @Test - public void mixedTypeInsertions_bothReturned() { + void mixedTypeInsertions_bothReturned() { var vehicleEntry = vehicleEntry("v1", start(0), stop(100)); var insertionAfterStart = insertion(vehicleEntry, 0, 11); var insertionAtEnd = insertion(vehicleEntry, 1, 10); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/MultiInsertionDetourPathCalculatorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/MultiInsertionDetourPathCalculatorTest.java index 83ad6959ffe..9c604cb7acd 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/MultiInsertionDetourPathCalculatorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/MultiInsertionDetourPathCalculatorTest.java @@ -32,7 +32,7 @@ import java.util.Map; import org.junit.After; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Node; @@ -76,7 +76,7 @@ public void after() { } @Test - public void calculatePaths() { + void calculatePaths() { var pathToPickup = mockCalcPathData(pickupLink, beforePickupLink, request.getEarliestStartTime(), false, 11); var pathFromPickup = mockCalcPathData(pickupLink, afterPickupLink, request.getEarliestStartTime(), true, 22); var pathToDropoff = mockCalcPathData(dropoffLink, beforeDropoffLink, request.getLatestArrivalTime(), false, 33); @@ -96,7 +96,7 @@ public void calculatePaths() { } @Test - public void calculatePaths_dropoffAfterPickup_dropoffAtEnd() { + void calculatePaths_dropoffAfterPickup_dropoffAtEnd() { //compute only 2 paths (instead of 4) var pathToPickup = mockCalcPathData(pickupLink, beforePickupLink, request.getEarliestStartTime(), false, 11); var pathFromPickup = mockCalcPathData(pickupLink, dropoffLink, request.getEarliestStartTime(), true, 22); @@ -117,7 +117,7 @@ public void calculatePaths_dropoffAfterPickup_dropoffAtEnd() { } @Test - public void calculatePaths_noDetours() { + void calculatePaths_noDetours() { // OneToManyPathSearch.calcPathDataMap() returns a map that contains entries for all toLinks // (unless the stop criterion terminates computations earlier) // If fromLink is in toLinks than PathData.EMPTY is mapped for such a link diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SingleInsertionDetourPathCalculatorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SingleInsertionDetourPathCalculatorTest.java index 95d69fe11c4..62a8f56f9e6 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SingleInsertionDetourPathCalculatorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SingleInsertionDetourPathCalculatorTest.java @@ -31,7 +31,7 @@ import java.util.List; import org.junit.After; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Node; @@ -80,7 +80,7 @@ public void after() { } @Test - public void calculatePaths() { + void calculatePaths() { var pathToPickup = mockCalcLeastCostPath(beforePickupLink, pickupLink, request.getEarliestStartTime(), 11); var pathFromPickup = mockCalcLeastCostPath(pickupLink, afterPickupLink, request.getEarliestStartTime(), 22); var pathToDropoff = mockCalcLeastCostPath(beforeDropoffLink, dropoffLink, request.getLatestArrivalTime(), 33); @@ -99,7 +99,7 @@ public void calculatePaths() { } @Test - public void calculatePaths_dropoffAfterPickup_dropoffAtEnd() { + void calculatePaths_dropoffAfterPickup_dropoffAtEnd() { //compute only 2 paths (instead of 4) var pathToPickup = mockCalcLeastCostPath(beforePickupLink, pickupLink, request.getEarliestStartTime(), 11); var pathFromPickup = mockCalcLeastCostPath(pickupLink, dropoffLink, request.getEarliestStartTime(), 22); @@ -120,7 +120,7 @@ public void calculatePaths_dropoffAfterPickup_dropoffAtEnd() { } @Test - public void calculatePaths_noDetours() { + void calculatePaths_noDetours() { var pickup = insertionPoint(waypoint(pickupLink), waypoint(pickupLink)); var dropoff = insertionPoint(waypoint(dropoffLink), waypoint(dropoffLink)); var insertion = new Insertion(null, pickup, dropoff); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/demandestimator/PreviousIterationDrtDemandEstimatorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/demandestimator/PreviousIterationDrtDemandEstimatorTest.java index 7a155267da4..954959480ba 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/demandestimator/PreviousIterationDrtDemandEstimatorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/demandestimator/PreviousIterationDrtDemandEstimatorTest.java @@ -24,7 +24,7 @@ import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -51,7 +51,7 @@ public class PreviousIterationDrtDemandEstimatorTest { private final DrtZonalSystem zonalSystem = new DrtZonalSystem(List.of(zone1, zone2)); @Test - public void noDepartures() { + void noDepartures() { PreviousIterationDrtDemandEstimator estimator = createEstimator(); //no events in previous iterations @@ -66,7 +66,7 @@ public void noDepartures() { } @Test - public void drtDepartures() { + void drtDepartures() { PreviousIterationDrtDemandEstimator estimator = createEstimator(); //time bin 0-1800 @@ -101,7 +101,7 @@ public void drtDepartures() { } @Test - public void nonDrtDepartures() { + void nonDrtDepartures() { PreviousIterationDrtDemandEstimator estimator = createEstimator(); estimator.handleEvent(departureEvent(100, link1, "mode X")); @@ -113,7 +113,7 @@ public void nonDrtDepartures() { } @Test - public void currentCountsAreCopiedToPreviousAfterReset() { + void currentCountsAreCopiedToPreviousAfterReset() { PreviousIterationDrtDemandEstimator estimator = createEstimator(); estimator.handleEvent(departureEvent(100, link1, TransportMode.drt)); @@ -129,7 +129,7 @@ public void currentCountsAreCopiedToPreviousAfterReset() { } @Test - public void timeBinsAreRespected() { + void timeBinsAreRespected() { PreviousIterationDrtDemandEstimator estimator = createEstimator(); estimator.handleEvent(departureEvent(100, link1, TransportMode.drt)); @@ -147,7 +147,7 @@ public void timeBinsAreRespected() { } @Test - public void noTimeLimitIsImposed() { + void noTimeLimitIsImposed() { PreviousIterationDrtDemandEstimator estimator = createEstimator(); estimator.handleEvent(departureEvent(10000000, link1, TransportMode.drt)); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/targetcalculator/EqualVehicleDensityTargetCalculatorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/targetcalculator/EqualVehicleDensityTargetCalculatorTest.java index b37ef0d10f1..4f51cb334a5 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/targetcalculator/EqualVehicleDensityTargetCalculatorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/targetcalculator/EqualVehicleDensityTargetCalculatorTest.java @@ -25,7 +25,7 @@ import java.util.Map; import java.util.function.ToDoubleFunction; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Network; import org.matsim.contrib.drt.analysis.zonal.DrtGridUtils; @@ -57,21 +57,21 @@ public class EqualVehicleDensityTargetCalculatorTest { DrtGridUtils.createGridFromNetwork(network, 500.)); @Test - public void calculate_oneVehiclePerZone() { + void calculate_oneVehiclePerZone() { var targetFunction = new EqualVehicleDensityTargetCalculator(zonalSystem, createFleetSpecification(8)).calculate(0, Map.of()); zonalSystem.getZones().keySet().forEach(id -> assertTarget(targetFunction, zonalSystem, id, 1)); } @Test - public void calculate_lessVehiclesThanZones() { + void calculate_lessVehiclesThanZones() { var targetFunction = new EqualVehicleDensityTargetCalculator(zonalSystem, createFleetSpecification(7)).calculate(0, Map.of()); zonalSystem.getZones().keySet().forEach(id -> assertTarget(targetFunction, zonalSystem, id, 7. / 8)); } @Test - public void calculate_moreVehiclesThanZones() { + void calculate_moreVehiclesThanZones() { var targetFunction = new EqualVehicleDensityTargetCalculator(zonalSystem, createFleetSpecification(9)).calculate(0, Map.of()); zonalSystem.getZones().keySet().forEach(id -> assertTarget(targetFunction, zonalSystem, id, 9. / 8)); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/targetcalculator/EqualVehiclesToPopulationRatioTargetCalculatorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/targetcalculator/EqualVehiclesToPopulationRatioTargetCalculatorTest.java index e27e9850b96..7d1044fcd6e 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/targetcalculator/EqualVehiclesToPopulationRatioTargetCalculatorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/rebalancing/targetcalculator/EqualVehiclesToPopulationRatioTargetCalculatorTest.java @@ -25,7 +25,7 @@ import java.util.Map; import java.util.function.ToDoubleFunction; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -66,7 +66,7 @@ public class EqualVehiclesToPopulationRatioTargetCalculatorTest { private final PopulationFactory factory = population.getFactory(); @Test - public void testCalculate_oneVehiclePerZone() { + void testCalculate_oneVehiclePerZone() { initPopulation(Map.of("2", 1, "4", 1, "8", 1)); var targetFunction = new EqualVehiclesToPopulationRatioTargetCalculator(zonalSystem, population, createFleetSpecification(8)).calculate(0, Map.of()); @@ -82,7 +82,7 @@ public void testCalculate_oneVehiclePerZone() { } @Test - public void testCalculate_twoVehiclesPerZone() { + void testCalculate_twoVehiclesPerZone() { initPopulation(Map.of("2", 1, "4", 1, "8", 1)); var targetFunction = new EqualVehiclesToPopulationRatioTargetCalculator(zonalSystem, population, createFleetSpecification(16)).calculate(0, Map.of()); @@ -98,7 +98,7 @@ public void testCalculate_twoVehiclesPerZone() { } @Test - public void testCalculate_noPopulation() { + void testCalculate_noPopulation() { initPopulation(Map.of()); var targetFunction = new EqualVehiclesToPopulationRatioTargetCalculator(zonalSystem, population, createFleetSpecification(16)).calculate(0, Map.of()); @@ -114,7 +114,7 @@ public void testCalculate_noPopulation() { } @Test - public void testCalculate_unevenDistributionOfActivitiesInPopulatedZones() { + void testCalculate_unevenDistributionOfActivitiesInPopulatedZones() { initPopulation(Map.of("2", 2, "4", 4, "8", 8)); var targetFunction = new EqualVehiclesToPopulationRatioTargetCalculator(zonalSystem, population, createFleetSpecification(16)).calculate(0, Map.of()); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java index ba9f10a787e..692657020d8 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java @@ -3,8 +3,8 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertTrue; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Leg; import org.matsim.contrib.drt.prebooking.PrebookingTestEnvironment.RequestInfo; @@ -25,7 +25,7 @@ public class AbandonAndCancelTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void noAbandonTest() { + void noAbandonTest() { /* * One person requests to depart at 2000 and also is there at 2000. Another * person asks also to depart at 2000, but only arrives at 4000, i.e. the person @@ -59,7 +59,7 @@ public void noAbandonTest() { } @Test - public void abandonTest() { + void abandonTest() { /* * One person requests to depart at 2000 and also is there at 2000. Another * person asks also to depart at 2000, but only arrives at 4000, i.e. the person @@ -98,7 +98,7 @@ public void abandonTest() { } @Test - public void abandonThenImmediateTest() { + void abandonThenImmediateTest() { /* * One person requests to depart at 2000 and also is there at 2000. Another * person asks also to depart at 2000, but only arrives at 4000, i.e. the person @@ -141,7 +141,7 @@ public void abandonThenImmediateTest() { } @Test - public void cancelEarlyTest() { + void cancelEarlyTest() { /* * One person requests to depart at 2000 and also is there at 2000. Another * person asks also to depart at 2000, but only arrives at 4000, i.e. the person @@ -204,7 +204,7 @@ public void notifyMobsimBeforeSimStep(MobsimBeforeSimStepEvent e) { } @Test - public void cancelLateTest() { + void cancelLateTest() { /* * One person requests to depart at 2000 and also is there at 2000. Another * person asks also to depart at 2000, but only arrives at 4000, i.e. the person diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/ComplexUnschedulerTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/ComplexUnschedulerTest.java index 84c3ada7791..f6155aceec8 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/ComplexUnschedulerTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/ComplexUnschedulerTest.java @@ -8,7 +8,7 @@ import java.util.LinkedList; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -55,7 +55,7 @@ */ public class ComplexUnschedulerTest { @Test - public void testDirectDropoffAfterPickup() { + void testDirectDropoffAfterPickup() { Fixture fixture = new Fixture(); Schedule schedule = fixture.schedule; @@ -115,7 +115,7 @@ public void testDirectDropoffAfterPickup() { } @Test - public void testStandardSituation() { + void testStandardSituation() { Fixture fixture = new Fixture(); Schedule schedule = fixture.schedule; @@ -179,7 +179,7 @@ public void testStandardSituation() { } @Test - public void testRemoveAtEnd() { + void testRemoveAtEnd() { Fixture fixture = new Fixture(); Schedule schedule = fixture.schedule; @@ -244,7 +244,7 @@ public void testRemoveAtEnd() { } @Test - public void testRemoveAtBeginningWithWaitSecond() { + void testRemoveAtBeginningWithWaitSecond() { Fixture fixture = new Fixture(); Schedule schedule = fixture.schedule; @@ -310,7 +310,7 @@ public void testRemoveAtBeginningWithWaitSecond() { } @Test - public void testRemoveAtBeginningWithWaitFirst() { + void testRemoveAtBeginningWithWaitFirst() { Fixture fixture = new Fixture(); Schedule schedule = fixture.schedule; @@ -374,7 +374,7 @@ public void testRemoveAtBeginningWithWaitFirst() { } @Test - public void testRemoveAtBeginningWithDriveDiversion() { + void testRemoveAtBeginningWithDriveDiversion() { Fixture fixture = new Fixture(); Schedule schedule = fixture.schedule; @@ -451,7 +451,7 @@ public void testRemoveAtBeginningWithDriveDiversion() { } @Test - public void testRemoveAllStartWithWait() { + void testRemoveAllStartWithWait() { Fixture fixture = new Fixture(); Schedule schedule = fixture.schedule; @@ -484,7 +484,7 @@ public void testRemoveAllStartWithWait() { } @Test - public void testRemoveAllStartWithDrive() { + void testRemoveAllStartWithDrive() { Fixture fixture = new Fixture(); Schedule schedule = fixture.schedule; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java index 1c017bc5f1a..35605aac125 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java @@ -6,8 +6,8 @@ import java.util.Collections; import java.util.Set; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; import org.matsim.api.core.v01.population.Leg; @@ -41,7 +41,7 @@ public class PersonStuckPrebookingTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void baselineTest() { + void baselineTest() { /* * Agent personA is performing three drt legs during the day. Agent personB does * exactly the same in parallel, both prebook their requests. @@ -72,7 +72,7 @@ public void baselineTest() { } @Test - public void cancelTest() { + void cancelTest() { /* * Agent personA is performing three drt legs during the day. Agent personB does * exactly the same in parallel, both prebook there requests. diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java index 2845a5d7af4..05f5eeb2eb8 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java @@ -2,8 +2,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.drt.prebooking.PrebookingTestEnvironment.RequestInfo; import org.matsim.contrib.drt.prebooking.logic.AttributeBasedPrebookingLogic; import org.matsim.contrib.drt.run.DrtConfigGroup; @@ -18,7 +18,7 @@ public class PrebookingTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void withoutPrebookedRequests() { + void withoutPrebookedRequests() { /*- * Standard test running with prebooking but without any prebooked requests */ @@ -66,7 +66,7 @@ static PrebookingParams installPrebooking(Controler controller, boolean installL } @Test - public void oneRequestArrivingLate() { + void oneRequestArrivingLate() { /*- * One request arriving after the requested departure time. Vehicle should wait * and depart with appropriate delay (taking into account a fixed duration for @@ -105,7 +105,7 @@ public void oneRequestArrivingLate() { } @Test - public void oneRequestArrivingEarly() { + void oneRequestArrivingEarly() { /*- * One request arriving in advance before the requested departure time. Vehicle * will pickup up agent and then depart after the duration to enter the vehicle. @@ -143,7 +143,7 @@ public void oneRequestArrivingEarly() { } @Test - public void twoSequentialRequests() { + void twoSequentialRequests() { /*- * Two requests that are scheduled in advance. * - First the early one is submitted, then the late one @@ -176,7 +176,7 @@ public void twoSequentialRequests() { } @Test - public void twoSequentialRequests_inverseSubmission() { + void twoSequentialRequests_inverseSubmission() { /*- * Two requests that are scheduled in advance. * - First the late one is submitted, then the early one (inverse of above test). @@ -210,7 +210,7 @@ public void twoSequentialRequests_inverseSubmission() { } @Test - public void sameTrip_differentDepartureTime() { + void sameTrip_differentDepartureTime() { /*- * Two requests with the same origin and destination, but distinct departure time. * - First, early one is submitted, then late one. @@ -248,7 +248,7 @@ public void sameTrip_differentDepartureTime() { } @Test - public void sameTrip_sameDepartureTime() { + void sameTrip_sameDepartureTime() { /*- * Two requests with the same origin and destination, and same departure time. * - First, A is submitted, then B. @@ -286,7 +286,7 @@ public void sameTrip_sameDepartureTime() { } @Test - public void sameTrip_extendPickupDuration() { + void sameTrip_extendPickupDuration() { /*- * Two requests with the same origin and destination, different departure times. * - First, A is submitted with departure time 2000 @@ -330,7 +330,7 @@ public void sameTrip_extendPickupDuration() { } @Test - public void sameTrip_splitPickup() { + void sameTrip_splitPickup() { /*- * Two requests with the same origin and destination, different departure times. * - First, A is submitted with departure time 2000 @@ -377,7 +377,7 @@ public void sameTrip_splitPickup() { } @Test - public void sameTrip_inverseSubmission_noPrepending() { + void sameTrip_inverseSubmission_noPrepending() { /*- * Two requests with the same origin and destination, different departure times. * - First, A is submitted with departure time 2020 @@ -435,7 +435,7 @@ public void sameTrip_inverseSubmission_noPrepending() { } @Test - public void sameTrip_inverseSubmission_splitPickup() { + void sameTrip_inverseSubmission_splitPickup() { /*- * Two requests with the same origin and destination, different departure times. * - First, A is submitted with departure time 2020 diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java index 2bf9646c17a..71dc3a222b8 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java @@ -23,8 +23,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -70,7 +70,7 @@ public class DrtRoutingModuleTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testCottbusClosestAccessEgressStopFinder() { + void testCottbusClosestAccessEgressStopFinder() { Scenario scenario = createTestScenario(); ActivityFacilities facilities = scenario.getActivityFacilities(); final double networkTravelSpeed = 0.83333; @@ -226,7 +226,7 @@ public void testCottbusClosestAccessEgressStopFinder() { } @Test - public void testRouteDescriptionHandling() { + void testRouteDescriptionHandling() { String oldRouteFormat = "600 400"; String newRouteFormat = "{\"maxWaitTime\":600.0,\"directRideTime\":400.0,\"unsharedPath\":[\"a\",\"b\",\"c\"]}"; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/MultiModeDrtMainModeIdentifierTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/MultiModeDrtMainModeIdentifierTest.java index d9af16f9896..517321d1305 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/MultiModeDrtMainModeIdentifierTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/MultiModeDrtMainModeIdentifierTest.java @@ -4,7 +4,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Activity; @@ -21,7 +21,7 @@ public class MultiModeDrtMainModeIdentifierTest { @Test - public void test() { + void test() { DrtConfigGroup drtConfigGroup = new DrtConfigGroup(); String drtMode = "drt"; drtConfigGroup.mode = drtMode; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java index 7878dad8604..04bd15fa5c8 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java @@ -30,9 +30,8 @@ import java.util.List; import java.util.Map; import java.util.stream.Collectors; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.drt.optimizer.DrtRequestInsertionRetryParams; import org.matsim.contrib.drt.optimizer.insertion.repeatedselective.RepeatedSelectiveInsertionSearchParams; @@ -76,7 +75,7 @@ public class RunDrtExampleIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testRunDrtExampleWithNoRejections_ExtensiveSearch() { + void testRunDrtExampleWithNoRejections_ExtensiveSearch() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_drt_config.xml"); Config config = ConfigUtils.loadConfig(configUrl, new MultiModeDrtConfigGroup(), new DvrpConfigGroup(), @@ -103,7 +102,7 @@ public void testRunDrtExampleWithNoRejections_ExtensiveSearch() { } @Test - public void testRunDrtExampleWithNoRejections_SelectiveSearch() { + void testRunDrtExampleWithNoRejections_SelectiveSearch() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_drt_config.xml"); Config config = ConfigUtils.loadConfig(configUrl, new MultiModeDrtConfigGroup(), new DvrpConfigGroup(), @@ -137,7 +136,7 @@ public void testRunDrtExampleWithNoRejections_SelectiveSearch() { } @Test - public void testRunDrtExampleWithNoRejections_RepeatedSelectiveSearch() { + void testRunDrtExampleWithNoRejections_RepeatedSelectiveSearch() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_drt_config.xml"); Config config = ConfigUtils.loadConfig(configUrl, new MultiModeDrtConfigGroup(), new DvrpConfigGroup(), @@ -172,7 +171,7 @@ public void testRunDrtExampleWithNoRejections_RepeatedSelectiveSearch() { } @Test - public void testRunDrtExampleWithRequestRetry() { + void testRunDrtExampleWithRequestRetry() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_drt_config.xml"); Config config = ConfigUtils.loadConfig(configUrl, new MultiModeDrtConfigGroup(), new DvrpConfigGroup(), @@ -201,7 +200,7 @@ public void testRunDrtExampleWithRequestRetry() { } @Test - public void testRunDrtStopbasedExample() { + void testRunDrtStopbasedExample() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_stop_based_drt_config.xml"); @@ -224,7 +223,7 @@ public void testRunDrtStopbasedExample() { } @Test - public void testRunDrtStopbasedExampleWithFlexibleStopDuration() { + void testRunDrtStopbasedExampleWithFlexibleStopDuration() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_stop_based_drt_config.xml"); @@ -259,7 +258,7 @@ public void install() { } @Test - public void testRunServiceAreabasedExampleWithSpeedUp() { + void testRunServiceAreabasedExampleWithSpeedUp() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_serviceArea_based_drt_config.xml"); @@ -282,7 +281,7 @@ public void testRunServiceAreabasedExampleWithSpeedUp() { } @Test - public void testRunDrtExampleWithIncrementalStopDuration() { + void testRunDrtExampleWithIncrementalStopDuration() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_drt_config.xml"); Config config = ConfigUtils.loadConfig(configUrl, new MultiModeDrtConfigGroup(), new DvrpConfigGroup(), @@ -321,7 +320,7 @@ public void install() { } @Test - public void testRunDrtWithPrebooking() { + void testRunDrtWithPrebooking() { Id.resetCaches(); URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_drt_config.xml"); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunMultiModeDrtExampleIT.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunMultiModeDrtExampleIT.java index 88aae448e87..b5bdb9ca19a 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunMultiModeDrtExampleIT.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunMultiModeDrtExampleIT.java @@ -22,13 +22,13 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; public class RunMultiModeDrtExampleIT { @Test - public void testRun() { + void testRun() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "multi_mode_one_shared_taxi_config.xml"); RunMultiModeDrtExample.run(configUrl, false, 0); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunOneSharedTaxiExampleIT.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunOneSharedTaxiExampleIT.java index db6373e49be..eaa173d1466 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunOneSharedTaxiExampleIT.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunOneSharedTaxiExampleIT.java @@ -20,7 +20,7 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; @@ -29,7 +29,7 @@ */ public class RunOneSharedTaxiExampleIT { @Test - public void testRun() { + void testRun() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "one_shared_taxi_config.xml"); RunOneSharedTaxiExample.run(configUrl, false, 1); } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/speedup/DrtSpeedUpTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/speedup/DrtSpeedUpTest.java index af92306b69e..1f08cf7c993 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/speedup/DrtSpeedUpTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/speedup/DrtSpeedUpTest.java @@ -30,8 +30,7 @@ import java.util.Collections; import java.util.List; import java.util.Map; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -72,7 +71,7 @@ public class DrtSpeedUpTest { private final ControllerConfigGroup controlerConfig = new ControllerConfigGroup(); @Test - public final void test_computeMovingAverage() { + final void test_computeMovingAverage() { List list = List.of(2., 5., 22.); assertThat(computeMovingAverage(2, list)).isEqualTo(27. / 2); assertThat(computeMovingAverage(3, list)).isEqualTo(29. / 3); @@ -80,7 +79,7 @@ public final void test_computeMovingAverage() { } @Test - public void test_isTeleportDrtUsers() { + void test_isTeleportDrtUsers() { drtSpeedUpParams.fractionOfIterationsSwitchOn = 0.1; drtSpeedUpParams.fractionOfIterationsSwitchOff = 0.9; drtSpeedUpParams.intervalDetailedIteration = 10; @@ -124,7 +123,7 @@ public void test_isTeleportDrtUsers() { private final DrtEventSequenceCollector requestAnalyzer = mock(DrtEventSequenceCollector.class); @Test - public void test_useOnlyInitialEstimates_noRegression() { + void test_useOnlyInitialEstimates_noRegression() { //iters 0 & 100 - simulated, iters 1...99 - teleported drtSpeedUpParams.fractionOfIterationsSwitchOn = 0.0; drtSpeedUpParams.fractionOfIterationsSwitchOff = 1.0; @@ -161,7 +160,7 @@ public void test_useOnlyInitialEstimates_noRegression() { } @Test - public void test_useAveragesFromLastTwoSimulations_noRegression() { + void test_useAveragesFromLastTwoSimulations_noRegression() { //iters 0, 2, 4 - simulated, iters 1, 3 - teleported drtSpeedUpParams.fractionOfIterationsSwitchOn = 0.0; drtSpeedUpParams.fractionOfIterationsSwitchOff = 1.0; @@ -209,7 +208,7 @@ public void test_useAveragesFromLastTwoSimulations_noRegression() { } @Test - public void test_linearRegression() { + void test_linearRegression() { //iters 0, 2, 4 - simulated, iters 1, 3 - teleported drtSpeedUpParams.fractionOfIterationsSwitchOn = 0.0; drtSpeedUpParams.fractionOfIterationsSwitchOff = 1.0; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/util/DrtEventsReadersTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/util/DrtEventsReadersTest.java index 27fcefc3b52..6ba4b41e0c8 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/util/DrtEventsReadersTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/util/DrtEventsReadersTest.java @@ -28,7 +28,7 @@ import java.util.Collections; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; import org.matsim.api.core.v01.network.Link; @@ -72,7 +72,7 @@ public class DrtEventsReadersTest { taskEnded(70, EmptyVehicleRelocator.RELOCATE_VEHICLE_TASK_TYPE, 3, link2)); @Test - public void testReader() { + void testReader() { var outputStream = new ByteArrayOutputStream(); EventWriterXML writer = new EventWriterXML(outputStream); drtEvents.forEach(writer::handleEvent); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/benchmark/DvrpBenchmarkQSimModuleTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/benchmark/DvrpBenchmarkQSimModuleTest.java index 1571faf0e43..da9b96c0036 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/benchmark/DvrpBenchmarkQSimModuleTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/benchmark/DvrpBenchmarkQSimModuleTest.java @@ -25,7 +25,7 @@ import static org.mockito.Mockito.mock; import static org.mockito.Mockito.when; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.network.NetworkUtils; import org.matsim.core.router.util.TravelTime; @@ -36,7 +36,7 @@ */ public class DvrpBenchmarkQSimModuleTest { @Test - public void calcLinkSpeed() { + void calcLinkSpeed() { var link = NetworkUtils.createLink(Id.createLinkId("id"), null, null, null, 150, 15, 10, 1); var vehicle = mock(Vehicle.class); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiExampleIT.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiExampleIT.java index 0e509daca53..cb490c13c13 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiExampleIT.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiExampleIT.java @@ -21,13 +21,13 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; public class RunOneTaxiExampleIT { @Test - public void testRun() { + void testRun() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "generic_dvrp_one_taxi_config.xml"); RunOneTaxiExample.run(configUrl, "one_taxi_vehicles.xml", false, 0); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java index 55e0e574dac..fc8deb6874c 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java @@ -33,8 +33,8 @@ import org.apache.logging.log4j.Logger; import org.assertj.core.data.Offset; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -73,7 +73,7 @@ public class RunOneTaxiWithPrebookingExampleIT { @Ignore @Test - public void testRun() { + void testRun() { // load config URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "generic_dvrp_one_taxi_config.xml"); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxionetruck/RunOneTaxiOneTruckExampleIT.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxionetruck/RunOneTaxiOneTruckExampleIT.java index 8f9ec937f63..10c9373563d 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxionetruck/RunOneTaxiOneTruckExampleIT.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxionetruck/RunOneTaxiOneTruckExampleIT.java @@ -22,13 +22,13 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; public class RunOneTaxiOneTruckExampleIT { @Test - public void testRun() { + void testRun() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "one_taxi_one_truck_config.xml"); RunOneTaxiOneTruckExample.run(configUrl, "one_taxi_vehicles.xml", "one_truck_vehicles.xml", false, 0); } diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetruck/RunOneTruckExampleIT.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetruck/RunOneTruckExampleIT.java index 1363005eb93..b43bcac98b5 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetruck/RunOneTruckExampleIT.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetruck/RunOneTruckExampleIT.java @@ -21,13 +21,13 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; public class RunOneTruckExampleIT { @Test - public void testRun() { + void testRun() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "one_truck_config.xml"); RunOneTruckExample.run(configUrl, "one_truck_vehicles.xml", false, 0); } diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/DefaultPassengerEngineTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/DefaultPassengerEngineTest.java index db4efe8d602..97579d14517 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/DefaultPassengerEngineTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/DefaultPassengerEngineTest.java @@ -25,8 +25,7 @@ import java.util.Collections; import java.util.List; import java.util.Set; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -80,7 +79,7 @@ public class DefaultPassengerEngineTest { private final Fleet fleet = () -> ImmutableMap.of(oneTaxi.getId(), oneTaxi); @Test - public void test_valid_served() { + void test_valid_served() { double departureTime = 0; fixture.addPersonWithLeg(fixture.linkAB, fixture.linkBA, departureTime, fixture.PERSON_ID); @@ -114,7 +113,7 @@ public void test_valid_served() { } @Test - public void test_invalid_rejected() { + void test_invalid_rejected() { double departureTime = 0; fixture.addPersonWithLeg(fixture.linkAB, fixture.linkBA, departureTime, fixture.PERSON_ID); @@ -132,7 +131,7 @@ public void test_invalid_rejected() { } @Test - public void test_valid_rejected() { + void test_valid_rejected() { double departureTime = 0; fixture.addPersonWithLeg(fixture.linkAB, fixture.linkBA, departureTime, fixture.PERSON_ID); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/GroupPassengerEngineTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/GroupPassengerEngineTest.java index 2f34014ca2f..9630efb9374 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/GroupPassengerEngineTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/GroupPassengerEngineTest.java @@ -2,7 +2,7 @@ import com.google.common.collect.ImmutableMap; import org.apache.commons.compress.utils.Sets; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.*; import org.matsim.api.core.v01.network.Network; @@ -49,7 +49,7 @@ public class GroupPassengerEngineTest { private final Fleet fleet = () -> ImmutableMap.of(oneTaxi.getId(), oneTaxi); @Test - public void test_group() { + void test_group() { double departureTime = 0; Id person1 = Id.createPersonId("1"); Id person2 = Id.createPersonId("2"); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/TeleportingPassengerEngineTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/TeleportingPassengerEngineTest.java index 6d1c3edd7d1..e26364800ab 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/TeleportingPassengerEngineTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/passenger/TeleportingPassengerEngineTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.dvrp.passenger; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.*; import org.matsim.api.core.v01.network.Network; @@ -50,7 +50,7 @@ public class TeleportingPassengerEngineTest { private final PassengerEngineTestFixture fixture = new PassengerEngineTestFixture(); @Test - public void test_valid_teleported() { + void test_valid_teleported() { double departureTime = 0; fixture.addPersonWithLeg(fixture.linkAB, fixture.linkBA, departureTime, fixture.PERSON_ID); @@ -81,7 +81,7 @@ public void test_valid_teleported() { } @Test - public void test_invalid_rejected() { + void test_invalid_rejected() { double departureTime = 0; fixture.addPersonWithLeg(fixture.linkAB, fixture.linkBA, departureTime, fixture.PERSON_ID); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/LeastCostPathTreeStopCriteriaTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/LeastCostPathTreeStopCriteriaTest.java index 9b83de3356f..b10829bc365 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/LeastCostPathTreeStopCriteriaTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/LeastCostPathTreeStopCriteriaTest.java @@ -28,7 +28,7 @@ import java.util.Map; import java.util.function.IntToDoubleFunction; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.router.speedy.LeastCostPathTree.StopCriterion; import org.matsim.testcases.fakes.FakeNode; @@ -39,7 +39,7 @@ public class LeastCostPathTreeStopCriteriaTest { @Test - public void testAnd() { + void testAnd() { StopCriterion scTrue = (nodeIndex, arrivalTime, travelCost, distance, departureTime) -> true; StopCriterion scFalse = (nodeIndex, arrivalTime, travelCost, distance, departureTime) -> false; @@ -51,7 +51,7 @@ public void testAnd() { } @Test - public void testOr() { + void testOr() { StopCriterion scTrue = (nodeIndex, arrivalTime, travelCost, distance, departureTime) -> true; StopCriterion scFalse = (nodeIndex, arrivalTime, travelCost, distance, departureTime) -> false; @@ -63,7 +63,7 @@ public void testOr() { } @Test - public void testMaxTravelTime() { + void testMaxTravelTime() { StopCriterion sc = maxTravelTime(100); //TT is 100 - continue @@ -74,13 +74,13 @@ public void testMaxTravelTime() { } @Test - public void testAllEndNodesReached_noEndNodes() { + void testAllEndNodesReached_noEndNodes() { assertThatThrownBy(() -> allEndNodesReached(List.of())).isExactlyInstanceOf(IllegalArgumentException.class) .hasMessage("At least one end node must be provided."); } @Test - public void testAllEndNodesReached_oneEndNode() { + void testAllEndNodesReached_oneEndNode() { var endNode = new FakeNode(Id.createNodeId("end_node")); var otherNode = new FakeNode(Id.createNodeId("other_node")); StopCriterion sc = allEndNodesReached(List.of(endNode)); @@ -96,7 +96,7 @@ public void testAllEndNodesReached_oneEndNode() { } @Test - public void testAllEndNodesReached_twoEndNodes() { + void testAllEndNodesReached_twoEndNodes() { var endNode1 = new FakeNode(Id.createNodeId("end_node_1")); var endNode2 = new FakeNode(Id.createNodeId("end_node_2")); var otherNode = new FakeNode(Id.createNodeId("other_node")); @@ -119,13 +119,13 @@ public void testAllEndNodesReached_twoEndNodes() { } @Test - public void testLeastCostEndNodeReached_noEndNodes() { + void testLeastCostEndNodeReached_noEndNodes() { assertThatThrownBy(() -> new LeastCostEndNodeReached(List.of(), value -> 0)).isExactlyInstanceOf( IllegalArgumentException.class).hasMessage("At least one end node must be provided."); } @Test - public void testLeastCostEndNodeReached_oneEndNode() { + void testLeastCostEndNodeReached_oneEndNode() { var endNodeId = Id.createNodeId("end_node"); var otherNodeId = Id.createNodeId("other_node"); @@ -152,7 +152,7 @@ public void testLeastCostEndNodeReached_oneEndNode() { } @Test - public void testLeastCostEndNodeReached_twoEndNodes_stopBeforeReachingTheOtherEndNode() { + void testLeastCostEndNodeReached_twoEndNodes_stopBeforeReachingTheOtherEndNode() { var endNodeId1 = Id.createNodeId("end_node"); var endNodeId2 = Id.createNodeId("end_node_2"); var otherNodeId = Id.createNodeId("other_node"); @@ -172,7 +172,7 @@ public void testLeastCostEndNodeReached_twoEndNodes_stopBeforeReachingTheOtherEn } @Test - public void testLeastCostEndNodeReached_twoEndNodes_bothVisited_fartherEndNodeWithLowerTotalCost() { + void testLeastCostEndNodeReached_twoEndNodes_bothVisited_fartherEndNodeWithLowerTotalCost() { var endNodeId1 = Id.createNodeId("end_node"); var endNodeId2 = Id.createNodeId("end_node_2"); @@ -192,7 +192,7 @@ public void testLeastCostEndNodeReached_twoEndNodes_bothVisited_fartherEndNodeWi } @Test - public void testLeastCostEndNodeReached_twoEndNodes_noAdditionalCost_stopAfterVisitingFirstEndNode() { + void testLeastCostEndNodeReached_twoEndNodes_noAdditionalCost_stopAfterVisitingFirstEndNode() { var endNodeId1 = Id.createNodeId("end_node"); var endNodeId2 = Id.createNodeId("end_node_2"); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/OneToManyPathCalculatorTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/OneToManyPathCalculatorTest.java index d042fb3c814..8730f17dcb9 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/OneToManyPathCalculatorTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/OneToManyPathCalculatorTest.java @@ -27,7 +27,7 @@ import java.util.List; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; @@ -76,7 +76,7 @@ public void init() { } @Test - public void forward_fromNodeB_toNodeB() { + void forward_fromNodeB_toNodeB() { //forward search starting from nodeB at time 0 var pathCalculator = new OneToManyPathCalculator(nodeMap, dijkstraTree, travelTime, true, linkAB, 0); @@ -94,7 +94,7 @@ public void forward_fromNodeB_toNodeB() { } @Test - public void forward_fromNodeB_toNodesBD() { + void forward_fromNodeB_toNodesBD() { //forward search starting from nodeB at time 0 var pathCalculator = new OneToManyPathCalculator(nodeMap, dijkstraTree, travelTime, true, linkAB, 0); @@ -109,7 +109,7 @@ public void forward_fromNodeB_toNodesBD() { } @Test - public void forward_fromNodeB_toNodesBD_maxTravelTime() { + void forward_fromNodeB_toNodesBD_maxTravelTime() { //forward search starting from nodeB at time 0 var pathCalculator = new OneToManyPathCalculator(nodeMap, dijkstraTree, travelTime, true, linkAB, 0); @@ -124,7 +124,7 @@ public void forward_fromNodeB_toNodesBD_maxTravelTime() { } @Test - public void backward_fromNodeD_toNodeD() { + void backward_fromNodeD_toNodeD() { //backward search starting from nodeD at time 0 var pathCalculator = new OneToManyPathCalculator(nodeMap, dijkstraTree, travelTime, false, linkDE, 0); @@ -142,7 +142,7 @@ public void backward_fromNodeD_toNodeD() { } @Test - public void backward_fromNodeD_toNodesBD() { + void backward_fromNodeD_toNodesBD() { //backward search starting from nodeD at time 0 var pathCalculator = new OneToManyPathCalculator(nodeMap, dijkstraTree, travelTime, false, linkDE, 0); @@ -157,7 +157,7 @@ public void backward_fromNodeD_toNodesBD() { } @Test - public void backward_fromNodeD_toNodesBD_maxTravelTime() { + void backward_fromNodeD_toNodesBD_maxTravelTime() { //backward search starting from nodeD at time 0 var pathCalculator = new OneToManyPathCalculator(nodeMap, dijkstraTree, travelTime, false, linkDE, 0); @@ -172,7 +172,7 @@ public void backward_fromNodeD_toNodesBD_maxTravelTime() { } @Test - public void equalFromLinkAndToLink() { + void equalFromLinkAndToLink() { LeastCostPathTree mockedTree = mock(LeastCostPathTree.class); for (boolean forward : List.of(true, false)) { @@ -186,7 +186,7 @@ public void equalFromLinkAndToLink() { } @Test - public void pathData_forward() { + void pathData_forward() { //forward search starting from linkAB at time 0 var pathCalculator = new OneToManyPathCalculator(nodeMap, dijkstraTree, travelTime, true, linkAB, 0); @@ -198,7 +198,7 @@ public void pathData_forward() { } @Test - public void pathData_backward() { + void pathData_backward() { //backward search starting from linkDE at time 0 var pathCalculator = new OneToManyPathCalculator(nodeMap, dijkstraTree, travelTime, false, linkDE, 0); @@ -210,7 +210,7 @@ public void pathData_backward() { } @Test - public void pathData_fromLinkEqualsToLink() { + void pathData_fromLinkEqualsToLink() { for (boolean forward : List.of(true, false)) { var pathCalculator = new OneToManyPathCalculator(nodeMap, dijkstraTree, travelTime, forward, linkAB, 0); pathCalculator.calculateDijkstraTree(List.of(linkAB)); @@ -219,7 +219,7 @@ public void pathData_fromLinkEqualsToLink() { } @Test - public void pathData_nodeNotReached() { + void pathData_nodeNotReached() { for (boolean forward : List.of(true, false)) { var pathCalculator = new OneToManyPathCalculator(nodeMap, dijkstraTree, travelTime, forward, linkAB, 0); pathCalculator.calculateDijkstraTree(List.of(linkBC)); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/DiversionTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/DiversionTest.java index adf44ba57ac..822f23b36c9 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/DiversionTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/DiversionTest.java @@ -6,7 +6,7 @@ import java.util.Set; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -75,7 +75,6 @@ public class DiversionTest { static public final String MODE = "testmode"; static public final int DIVERSION_FREQUENCY = 10; - @Test /** * This is a relatively complex test to the the diversion behaviour. The * experiment is constructed as folows: We have one DVRP vehicle which moves @@ -120,7 +119,8 @@ public class DiversionTest { * current one. * */ - public void testRepeatedSameDestinationDiversions() { + @Test + void testRepeatedSameDestinationDiversions() { Config config = ConfigUtils.createConfig(); { @@ -423,7 +423,6 @@ static private class TestTracker { private List taskEndTimes = new LinkedList<>(); } - @Test /** * This test is similar as the one above. However, there is another catch when * diverting, which is not covered on top. In fact, following the QSim and @@ -447,7 +446,8 @@ static private class TestTracker { * get a reduced arrival time estimate by one second. * */ - public void testRepeatedDiversionToDifferentDestinationRightBeforeLastLink() { + @Test + void testRepeatedDiversionToDifferentDestinationRightBeforeLastLink() { Config config = ConfigUtils.createConfig(); { diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/RoutingTimeStructureTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/RoutingTimeStructureTest.java index 41760878b96..f670f83a405 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/RoutingTimeStructureTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/RoutingTimeStructureTest.java @@ -28,7 +28,7 @@ import java.util.Optional; import org.apache.commons.lang3.tuple.Pair; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; @@ -49,7 +49,7 @@ */ public class RoutingTimeStructureTest { @Test - public void testTimingWithSimpleAccess() { + void testTimingWithSimpleAccess() { TimeInterpretation timeInterpretation = TimeInterpretation.create(ConfigUtils.createConfig()); Facility fromFacility = mock(Facility.class); @@ -109,7 +109,7 @@ public void testTimingWithSimpleAccess() { } @Test - public void testTimingWithComplexAccess() { + void testTimingWithComplexAccess() { TimeInterpretation timeInterpretation = TimeInterpretation.create(ConfigUtils.createConfig()); Facility fromFacility = mock(Facility.class); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/trafficmonitoring/DvrpOfflineTravelTimeEstimatorTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/trafficmonitoring/DvrpOfflineTravelTimeEstimatorTest.java index 229738c16ce..808df1ff835 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/trafficmonitoring/DvrpOfflineTravelTimeEstimatorTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/trafficmonitoring/DvrpOfflineTravelTimeEstimatorTest.java @@ -22,8 +22,7 @@ import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -61,7 +60,7 @@ public class DvrpOfflineTravelTimeEstimatorTest { private final TimeDiscretizer timeDiscretizer = new TimeDiscretizer(200, 100); @Test - public void getLinkTravelTime_timeAreCorrectlyBinned() { + void getLinkTravelTime_timeAreCorrectlyBinned() { var estimator = new DvrpOfflineTravelTimeEstimator(initialTT, null, network, timeDiscretizer, 0.25, null); //bin 0 @@ -79,7 +78,7 @@ public void getLinkTravelTime_timeAreCorrectlyBinned() { } @Test - public void getLinkTravelTime_exponentialAveragingOverIterations() { + void getLinkTravelTime_exponentialAveragingOverIterations() { double alpha = 0.25; //observed TTs for each time bin @@ -124,7 +123,7 @@ public void getLinkTravelTime_exponentialAveragingOverIterations() { } @Test - public void getLinkTravelTime_linkOutsideNetwork_fail() { + void getLinkTravelTime_linkOutsideNetwork_fail() { var linkOutsideNetwork = new FakeLink(Id.createLinkId("some-link")); var estimator = new DvrpOfflineTravelTimeEstimator(initialTT, null, network, timeDiscretizer, 0.25, null); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/trafficmonitoring/DvrpOfflineTravelTimesTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/trafficmonitoring/DvrpOfflineTravelTimesTest.java index efaa83bac7b..e3b904d4084 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/trafficmonitoring/DvrpOfflineTravelTimesTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/trafficmonitoring/DvrpOfflineTravelTimesTest.java @@ -34,8 +34,7 @@ import java.util.Arrays; import java.util.List; import java.util.Objects; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.common.timeprofile.TimeDiscretizer; @@ -52,7 +51,7 @@ public class DvrpOfflineTravelTimesTest { private final Id linkIdB = Id.createLinkId("B"); @Test - public void saveLinkTravelTimes() throws IOException { + void saveLinkTravelTimes() throws IOException { //the matrix may have more than 2 rows (depends on how many link ids are cached) var linkTTs = new double[Id.getNumberOfIds(Link.class)][]; @@ -70,7 +69,7 @@ public void saveLinkTravelTimes() throws IOException { } @Test - public void loadLinkTravelTimes() throws IOException { + void loadLinkTravelTimes() throws IOException { var line0 = String.join(";", "linkId", "0.0", "900.0", "1800.0", "2700.0", "3600.0"); var line1 = String.join(";", "A", 0.1 + "", 1.1 + "", 2.2 + "", 3.3 + "", 4.4 + ""); var line2 = String.join(";", "B", 5.5 + "", 6.6 + "", 7.7 + "", 8.8 + "", 9.9 + ""); @@ -89,7 +88,7 @@ public void loadLinkTravelTimes() throws IOException { } @Test - public void convertToLinkTravelTimes() { + void convertToLinkTravelTimes() { var link = new FakeLink(Id.createLinkId("link_A")); var timeDiscretizer = new TimeDiscretizer(100, 100); @@ -105,7 +104,7 @@ public void convertToLinkTravelTimes() { } @Test - public void asTravelTime() { + void asTravelTime() { var linkA = new FakeLink(Id.createLinkId("link_A")); var linkB = new FakeLink(Id.createLinkId("link_B")); var timeDiscretizer = new TimeDiscretizer(100, 100); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/util/DvrpEventsReadersTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/util/DvrpEventsReadersTest.java index b9452d7c495..3f8cbc2594e 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/util/DvrpEventsReadersTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/util/DvrpEventsReadersTest.java @@ -29,7 +29,7 @@ import java.util.Collections; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; import org.matsim.api.core.v01.network.Link; @@ -81,7 +81,7 @@ private enum TestTaskType implements Task.TaskType { new TaskEndedEvent(333, mode, vehicle, driver, TestTaskType.DRIVE_TASK, 0, toLink)); @Test - public void testReader() { + void testReader() { var outputStream = new ByteArrayOutputStream(); EventWriterXML writer = new EventWriterXML(outputStream); dvrpEvents.forEach(writer::handleEvent); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/vrpagent/VrpAgentLogicTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/vrpagent/VrpAgentLogicTest.java index 89958aed641..9546a1ce4e4 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/vrpagent/VrpAgentLogicTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/vrpagent/VrpAgentLogicTest.java @@ -26,7 +26,7 @@ import static org.matsim.contrib.dvrp.vrpagent.VrpAgentLogic.BEFORE_SCHEDULE_ACTIVITY_TYPE; import static org.mockito.Mockito.*; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.dvrp.fleet.DvrpVehicle; @@ -86,7 +86,7 @@ public void nextTask(DvrpVehicle vehicle) { null, dynAgentLogic); @Test - public void testInitialActivity_unplanned() { + void testInitialActivity_unplanned() { DynActivity initialActivity = dynAgentLogic.computeInitialActivity(dynAgent); assertThat(initialActivity.getActivityType()).isEqualTo(BEFORE_SCHEDULE_ACTIVITY_TYPE); @@ -95,7 +95,7 @@ public void testInitialActivity_unplanned() { } @Test - public void testInitialActivity_planned() { + void testInitialActivity_planned() { DynActivity initialActivity = dynAgentLogic.computeInitialActivity(dynAgent); StayTask task0 = new DefaultStayTask(TestTaskType.TYPE, 10, 90, startLink); @@ -107,7 +107,7 @@ public void testInitialActivity_planned() { } @Test - public void testInitialActivity_started_failure() { + void testInitialActivity_started_failure() { DynActivity initialActivity = dynAgentLogic.computeInitialActivity(dynAgent); StayTask task0 = new DefaultStayTask(TestTaskType.TYPE, 10, 90, startLink); @@ -121,7 +121,7 @@ public void testInitialActivity_started_failure() { } @Test - public void testNextAction_unplanned_completed() { + void testNextAction_unplanned_completed() { IdleDynActivity nextAction = (IdleDynActivity)dynAgentLogic.computeNextAction(null, vehicle.getServiceEndTime()); @@ -131,7 +131,7 @@ public void testNextAction_unplanned_completed() { } @Test - public void testNextAction_planned_started() { + void testNextAction_planned_started() { double time = 10; StayTask task0 = new DefaultStayTask(TestTaskType.TYPE, time, 90, startLink); vehicle.getSchedule().addTask(task0); @@ -142,7 +142,7 @@ public void testNextAction_planned_started() { } @Test - public void testNextAction_started_started() { + void testNextAction_started_started() { double time = 50; StayTask task0 = new DefaultStayTask(TestTaskType.TYPE, 10, time, startLink); vehicle.getSchedule().addTask(task0); @@ -156,7 +156,7 @@ public void testNextAction_started_started() { } @Test - public void testNextAction_started_completed() { + void testNextAction_started_completed() { double time = 90; StayTask task0 = new DefaultStayTask(TestTaskType.TYPE, 10, time, startLink); vehicle.getSchedule().addTask(task0); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dynagent/examples/random/RunRandomDynAgentExampleTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dynagent/examples/random/RunRandomDynAgentExampleTest.java index 7076c71a804..78db1598058 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dynagent/examples/random/RunRandomDynAgentExampleTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dynagent/examples/random/RunRandomDynAgentExampleTest.java @@ -21,13 +21,13 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; public class RunRandomDynAgentExampleTest { @Test - public void testRun() { + void testRun() { URL networkUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "config.xml"); RunRandomDynAgentExample.run(networkUrl, "grid_network.xml", false); } diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/zone/SquareGridTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/zone/SquareGridTest.java index 697585b3ff6..dc09184888e 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/zone/SquareGridTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/zone/SquareGridTest.java @@ -25,7 +25,7 @@ import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Node; @@ -36,20 +36,20 @@ */ public class SquareGridTest { @Test - public void emptyNodes_fail() { + void emptyNodes_fail() { assertThatThrownBy(() -> new SquareGrid(List.of(), 100)).isExactlyInstanceOf(IllegalArgumentException.class) .hasMessage("Cannot create SquareGrid if no nodes"); } @Test - public void outsideBoundaries_withinEpsilon_success() { + void outsideBoundaries_withinEpsilon_success() { Node node_0_0 = node(0, 0); SquareGrid grid = new SquareGrid(List.of(node_0_0), 100); assertThatCode(() -> grid.getZone(new Coord(-EPSILON, EPSILON))).doesNotThrowAnyException(); } @Test - public void outsideBoundaries_outsideEpsilon_fail() { + void outsideBoundaries_outsideEpsilon_fail() { Node node_0_0 = node(0, 0); SquareGrid grid = new SquareGrid(List.of(node_0_0), 100); assertThatThrownBy(() -> grid.getZone(new Coord(-2 * EPSILON, 0))).isExactlyInstanceOf( @@ -57,7 +57,7 @@ public void outsideBoundaries_outsideEpsilon_fail() { } @Test - public void testLazyZoneCreation() { + void testLazyZoneCreation() { Node node_0_0 = node(0, 0); SquareGrid grid = new SquareGrid(List.of(node_0_0), 100); @@ -69,7 +69,7 @@ public void testLazyZoneCreation() { } @Test - public void testGrid() { + void testGrid() { Node node_0_0 = node(0, 0); Node node_150_150 = node(150, 150); SquareGrid grid = new SquareGrid(List.of(node_0_0, node_150_150), 100); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/FreeSpeedTravelTimeMatrixTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/FreeSpeedTravelTimeMatrixTest.java index e5522c47942..c5743ffaafb 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/FreeSpeedTravelTimeMatrixTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/FreeSpeedTravelTimeMatrixTest.java @@ -22,7 +22,7 @@ import static org.assertj.core.api.Assertions.assertThat; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Network; @@ -47,7 +47,7 @@ public FreeSpeedTravelTimeMatrixTest() { } @Test - public void matrix() { + void matrix() { DvrpTravelTimeMatrixParams params = new DvrpTravelTimeMatrixParams(); params.cellSize = 100; params.maxNeighborDistance = 0; @@ -67,7 +67,7 @@ public void matrix() { } @Test - public void sparseMatrix() { + void sparseMatrix() { DvrpTravelTimeMatrixParams params = new DvrpTravelTimeMatrixParams(); params.cellSize = 100; params.maxNeighborDistance = 9999; diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/MatrixTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/MatrixTest.java index 18f59308d00..02e6f9fc5dd 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/MatrixTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/MatrixTest.java @@ -26,7 +26,7 @@ import java.util.NoSuchElementException; import java.util.Set; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.zone.Zone; @@ -46,7 +46,7 @@ public class MatrixTest { private final static int MAX_ALLOWED_VALUE = (1 << 16) - 2; @Test - public void get_unsetValue() { + void get_unsetValue() { for (Zone from : zones) { for (Zone to : zones) { assertThatThrownBy(() -> matrix.get(from, to)).isExactlyInstanceOf(NoSuchElementException.class) @@ -56,7 +56,7 @@ public void get_unsetValue() { } @Test - public void get_validValue() { + void get_validValue() { matrix.set(zoneA, zoneB, 0); assertThat(matrix.get(zoneA, zoneB)).isEqualTo(0); @@ -65,7 +65,7 @@ public void get_validValue() { } @Test - public void set_invalidValue() { + void set_invalidValue() { assertThatThrownBy(() -> matrix.set(zoneA, zoneB, Double.POSITIVE_INFINITY)).isExactlyInstanceOf( IllegalArgumentException.class); assertThatThrownBy(() -> matrix.set(zoneA, zoneC, -1)).isExactlyInstanceOf(IllegalArgumentException.class); @@ -74,13 +74,13 @@ public void set_invalidValue() { } @Test - public void get_unknownZone() { + void get_unknownZone() { assertThatThrownBy(() -> matrix.get(zoneA, unknownZone)).isExactlyInstanceOf(IllegalArgumentException.class); assertThatThrownBy(() -> matrix.get(unknownZone, zoneC)).isExactlyInstanceOf(IllegalArgumentException.class); } @Test - public void set_unknownZone() { + void set_unknownZone() { assertThatThrownBy(() -> matrix.set(zoneA, unknownZone, 1)).isExactlyInstanceOf(IllegalArgumentException.class); assertThatThrownBy(() -> matrix.set(unknownZone, zoneC, 1)).isExactlyInstanceOf(IllegalArgumentException.class); } diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/SparseMatrixTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/SparseMatrixTest.java index 808730fea7c..a277900e956 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/SparseMatrixTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/SparseMatrixTest.java @@ -24,8 +24,7 @@ import static org.matsim.contrib.zone.skims.SparseMatrix.SparseRow; import java.util.List; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Node; import org.matsim.contrib.zone.skims.SparseMatrix.NodeAndTime; @@ -44,7 +43,7 @@ public class SparseMatrixTest { private final List allNodes = List.of(nodeA, nodeB, nodeC); @Test - public void emptyMatrix() { + void emptyMatrix() { var matrix = new SparseMatrix(); for (Node from : allNodes) { for (Node to : allNodes) { @@ -54,7 +53,7 @@ public void emptyMatrix() { } @Test - public void triangularMatrix() { + void triangularMatrix() { var matrix = new SparseMatrix(); //A -> A, B, C matrix.setRow(nodeA, @@ -76,7 +75,7 @@ public void triangularMatrix() { } @Test - public void nodeAndTimeOrderNotImportant() { + void nodeAndTimeOrderNotImportant() { //A -> A, B, C var nodeAndTimes = List.of(nodeAndTime(nodeA, 0), nodeAndTime(nodeB, 1), nodeAndTime(nodeC, 2)); diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/TravelTimeMatricesTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/TravelTimeMatricesTest.java index d60f34f7fa2..02d7b7bd241 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/TravelTimeMatricesTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/zone/skims/TravelTimeMatricesTest.java @@ -24,7 +24,7 @@ import java.util.Map; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Network; @@ -39,7 +39,7 @@ */ public class TravelTimeMatricesTest { @Test - public void travelTimeMatrix() { + void travelTimeMatrix() { Network network = NetworkUtils.createNetwork(); Node nodeA = NetworkUtils.createAndAddNode(network, Id.createNodeId("A"), new Coord(0, 0)); Node nodeB = NetworkUtils.createAndAddNode(network, Id.createNodeId("B"), new Coord(150, 150)); @@ -58,7 +58,7 @@ public void travelTimeMatrix() { } @Test - public void travelTimeSparseMatrix_maxDistance() { + void travelTimeSparseMatrix_maxDistance() { Network network = NetworkUtils.createNetwork(); Node nodeA = NetworkUtils.createAndAddNode(network, Id.createNodeId("A"), new Coord(0, 0)); Node nodeB = NetworkUtils.createAndAddNode(network, Id.createNodeId("B"), new Coord(150, 150)); @@ -85,7 +85,7 @@ public void travelTimeSparseMatrix_maxDistance() { } @Test - public void travelTimeSparseMatrix_maxTravelTime() { + void travelTimeSparseMatrix_maxTravelTime() { Network network = NetworkUtils.createNetwork(); Node nodeA = NetworkUtils.createAndAddNode(network, Id.createNodeId("A"), new Coord(0, 0)); Node nodeB = NetworkUtils.createAndAddNode(network, Id.createNodeId("B"), new Coord(150, 150)); diff --git a/contribs/dvrp/src/test/java/org/matsim/core/router/speedy/SpeedyMultiSourceALTBackwardTest.java b/contribs/dvrp/src/test/java/org/matsim/core/router/speedy/SpeedyMultiSourceALTBackwardTest.java index 7377d2c7ba0..828831db27b 100644 --- a/contribs/dvrp/src/test/java/org/matsim/core/router/speedy/SpeedyMultiSourceALTBackwardTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/core/router/speedy/SpeedyMultiSourceALTBackwardTest.java @@ -24,7 +24,7 @@ import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -80,7 +80,7 @@ public class SpeedyMultiSourceALTBackwardTest { travelDisutility); @Test - public void testOneSource_backward() { + void testOneSource_backward() { var startNode = new StartNode(nodeB, 9999, 7777); var path = multiSourceALT.calcLeastCostPath(List.of(startNode), nodeA, null, null, true); assertThat(path.nodes).containsExactly(nodeA, nodeE, nodeD, nodeB); @@ -90,7 +90,7 @@ public void testOneSource_backward() { } @Test - public void testManySources_backward_sameStartCost() { + void testManySources_backward_sameStartCost() { var startNodeB = new StartNode(nodeB, 9999, 7777); var startNodeC = new StartNode(nodeC, 9999, 7777); var path = multiSourceALT.calcLeastCostPath(List.of(startNodeB, startNodeC), nodeA, null, null, true); @@ -101,7 +101,7 @@ public void testManySources_backward_sameStartCost() { } @Test - public void testManySources_backward_selectFartherNodeWithLowerCost() { + void testManySources_backward_selectFartherNodeWithLowerCost() { var startNodeB = new StartNode(nodeB, 100, 7777); var startNodeC = new StartNode(nodeC, 111, 1111); var path = multiSourceALT.calcLeastCostPath(List.of(startNodeB, startNodeC), nodeA, null, null, true); @@ -112,7 +112,7 @@ public void testManySources_backward_selectFartherNodeWithLowerCost() { } @Test - public void testManySources_backward_selectNearestNodeWithHigherCost() { + void testManySources_backward_selectNearestNodeWithHigherCost() { var startNodeB = new StartNode(nodeB, 100, 7777); var startNodeC = new StartNode(nodeC, 109, 1111); var path = multiSourceALT.calcLeastCostPath(List.of(startNodeB, startNodeC), nodeA, null, null, true); diff --git a/contribs/dvrp/src/test/java/org/matsim/core/router/speedy/SpeedyMultiSourceALTForwardTest.java b/contribs/dvrp/src/test/java/org/matsim/core/router/speedy/SpeedyMultiSourceALTForwardTest.java index 35158e0b0c1..45287f7b776 100644 --- a/contribs/dvrp/src/test/java/org/matsim/core/router/speedy/SpeedyMultiSourceALTForwardTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/core/router/speedy/SpeedyMultiSourceALTForwardTest.java @@ -24,7 +24,7 @@ import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -78,7 +78,7 @@ public class SpeedyMultiSourceALTForwardTest { travelDisutility); @Test - public void testOneSource_forward() { + void testOneSource_forward() { var startNode = new StartNode(nodeB, 9999, 7777); var path = multiSourceALT.calcLeastCostPath(List.of(startNode), nodeA, null, null, false); assertThat(path.nodes).containsExactly(nodeB, nodeD, nodeE, nodeA); @@ -88,7 +88,7 @@ public void testOneSource_forward() { } @Test - public void testManySources_forward_sameStartCost() { + void testManySources_forward_sameStartCost() { var startNodeB = new StartNode(nodeB, 9999, 7777); var startNodeC = new StartNode(nodeC, 9999, 7777); var path = multiSourceALT.calcLeastCostPath(List.of(startNodeB, startNodeC), nodeA, null, null, false); @@ -99,7 +99,7 @@ public void testManySources_forward_sameStartCost() { } @Test - public void testManySources_forward_selectFartherNodeWithLowerCost() { + void testManySources_forward_selectFartherNodeWithLowerCost() { var startNodeB = new StartNode(nodeB, 100, 7777); var startNodeC = new StartNode(nodeC, 111, 1111); var path = multiSourceALT.calcLeastCostPath(List.of(startNodeB, startNodeC), nodeA, null, null, false); @@ -110,7 +110,7 @@ public void testManySources_forward_selectFartherNodeWithLowerCost() { } @Test - public void testManySources_forward_selectNearestNodeWithHigherCost() { + void testManySources_forward_selectNearestNodeWithHigherCost() { var startNodeB = new StartNode(nodeB, 100, 7777); var startNodeC = new StartNode(nodeC, 109, 1111); var path = multiSourceALT.calcLeastCostPath(List.of(startNodeB, startNodeC), nodeA, null, null, false); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java index 6af6c9b7abe..ea2bb982d8e 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.emissions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; import org.matsim.contrib.emissions.utils.TestUtils; @@ -16,6 +16,7 @@ import org.matsim.testcases.MatsimTestUtils; import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.assertThrows; /** * Most of the other test implicitly test the EmissionModule as well. Still, I guess it makes sense to have this here @@ -25,42 +26,44 @@ public class EmissionModuleTest { @RegisterExtension public MatsimTestUtils testUtils = new MatsimTestUtils(); - @Test(expected = RuntimeException.class) - public void testWithIncorrectNetwork() { + @Test + void testWithIncorrectNetwork() { + assertThrows(RuntimeException.class, () -> { - var scenarioURL = ExamplesUtils.getTestScenarioURL("emissions-sampleScenario"); + var scenarioURL = ExamplesUtils.getTestScenarioURL("emissions-sampleScenario"); - var emissionConfig = new EmissionsConfigGroup(); - emissionConfig.setHbefaTableConsistencyCheckingLevel(EmissionsConfigGroup.HbefaTableConsistencyCheckingLevel.none); - emissionConfig.setAverageColdEmissionFactorsFile(IOUtils.extendUrl(scenarioURL, "sample_41_EFA_ColdStart_SubSegm_2020detailed.csv").toString()); - emissionConfig.setAverageWarmEmissionFactorsFile(IOUtils.extendUrl(scenarioURL, "sample_41_EFA_HOT_vehcat_2020average.csv").toString()); - emissionConfig.setDetailedVsAverageLookupBehavior(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.directlyTryAverageTable); + var emissionConfig = new EmissionsConfigGroup(); + emissionConfig.setHbefaTableConsistencyCheckingLevel(EmissionsConfigGroup.HbefaTableConsistencyCheckingLevel.none); + emissionConfig.setAverageColdEmissionFactorsFile(IOUtils.extendUrl(scenarioURL, "sample_41_EFA_ColdStart_SubSegm_2020detailed.csv").toString()); + emissionConfig.setAverageWarmEmissionFactorsFile(IOUtils.extendUrl(scenarioURL, "sample_41_EFA_HOT_vehcat_2020average.csv").toString()); + emissionConfig.setDetailedVsAverageLookupBehavior(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.directlyTryAverageTable); - var config = ConfigUtils.createConfig(emissionConfig); + var config = ConfigUtils.createConfig(emissionConfig); - // create a scenario with a random network where every link has a hbefa road type except one link. - var scenario = ScenarioUtils.createMutableScenario(config); - var network = TestUtils.createRandomNetwork(1000, 10000, 10000); - new VspHbefaRoadTypeMapping().addHbefaMappings(network); - network.getLinks().values().iterator().next().getAttributes().removeAttribute(EmissionUtils.HBEFA_ROAD_TYPE); - scenario.setNetwork(network); + // create a scenario with a random network where every link has a hbefa road type except one link. + var scenario = ScenarioUtils.createMutableScenario(config); + var network = TestUtils.createRandomNetwork(1000, 10000, 10000); + new VspHbefaRoadTypeMapping().addHbefaMappings(network); + network.getLinks().values().iterator().next().getAttributes().removeAttribute(EmissionUtils.HBEFA_ROAD_TYPE); + scenario.setNetwork(network); - var eventsManager = EventsUtils.createEventsManager(); + var eventsManager = EventsUtils.createEventsManager(); - var module = new AbstractModule() { - @Override - public void install() { - bind(Scenario.class).toInstance(scenario); - bind(EventsManager.class).toInstance(eventsManager); - bind(EmissionModule.class); - } - }; + var module = new AbstractModule() { + @Override + public void install() { + bind(Scenario.class).toInstance(scenario); + bind(EventsManager.class).toInstance(eventsManager); + bind(EmissionModule.class); + } + }; - com.google.inject.Injector injector = Injector.createInjector(config, module); - // this call should cause an exception when the consistency check in the constructor of the emission module fails - injector.getInstance(EmissionModule.class); + com.google.inject.Injector injector = Injector.createInjector(config, module); + // this call should cause an exception when the consistency check in the constructor of the emission module fails + injector.getInstance(EmissionModule.class); - fail("Was expecting exception"); - } + fail("Was expecting exception"); + }); + } } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/OsmHbefaMappingTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/OsmHbefaMappingTest.java index d0bf9433dfa..af88ae935a2 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/OsmHbefaMappingTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/OsmHbefaMappingTest.java @@ -1,17 +1,18 @@ package org.matsim.contrib.emissions; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.core.network.NetworkUtils; import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.assertThrows; public class OsmHbefaMappingTest { - @Test - public void testRegularMapping() { + @Test + void testRegularMapping() { var mapping = OsmHbefaMapping.build(); var link = getTestLink("primary", 70 / 3.6); @@ -22,7 +23,7 @@ public void testRegularMapping() { } @Test - public void testMergedLinkTypeMapping() { + void testMergedLinkTypeMapping() { var mapping = OsmHbefaMapping.build(); var link = getTestLink("primary|railway.tram", 70 / 3.6); @@ -32,19 +33,21 @@ public void testMergedLinkTypeMapping() { assertEquals("URB/Trunk-City/70", hbefaType); } - @Test(expected = RuntimeException.class) - public void testUnknownType() { + @Test + void testUnknownType() { + assertThrows(RuntimeException.class, () -> { - var mapping = OsmHbefaMapping.build(); - var link = getTestLink("unknown-tag", 100 / 3.6); + var mapping = OsmHbefaMapping.build(); + var link = getTestLink("unknown-tag", 100 / 3.6); - mapping.determineHebfaType(link); + mapping.determineHebfaType(link); - fail("Expected Runtime Exception."); - } + fail("Expected Runtime Exception."); + }); + } - @Test - public void testFastMotorway() { + @Test + void testFastMotorway() { var mapping = OsmHbefaMapping.build(); var link = getTestLink("motorway", 100 / 3.6); @@ -55,7 +58,7 @@ public void testFastMotorway() { } @Test - public void testMotorwayWithNoExactSpeedTag() { + void testMotorwayWithNoExactSpeedTag() { var mapping = OsmHbefaMapping.build(); @@ -70,7 +73,7 @@ public void testMotorwayWithNoExactSpeedTag() { } @Test - public void testFastMotorwayLink() { + void testFastMotorwayLink() { var mapping = OsmHbefaMapping.build(); var link = getTestLink("motorway_link", 100 / 3.6); @@ -81,7 +84,7 @@ public void testFastMotorwayLink() { } @Test - public void testLivingStreet() { + void testLivingStreet() { var mapping = OsmHbefaMapping.build(); var link = getTestLink("living_street", 50 / 3.6); @@ -90,8 +93,8 @@ public void testLivingStreet() { assertEquals("URB/Access/50", hbefaType); } - @Test - public void testUnclassified() { + @Test + void testUnclassified() { var mapping = OsmHbefaMapping.build(); var link = getTestLink("unclassified", 50 / 3.6); @@ -101,8 +104,8 @@ public void testUnclassified() { assertEquals("URB/Access/50", hbefaType); } - @Test - public void testNoHighwayType() { + @Test + void testNoHighwayType() { var mapping = OsmHbefaMapping.build(); var link = getTestLink(" ", 60 / 3.6); @@ -112,8 +115,8 @@ public void testNoHighwayType() { assertEquals("URB/Local/60", hbefaType); } - @Test - public void testNoAllowedSpeedTag() { + @Test + void testNoAllowedSpeedTag() { var mapping = OsmHbefaMapping.build(); var link = getTestLink("residential", 40 / 3.6); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java index 57c8636221a..5f39db1437a 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java @@ -22,7 +22,7 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -104,7 +104,7 @@ public class TestColdEmissionAnalysisModule { * all of them should throw exceptions */ @Test - public void calculateColdEmissionsAndThrowEventTest_Exceptions() { + void calculateColdEmissionsAndThrowEventTest_Exceptions() { ColdEmissionAnalysisModule coldEmissionAnalysisModule = setUp(); List> testCasesExceptions = new ArrayList<>(); @@ -135,7 +135,7 @@ public void calculateColdEmissionsAndThrowEventTest_Exceptions() { } @Test - public void calculateColdEmissionsAndThrowEventTest_minimalVehicleInformation() { + void calculateColdEmissionsAndThrowEventTest_minimalVehicleInformation() { ColdEmissionAnalysisModule coldEmissionAnalysisModule = setUp(); excep = false; diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase1.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase1.java index fc4d54bb0cf..a5785997e66 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase1.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase1.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -101,7 +101,7 @@ public class TestColdEmissionAnalysisModuleCase1 { private static final double fakeFactor = -1.; @Test - public void calculateColdEmissionsAndThrowEventTest_completeData() { + void calculateColdEmissionsAndThrowEventTest_completeData() { ColdEmissionAnalysisModule coldEmissionAnalysisModule = setUp(); ArrayList testCase1 = new ArrayList<>(); // first case: complete data diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase2.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase2.java index feed9108fb3..d975c75f447 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase2.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase2.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -93,7 +93,7 @@ public class TestColdEmissionAnalysisModuleCase2 { private static final double fakeFactor = -1.; @Test - public void calculateColdEmissionsAndThrowEventTest_completeData() { + void calculateColdEmissionsAndThrowEventTest_completeData() { ColdEmissionAnalysisModule coldEmissionAnalysisModule = setUp(); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase3.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase3.java index 861850165d5..e925e1df1d6 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase3.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase3.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -94,7 +94,7 @@ public class TestColdEmissionAnalysisModuleCase3 { private static final double fakeFactor = -1.; @Test - public void calculateColdEmissionsAndThrowEventTest_completeData() { + void calculateColdEmissionsAndThrowEventTest_completeData() { ColdEmissionAnalysisModule coldEmissionAnalysisModule = setUp(); ArrayList testCase3 = new ArrayList<>(); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase4.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase4.java index 8664f465e36..06a4298fb58 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase4.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase4.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -97,9 +97,9 @@ public class TestColdEmissionAnalysisModuleCase4 { private static final double fakeFactor = -1.; - + @Test - public void calculateColdEmissionsAndThrowEventTest_completeData() { + void calculateColdEmissionsAndThrowEventTest_completeData() { /* * test cases with complete input data or input that should be assigned to average/default cases diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase6.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase6.java index 2901ffba8c9..735adde0f16 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase6.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase6.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -91,9 +91,9 @@ public class TestColdEmissionAnalysisModuleCase6 { private static final double heavyGoodsFactor = -1.; - + @Test - public void calculateColdEmissionsAndThrowEventTest_completeData() { + void calculateColdEmissionsAndThrowEventTest_completeData() { /* * six test cases with complete input data diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionsFallbackBehaviour.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionsFallbackBehaviour.java index 4022a553a46..6c81637cc12 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionsFallbackBehaviour.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionsFallbackBehaviour.java @@ -21,8 +21,10 @@ package org.matsim.contrib.emissions; +import static org.junit.jupiter.api.Assertions.assertThrows; + import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -80,7 +82,7 @@ public class TestColdEmissionsFallbackBehaviour { * -> should calculate value */ @Test - public void testColdDetailedValueOnlyDetailed() { + void testColdDetailedValueOnlyDetailed() { EmissionModule emissionModule = setUpScenario( DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort ); Map coldEmissions = emissionModule.getColdEmissionAnalysisModule() @@ -98,13 +100,15 @@ public void testColdDetailedValueOnlyDetailed() { * * -> should abort --> RuntimeException */ - @Test(expected=RuntimeException.class) - public void testCold_DetailedElseAbort_ShouldAbort1() { - EmissionModule emissionModule = setUpScenario( DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort ); - - emissionModule.getColdEmissionAnalysisModule() - .checkVehicleInfoAndCalculateWColdEmissions(vehicleFallbackToTechnologyAverage.getType(), - vehicleFallbackToTechnologyAverage.getId(), link.getId(), startTime, parkingDuration, distance); + @Test + void testCold_DetailedElseAbort_ShouldAbort1() { + assertThrows(RuntimeException.class, () -> { + EmissionModule emissionModule = setUpScenario(DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); + + emissionModule.getColdEmissionAnalysisModule() + .checkVehicleInfoAndCalculateWColdEmissions(vehicleFallbackToTechnologyAverage.getType(), + vehicleFallbackToTechnologyAverage.getId(), link.getId(), startTime, parkingDuration, distance); + }); } /** @@ -115,13 +119,15 @@ public void testCold_DetailedElseAbort_ShouldAbort1() { * * -> should abort --> RuntimeException */ - @Test(expected=RuntimeException.class) - public void testCold_DetailedElseAbort_ShouldAbort2() { - EmissionModule emissionModule = setUpScenario( DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort ); - - emissionModule.getColdEmissionAnalysisModule() - .checkVehicleInfoAndCalculateWColdEmissions(vehicleFallbackToTechnologyAverage.getType(), - vehicleFallbackToAverageTable.getId(), link.getId(), startTime, parkingDuration, distance); + @Test + void testCold_DetailedElseAbort_ShouldAbort2() { + assertThrows(RuntimeException.class, () -> { + EmissionModule emissionModule = setUpScenario(DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); + + emissionModule.getColdEmissionAnalysisModule() + .checkVehicleInfoAndCalculateWColdEmissions(vehicleFallbackToTechnologyAverage.getType(), + vehicleFallbackToAverageTable.getId(), link.getId(), startTime, parkingDuration, distance); + }); } @@ -134,7 +140,7 @@ public void testCold_DetailedElseAbort_ShouldAbort2() { * ---> should calculate value from detailed value */ @Test - public void testCold_DetailedThenTechnologyAverageElseAbort_FallbackNotNeeded() { + void testCold_DetailedThenTechnologyAverageElseAbort_FallbackNotNeeded() { EmissionModule emissionModule = setUpScenario( DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageElseAbort ); Map coldEmissions = emissionModule.getColdEmissionAnalysisModule() @@ -153,7 +159,7 @@ public void testCold_DetailedThenTechnologyAverageElseAbort_FallbackNotNeeded() * ---> should calculate value from technology average */ @Test - public void testCold_DetailedThenTechnologyAverageElseAbort_FallbackToTechnologyAverage() { + void testCold_DetailedThenTechnologyAverageElseAbort_FallbackToTechnologyAverage() { EmissionModule emissionModule = setUpScenario( DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageElseAbort ); Map coldEmissions = emissionModule.getColdEmissionAnalysisModule() @@ -172,13 +178,15 @@ public void testCold_DetailedThenTechnologyAverageElseAbort_FallbackToTechnology * * -> should abort --> RuntimeException */ - @Test(expected=RuntimeException.class) - public void testCold_DetailedThenTechnologyAverageElseAbort_ShouldAbort() { - EmissionModule emissionModule = setUpScenario( DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort ); - - emissionModule.getColdEmissionAnalysisModule() - .checkVehicleInfoAndCalculateWColdEmissions(vehicleFallbackToAverageTable.getType(), - vehicleFallbackToAverageTable.getId(), link.getId(), startTime, parkingDuration, distance); + @Test + void testCold_DetailedThenTechnologyAverageElseAbort_ShouldAbort() { + assertThrows(RuntimeException.class, () -> { + EmissionModule emissionModule = setUpScenario(DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); + + emissionModule.getColdEmissionAnalysisModule() + .checkVehicleInfoAndCalculateWColdEmissions(vehicleFallbackToAverageTable.getType(), + vehicleFallbackToAverageTable.getId(), link.getId(), startTime, parkingDuration, distance); + }); } // --------- DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ----------- @@ -190,7 +198,7 @@ public void testCold_DetailedThenTechnologyAverageElseAbort_ShouldAbort() { * ---> should calculate value from detailed value */ @Test - public void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackNotNeeded() { + void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackNotNeeded() { EmissionModule emissionModule = setUpScenario( DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ); Map coldEmissions = emissionModule.getColdEmissionAnalysisModule() @@ -209,7 +217,7 @@ public void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackNotNe * ---> should calculate value from technology average */ @Test - public void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackToTechnology() { + void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackToTechnology() { EmissionModule emissionModule = setUpScenario( DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ); Map coldEmissions = emissionModule.getColdEmissionAnalysisModule() @@ -229,7 +237,7 @@ public void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackToTec * ---> should calculate value from average table */ @Test - public void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackToAverageTable() { + void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackToAverageTable() { EmissionModule emissionModule = setUpScenario( DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ); Map coldEmissions = emissionModule.getColdEmissionAnalysisModule() diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaColdEmissionFactorKey.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaColdEmissionFactorKey.java index 861d12b5b2b..e3bbaecef8f 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaColdEmissionFactorKey.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaColdEmissionFactorKey.java @@ -21,7 +21,7 @@ package org.matsim.contrib.emissions; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import static org.junit.Assert.*; import static org.matsim.contrib.emissions.Pollutant.CO; @@ -61,7 +61,7 @@ private void setUp(){ @Test - public final void testEqualsForCompleteKeys() { + final void testEqualsForCompleteKeys() { setUp(); @@ -113,7 +113,7 @@ public final void testEqualsForCompleteKeys() { //exception: if the vehicleAttributes are set to 'average' by default @Test - public final void testEqualsForIncompleteKeys_vehicleCategory(){ + final void testEqualsForIncompleteKeys_vehicleCategory(){ setUp(); //normal HbefaColdEmissionFactorKey @@ -132,7 +132,7 @@ public final void testEqualsForIncompleteKeys_vehicleCategory(){ } @Test - public final void testEqualsForIncompleteKeys_pollutant(){ + final void testEqualsForIncompleteKeys_pollutant(){ // generate a complete HbefaColdEmissionFactorKey: 'normal' // and set some parameters @@ -151,7 +151,7 @@ public final void testEqualsForIncompleteKeys_pollutant(){ } @Test - public final void testEqualsForIncompleteKeys_parkingTime() { + final void testEqualsForIncompleteKeys_parkingTime() { // generate a complete HbefaColdEmissionFactorKey: 'normal' // and set some parameters @@ -170,7 +170,7 @@ public final void testEqualsForIncompleteKeys_parkingTime() { } @Test - public final void testEqualsForIncompleteKeys_distance() { + final void testEqualsForIncompleteKeys_distance() { // generate a complete HbefaColdEmissionFactorKey: 'normal' // and set some parameters @@ -189,7 +189,7 @@ public final void testEqualsForIncompleteKeys_distance() { } @Test - public final void testEqualsForIncompleteKeys_emptyKey() { + final void testEqualsForIncompleteKeys_emptyKey() { // generate a complete HbefaColdEmissionFactorKey: 'normal' // and set some parameters @@ -204,7 +204,7 @@ public final void testEqualsForIncompleteKeys_emptyKey() { } @Test - public final void testEqualsForIncompleteKeys_VehicleAttributes(){ + final void testEqualsForIncompleteKeys_VehicleAttributes(){ //if no vehicle attributes are set manually they are set to 'average' by default // thus, the equals method should not throw nullpointer exceptions but return false or respectively true diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaVehicleAttributes.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaVehicleAttributes.java index 1709424db79..49a3e04e8cd 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaVehicleAttributes.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaVehicleAttributes.java @@ -21,7 +21,7 @@ package org.matsim.contrib.emissions; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /* @@ -41,7 +41,7 @@ public class TestHbefaVehicleAttributes { private HbefaVehicleAttributes differentValues; @Test - public final void testEqualsForCompleteAttributes(){ + final void testEqualsForCompleteAttributes(){ //two equal objects - no default values normal = new HbefaVehicleAttributes(); @@ -60,7 +60,7 @@ public final void testEqualsForCompleteAttributes(){ } @Test - public final void testEqualsForCompleteAttributes_emConcept(){ + final void testEqualsForCompleteAttributes_emConcept(){ //two unequal but complete objects normal = new HbefaVehicleAttributes(); @@ -79,7 +79,7 @@ public final void testEqualsForCompleteAttributes_emConcept(){ } @Test - public final void testEqualsForCompleteAttributes_sizeClass(){ + final void testEqualsForCompleteAttributes_sizeClass(){ //two unequal but complete objects normal = new HbefaVehicleAttributes(); @@ -98,7 +98,7 @@ public final void testEqualsForCompleteAttributes_sizeClass(){ } @Test - public final void testEqualsForCompleteAttributes_technologies(){ + final void testEqualsForCompleteAttributes_technologies(){ //two unequal but complete objects normal = new HbefaVehicleAttributes(); @@ -121,7 +121,7 @@ public final void testEqualsForCompleteAttributes_technologies(){ // thus, the equals method should not throw nullpointer exceptions but return false or respectively true @Test - public final void testEqualsForIncompleteAttributes_emConcept(){ + final void testEqualsForIncompleteAttributes_emConcept(){ //generate a complete key and set its parameters normal = new HbefaVehicleAttributes(); setToNormal(normal); @@ -142,7 +142,7 @@ public final void testEqualsForIncompleteAttributes_emConcept(){ @Test - public final void testEqualsForIncompleteAttributes_technology() { + final void testEqualsForIncompleteAttributes_technology() { // generate a complete key and set its parameters normal = new HbefaVehicleAttributes(); @@ -166,7 +166,7 @@ public final void testEqualsForIncompleteAttributes_technology() { } @Test - public final void testEqualsForIncompleteAttributes_sizeClass(){ + final void testEqualsForIncompleteAttributes_sizeClass(){ //generate a complete key and set its parameters normal = new HbefaVehicleAttributes(); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaWarmEmissionFactorKey.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaWarmEmissionFactorKey.java index 74eb698f206..c8c60aeaee3 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaWarmEmissionFactorKey.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaWarmEmissionFactorKey.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import static org.junit.Assert.assertFalse; import static org.matsim.contrib.emissions.Pollutant.CO; @@ -64,7 +64,7 @@ private void setUp(){ } @Test - public final void testEqualsForCompleteKeys(){ + final void testEqualsForCompleteKeys(){ // generate a complete HbefaWarmEmissionFactorKey: 'normal' // and set some parameters @@ -100,7 +100,7 @@ public final void testEqualsForCompleteKeys(){ assertFalse(message, different.equals(normal)); assertFalse(message, normal.equals(different)); } - + // the following tests each compare a incomplete key to a complete key // wanted result: // completeData.equals(partialData) -> return false @@ -108,7 +108,7 @@ public final void testEqualsForCompleteKeys(){ // exception: if the vehicleAttributes are set to 'average' by default @Test - public final void testEqualsForIncompleteKeys_vehicleCategory() { + final void testEqualsForIncompleteKeys_vehicleCategory() { // generate a complete HbefaWarmEmissionFactorKey: 'normal' // and set some parameters setUp(); @@ -128,9 +128,9 @@ public final void testEqualsForIncompleteKeys_vehicleCategory() { assertFalse(result); } - + @Test - public final void testEqualsForIncompleteKeys_pollutant() { + final void testEqualsForIncompleteKeys_pollutant() { // generate a complete HbefaWarmEmissionFactorKey: 'normal' // and set some parameters setUp(); @@ -145,9 +145,9 @@ public final void testEqualsForIncompleteKeys_pollutant() { var result = noPollutant.equals(normal); } - + @Test - public final void testEqualsForIncompleteKeys_roadCategory() { + final void testEqualsForIncompleteKeys_roadCategory() { // generate a complete HbefaWarmEmissionFactorKey: 'normal' // and set some parameters setUp(); @@ -172,9 +172,9 @@ public final void testEqualsForIncompleteKeys_roadCategory() { Assert.assertTrue(message2, equalErr); assertFalse(message, normal.equals(noRoadCat)); } - + @Test - public final void testEqualsForIncompleteKeys_trafficSituation() { + final void testEqualsForIncompleteKeys_trafficSituation() { // generate a complete HbefaWarmEmissionFactorKey: 'normal' // and set some parameters setUp(); @@ -191,9 +191,9 @@ public final void testEqualsForIncompleteKeys_trafficSituation() { assertFalse(result); } - + @Test - public final void testEqualsForIncompleteKeys_emptyKey() { + final void testEqualsForIncompleteKeys_emptyKey() { // generate a complete HbefaWarmEmissionFactorKey: 'normal' // and set some parameters setUp(); @@ -206,9 +206,9 @@ public final void testEqualsForIncompleteKeys_emptyKey() { assertFalse(result); } - + @Test - public final void testEqualsForIncompleteKeys_vehicleAttributes(){ + final void testEqualsForIncompleteKeys_vehicleAttributes(){ // if no vehicle attributes are set manually they are set to 'average' by default // thus, the equals method should not throw nullpointer exceptions but return false or respectively true diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java index 3e9d93e186a..03d6e88cbbf 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java @@ -1,8 +1,8 @@ package org.matsim.contrib.emissions; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -58,9 +58,9 @@ public class TestPositionEmissionModule { @RegisterExtension public MatsimTestUtils testUtils = new MatsimTestUtils(); - @Test - @Ignore - public void simpleTest() { + @Test + @Ignore + void simpleTest() { var emissionConfig = new EmissionsConfigGroup(); emissionConfig.setHbefaVehicleDescriptionSource(EmissionsConfigGroup.HbefaVehicleDescriptionSource.fromVehicleTypeDescription); @@ -81,8 +81,8 @@ public void simpleTest() { controler.run(); } - @Test - public void compareToOtherModule_singleVehicleSingleLink() { + @Test + void compareToOtherModule_singleVehicleSingleLink() { var emissionConfig = new EmissionsConfigGroup(); emissionConfig.setHbefaVehicleDescriptionSource(EmissionsConfigGroup.HbefaVehicleDescriptionSource.fromVehicleTypeDescription); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java index c65dd54fd27..fd437883c91 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java @@ -21,7 +21,7 @@ package org.matsim.contrib.emissions; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Id; @@ -127,9 +127,8 @@ public TestWarmEmissionAnalysisModule( EmissionsConfigGroup.EmissionsComputation } - @Test - public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent6(){ + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent6(){ //-- set up tables, event handler, parameters, module setUp(); @@ -166,7 +165,7 @@ public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionE } @Test - public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions1(){ + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions1(){ //-- set up tables, event handler, parameters, module setUp(); @@ -198,7 +197,7 @@ public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionE } @Test - public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions2(){ + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions2(){ //-- set up tables, event handler, parameters, module setUp(); @@ -223,7 +222,7 @@ public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionE } @Test - public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions3(){ + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions3(){ //-- set up tables, event handler, parameters, module setUp(); @@ -247,7 +246,7 @@ public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionE } @Test - public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions4(){ + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions4(){ //-- set up tables, event handler, parameters, module setUp(); // vehicle information string is 'null' @@ -270,7 +269,7 @@ public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionE } @Test - public void testCounters7(){ + void testCounters7(){ setUp(); emissionsModule.reset(); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java index ae5a6ed5d28..ed4a1e7322a 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java @@ -21,7 +21,7 @@ package org.matsim.contrib.emissions; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Id; @@ -133,12 +133,12 @@ private WarmEmissionAnalysisModule setUp() { return new WarmEmissionAnalysisModule( avgHbefaWarmTable, detailedHbefaWarmTable, hbefaRoadTrafficSpeeds, pollutants, emissionEventManager, ecg ); } - + //this test method creates a mock link and mock vehicle with a complete vehicleTypId --> detailed values are used //the CO2_TOTAL warm Emissions are compared to a given value --> computed by using detailed Petrol and traffic state freeflow //the "Sum" of all emissions is tested @Test - public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent1(){ + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent1(){ //-- set up tables, event handler, parameters, module WarmEmissionAnalysisModule warmEmissionAnalysisModule = setUp(); // case 1 - data in both tables -> use detailed @@ -160,15 +160,15 @@ public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionE emissionEventManager.reset(); warmEmissions.clear(); } - - + + /* * this test method creates a mock link and mock vehicle (petrol technology) with a complete vehicleTypId --> detailed values are used * the counters for all possible combinations of avg, stop go and free flow speed are tested * for the cases: > s&g speed, use average table diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase5.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase5.java index 8196789c523..3fd040f0950 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase5.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase5.java @@ -21,7 +21,7 @@ package org.matsim.contrib.emissions; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Id; @@ -119,7 +119,7 @@ public TestWarmEmissionAnalysisModuleCase5( EmissionsConfigGroup.EmissionsComput * detailed values are used */ @Test - public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent5(){ + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent5(){ //-- set up tables, event handler, parameters, module WarmEmissionAnalysisModule emissionsModule = setUp(); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionsFallbackBehaviour.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionsFallbackBehaviour.java index 3b7ec8f09e8..ee7ccc6eeee 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionsFallbackBehaviour.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionsFallbackBehaviour.java @@ -21,8 +21,10 @@ package org.matsim.contrib.emissions; +import static org.junit.jupiter.api.Assertions.assertThrows; + import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -67,7 +69,7 @@ public class TestWarmEmissionsFallbackBehaviour { * -> should calculate value */ @Test - public void testWarmDetailedValueOnlyDetailed() { + void testWarmDetailedValueOnlyDetailed() { EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s @@ -85,12 +87,14 @@ public void testWarmDetailedValueOnlyDetailed() { * * -> should abort --> RuntimeException */ - @Test(expected=RuntimeException.class) - public void testWarm_DetailedElseAbort_ShouldAbort1() { - EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); + @Test + void testWarm_DetailedElseAbort_ShouldAbort1() { + assertThrows(RuntimeException.class, () -> { + EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); - double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s - emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFallbackToTechnologyAverage, link, travelTimeOnLink); + double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s + emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFallbackToTechnologyAverage, link, travelTimeOnLink); + }); } /** @@ -101,15 +105,17 @@ public void testWarm_DetailedElseAbort_ShouldAbort1() { * * -> should abort --> RuntimeException */ - @Test(expected=RuntimeException.class) - public void testWarm_DetailedElseAbort_ShouldAbort2() { - EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); + @Test + void testWarm_DetailedElseAbort_ShouldAbort2() { + assertThrows(RuntimeException.class, () -> { + EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); - double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s - emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFallbackToAverageTable, link, travelTimeOnLink); + double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s + emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFallbackToAverageTable, link, travelTimeOnLink); + }); } - + // --------- DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageElseAbort) ----------- /** * vehicles information is complete @@ -119,7 +125,7 @@ public void testWarm_DetailedElseAbort_ShouldAbort2() { * ---> should calculate value from detailed value */ @Test - public void testWarm_DetailedThenTechnologyAverageElseAbort_FallbackNotNeeded() { + void testWarm_DetailedThenTechnologyAverageElseAbort_FallbackNotNeeded() { EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageElseAbort); double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s @@ -138,7 +144,7 @@ public void testWarm_DetailedThenTechnologyAverageElseAbort_FallbackNotNeeded() * ---> should calculate value from technology average */ @Test - public void testWarm_DetailedThenTechnologyAverageElseAbort_FallbackToTechnologyAverage() { + void testWarm_DetailedThenTechnologyAverageElseAbort_FallbackToTechnologyAverage() { EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageElseAbort); double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s @@ -156,12 +162,14 @@ public void testWarm_DetailedThenTechnologyAverageElseAbort_FallbackToTechnology * * -> should abort --> RuntimeException */ - @Test(expected=RuntimeException.class) - public void testWarm_DetailedThenTechnologyAverageElseAbort_ShouldAbort() { - EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); + @Test + void testWarm_DetailedThenTechnologyAverageElseAbort_ShouldAbort() { + assertThrows(RuntimeException.class, () -> { + EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); - double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s - emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFallbackToAverageTable, link, travelTimeOnLink); + double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s + emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFallbackToAverageTable, link, travelTimeOnLink); + }); } // --------- DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ----------- @@ -173,7 +181,7 @@ public void testWarm_DetailedThenTechnologyAverageElseAbort_ShouldAbort() { * ---> should calculate value from detailed value */ @Test - public void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackNotNeeded() { + void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackNotNeeded() { EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable); double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s @@ -192,7 +200,7 @@ public void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackNotNe * ---> should calculate value from technology average */ @Test - public void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackToTechnology() { + void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackToTechnology() { EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable); double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s @@ -212,7 +220,7 @@ public void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackToTec * ---> should calculate value from average table */ @Test - public void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackToAverageTable() { + void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackToAverageTable() { EmissionModule emissionModule = setUpScenario(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable); double travelTimeOnLink = 21; //sec. approx freeSpeed of link12 is : (200 m) / (9.72.. m/s) approx 20.57 s diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/VspHbefaRoadTypeMappingTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/VspHbefaRoadTypeMappingTest.java index c46b4a65ac6..7caf57a3bc9 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/VspHbefaRoadTypeMappingTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/VspHbefaRoadTypeMappingTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.emissions; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -10,8 +10,8 @@ public class VspHbefaRoadTypeMappingTest { - @Test - public void testSimpleMapping() { + @Test + void testSimpleMapping() { var mapper = new VspHbefaRoadTypeMapping(); var link = getTestLink("", 70 / 3.6); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java index 7cf055ff33e..df4bd3474a3 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java @@ -3,8 +3,8 @@ import org.apache.commons.csv.CSVFormat; import org.apache.commons.csv.CSVPrinter; import org.apache.commons.csv.CSVRecord; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; import org.locationtech.jts.geom.GeometryFactory; @@ -33,6 +33,7 @@ import java.util.UUID; import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.assertThrows; import static org.matsim.contrib.emissions.Pollutant.*; public class EmissionGridAnalyzerTest { @@ -49,21 +50,23 @@ private Geometry createRect(double maxX, double maxY) { new Coordinate(0, 0)}); } - @Test(expected = IllegalArgumentException.class) - public void initialize_invalidGridSizeToSmoothingRadiusRatio_exception() { + @Test + void initialize_invalidGridSizeToSmoothingRadiusRatio_exception() { + assertThrows(IllegalArgumentException.class, () -> { - new EmissionGridAnalyzer.Builder() - .withSmoothingRadius(1) - .withGridSize(1000) - .withNetwork(NetworkUtils.createNetwork()) - .withTimeBinSize(1) - .build(); + new EmissionGridAnalyzer.Builder() + .withSmoothingRadius(1) + .withGridSize(1000) + .withNetwork(NetworkUtils.createNetwork()) + .withTimeBinSize(1) + .build(); - fail("invalid grid size to smoothing radius ratio should cause exception"); - } + fail("invalid grid size to smoothing radius ratio should cause exception"); + }); + } - @Test - public void process() { + @Test + void process() { final Pollutant pollutant = HC; final double pollutionPerEvent = 1; @@ -87,8 +90,8 @@ public void process() { }); } - @Test - public void process_singleLinkWithOneEvent() { + @Test + void process_singleLinkWithOneEvent() { final Pollutant pollutant = CO; final double pollutionPerEvent = 1000; @@ -126,8 +129,8 @@ public void process_singleLinkWithOneEvent() { bin.getValue().getCells().forEach(cell -> assertTrue(cell.getValue().get(pollutant) <= valueOfCellWithLink)); } - @Test - public void process_singleLinkWithTwoEvents() { + @Test + void process_singleLinkWithTwoEvents() { final Pollutant pollutant = CO; final double pollutionPerEvent = 1000; @@ -165,8 +168,8 @@ public void process_singleLinkWithTwoEvents() { bin.getValue().getCells().forEach(cell -> assertTrue(cell.getValue().get(pollutant) <= valueOfCellWithLink)); } - @Test - public void process_twoLinksWithOneEventEach() { + @Test + void process_twoLinksWithOneEventEach() { final Pollutant pollutant = CO; final double pollutionPerEvent = 1000; @@ -207,8 +210,8 @@ public void process_twoLinksWithOneEventEach() { bin.getValue().getCells().forEach(cell -> assertTrue(cell.getValue().get(pollutant) <= valueOfCellWithLink + 0.1)); } - @Test - public void process_twoLinksWithTwoEventsEach() { + @Test + void process_twoLinksWithTwoEventsEach() { final Pollutant pollutant = NOx; final double pollutionPerEvent = 1000; @@ -249,8 +252,8 @@ public void process_twoLinksWithTwoEventsEach() { bin.getValue().getCells().forEach(cell -> assertTrue(cell.getValue().get(pollutant) <= valueOfCellWithLink + 0.1)); } - @Test - public void process_withBoundaries() { + @Test + void process_withBoundaries() { final double pollutionPerEvent = 1; Path eventsFile = Paths.get(testUtils.getOutputDirectory()).resolve(UUID.randomUUID().toString() + ".xml"); @@ -274,8 +277,8 @@ public void process_withBoundaries() { assertEquals(25, bin.getValue().getCells().size()); } - @Test - public void processToJson() { + @Test + void processToJson() { final double pollutionPerEvent = 1; final int time = 1; @@ -295,8 +298,8 @@ public void processToJson() { assertNotNull(json); } - @Test - public void processToJsonFile() throws IOException { + @Test + void processToJsonFile() throws IOException { final double pollutionPerEvent = 1; final int time = 1; @@ -319,8 +322,8 @@ public void processToJsonFile() throws IOException { assertTrue(jsonFileData.length > 0); } - @Test - public void process_regression() throws IOException { + @Test + void process_regression() throws IOException { var scenarioUrl = ExamplesUtils.getTestScenarioURL( "emissions-sampleScenario" ); var configUrl = IOUtils.extendUrl( scenarioUrl, "config_empty.xml" ); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsByPollutantTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsByPollutantTest.java index f4a970526ad..2575ebf4470 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsByPollutantTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsByPollutantTest.java @@ -9,19 +9,19 @@ import java.util.LinkedHashMap; import java.util.Map; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.emissions.Pollutant; import org.matsim.contrib.emissions.utils.EmissionUtilsTest; public class EmissionsByPollutantTest { - // The EmissionsByPollutant potentially adds up the same emissions coming from cold and warm. Thus, this cannot be combined into the enum approach - // without some thinking. kai, jan'20 - // Quite possibly, should just combine them into an enum "pollutant"?! There is, anyways, the JM map of those emissions that are actually present in the - // input file. kai, jan'20 + // The EmissionsByPollutant potentially adds up the same emissions coming from cold and warm. Thus, this cannot be combined into the enum approach + // without some thinking. kai, jan'20 + // Quite possibly, should just combine them into an enum "pollutant"?! There is, anyways, the JM map of those emissions that are actually present in the + // input file. kai, jan'20 - @Test - public void initialize() { + @Test + void initialize() { Map emissions = EmissionUtilsTest.createEmissions(); @@ -38,8 +38,8 @@ public void initialize() { }); } - @Test - public void addEmission() { + @Test + void addEmission() { Map emissions = EmissionUtilsTest.createEmissions(); final double valueToAdd = 5; @@ -58,8 +58,8 @@ public void addEmission() { assertEquals(expectedValue, retrievedResult, 0); } - @Test - public void addEmission_PollutantNotPresentYet() { + @Test + void addEmission_PollutantNotPresentYet() { Map initialPollutants = new HashMap<>(); initialPollutants.put(CO, Math.random()); @@ -74,8 +74,8 @@ public void addEmission_PollutantNotPresentYet() { assertEquals(valueToAdd, retrievedResult, 0); } - @Test - public void addEmissions() { + @Test + void addEmissions() { Map emissions = EmissionUtilsTest.createEmissions(); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsOnLinkEventHandlerTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsOnLinkEventHandlerTest.java index 9013c08e763..cc7b9df638c 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsOnLinkEventHandlerTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsOnLinkEventHandlerTest.java @@ -10,7 +10,7 @@ import java.util.UUID; import java.util.stream.Collectors; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.analysis.time.TimeBinMap; @@ -37,8 +37,8 @@ private static Collection createWarmEmissionEvents(Id l return result; } - @Test - public void handleWarmEmissionsEvent() { + @Test + void handleWarmEmissionsEvent() { Id linkId = Id.createLinkId(UUID.randomUUID().toString()); Id vehicleId = Id.createVehicleId(UUID.randomUUID().toString()); @@ -66,8 +66,8 @@ public void handleWarmEmissionsEvent() { emissions.forEach((key, value) -> assertEquals(value, link2pollutantsMap.get(linkId).get(key), 0.0001)); } - @Test - public void handleColdEmissionEvent() { + @Test + void handleColdEmissionEvent() { Id linkId = Id.createLinkId(UUID.randomUUID().toString()); Id vehicleId = Id.createVehicleId(UUID.randomUUID().toString()); @@ -89,8 +89,8 @@ public void handleColdEmissionEvent() { emissions.forEach((key, value) -> assertEquals(value, link2pollutantsMap.get(linkId).get(key), 0.0001)); } - @Test - public void handleMultipleEvents() { + @Test + void handleMultipleEvents() { final Id linkId = Id.createLinkId(UUID.randomUUID().toString()); final int numberOfEvents = 1000; @@ -121,8 +121,8 @@ public void handleMultipleEvents() { assertEquals(3 * numberOfEvents * emissionValue, value, 0.0001)); } - @Test - public void handleSingleLinkWithSingleEvent() { + @Test + void handleSingleLinkWithSingleEvent() { Id linkId = Id.createLinkId(UUID.randomUUID().toString()); Id vehicleId = Id.createVehicleId(UUID.randomUUID().toString()); @@ -144,8 +144,8 @@ public void handleSingleLinkWithSingleEvent() { link2pollutantsMap.get(linkId).forEach((pollutant, value) -> assertEquals(emissionValue, value, 0.0001)); } - @Test - public void handleSingleLinkWithMultipleEvents() { + @Test + void handleSingleLinkWithMultipleEvents() { Id linkId = Id.createLinkId(UUID.randomUUID().toString()); Id vehicleId = Id.createVehicleId(UUID.randomUUID().toString()); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java index 25c0a8b4122..0ea0f7b3f9b 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.emissions.analysis; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.contrib.emissions.Pollutant; @@ -23,8 +23,8 @@ public class FastEmissionGridAnalyzerTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void rasterNetwork_singleLink() { + @Test + void rasterNetwork_singleLink() { final var cellSize = 10.; final var cellArea = cellSize * cellSize; @@ -50,8 +50,8 @@ public void rasterNetwork_singleLink() { raster.forEachIndex((xi, yi, value) -> assertEquals(emissionPerLink / expectedCellNumber / cellArea, value, 0.00000001)); } - @Test - public void rasterNetwork_singleLinkWithBackwardsOrientation() { + @Test + void rasterNetwork_singleLinkWithBackwardsOrientation() { final var cellSize = 10.; final var cellArea = cellSize * cellSize; @@ -77,8 +77,8 @@ public void rasterNetwork_singleLinkWithBackwardsOrientation() { raster.forEachIndex((xi, yi, value) -> assertEquals(emissionPerLink / expectedCellNumber / cellArea, value, 0.00000001)); } - @Test - public void rasterNetwork_twoLinks() { + @Test + void rasterNetwork_twoLinks() { final var cellSize = 10.; final var cellArea = cellSize * cellSize; @@ -121,8 +121,8 @@ public void rasterNetwork_twoLinks() { } - @Test - public void blur_rasterWithSingleValue() { + @Test + void blur_rasterWithSingleValue() { final var initialValue = 10.; final var EPSILON = 0.000000001; @@ -150,8 +150,8 @@ public void blur_rasterWithSingleValue() { }); } - @Test - public void processLinkEmissions_twoLinks() { + @Test + void processLinkEmissions_twoLinks() { var network = NetworkUtils.createNetwork(new NetworkConfigGroup()); var node1 = network.getFactory().createNode(Id.createNodeId("node1"), new Coord(0, 49)); @@ -182,8 +182,8 @@ public void processLinkEmissions_twoLinks() { }); } - @Test - public void processEventsFile() { + @Test + void processEventsFile() { final var networkUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "network.xml"); final var emissionEvents = Paths.get(utils.getOutputDirectory()).resolve("emission.events.xml.gz"); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RasterTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RasterTest.java index ee57b97cb2d..2bcc4d639db 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RasterTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RasterTest.java @@ -1,14 +1,14 @@ package org.matsim.contrib.emissions.analysis; -import org.junit.Test; - import static org.junit.Assert.assertEquals; import static org.junit.Assert.fail; +import org.junit.jupiter.api.Test; + public class RasterTest { - @Test - public void test() { + @Test + void test() { var bounds = new Raster.Bounds(10, 10, 100, 100); var raster = new Raster(bounds, 10); @@ -38,8 +38,8 @@ public void test() { } } - @Test - public void testInsertion() { + @Test + void testInsertion() { var bounds = new Raster.Bounds(4, 5, 123, 244); var raster = new Raster(bounds, 10); @@ -50,8 +50,8 @@ public void testInsertion() { raster.forEachIndex((x, y, value) -> assertEquals(10, value, 0.000001)); } - @Test - public void testIterationByIndex() { + @Test + void testIterationByIndex() { var bounds = new Raster.Bounds(4, 5, 123, 244); var raster = new Raster(bounds, 10); @@ -68,8 +68,8 @@ public void testIterationByIndex() { }); } - @Test - public void testIterationByCoord() { + @Test + void testIterationByCoord() { var bounds = new Raster.Bounds(4, 5, 123, 244); var raster = new Raster(bounds, 10); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java index 08678b9549f..307667309b6 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.emissions.analysis; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.emissions.Pollutant; import org.matsim.contrib.emissions.utils.TestUtils; @@ -19,8 +19,8 @@ public class RawEmissionEventsReaderTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void handleNonEventNode() { + @Test + void handleNonEventNode() { // read in an xml file which doesn't have events. It will parse the whole file but will not handle any of the // parsed nodes @@ -33,8 +33,8 @@ public void handleNonEventNode() { // this test passes if the in the callback 'fail()' is not reached. } - @Test - public void handleNonEmissionEvent() { + @Test + void handleNonEmissionEvent() { // read in events file wihtout emission events. Those events should be ignored var eventsUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "output_events.xml.gz"); @@ -46,8 +46,8 @@ public void handleNonEmissionEvent() { // this test passes if the in the callback 'fail()' is not reached. } - @Test - public void handleColdEmissionEvent() { + @Test + void handleColdEmissionEvent() { final double expectedValue = 10; final int expectedTime = 1; @@ -71,8 +71,8 @@ public void handleColdEmissionEvent() { assertEquals(expectedEventsCount, counter.get()); } - @Test - public void handleWarmEmissionEvent() { + @Test + void handleWarmEmissionEvent() { final double expectedValue = 10; final int expectedTime = 1; diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestColdEmissionEventImpl.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestColdEmissionEventImpl.java index 5be0e9e9ca6..c4dff777494 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestColdEmissionEventImpl.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestColdEmissionEventImpl.java @@ -22,7 +22,7 @@ package org.matsim.contrib.emissions.events; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.emissions.Pollutant; @@ -55,7 +55,7 @@ public class TestColdEmissionEventImpl { private final Set coldPollutants = new HashSet<>(Arrays.asList(CO, FC, HC, NMHC, NOx, NO2,PM)); @Test - public final void testGetAttributesForCompleteEmissionMaps(){ + final void testGetAttributesForCompleteEmissionMaps(){ //test normal functionality //create a normal event impl @@ -91,9 +91,9 @@ private void setColdEmissions( Map coldEmissionsMap ) { coldEmissionsMap.put(PM, pm); } - + @Test - public final void testGetAttributesForIncompleteMaps(){ + final void testGetAttributesForIncompleteMaps(){ //the getAttributesMethod should // - return null if the emission map is empty // - throw NullPointerExceptions if the emission values are not set diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestWarmEmissionEventImpl.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestWarmEmissionEventImpl.java index c1ca71ad628..b10f7129d27 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestWarmEmissionEventImpl.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestWarmEmissionEventImpl.java @@ -29,7 +29,7 @@ */ import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.emissions.Pollutant; @@ -59,7 +59,7 @@ public class TestWarmEmissionEventImpl { @Test - public final void testGetAttributesForCompleteEmissionMaps(){ + final void testGetAttributesForCompleteEmissionMaps(){ //test normal functionality //create a normal event impl @@ -103,7 +103,7 @@ public final void testGetAttributesForCompleteEmissionMaps(){ } @Test - public final void testGetAttributesForIncompleteMaps(){ + final void testGetAttributesForIncompleteMaps(){ //the getAttributesMethod should // - return null if the emission map is empty // - throw NullPointerExceptions if the emission values are not set diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java index bc2a404634c..28c1b9ab2a6 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java @@ -1,8 +1,8 @@ package org.matsim.contrib.emissions.events; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.EmissionModule; import org.matsim.contrib.emissions.VspHbefaRoadTypeMapping; @@ -38,8 +38,8 @@ public class VehicleLeavesTrafficEventTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public final void testRareEventsFromBerlinScenario (){ + @Test + final void testRareEventsFromBerlinScenario(){ final String emissionEventsFileName = "smallBerlinSample.emissions.events.offline.xml.gz"; final String resultingEvents = utils.getOutputDirectory() + emissionEventsFileName; diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java index eb79ad597b5..ede97411a51 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java @@ -19,8 +19,8 @@ package org.matsim.contrib.emissions.example; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.emissions.EmissionUtils; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup.HbefaVehicleDescriptionSource; @@ -42,7 +42,7 @@ public class RunAverageEmissionToolOfflineExampleIT{ @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test - public final void testAverage_vehTypeV1() { + final void testAverage_vehTypeV1() { RunAverageEmissionToolOfflineExample offlineExample = new RunAverageEmissionToolOfflineExample(); // Config config = offlineExample.prepareConfig("./scenarios/sampleScenario/testv2_Vehv1/config_average.xml"); @@ -63,7 +63,7 @@ public final void testAverage_vehTypeV1() { } @Test - public final void testAverage_vehTypeV2() { + final void testAverage_vehTypeV2() { RunAverageEmissionToolOfflineExample offlineExample = new RunAverageEmissionToolOfflineExample(); // Config config = offlineExample.prepareConfig("./scenarios/sampleScenario/testv2_Vehv2/config_average.xml"); @@ -90,7 +90,7 @@ public final void testAverage_vehTypeV2() { * where this is used, has no way to know which file format was originally read. See some discussion there. :-( */ @Test - public final void testAverage_vehTypeV2b() { + final void testAverage_vehTypeV2b() { RunAverageEmissionToolOfflineExample offlineExample = new RunAverageEmissionToolOfflineExample(); // Config config = offlineExample.prepareConfig("./scenarios/sampleScenario/testv2_Vehv2/config_average.xml"); @@ -112,7 +112,7 @@ public final void testAverage_vehTypeV2b() { } @Test - public final void testAverage_vehTypeV2_HBEFA4() { + final void testAverage_vehTypeV2_HBEFA4() { RunAverageEmissionToolOfflineExample offlineExample = new RunAverageEmissionToolOfflineExample(); // Config config = offlineExample.prepareConfig("./scenarios/sampleScenario/testv2_Vehv2/config_average.xml"); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java index 4a3edaf60dd..26a96f651e4 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java @@ -19,8 +19,8 @@ package org.matsim.contrib.emissions.example; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup.DetailedVsAverageLookupBehavior; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup.HbefaVehicleDescriptionSource; @@ -45,7 +45,7 @@ public class RunDetailedEmissionToolOfflineExampleIT { // Expecting RuntimeException, because requested values are only in average file. Without fallback it has to fail! // @Test(expected=RuntimeException.class) @Test - public final void testDetailed_vehTypeV1() { + final void testDetailed_vehTypeV1() { boolean gotAnException = false ; try { RunDetailedEmissionToolOfflineExample offlineExample = new RunDetailedEmissionToolOfflineExample(); @@ -70,7 +70,7 @@ public final void testDetailed_vehTypeV1() { // Expecting RuntimeException, because requested values are only in average file. Without fallback it has to fail! // @Test(expected=RuntimeException.class) @Test - public final void testDetailed_vehTypeV2() { + final void testDetailed_vehTypeV2() { boolean gotAnException = false ; try { RunDetailedEmissionToolOfflineExample offlineExample = new RunDetailedEmissionToolOfflineExample(); @@ -94,7 +94,7 @@ public final void testDetailed_vehTypeV2() { // Expecting RuntimeException, because requested values are only in average file. Without fallback it has to fail! // @Test(expected=RuntimeException.class) @Test - public final void testDetailed_vehTypeV2_HBEFA4() { + final void testDetailed_vehTypeV2_HBEFA4() { boolean gotAnException = false ; try { RunDetailedEmissionToolOfflineExample offlineExample = new RunDetailedEmissionToolOfflineExample(); @@ -126,7 +126,7 @@ public final void testDetailed_vehTypeV2_HBEFA4() { * */ @Test - public final void testDetailed_vehTypeV1_FallbackToAverage() { + final void testDetailed_vehTypeV1_FallbackToAverage() { RunDetailedEmissionToolOfflineExample offlineExample = new RunDetailedEmissionToolOfflineExample(); // Config config = offlineExample.prepareConfig("./scenarios/sampleScenario/testv2_Vehv1/config_detailed.xml"); @@ -147,7 +147,7 @@ public final void testDetailed_vehTypeV1_FallbackToAverage() { } @Test - public final void testDetailed_vehTypeV2_FallbackToAverage() { + final void testDetailed_vehTypeV2_FallbackToAverage() { RunDetailedEmissionToolOfflineExample offlineExample = new RunDetailedEmissionToolOfflineExample(); // Config config = offlineExample.prepareConfig("./scenarios/sampleScenario/testv2_Vehv2/config_detailed.xml"); @@ -167,7 +167,7 @@ public final void testDetailed_vehTypeV2_FallbackToAverage() { } @Test - public final void testDetailed_vehTypeV2_HBEFA4_FallbackToAverage() { + final void testDetailed_vehTypeV2_HBEFA4_FallbackToAverage() { RunDetailedEmissionToolOfflineExample offlineExample = new RunDetailedEmissionToolOfflineExample(); // Config config = offlineExample.prepareConfig("./scenarios/sampleScenario/testv2_Vehv2/config_detailed.xml"); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java index 375cae0855b..ad7e875891a 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java @@ -20,8 +20,8 @@ import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; import org.matsim.core.config.Config; @@ -50,7 +50,7 @@ public class RunDetailedEmissionToolOnlineExampleIT_vehTypeV1 { // @Test(expected=RuntimeException.class) // Expecting RuntimeException, because requested values are only in average file. Without fallback it has to fail! @Ignore //Ignore this test, because the thrown exception during events handling does not always leads to an abort of the Simulation ->> Maybe a problem in @link{ParallelEventsManagerImpl.class}? @Test - public final void testDetailed_vehTypeV1() { + final void testDetailed_vehTypeV1() { boolean gotAnException = false ; try { RunDetailedEmissionToolOnlineExample onlineExample = new RunDetailedEmissionToolOnlineExample(); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java index fc23f2cefbd..2ba07507548 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java @@ -18,8 +18,8 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; import org.matsim.core.config.Config; @@ -48,7 +48,7 @@ public class RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage { * * */ @Test - public final void testDetailed_vehTypeV1_FallbackToAverage() { + final void testDetailed_vehTypeV1_FallbackToAverage() { try { // Config config = onlineExample.prepareConfig( new String[]{"./scenarios/sampleScenario/testv2_Vehv1/config_detailed.xml"} ) ; var scenarioUrl = ExamplesUtils.getTestScenarioURL( "emissions-sampleScenario/testv2_Vehv1" ); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java index 213c933c504..8ebcee11237 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java @@ -20,8 +20,8 @@ import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; import org.matsim.core.config.Config; @@ -44,7 +44,7 @@ public class RunDetailedEmissionToolOnlineExampleIT_vehTypeV2 { // @Test(expected=RuntimeException.class) // Expecting RuntimeException, because requested values are only in average file. Without fallback it has to fail! @Ignore //Ignore this test, because the thrown exception during events handling does not always leads to an abort of the Simulation ->> Maybe a problem in @link{ParallelEventsManagerImpl.class}? @Test - public final void testDetailed_vehTypeV2() { + final void testDetailed_vehTypeV2() { boolean gotAnException = false ; try { RunDetailedEmissionToolOnlineExample onlineExample = new RunDetailedEmissionToolOnlineExample(); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java index 1c387a47d73..346f29f433c 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java @@ -18,8 +18,8 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup.DetailedVsAverageLookupBehavior; @@ -42,7 +42,7 @@ public class RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage { * Test method for {@link RunDetailedEmissionToolOnlineExample#main(String[])}. */ @Test - public final void testDetailed_vehTypeV2_FallbackToAverage() { + final void testDetailed_vehTypeV2_FallbackToAverage() { try { // RunDetailedEmissionToolOnlineExample onlineExample = new RunDetailedEmissionToolOnlineExample(); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/utils/EmissionUtilsTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/utils/EmissionUtilsTest.java index 77aca8075f1..6fdf91cdb46 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/utils/EmissionUtilsTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/utils/EmissionUtilsTest.java @@ -21,7 +21,7 @@ package org.matsim.contrib.emissions.utils; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -43,6 +43,7 @@ import java.util.stream.Collectors; import java.util.stream.Stream; +import static org.junit.jupiter.api.Assertions.assertThrows; import static org.matsim.contrib.emissions.Pollutant.*; @@ -80,7 +81,7 @@ public static Map createUntypedEmissions() { } @Test - public final void testSumUpEmissions() { + final void testSumUpEmissions() { // test the method EmissionUtils.sumUpEmissions for a complete list of pollutants // missing data is not tested here @@ -135,7 +136,7 @@ public final void testSumUpEmissions() { } @Test - public final void testSumUpEmissionsPerId() { + final void testSumUpEmissionsPerId() { Map, Map> warmEmissions = new HashMap<>(); Map, Map> coldEmissions = new HashMap<>(); @@ -256,17 +257,20 @@ public final void testSumUpEmissionsPerId() { } - @Test(expected = NullPointerException.class) - public final void testGetTotalEmissions_nullInput() { + @Test + final void testGetTotalEmissions_nullInput() { + assertThrows(NullPointerException.class, () -> { + + @SuppressWarnings("ConstantConditions") + SortedMap totalEmissions = EmissionUtils.getTotalEmissions(null); + Assert.fail("Expected NullPointerException, got none."); - @SuppressWarnings("ConstantConditions") - SortedMap totalEmissions = EmissionUtils.getTotalEmissions(null); - Assert.fail("Expected NullPointerException, got none."); + }); } @Test - public final void testGetTotalEmissions_emptyList() { + final void testGetTotalEmissions_emptyList() { //test an empty list as input SortedMap totalEmissions; @@ -278,7 +282,7 @@ public final void testGetTotalEmissions_emptyList() { } @Test - public final void testGetTotalEmissions_completeData() { + final void testGetTotalEmissions_completeData() { //test getTotalEmissions for complete data Set pollsFromEU = new HashSet<>(Arrays.asList(CO, CO2_TOTAL, FC, HC, NMHC, NOx, NO2, PM, SO2)); @@ -356,9 +360,9 @@ public final void testGetTotalEmissions_completeData() { Assert.assertEquals("this list should be as long as number of pollutants", totalEmissions.keySet().size(), pollsFromEU.size()); } - + @Test - public final void testSetNonCalculatedEmissionsForPopulation_completeData(){ + final void testSetNonCalculatedEmissionsForPopulation_completeData(){ //test setNonCalculatedEmissionsForPopulation for three persons with complete lists of emissions //check values @@ -465,9 +469,9 @@ public final void testSetNonCalculatedEmissionsForPopulation_completeData(){ Assert.assertEquals("SO value for person 2 is not correct", sov2, finalMap.get(idp2).get( SO2 ), MatsimTestUtils.EPSILON ); } - + @Test - public final void testSetNonCalculatedEmissionsForPopulation_missingMap() { + final void testSetNonCalculatedEmissionsForPopulation_missingMap() { setUpForNonCaculatedEmissions(); @@ -512,7 +516,7 @@ private void setUpForNonCaculatedEmissions() { } @Test - public final void testSetNonCalculatedEmissionsForPopulation_missingPerson() { + final void testSetNonCalculatedEmissionsForPopulation_missingPerson() { setUpForNonCaculatedEmissions(); @@ -544,9 +548,9 @@ public final void testSetNonCalculatedEmissionsForPopulation_missingPerson() { Assert.assertEquals(message, pop.getPersons().keySet().size(), finalMap.keySet().size()); } - + @Test - public final void testSetNonCalculatedEmissionsForPopulation_nullEmissions(){ + final void testSetNonCalculatedEmissionsForPopulation_nullEmissions(){ //test setNonCalculatedEmissionsForPopulation with 'null' // throw nullpointer exception setUpForNonCaculatedEmissions(); @@ -566,9 +570,9 @@ public final void testSetNonCalculatedEmissionsForPopulation_nullEmissions(){ } Assert.assertTrue(nullPointerEx); } - + @Test - public final void testSetNonCalculatedEmissionsForPopulation_emptyPopulation(){ + final void testSetNonCalculatedEmissionsForPopulation_emptyPopulation(){ // test setNonCalculatedEmissionsForPopulation with an empty population // empty list should be returned setUpForNonCaculatedEmissions(); @@ -599,7 +603,7 @@ public final void testSetNonCalculatedEmissionsForPopulation_emptyPopulation(){ } @Test - public final void testSetNonCalculatedEmissionsForPopulation_emptyEmissionMap() { + final void testSetNonCalculatedEmissionsForPopulation_emptyEmissionMap() { //test setNonCalculatedEmissionsForPopulation with an empty emission map setUpForNonCaculatedEmissions(); @@ -643,7 +647,7 @@ public final void testSetNonCalculatedEmissionsForPopulation_emptyEmissionMap() } @Test - public final void testSetNonCalculatedEmissionsForNetwork() { + final void testSetNonCalculatedEmissionsForNetwork() { //test setNonCalculatedEmissionsForNetwork // network consists of four nodes 1,2,3,4 // and six links 12, 13, 14, 23, 24, 34 diff --git a/contribs/ev/src/test/java/org/matsim/contrib/ev/charging/FastThenSlowChargingTest.java b/contribs/ev/src/test/java/org/matsim/contrib/ev/charging/FastThenSlowChargingTest.java index 08eed4fe613..62e2013f14c 100644 --- a/contribs/ev/src/test/java/org/matsim/contrib/ev/charging/FastThenSlowChargingTest.java +++ b/contribs/ev/src/test/java/org/matsim/contrib/ev/charging/FastThenSlowChargingTest.java @@ -22,7 +22,7 @@ import org.assertj.core.api.Assertions; import org.assertj.core.data.Percentage; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.ev.EvUnits; import org.matsim.contrib.ev.fleet.ElectricFleetUtils; @@ -41,7 +41,7 @@ public class FastThenSlowChargingTest { @Test - public void calcChargingPower() { + void calcChargingPower() { //fast charger (2 c) assertCalcChargingPower(100, 0, 200, 175); assertCalcChargingPower(100, 50, 200, 175); @@ -76,7 +76,7 @@ private void assertCalcChargingPower(double capacity_kWh, double charge_kWh, dou } @Test - public void calcChargingTime_singleSection() { + void calcChargingTime_singleSection() { //fast charger (2 c) assertCalcChargingTime(100, 0, 0, 200, 0); assertCalcChargingTime(100, 0, 17.5, 200, 360); @@ -106,7 +106,7 @@ public void calcChargingTime_singleSection() { } @Test - public void calcChargingTime_crossSection() { + void calcChargingTime_crossSection() { //fast charger (2 c) assertCalcChargingTime(100, 32.5, 17.5 + 12.5, 200, 2 * 360); assertCalcChargingTime(100, 62.5, 12.5 + 5, 200, 2 * 360); @@ -124,7 +124,7 @@ public void calcChargingTime_crossSection() { } @Test - public void calcChargingTime_exceptions() { + void calcChargingTime_exceptions() { Assertions.assertThatThrownBy(() -> assertCalcChargingTime(100, 0, -1, 200, 2 * 360)) .isExactlyInstanceOf(IllegalArgumentException.class) .hasMessageStartingWith("Energy is negative: "); @@ -168,7 +168,7 @@ record TestEvSpecification(Id getId, Vehicle getMatsimVehicle, String g } @Test - public void calcEnergyCharge() { + void calcEnergyCharge() { assertCalcEnergyCharge(100, 100, 200, 10, 0); assertCalcEnergyCharge(100, 76, 200, 10, 500000); assertCalcEnergyCharge(100, 51, 200, 10, 1250000); @@ -186,14 +186,14 @@ private void assertCalcEnergyCharge(double capacity_kWh, double charge_kWh, doub } @Test - public void calcEnergyCharged_exceptions() { + void calcEnergyCharged_exceptions() { Assertions.assertThatThrownBy(() -> assertCalcEnergyCharge(100, 100, 10, -1, 0)) .isExactlyInstanceOf(IllegalArgumentException.class) .hasMessageStartingWith("Charging period is negative: "); } @Test - public void calcEnergyChargeAndVerifyWithDuration() { + void calcEnergyChargeAndVerifyWithDuration() { assertEnergyAndDurationCalcCompliance(100, 76, 200, 100); assertEnergyAndDurationCalcCompliance(100, 51, 200, 100); assertEnergyAndDurationCalcCompliance(100, 50, 200, 100); diff --git a/contribs/ev/src/test/java/org/matsim/contrib/ev/charging/VariableSpeedChargingTest.java b/contribs/ev/src/test/java/org/matsim/contrib/ev/charging/VariableSpeedChargingTest.java index 1f0c78ffab9..4178854fa93 100644 --- a/contribs/ev/src/test/java/org/matsim/contrib/ev/charging/VariableSpeedChargingTest.java +++ b/contribs/ev/src/test/java/org/matsim/contrib/ev/charging/VariableSpeedChargingTest.java @@ -22,7 +22,7 @@ import org.assertj.core.api.Assertions; import org.assertj.core.data.Percentage; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.ev.EvUnits; import org.matsim.contrib.ev.fleet.ElectricFleetUtils; @@ -40,7 +40,7 @@ public class VariableSpeedChargingTest { @Test - public void testCalcEnergyCharge() { + void testCalcEnergyCharge() { //fast charger (2 c) assertCalcChargingPower(100, 0, 200, 75); assertCalcChargingPower(100, 5, 200, 100); diff --git a/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java b/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java index 543e1a643da..0fe8353c9d8 100644 --- a/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java +++ b/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java @@ -3,8 +3,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; import org.matsim.core.events.EventsUtils; @@ -22,7 +22,8 @@ public class RunEvExampleWithLTHConsumptionModelTest{ @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; - @Test public void runTest(){ + @Test + void runTest(){ try { String [] args = { RunEvExampleWithLTHConsumptionModel.DEFAULT_CONFIG_FILE ,"--config:controler.outputDirectory", utils.getOutputDirectory() diff --git a/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java b/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java index a7c51e597b1..dbd13c7a8b6 100644 --- a/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java +++ b/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java @@ -22,8 +22,8 @@ import jakarta.inject.Inject; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.PersonDepartureEvent; @@ -45,7 +45,7 @@ public class TemperatureChangeModuleIntegrationTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testTemperatureChangeModule() { + void testTemperatureChangeModule() { Config config = ConfigUtils.loadConfig(utils.getClassInputDirectory() + "/config.xml", new TemperatureChangeConfigGroup()); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java index 60c0c236e32..89a1108290d 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java @@ -21,8 +21,8 @@ package org.matsim.freight.carriers; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; import org.matsim.api.core.v01.network.Link; @@ -73,7 +73,7 @@ public class CarrierEventsReadersTest { ); @Test - public void testWriteReadServiceBasedEvents() { + void testWriteReadServiceBasedEvents() { EventsManager eventsManager1 = EventsUtils.createEventsManager(); EventsManager eventsManager2 = EventsUtils.createEventsManager(); EventsCollector collector1 = new EventsCollector(); @@ -101,7 +101,7 @@ public void testWriteReadServiceBasedEvents() { @Test - public void testReadServiceBasedEvents() { + void testReadServiceBasedEvents() { EventsManager eventsManager = EventsUtils.createEventsManager(); TestEventHandlerTours eventHandlerTours = new TestEventHandlerTours(); @@ -119,7 +119,7 @@ public void testReadServiceBasedEvents() { } @Test - public void testWriteReadShipmentBasedEvents() { + void testWriteReadShipmentBasedEvents() { EventsManager eventsManager1 = EventsUtils.createEventsManager(); EventsManager eventsManager2 = EventsUtils.createEventsManager(); EventsCollector collector1 = new EventsCollector(); @@ -146,7 +146,7 @@ public void testWriteReadShipmentBasedEvents() { } @Test - public void testReadShipmentBasedEvents() { + void testReadShipmentBasedEvents() { EventsManager eventsManager = EventsUtils.createEventsManager(); TestEventHandlerTours eventHandlerTours = new TestEventHandlerTours(); @@ -169,7 +169,7 @@ public void testReadShipmentBasedEvents() { * This test is inspired by the DrtEventsReaderTest from michalm. */ @Test - public void testReader() { + void testReader() { var outputStream = new ByteArrayOutputStream(); EventWriterXML writer = new EventWriterXML(outputStream); carrierEvents.forEach(writer::handleEvent); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierModuleTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierModuleTest.java index 6971e244003..b9794b3aeed 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierModuleTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierModuleTest.java @@ -22,8 +22,8 @@ package org.matsim.freight.carriers; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -80,10 +80,10 @@ public void setUp(){ } + //using this constructor does not work at the moment, as the module would need to derive the carriers out of the scenario. + // to me, it is currently not clear how to do that, tschlenther oct 10 '19 @Test - //using this constructor does not work at the moment, as the module would need to derive the carriers out of the scenario. - // to me, it is currently not clear how to do that, tschlenther oct 10 '19 - public void test_ConstructorWOParameters(){ + void test_ConstructorWOParameters(){ // note setUp method! controler.addOverridingModule(new CarrierModule()); controler.addOverridingModule(new AbstractModule() { @@ -96,8 +96,8 @@ public void install() { controler.run(); } - @Test - public void test_ConstructorWithOneParameter(){ + @Test + void test_ConstructorWithOneParameter(){ // note setUp method! controler.addOverridingModule(new CarrierModule()); controler.addOverridingModule(new AbstractModule() { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java index e99df84a363..9a8bfba14f9 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java @@ -22,8 +22,8 @@ package org.matsim.freight.carriers; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.population.routes.NetworkRoute; import org.matsim.freight.carriers.*; @@ -42,7 +42,7 @@ public class CarrierPlanReaderV1Test { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testCarrierPlanReaderDoesSomething() { + void testCarrierPlanReaderDoesSomething() { CarrierVehicleTypes carrierVehicleTypes = new CarrierVehicleTypes(); new CarrierVehicleTypeReader( carrierVehicleTypes ).readFile( utils.getPackageInputDirectory() + "vehicleTypes_v2.xml" ); @@ -56,7 +56,7 @@ public void testCarrierPlanReaderDoesSomething() { } @Test - public void testReaderReadsCorrectly() { + void testReaderReadsCorrectly() { CarrierVehicleTypes carrierVehicleTypes = new CarrierVehicleTypes(); new CarrierVehicleTypeReader( carrierVehicleTypes ).readFile( utils.getPackageInputDirectory() + "vehicleTypes_v2.xml" ); @@ -81,7 +81,7 @@ public void testReaderReadsCorrectly() { } @Test - public void testReaderReadsScoreAndSelectedPlanCorrectly() { + void testReaderReadsScoreAndSelectedPlanCorrectly() { CarrierVehicleTypes carrierVehicleTypes = new CarrierVehicleTypes(); new CarrierVehicleTypeReader( carrierVehicleTypes ).readFile( utils.getPackageInputDirectory() + "vehicleTypes_v2.xml" ); @@ -98,7 +98,7 @@ public void testReaderReadsScoreAndSelectedPlanCorrectly() { } @Test - public void testReaderReadsUnScoredAndUnselectedPlanCorrectly() { + void testReaderReadsUnScoredAndUnselectedPlanCorrectly() { CarrierVehicleTypes carrierVehicleTypes = new CarrierVehicleTypes(); new CarrierVehicleTypeReader( carrierVehicleTypes ).readFile( utils.getPackageInputDirectory() + "vehicleTypes_v2.xml" ); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java index 1a491be3e95..8d2c910226d 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java @@ -23,8 +23,8 @@ import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -61,12 +61,12 @@ public void setUp() throws Exception{ } @Test - public void test_whenReadingServices_nuOfServicesIsCorrect(){ + void test_whenReadingServices_nuOfServicesIsCorrect(){ Assert.assertEquals(3,testCarrier.getServices().size()); } @Test - public void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ + void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ CarrierVehicle light = CarriersUtils.getCarrierVehicle(testCarrier, Id.createVehicleId("lightVehicle")); Gbl.assertNotNull(light); @@ -82,7 +82,7 @@ public void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ } @Test - public void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ + void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ Map, CarrierVehicle> carrierVehicles = testCarrier.getCarrierCapabilities().getCarrierVehicles(); Assert.assertEquals(3,carrierVehicles.size()); Assert.assertTrue(exactlyTheseVehiclesAreInVehicleCollection(Arrays.asList(Id.create("lightVehicle", Vehicle.class), @@ -90,27 +90,27 @@ public void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ } @Test - public void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ + void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ Assert.assertEquals(FleetSize.INFINITE, testCarrier.getCarrierCapabilities().getFleetSize()); } @Test - public void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ + void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ Assert.assertEquals(2, testCarrier.getShipments().size()); } @Test - public void test_whenReadingCarrier_itReadsPlansCorrectly(){ + void test_whenReadingCarrier_itReadsPlansCorrectly(){ Assert.assertEquals(3, testCarrier.getPlans().size()); } @Test - public void test_whenReadingCarrier_itSelectsPlansCorrectly(){ + void test_whenReadingCarrier_itSelectsPlansCorrectly(){ Assert.assertNotNull(testCarrier.getSelectedPlan()); } @Test - public void test_whenReadingCarrierWithFiniteFleet_itSetsFleetSizeCorrectly(){ + void test_whenReadingCarrierWithFiniteFleet_itSetsFleetSizeCorrectly(){ CarrierVehicleTypes carrierVehicleTypes = new CarrierVehicleTypes(); new CarrierVehicleTypeReader( carrierVehicleTypes ).readFile( utils.getPackageInputDirectory() + "vehicleTypes_v2.xml" ); @@ -122,7 +122,7 @@ public void test_whenReadingCarrierWithFiniteFleet_itSetsFleetSizeCorrectly(){ } @Test - public void test_whenReadingPlans_nuOfToursIsCorrect(){ + void test_whenReadingPlans_nuOfToursIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); Assert.assertEquals(1, plans.get(0).getScheduledTours().size()); Assert.assertEquals(1, plans.get(1).getScheduledTours().size()); @@ -130,7 +130,7 @@ public void test_whenReadingPlans_nuOfToursIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ + void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan1 = plans.get(0); ScheduledTour tour1 = plan1.getScheduledTours().iterator().next(); @@ -138,7 +138,7 @@ public void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ + void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan2 = plans.get(1); ScheduledTour tour1 = plan2.getScheduledTours().iterator().next(); @@ -146,7 +146,7 @@ public void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ + void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan3 = plans.get(2); ScheduledTour tour1 = plan3.getScheduledTours().iterator().next(); @@ -162,13 +162,13 @@ private boolean exactlyTheseVehiclesAreInVehicleCollection(List> asL @Test - public void test_CarrierHasAttributes(){ + void test_CarrierHasAttributes(){ Assert.assertEquals((TransportMode.drt), CarriersUtils.getCarrierMode(testCarrier)); Assert.assertEquals(50, CarriersUtils.getJspritIterations(testCarrier)); } @Test - public void test_ServicesAndShipmentsHaveAttributes(){ + void test_ServicesAndShipmentsHaveAttributes(){ Object serviceCustomerAtt = testCarrier.getServices().get(Id.create("serv1", CarrierService.class)).getAttributes().getAttribute("customer"); Assert.assertNotNull(serviceCustomerAtt); Assert.assertEquals("someRandomCustomer", serviceCustomerAtt); @@ -178,7 +178,7 @@ public void test_ServicesAndShipmentsHaveAttributes(){ } @Test - public void test_readStream() { + void test_readStream() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); Carriers carriers = CarriersUtils.addOrGetCarriers(scenario); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java index 00d92714dc3..32b3dd45307 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java @@ -21,7 +21,10 @@ package org.matsim.freight.carriers; -import org.junit.*; +import org.junit.Assert; +import org.junit.Before; +import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.core.gbl.Gbl; @@ -51,13 +54,14 @@ public void setUp() throws Exception{ testCarrier = carriers.getCarriers().get(Id.create("testCarrier", Carrier.class)); } - @Test @Ignore - public void test_whenReadingServices_nuOfServicesIsCorrect(){ + @Test + @Ignore + void test_whenReadingServices_nuOfServicesIsCorrect(){ Assert.assertEquals(3,testCarrier.getServices().size()); } @Test - public void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ + void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ CarrierVehicle light = CarriersUtils.getCarrierVehicle(testCarrier, Id.createVehicleId("lightVehicle")); Gbl.assertNotNull(light); @@ -72,36 +76,41 @@ public void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ Assert.assertEquals("heavy",heavy.getVehicleTypeId().toString()); } - @Test @Ignore - public void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ + @Test + @Ignore + void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ Map, CarrierVehicle> carrierVehicles = testCarrier.getCarrierCapabilities().getCarrierVehicles(); Assert.assertEquals(3,carrierVehicles.size()); Assert.assertTrue(exactlyTheseVehiclesAreInVehicleCollection(Arrays.asList(Id.create("lightVehicle", Vehicle.class), Id.create("mediumVehicle", Vehicle.class),Id.create("heavyVehicle", Vehicle.class)),carrierVehicles.values())); } - @Test @Ignore - public void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ + @Test + @Ignore + void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ Assert.assertEquals(FleetSize.INFINITE, testCarrier.getCarrierCapabilities().getFleetSize()); } - @Test @Ignore - public void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ + @Test + @Ignore + void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ Assert.assertEquals(2, testCarrier.getShipments().size()); } - @Test @Ignore - public void test_whenReadingCarrier_itReadsPlansCorrectly(){ + @Test + @Ignore + void test_whenReadingCarrier_itReadsPlansCorrectly(){ Assert.assertEquals(3, testCarrier.getPlans().size()); } - @Test @Ignore - public void test_whenReadingCarrier_itSelectsPlansCorrectly(){ + @Test + @Ignore + void test_whenReadingCarrier_itSelectsPlansCorrectly(){ Assert.assertNotNull(testCarrier.getSelectedPlan()); } @Test - public void test_whenReadingCarrierWithFiniteFleet_itSetsFleetSizeCorrectly(){ + void test_whenReadingCarrierWithFiniteFleet_itSetsFleetSizeCorrectly(){ CarrierVehicleTypes carrierVehicleTypes = new CarrierVehicleTypes(); new CarrierVehicleTypeReader( carrierVehicleTypes ).readFile( utils.getPackageInputDirectory() + "vehicleTypes_v2.xml" ); @@ -112,16 +121,18 @@ public void test_whenReadingCarrierWithFiniteFleet_itSetsFleetSizeCorrectly(){ Assert.assertEquals(FleetSize.FINITE, carriers.getCarriers().get(Id.create("testCarrier", Carrier.class)).getCarrierCapabilities().getFleetSize()); } - @Test @Ignore - public void test_whenReadingPlans_nuOfToursIsCorrect(){ + @Test + @Ignore + void test_whenReadingPlans_nuOfToursIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); Assert.assertEquals(1, plans.get(0).getScheduledTours().size()); Assert.assertEquals(1, plans.get(1).getScheduledTours().size()); Assert.assertEquals(1, plans.get(2).getScheduledTours().size()); } - @Test @Ignore - public void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ + @Test + @Ignore + void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan1 = plans.get(0); ScheduledTour tour1 = plan1.getScheduledTours().iterator().next(); @@ -129,15 +140,16 @@ public void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ + void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan2 = plans.get(1); ScheduledTour tour1 = plan2.getScheduledTours().iterator().next(); Assert.assertEquals(9,tour1.getTour().getTourElements().size()); } - @Test @Ignore - public void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ + @Test + @Ignore + void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan3 = plans.get(2); ScheduledTour tour1 = plan3.getScheduledTours().iterator().next(); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV1Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV1Test.java index 4dd9a950d5a..f4840b577ae 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV1Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV1Test.java @@ -21,8 +21,8 @@ package org.matsim.freight.carriers; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.freight.carriers.*; import org.matsim.testcases.MatsimTestUtils; @@ -37,7 +37,7 @@ public class CarrierPlanXmlWriterV1Test { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testCarrierPlanWriterWrites() { + void testCarrierPlanWriterWrites() { CarrierVehicleTypes carrierVehicleTypes = new CarrierVehicleTypes(); new CarrierVehicleTypeReader( carrierVehicleTypes ).readFile( testUtils.getPackageInputDirectory() + "vehicleTypes_v2.xml" ); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java index 252254f9a24..c6a5c2f42b1 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java @@ -22,8 +22,8 @@ package org.matsim.freight.carriers; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.freight.carriers.*; @@ -57,12 +57,12 @@ public void setUp() throws Exception{ } @Test - public void test_whenReadingServices_nuOfServicesIsCorrect(){ + void test_whenReadingServices_nuOfServicesIsCorrect(){ assertEquals(3,testCarrier.getServices().size()); } @Test - public void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ + void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ CarrierVehicle light = CarriersUtils.getCarrierVehicle(testCarrier, Id.createVehicleId("lightVehicle")); assertEquals("light",light.getVehicleTypeId().toString()); @@ -75,7 +75,7 @@ public void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ } @Test - public void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ + void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ Map, CarrierVehicle> carrierVehicles = testCarrier.getCarrierCapabilities().getCarrierVehicles(); assertEquals(3,carrierVehicles.size()); assertTrue(exactlyTheseVehiclesAreInVehicleCollection(Arrays.asList(Id.create("lightVehicle", Vehicle.class), @@ -83,27 +83,27 @@ public void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ } @Test - public void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ + void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ assertEquals(FleetSize.INFINITE, testCarrier.getCarrierCapabilities().getFleetSize()); } @Test - public void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ + void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ assertEquals(2, testCarrier.getShipments().size()); } @Test - public void test_whenReadingCarrier_itReadsPlansCorrectly(){ + void test_whenReadingCarrier_itReadsPlansCorrectly(){ assertEquals(3, testCarrier.getPlans().size()); } @Test - public void test_whenReadingCarrier_itSelectsPlansCorrectly(){ + void test_whenReadingCarrier_itSelectsPlansCorrectly(){ assertNotNull(testCarrier.getSelectedPlan()); } @Test - public void test_whenReadingPlans_nuOfToursIsCorrect(){ + void test_whenReadingPlans_nuOfToursIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); assertEquals(1, plans.get(0).getScheduledTours().size()); assertEquals(1, plans.get(1).getScheduledTours().size()); @@ -111,7 +111,7 @@ public void test_whenReadingPlans_nuOfToursIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ + void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); CarrierPlan plan1 = plans.get(0); ScheduledTour tour1 = plan1.getScheduledTours().iterator().next(); @@ -119,7 +119,7 @@ public void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ + void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); CarrierPlan plan2 = plans.get(1); ScheduledTour tour1 = plan2.getScheduledTours().iterator().next(); @@ -127,7 +127,7 @@ public void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ + void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); CarrierPlan plan3 = plans.get(2); ScheduledTour tour1 = plan3.getScheduledTours().iterator().next(); @@ -142,13 +142,13 @@ private boolean exactlyTheseVehiclesAreInVehicleCollection(List> asL } @Test - public void test_CarrierHasAttributes(){ + void test_CarrierHasAttributes(){ assertEquals((TransportMode.drt), CarriersUtils.getCarrierMode(testCarrier)); assertEquals(50, CarriersUtils.getJspritIterations(testCarrier)); } @Test - public void test_ServicesAndShipmentsHaveAttributes(){ + void test_ServicesAndShipmentsHaveAttributes(){ Object serviceCustomerAtt = testCarrier.getServices().get(Id.create("serv1",CarrierService.class)).getAttributes().getAttribute("customer"); assertNotNull(serviceCustomerAtt); assertEquals("someRandomCustomer", (String) serviceCustomerAtt); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java index a122bae47cb..315570c91a2 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java @@ -22,8 +22,8 @@ package org.matsim.freight.carriers; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.freight.carriers.*; @@ -57,12 +57,12 @@ public void setUp() throws Exception{ } @Test - public void test_whenReadingServices_nuOfServicesIsCorrect(){ + void test_whenReadingServices_nuOfServicesIsCorrect(){ assertEquals(3,testCarrier.getServices().size()); } @Test - public void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ + void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ CarrierVehicle light = CarriersUtils.getCarrierVehicle(testCarrier, Id.createVehicleId("lightVehicle")); assertEquals("light",light.getVehicleTypeId().toString()); @@ -75,7 +75,7 @@ public void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ } @Test - public void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ + void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ Map, CarrierVehicle> carrierVehicles = testCarrier.getCarrierCapabilities().getCarrierVehicles(); assertEquals(3,carrierVehicles.size()); assertTrue(exactlyTheseVehiclesAreInVehicleCollection(Arrays.asList(Id.create("lightVehicle", Vehicle.class), @@ -83,27 +83,27 @@ public void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ } @Test - public void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ + void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ assertEquals(FleetSize.INFINITE, testCarrier.getCarrierCapabilities().getFleetSize()); } @Test - public void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ + void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ assertEquals(2, testCarrier.getShipments().size()); } @Test - public void test_whenReadingCarrier_itReadsPlansCorrectly(){ + void test_whenReadingCarrier_itReadsPlansCorrectly(){ assertEquals(3, testCarrier.getPlans().size()); } @Test - public void test_whenReadingCarrier_itSelectsPlansCorrectly(){ + void test_whenReadingCarrier_itSelectsPlansCorrectly(){ assertNotNull(testCarrier.getSelectedPlan()); } @Test - public void test_whenReadingPlans_nuOfToursIsCorrect(){ + void test_whenReadingPlans_nuOfToursIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); assertEquals(1, plans.get(0).getScheduledTours().size()); assertEquals(1, plans.get(1).getScheduledTours().size()); @@ -111,7 +111,7 @@ public void test_whenReadingPlans_nuOfToursIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ + void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); CarrierPlan plan1 = plans.get(0); ScheduledTour tour1 = plan1.getScheduledTours().iterator().next(); @@ -119,7 +119,7 @@ public void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ + void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); CarrierPlan plan2 = plans.get(1); ScheduledTour tour1 = plan2.getScheduledTours().iterator().next(); @@ -127,7 +127,7 @@ public void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ + void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); CarrierPlan plan3 = plans.get(2); ScheduledTour tour1 = plan3.getScheduledTours().iterator().next(); @@ -135,7 +135,7 @@ public void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan1_SpritScoreIsCorrect(){ + void test_whenReadingToursOfPlan1_SpritScoreIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); CarrierPlan plan1 = plans.get(0); plan1.getAttributes().getAttribute("jspritScore"); @@ -143,7 +143,7 @@ public void test_whenReadingToursOfPlan1_SpritScoreIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan2_jSpritScoreIsCorrect(){ + void test_whenReadingToursOfPlan2_jSpritScoreIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); CarrierPlan plan2 = plans.get(1); plan2.getAttributes().getAttribute("jspritScore"); @@ -151,7 +151,7 @@ public void test_whenReadingToursOfPlan2_jSpritScoreIsCorrect(){ } @Test - public void test_whenReadingToursOfPlan3_jSpritIsCorrect(){ + void test_whenReadingToursOfPlan3_jSpritIsCorrect(){ List plans = new ArrayList(testCarrier.getPlans()); CarrierPlan plan3 = plans.get(2); plan3.getAttributes().getAttribute("jspritScore"); @@ -166,13 +166,13 @@ private boolean exactlyTheseVehiclesAreInVehicleCollection(List> asL } @Test - public void test_CarrierHasAttributes(){ + void test_CarrierHasAttributes(){ assertEquals((TransportMode.drt), CarriersUtils.getCarrierMode(testCarrier)); assertEquals(50, CarriersUtils.getJspritIterations(testCarrier)); } @Test - public void test_ServicesAndShipmentsHaveAttributes(){ + void test_ServicesAndShipmentsHaveAttributes(){ Object serviceCustomerAtt = testCarrier.getServices().get(Id.create("serv1",CarrierService.class)).getAttributes().getAttribute("customer"); assertNotNull(serviceCustomerAtt); assertEquals("someRandomCustomer", (String) serviceCustomerAtt); @@ -180,8 +180,9 @@ public void test_ServicesAndShipmentsHaveAttributes(){ assertNotNull(shipmentCustomerAtt); assertEquals("someRandomCustomer", (String) shipmentCustomerAtt); } + @Test - public void test_ReadWriteFilesAreEqual(){ + void test_ReadWriteFilesAreEqual(){ MatsimTestUtils.assertEqualFilesLineByLine(this.testUtils.getClassInputDirectory() + "carrierPlansEquils.xml", this.testUtils.getClassInputDirectory() + "carrierPlansEquilsWritten.xml"); } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierReadWriteV2_1Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierReadWriteV2_1Test.java index 741d20cb168..be71e48b2ca 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierReadWriteV2_1Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierReadWriteV2_1Test.java @@ -21,8 +21,8 @@ package org.matsim.freight.carriers; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.freight.carriers.*; import org.matsim.testcases.MatsimTestUtils; @@ -36,7 +36,7 @@ public class CarrierReadWriteV2_1Test { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void readWriteTest() throws FileNotFoundException, IOException { + void readWriteTest() throws FileNotFoundException, IOException { Carriers carriers = new Carriers(Collections.emptyList()); CarrierVehicleTypes carrierVehicleTypes = new CarrierVehicleTypes(); @@ -57,7 +57,7 @@ public void readWriteTest() throws FileNotFoundException, IOException { @Test - public void readWriteReadTest() throws FileNotFoundException, IOException { + void readWriteReadTest() throws FileNotFoundException, IOException { Carriers carriers = new Carriers(Collections.emptyList()); CarrierVehicleTypes carrierVehicleTypes = new CarrierVehicleTypes(); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java index 06a24c9e6ee..6f6a002f19c 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java @@ -23,8 +23,8 @@ import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.freight.carriers.*; import org.matsim.testcases.MatsimTestUtils; @@ -48,7 +48,7 @@ public void setUp() throws Exception{ } @Test - public void test_whenLoadingTypes_allAssignmentsInLightVehicleAreCorrectly(){ + void test_whenLoadingTypes_allAssignmentsInLightVehicleAreCorrectly(){ new CarrierVehicleTypeLoader(carriers).loadVehicleTypes(types); Carrier testCarrier = carriers.getCarriers().get(Id.create("testCarrier", Carrier.class)); CarrierVehicle v = CarriersUtils.getCarrierVehicle(testCarrier,Id.createVehicleId("lightVehicle")); @@ -67,7 +67,7 @@ public void test_whenLoadingTypes_allAssignmentsInLightVehicleAreCorrectly(){ } @Test - public void test_whenLoadingTypes_allAssignmentsInMediumVehicleAreCorrectly(){ + void test_whenLoadingTypes_allAssignmentsInMediumVehicleAreCorrectly(){ new CarrierVehicleTypeLoader(carriers).loadVehicleTypes(types); Carrier testCarrier = carriers.getCarriers().get(Id.create("testCarrier", Carrier.class)); CarrierVehicle v = CarriersUtils.getCarrierVehicle(testCarrier,Id.createVehicleId("mediumVehicle")); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java index 720dcb63c32..5801d07e523 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; import org.matsim.vehicles.VehicleType; @@ -49,31 +49,31 @@ public void setUp() { } @Test - public void test_whenReadingTypes_nuOfTypesIsReadCorrectly(){ + void test_whenReadingTypes_nuOfTypesIsReadCorrectly(){ assertEquals(2, types.getVehicleTypes().size()); } @Test - public void test_whenReadingTypes_itReadyExactlyTheTypesFromFile(){ + void test_whenReadingTypes_itReadyExactlyTheTypesFromFile(){ assertTrue(types.getVehicleTypes().containsKey(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ) ); assertTrue(types.getVehicleTypes().containsKey(Id.create("light", org.matsim.vehicles.VehicleType.class ) ) ); assertEquals(2, types.getVehicleTypes().size()); } @Test - public void test_whenReadingTypeMedium_itReadsDescriptionCorrectly(){ + void test_whenReadingTypeMedium_itReadsDescriptionCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); assertEquals("Medium Vehicle", medium.getDescription()); } @Test - public void test_whenReadingTypeMedium_itReadsCapacityCorrectly(){ + void test_whenReadingTypeMedium_itReadsCapacityCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); assertEquals(30., (double) medium.getCapacity().getOther(), Double.MIN_VALUE ); } @Test - public void test_whenReadingTypeMedium_itReadsCostInfoCorrectly(){ + void test_whenReadingTypeMedium_itReadsCostInfoCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); assertEquals(50.0, medium.getCostInformation().getFixedCosts(),0.01 ); assertEquals(0.4, medium.getCostInformation().getCostsPerMeter(),0.01 ); @@ -81,14 +81,14 @@ public void test_whenReadingTypeMedium_itReadsCostInfoCorrectly(){ } @Test - public void test_whenReadingTypeMedium_itReadsEngineInfoCorrectly(){ + void test_whenReadingTypeMedium_itReadsEngineInfoCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); assertEquals(0.02, medium.getEngineInformation().getFuelConsumption(),0.01); assertEquals("gasoline", medium.getEngineInformation().getFuelType().toString()); } @Test - public void readV1andWriteV2(){ + void readV1andWriteV2(){ final String outFilename = utils.getOutputDirectory() + "/vehicleTypes_v2.xml"; new CarrierVehicleTypeWriter( types ).write( outFilename ) ; final String referenceFilename = utils.getClassInputDirectory() + "/vehicleTypes_v2.xml" ; @@ -96,7 +96,7 @@ public void readV1andWriteV2(){ } @Test - public void readV2andWriteV2() { + void readV2andWriteV2() { // yyyyyy FIXME because of "setUp" this will be doing an irrelevant read first. log.info("") ; log.info("") ; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java index a17f15744aa..080ea93de26 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java @@ -23,8 +23,8 @@ import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.freight.carriers.CarrierVehicleTypes; import org.matsim.testcases.MatsimTestUtils; @@ -84,19 +84,19 @@ public void setUp() throws Exception{ } @Test - public void test_whenCreatingTypeMedium_itCreatesDescriptionCorrectly(){ + void test_whenCreatingTypeMedium_itCreatesDescriptionCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals("Medium Vehicle", medium.getDescription()); } @Test - public void test_whenCreatingTypeMedium_itCreatesCapacityCorrectly(){ + void test_whenCreatingTypeMedium_itCreatesCapacityCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(30., medium.getCapacity().getWeightInTons(), MatsimTestUtils.EPSILON ); } @Test - public void test_whenCreatingTypeMedium_itCreatesCostInfoCorrectly(){ + void test_whenCreatingTypeMedium_itCreatesCostInfoCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(50.0, medium.getCostInformation().getFixedCosts(),0.01 ); Assert.assertEquals(1.0, medium.getCostInformation().getCostsPerMeter(),0.01 ); @@ -104,33 +104,33 @@ public void test_whenCreatingTypeMedium_itCreatesCostInfoCorrectly(){ } @Test - public void test_whenCreatingTypeMedium_itCreatesEngineInfoCorrectly(){ + void test_whenCreatingTypeMedium_itCreatesEngineInfoCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(0.02, medium.getEngineInformation().getFuelConsumption(),0.001); Assert.assertEquals(FuelType.diesel, medium.getEngineInformation().getFuelType()); } @Test - public void test_whenCreatingTypeMedium_itCreatesMaxVelocityCorrectly(){ + void test_whenCreatingTypeMedium_itCreatesMaxVelocityCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(13.89, medium.getMaximumVelocity(), 0.01); } //Now testing the copy @Test - public void test_whenCopyingTypeMedium_itCopiesDescriptionCorrectly(){ + void test_whenCopyingTypeMedium_itCopiesDescriptionCorrectly(){ VehicleType medium2 = types.getVehicleTypes().get(Id.create("medium2", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals("Medium Vehicle", medium2.getDescription()); } @Test - public void test_whenCopyingTypeMedium_itCopiesCapacityCorrectly(){ + void test_whenCopyingTypeMedium_itCopiesCapacityCorrectly(){ VehicleType medium2 = types.getVehicleTypes().get(Id.create("medium2", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(30., medium2.getCapacity().getWeightInTons(), MatsimTestUtils.EPSILON ); } @Test - public void test_whenCopyingTypeMedium_itCopiesCostInfoCorrectly(){ + void test_whenCopyingTypeMedium_itCopiesCostInfoCorrectly(){ VehicleType medium2 = types.getVehicleTypes().get(Id.create("medium2", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(50.0, medium2.getCostInformation().getFixedCosts(),0.01 ); Assert.assertEquals(1.0, medium2.getCostInformation().getCostsPerMeter(),0.01 ); @@ -138,33 +138,33 @@ public void test_whenCopyingTypeMedium_itCopiesCostInfoCorrectly(){ } @Test - public void test_whenCopyingTypeMedium_itCopiesEngineInfoCorrectly(){ + void test_whenCopyingTypeMedium_itCopiesEngineInfoCorrectly(){ VehicleType medium2 = types.getVehicleTypes().get(Id.create("medium2", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(0.02, medium2.getEngineInformation().getFuelConsumption(),0.001); Assert.assertEquals(FuelType.diesel, medium2.getEngineInformation().getFuelType()); } @Test - public void test_whenCopyingTypeMedium_itCopiesMaxVelocityCorrectly(){ + void test_whenCopyingTypeMedium_itCopiesMaxVelocityCorrectly(){ VehicleType medium2 = types.getVehicleTypes().get(Id.create("medium2", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(13.89, medium2.getMaximumVelocity(), 0.01); } //Now testing the modified type. @Test - public void test_whenModifyingTypeSmall_itModifiesDescriptionCorrectly(){ + void test_whenModifyingTypeSmall_itModifiesDescriptionCorrectly(){ VehicleType small = types.getVehicleTypes().get(Id.create("small", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals("Small Vehicle", small.getDescription()); } @Test - public void test_whenModifyingTypeSmall_itModifiesCapacityCorrectly(){ + void test_whenModifyingTypeSmall_itModifiesCapacityCorrectly(){ VehicleType small = types.getVehicleTypes().get(Id.create("small", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(16., small.getCapacity().getWeightInTons(), MatsimTestUtils.EPSILON ); } @Test - public void test_whenModifyingTypeSmall_itModifiesCostInfoCorrectly(){ + void test_whenModifyingTypeSmall_itModifiesCostInfoCorrectly(){ VehicleType small = types.getVehicleTypes().get(Id.create("small", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(25.0, small.getCostInformation().getFixedCosts(),0.01 ); Assert.assertEquals(0.75, small.getCostInformation().getCostsPerMeter(),0.01 ); @@ -172,14 +172,14 @@ public void test_whenModifyingTypeSmall_itModifiesCostInfoCorrectly(){ } @Test - public void test_whenModifyingTypeSmall_itModifiesEngineInfoCorrectly(){ + void test_whenModifyingTypeSmall_itModifiesEngineInfoCorrectly(){ VehicleType small = types.getVehicleTypes().get(Id.create("small", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(0.015, small.getEngineInformation().getFuelConsumption(),0.001); Assert.assertEquals(FuelType.gasoline, small.getEngineInformation().getFuelType()); } @Test - public void test_whenModifyingTypeSmall_itModifiesMaxVelocityCorrectly(){ + void test_whenModifyingTypeSmall_itModifiesMaxVelocityCorrectly(){ VehicleType small = types.getVehicleTypes().get(Id.create("small", org.matsim.vehicles.VehicleType.class ) ); Assert.assertEquals(10.0, small.getMaximumVelocity(), 0.01); } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeWriterTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeWriterTest.java index c47029826e6..307408885a6 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeWriterTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeWriterTest.java @@ -21,8 +21,8 @@ package org.matsim.freight.carriers; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.freight.carriers.CarrierVehicleTypeReader; import org.matsim.freight.carriers.CarrierVehicleTypeWriter; import org.matsim.freight.carriers.CarrierVehicleTypes; @@ -34,7 +34,7 @@ public class CarrierVehicleTypeWriterTest { private MatsimTestUtils utils = new MatsimTestUtils() ; @Test - public void testTypeWriter(){ + void testTypeWriter(){ CarrierVehicleTypes types = new CarrierVehicleTypes(); new CarrierVehicleTypeReader(types).readFile(utils.getClassInputDirectory()+ "vehicleTypes.xml"); final String outputVehTypeFile = utils.getOutputDirectory()+ "vehicleTypesWritten.xml"; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java index b1a831f0763..a70e13239eb 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java @@ -22,8 +22,8 @@ package org.matsim.freight.carriers; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.freight.carriers.*; import org.matsim.testcases.MatsimTestUtils; @@ -40,7 +40,7 @@ public class CarriersUtilsTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testAddAndGetVehicleToCarrier() { + void testAddAndGetVehicleToCarrier() { Carrier carrier = new CarrierImpl(Id.create("carrier", Carrier.class)); Id testVehicleId = Id.createVehicleId("testVehicle"); CarrierVehicle carrierVehicle = CarrierVehicle.newInstance(testVehicleId, Id.createLinkId("link0"),VehicleUtils.getDefaultVehicleType()); @@ -61,7 +61,7 @@ public void testAddAndGetVehicleToCarrier() { } @Test - public void testAddAndGetServiceToCarrier() { + void testAddAndGetServiceToCarrier() { Carrier carrier = new CarrierImpl(Id.create("carrier", Carrier.class)); Id serviceId = Id.create("testVehicle", CarrierService.class); CarrierService service1 = CarrierService.Builder.newInstance(serviceId,Id.createLinkId("link0") ) @@ -83,7 +83,7 @@ public void testAddAndGetServiceToCarrier() { } @Test - public void testAddAndGetShipmentToCarrier() { + void testAddAndGetShipmentToCarrier() { Carrier carrier = new CarrierImpl(Id.create("carrier", Carrier.class)); Id shipmentId = Id.create("testVehicle", CarrierShipment.class); CarrierShipment service1 = CarrierShipment.Builder.newInstance(shipmentId,Id.createLinkId("link0"), Id.createLinkId("link1"), 20 ).build(); @@ -104,7 +104,7 @@ public void testAddAndGetShipmentToCarrier() { } @Test - public void testGetSetJspritIteration(){ + void testGetSetJspritIteration(){ Carrier carrier = new CarrierImpl(Id.create("carrier", Carrier.class)); //jspirtIterations is not set. should return Integer.Min_Value (null is not possible because returning (int) Assert.assertEquals(Integer.MIN_VALUE, CarriersUtils.getJspritIterations(carrier) ); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/FreightCarriersConfigGroupTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/FreightCarriersConfigGroupTest.java index 9310bf5716c..a56f1fce3aa 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/FreightCarriersConfigGroupTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/FreightCarriersConfigGroupTest.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigReader; import org.matsim.core.config.ConfigUtils; @@ -39,7 +39,7 @@ public class FreightCarriersConfigGroupTest { @Test - public void test_allParametersAreWrittenToXml() { + void test_allParametersAreWrittenToXml() { FreightCarriersConfigGroup freight = new FreightCarriersConfigGroup(); Map params = freight.getParams(); @@ -51,7 +51,7 @@ public void test_allParametersAreWrittenToXml() { } @Test - public void test_configXmlCanBeParsed() { + void test_configXmlCanBeParsed() { FreightCarriersConfigGroup freight = new FreightCarriersConfigGroup(); Config config = ConfigUtils.createConfig(freight); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java index 7a157805173..c073356e1f0 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java @@ -23,8 +23,8 @@ import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -86,7 +86,7 @@ static Scenario commonScenario( Config config, MatsimTestUtils testUtils ){ } @Test - public void testScoringInMeters(){ + void testScoringInMeters(){ controler.addOverridingModule(new CarrierModule()); controler.addOverridingModule(new AbstractModule() { @Override diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java index 4de7e0d3267..e82e956b9da 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java @@ -21,9 +21,11 @@ package org.matsim.freight.carriers.controler; +import static org.junit.jupiter.api.Assertions.assertThrows; + import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -53,7 +55,7 @@ public void setUp() { } @Test - public void testMobsimWithCarrierRunsWithoutException() { + void testMobsimWithCarrierRunsWithoutException() { setUp(); controler.addOverridingModule(new CarrierModule()); controler.addOverridingModule(new AbstractModule() { @@ -66,39 +68,41 @@ public void install() { controler.run(); } - @Test(expected = IllegalStateException.class ) - public void testWithoutCarrierRoutes() { - Config config = EquilWithCarrierWithPersonsIT.commonConfig( testUtils ); - Scenario scenario = EquilWithCarrierWithPersonsIT.commonScenario( config, testUtils ); - - // set the routes to null: - for( Carrier carrier : CarriersUtils.getCarriers( scenario ).getCarriers().values() ){ - for( ScheduledTour tour : carrier.getSelectedPlan().getScheduledTours() ){ - for( Tour.TourElement tourElement : tour.getTour().getTourElements() ){ - if ( tourElement instanceof Tour.Leg ) { - ((Tour.Leg) tourElement).setRoute( null ); + @Test + void testWithoutCarrierRoutes() { + assertThrows(IllegalStateException.class, () -> { + Config config = EquilWithCarrierWithPersonsIT.commonConfig(testUtils); + Scenario scenario = EquilWithCarrierWithPersonsIT.commonScenario(config, testUtils); + + // set the routes to null: + for (Carrier carrier : CarriersUtils.getCarriers(scenario).getCarriers().values()) { + for (ScheduledTour tour : carrier.getSelectedPlan().getScheduledTours()) { + for (Tour.TourElement tourElement : tour.getTour().getTourElements()) { + if (tourElement instanceof Tour.Leg) { + ((Tour.Leg) tourElement).setRoute(null); + } } } } - } - controler = new Controler(scenario); - controler.addOverridingModule(new CarrierModule()); - controler.addOverridingModule(new AbstractModule() { - @Override - public void install() { - bind( CarrierStrategyManager.class ).toProvider(StrategyManagerFactoryForTests.class ).asEagerSingleton(); - bind(CarrierScoringFunctionFactory.class).to(DistanceScoringFunctionFactoryForTests.class).asEagerSingleton(); - } - }); + controler = new Controler(scenario); + controler.addOverridingModule(new CarrierModule()); + controler.addOverridingModule(new AbstractModule() { + @Override + public void install() { + bind(CarrierStrategyManager.class).toProvider(StrategyManagerFactoryForTests.class).asEagerSingleton(); + bind(CarrierScoringFunctionFactory.class).to(DistanceScoringFunctionFactoryForTests.class).asEagerSingleton(); + } + }); - // this fails in CarrierAgent#createDriverPlans(...). Could be made pass there, but then does not seem to drive on network. Would - // need carrier equivalent to PersonPrepareForSim. Could then adapt this test accordingly. kai, jul'22 - controler.run(); + // this fails in CarrierAgent#createDriverPlans(...). Could be made pass there, but then does not seem to drive on network. Would + // need carrier equivalent to PersonPrepareForSim. Could then adapt this test accordingly. kai, jul'22 + controler.run(); + }); } @Test - public void testScoringInMeters(){ + void testScoringInMeters(){ setUp(); controler.addOverridingModule(new CarrierModule()); controler.addOverridingModule(new AbstractModule() { @@ -118,7 +122,7 @@ public void install() { } @Test - public void testScoringInSecondsWoTimeWindowEnforcement(){ + void testScoringInSecondsWoTimeWindowEnforcement(){ setUp(); FreightCarriersConfigGroup freightCarriersConfigGroup = ConfigUtils.addOrGetModule( controler.getConfig(), FreightCarriersConfigGroup.class ); if ( false ){ @@ -145,7 +149,7 @@ public void install() { } @Test - public void testScoringInSecondsWTimeWindowEnforcement(){ + void testScoringInSecondsWTimeWindowEnforcement(){ setUp(); FreightCarriersConfigGroup freightCarriersConfigGroup = ConfigUtils.addOrGetModule( controler.getConfig(), FreightCarriersConfigGroup.class ); if ( true ){ @@ -173,7 +177,7 @@ public void install() { } @Test - public void testScoringInSecondsWithWithinDayRescheduling(){ + void testScoringInSecondsWithWithinDayRescheduling(){ setUp(); FreightCarriersConfigGroup freightCarriersConfigGroup = ConfigUtils.addOrGetModule( controler.getConfig(), FreightCarriersConfigGroup.class ); if ( true ){ @@ -197,7 +201,7 @@ public void install() { } @Test - public void testEventFilessAreEqual(){ + void testEventFilessAreEqual(){ setUp(); controler.addOverridingModule(new CarrierModule()); controler.addOverridingModule(new AbstractModule() { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java index 99f0c7ebe80..7879f26e03d 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -76,7 +76,7 @@ public class DistanceConstraintFromVehiclesFileTest { * */ @Test - public final void CarrierSmallBatteryTest_Version1() throws ExecutionException, InterruptedException { + final void CarrierSmallBatteryTest_Version1() throws ExecutionException, InterruptedException { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); @@ -150,7 +150,7 @@ public final void CarrierSmallBatteryTest_Version1() throws ExecutionException, * */ @Test - public final void CarrierLargeBatteryTest_Version2() throws ExecutionException, InterruptedException { + final void CarrierLargeBatteryTest_Version2() throws ExecutionException, InterruptedException { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); prepareConfig(config); @@ -226,7 +226,7 @@ public final void CarrierLargeBatteryTest_Version2() throws ExecutionException, */ @Test - public final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, InterruptedException { + final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, InterruptedException { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); prepareConfig(config); @@ -307,7 +307,7 @@ public final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, */ @Test - public final void CarrierWithAdditionalDieselVehicleTest_Version4() throws ExecutionException, InterruptedException { + final void CarrierWithAdditionalDieselVehicleTest_Version4() throws ExecutionException, InterruptedException { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); prepareConfig(config); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java index f55ccf201ed..f84e547bb14 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -78,7 +78,7 @@ public class DistanceConstraintTest { * @throws ExecutionException, InterruptedException */ @Test - public final void CarrierSmallBatteryTest_Version1() throws ExecutionException, InterruptedException { + final void CarrierSmallBatteryTest_Version1() throws ExecutionException, InterruptedException { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); @@ -157,7 +157,7 @@ public final void CarrierSmallBatteryTest_Version1() throws ExecutionException, * */ @Test - public final void CarrierLargeBatteryTest_Version2() throws ExecutionException, InterruptedException { + final void CarrierLargeBatteryTest_Version2() throws ExecutionException, InterruptedException { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); prepareConfig(config); @@ -239,7 +239,7 @@ public final void CarrierLargeBatteryTest_Version2() throws ExecutionException, */ @Test - public final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, InterruptedException { + final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, InterruptedException { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); prepareConfig(config); @@ -329,7 +329,7 @@ public final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, */ @Test - public final void CarrierWithAdditionalDieselVehicleTest_Version4() throws ExecutionException, InterruptedException { + final void CarrierWithAdditionalDieselVehicleTest_Version4() throws ExecutionException, InterruptedException { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); prepareConfig(config); @@ -428,7 +428,7 @@ else if (thisTypeId.equals("DieselVehicle")) */ @Test - public final void CarrierWithShipmentsMidSizeBatteryTest_Version5() throws ExecutionException, InterruptedException { + final void CarrierWithShipmentsMidSizeBatteryTest_Version5() throws ExecutionException, InterruptedException { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); prepareConfig(config); @@ -507,7 +507,7 @@ public final void CarrierWithShipmentsMidSizeBatteryTest_Version5() throws Execu */ @Test - public final void CarrierWithShipmentsLargeBatteryTest_Version6() throws ExecutionException, InterruptedException { + final void CarrierWithShipmentsLargeBatteryTest_Version6() throws ExecutionException, InterruptedException { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); prepareConfig(config); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java index 1adec7e30a1..a0001daba4b 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java @@ -31,8 +31,8 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -186,7 +186,7 @@ public void setUp() throws Exception { * nearby service1: 8km -> 8 EUR; service2: 36km -> 36 EUR --> total 44EUR -> score = -44 */ @Test - public final void test_carrier1CostsAreCorrectly() { + final void test_carrier1CostsAreCorrectly() { Assert.assertEquals(-44, carriersPlannedAndRouted.getCarriers().get(Id.create("carrier1", Carrier.class)).getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); } @@ -195,7 +195,7 @@ public final void test_carrier1CostsAreCorrectly() { * carrier2: only vehicles of Type B (fixed costs of 10 EUR/vehicle, no variable costs) */ @Test - public final void test_carrier2CostsAreCorrectly() { + final void test_carrier2CostsAreCorrectly() { Assert.assertEquals(-20.44, carriersPlannedAndRouted.getCarriers().get(Id.create("carrier2", Carrier.class)).getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); } @@ -204,7 +204,7 @@ public final void test_carrier2CostsAreCorrectly() { * should use A for short trip (8 EUR) and B for the long trip (10.36 EUR) */ @Test - public final void test_carrier3CostsAreCorrectly() { + final void test_carrier3CostsAreCorrectly() { Assert.assertEquals(-18.36, carriersPlannedAndRouted.getCarriers().get(Id.create("carrier3", Carrier.class)).getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java index 1e0988f6529..5131d83904d 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java @@ -28,8 +28,8 @@ import com.graphhopper.jsprit.core.reporting.SolutionPrinter; import com.graphhopper.jsprit.core.util.Solutions; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; import org.matsim.core.config.Config; @@ -48,7 +48,7 @@ public class IntegrationIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testJsprit() throws ExecutionException, InterruptedException { + void testJsprit() throws ExecutionException, InterruptedException { final String networkFilename = utils.getClassInputDirectory() + "/merged-network-simplified.xml.gz"; final String vehicleTypeFilename = utils.getClassInputDirectory() + "/vehicleTypes.xml"; final String carrierFilename = utils.getClassInputDirectory() + "/carrier.xml"; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java index 16cef601c1a..ec82034c573 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java @@ -31,8 +31,8 @@ import com.graphhopper.jsprit.core.problem.vehicle.Vehicle; import com.graphhopper.jsprit.core.problem.vehicle.VehicleImpl; import com.graphhopper.jsprit.core.problem.vehicle.VehicleTypeImpl; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -58,7 +58,7 @@ public class MatsimTransformerTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void whenTransforming_jSpritType2matsimType_itIsMadeCorrectly() { + void whenTransforming_jSpritType2matsimType_itIsMadeCorrectly() { com.graphhopper.jsprit.core.problem.vehicle.VehicleType jspritType = VehicleTypeImpl.Builder .newInstance("myType").addCapacityDimension(0, 50).setCostPerDistance(10.0).setCostPerTransportTime(5.0) .setFixedCost(100.0).build(); @@ -72,7 +72,7 @@ public void whenTransforming_jSpritType2matsimType_itIsMadeCorrectly() { } @Test - public void whenTransforming_jSpritType2matsimType_withCaching_itIsNotCached() { + void whenTransforming_jSpritType2matsimType_withCaching_itIsNotCached() { com.graphhopper.jsprit.core.problem.vehicle.VehicleType jspritType = VehicleTypeImpl.Builder .newInstance("myType").addCapacityDimension(0, 50).setCostPerDistance(10.0).setCostPerTransportTime(5.0) .setFixedCost(100.0).build(); @@ -81,7 +81,7 @@ public void whenTransforming_jSpritType2matsimType_withCaching_itIsNotCached() { } @Test - public void whenTransforming_matsimType2jSpritType_itIsMadeCorrectly() { + void whenTransforming_matsimType2jSpritType_itIsMadeCorrectly() { VehicleType matsimType = getMatsimVehicleType(); com.graphhopper.jsprit.core.problem.vehicle.VehicleType jspritType = MatsimJspritFactory .createJspritVehicleType(matsimType); @@ -93,7 +93,7 @@ public void whenTransforming_matsimType2jSpritType_itIsMadeCorrectly() { } @Test - public void whenTransforming_jspritVehicle2matsimVehicle_itIsMadeCorrectly() { + void whenTransforming_jspritVehicle2matsimVehicle_itIsMadeCorrectly() { com.graphhopper.jsprit.core.problem.vehicle.VehicleType jspritType = VehicleTypeImpl.Builder .newInstance("myType").addCapacityDimension(0, 50).setCostPerDistance(10.0).setCostPerTransportTime(5.0) .setFixedCost(100.0).build(); @@ -109,7 +109,7 @@ public void whenTransforming_jspritVehicle2matsimVehicle_itIsMadeCorrectly() { } @Test - public void whenTransforming_matsimVehicle2jspritVehicle_itIsMadeCorrectly() { + void whenTransforming_matsimVehicle2jspritVehicle_itIsMadeCorrectly() { VehicleType matsimType = getMatsimVehicleType(); CarrierVehicle matsimVehicle = getMatsimVehicle("matsimVehicle", "loc", matsimType); Vehicle jspritVehicle = MatsimJspritFactory.createJspritVehicle(matsimVehicle, null); @@ -122,7 +122,7 @@ public void whenTransforming_matsimVehicle2jspritVehicle_itIsMadeCorrectly() { } @Test - public void whenTransforming_matsimService2jspritService_isMadeCorrectly() { + void whenTransforming_matsimService2jspritService_isMadeCorrectly() { CarrierService carrierService = CarrierService.Builder .newInstance(Id.create("serviceId", CarrierService.class), Id.create("locationId", Link.class)) .setCapacityDemand(50).setServiceDuration(30.0) @@ -140,7 +140,7 @@ public void whenTransforming_matsimService2jspritService_isMadeCorrectly() { } @Test - public void whenTransforming_jspritService2matsimService_isMadeCorrectly() { + void whenTransforming_jspritService2matsimService_isMadeCorrectly() { Service carrierService = Service.Builder.newInstance("serviceId").addSizeDimension(0, 50) .setLocation(Location.newInstance("locationId")).setServiceTime(30.0) .setTimeWindow( @@ -160,7 +160,7 @@ public void whenTransforming_jspritService2matsimService_isMadeCorrectly() { } @Test - public void whenTransforming_matsimShipment2jspritShipment_isMadeCorrectly() { + void whenTransforming_matsimShipment2jspritShipment_isMadeCorrectly() { CarrierShipment carrierShipment = CarrierShipment.Builder .newInstance(Id.create("ShipmentId", CarrierShipment.class), Id.createLinkId("PickupLocationId"), Id.createLinkId("DeliveryLocationId"), 50) @@ -184,7 +184,7 @@ public void whenTransforming_matsimShipment2jspritShipment_isMadeCorrectly() { } @Test - public void whenTransforming_jspritShipment2matsimShipment_isMadeCorrectly() { + void whenTransforming_jspritShipment2matsimShipment_isMadeCorrectly() { Shipment shipment = Shipment.Builder.newInstance("shipmentId").addSizeDimension(0, 50) .setPickupLocation(Location.newInstance("PickupLocationId")).setPickupServiceTime(30.0) .setPickupTimeWindow( @@ -212,7 +212,7 @@ public void whenTransforming_jspritShipment2matsimShipment_isMadeCorrectly() { } @Test - public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_routeStartMustBe15() { + void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_routeStartMustBe15() { ScheduledTour sTour = getMatsimServiceTour(); VehicleRoutingProblem vrp = getVehicleRoutingProblem(sTour); @@ -252,7 +252,7 @@ private VehicleImpl createJspritVehicle(CarrierVehicle vehicle) { } @Test - public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_routeAndVehicleMustNotBeNull() { + void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_routeAndVehicleMustNotBeNull() { ScheduledTour sTour = getMatsimServiceTour(); VehicleRoutingProblem vehicleRoutingProblem = getVehicleRoutingProblem(sTour); VehicleRoute route = MatsimJspritFactory.createRoute(sTour, vehicleRoutingProblem); @@ -261,7 +261,7 @@ public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_rout } @Test - public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_vehicleMustHaveTheCorrectId() { + void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_vehicleMustHaveTheCorrectId() { ScheduledTour sTour = getMatsimServiceTour(); VehicleRoutingProblem vehicleRoutingProblem = getVehicleRoutingProblem(sTour); VehicleRoute route = MatsimJspritFactory.createRoute(sTour, vehicleRoutingProblem); @@ -269,7 +269,7 @@ public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_vehi } @Test - public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_earliestStartMustBe10() { + void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_earliestStartMustBe10() { ScheduledTour sTour = getMatsimServiceTour(); VehicleRoutingProblem vehicleRoutingProblem = getVehicleRoutingProblem(sTour); VehicleRoute route = MatsimJspritFactory.createRoute(sTour, vehicleRoutingProblem); @@ -277,7 +277,7 @@ public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_earl } @Test - public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_latestEndMustBe20() { + void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_latestEndMustBe20() { ScheduledTour sTour = getMatsimServiceTour(); VehicleRoutingProblem vehicleRoutingProblem = getVehicleRoutingProblem(sTour); VehicleRoute route = MatsimJspritFactory.createRoute(sTour, vehicleRoutingProblem); @@ -285,7 +285,7 @@ public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_late } @Test - public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_sizeOfTourMustBe2() { + void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_sizeOfTourMustBe2() { ScheduledTour sTour = getMatsimServiceTour(); VehicleRoutingProblem vehicleRoutingProblem = getVehicleRoutingProblem(sTour); VehicleRoute route = MatsimJspritFactory.createRoute(sTour, vehicleRoutingProblem); @@ -293,7 +293,7 @@ public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_size } @Test - public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_firstActIdMustBeCorrect() { + void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_firstActIdMustBeCorrect() { ScheduledTour sTour = getMatsimServiceTour(); VehicleRoutingProblem vehicleRoutingProblem = getVehicleRoutingProblem(sTour); VehicleRoute route = MatsimJspritFactory.createRoute(sTour, vehicleRoutingProblem); @@ -301,7 +301,7 @@ public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_firs } @Test - public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_secondActIdMustBeCorrect() { + void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_secondActIdMustBeCorrect() { ScheduledTour sTour = getMatsimServiceTour(); VehicleRoutingProblem vehicleRoutingProblem = getVehicleRoutingProblem(sTour); VehicleRoute route = MatsimJspritFactory.createRoute(sTour, vehicleRoutingProblem); @@ -309,7 +309,7 @@ public void whenTransforming_matsimScheduledTourWithServiceAct2vehicleRoute_seco } @Test - public void whenTransforming_matsimPlan2vehicleRouteSolution_itIsMadeCorrectly() { + void whenTransforming_matsimPlan2vehicleRouteSolution_itIsMadeCorrectly() { List sTours = new ArrayList(); ScheduledTour matsimTour = getMatsimTour("matsimVehicle"); sTours.add(matsimTour); @@ -404,12 +404,12 @@ private CarrierShipment getMatsimShipment(String id, String from, String to, int } @Test - public void createVehicleRoutingProblemWithServices_isMadeCorrectly() { + void createVehicleRoutingProblemWithServices_isMadeCorrectly() { // TODO create } @Test - public void createVehicleRoutingProblemBuilderWithServices_isMadeCorrectly() { + void createVehicleRoutingProblemBuilderWithServices_isMadeCorrectly() { Carrier carrier = createCarrierWithServices(); Network network = NetworkUtils.createNetwork(); new MatsimNetworkReader(network).readFile(testUtils.getClassInputDirectory() + "grid-network.xml"); @@ -456,13 +456,13 @@ public void createVehicleRoutingProblemBuilderWithServices_isMadeCorrectly() { } @Test - public void createVehicleRoutingProblemWithShipments_isMadeCorrectly() { + void createVehicleRoutingProblemWithShipments_isMadeCorrectly() { // TODO create } + // @Ignore //Set to ignore due to not implemented functionality of Shipments in MatsimJspritFactory @Test -// @Ignore //Set to ignore due to not implemented functionality of Shipments in MatsimJspritFactory - public void createVehicleRoutingProblemBuilderWithShipments_isMadeCorrectly() { + void createVehicleRoutingProblemBuilderWithShipments_isMadeCorrectly() { Carrier carrier = createCarrierWithShipments(); Network network = NetworkUtils.createNetwork(); new MatsimNetworkReader(network).readFile(testUtils.getClassInputDirectory() + "grid-network.xml"); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java index bc8bc2d0e81..b1c1e3a83f5 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java @@ -25,8 +25,8 @@ import com.graphhopper.jsprit.core.problem.driver.Driver; import com.graphhopper.jsprit.core.problem.vehicle.Vehicle; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; @@ -51,7 +51,7 @@ public class NetworkBasedTransportCostsTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void test_whenAddingTwoDifferentVehicleTypes_itMustAccountForThem(){ + void test_whenAddingTwoDifferentVehicleTypes_itMustAccountForThem(){ Config config = new Config(); config.addCoreModules(); Scenario scenario = ScenarioUtils.createScenario(config); @@ -85,7 +85,7 @@ public void test_whenAddingTwoDifferentVehicleTypes_itMustAccountForThem(){ } @Test - public void test_whenVehicleTypeNotKnow_throwException(){ + void test_whenVehicleTypeNotKnow_throwException(){ Config config = new Config(); config.addCoreModules(); Scenario scenario = ScenarioUtils.createScenario(config); @@ -113,7 +113,7 @@ public void test_whenVehicleTypeNotKnow_throwException(){ } @Test - public void test_whenAddingTwoVehicleTypesViaConstructor_itMustAccountForThat(){ + void test_whenAddingTwoVehicleTypesViaConstructor_itMustAccountForThat(){ Config config = new Config(); config.addCoreModules(); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java index 41f746ec87a..ed4ab348dd4 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java @@ -27,8 +27,8 @@ import com.graphhopper.jsprit.core.reporting.SolutionPrinter; import com.graphhopper.jsprit.core.util.Solutions; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -46,7 +46,7 @@ public class SkillsIT { private final Id carrierLocation = Id.createLinkId("i(1,0)"); @Test - public void testJspritWithDifferentSkillsRequired() { + void testJspritWithDifferentSkillsRequired() { /* First test with different skills. */ Scenario scenario = setupTestScenario(); addShipmentsRequiringDifferentSkills(scenario); @@ -62,7 +62,7 @@ public void testJspritWithDifferentSkillsRequired() { } @Test - public void testJspritWithSameSkillsRequired(){ + void testJspritWithSameSkillsRequired(){ /* Test with same skills. */ Scenario scenario = setupTestScenario(); addShipmentsRequiringSameSkills(scenario); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java index eb884308c2c..f93f457f58e 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java @@ -22,8 +22,8 @@ package org.matsim.freight.carriers.usecases.chessboard; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; import org.matsim.core.events.EventsUtils; @@ -39,7 +39,7 @@ public class RunChessboardIT { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test - public void runChessboard() { + void runChessboard() { String [] args = { IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "freight-chessboard-9x9" ), "config.xml" ).toString() , "--config:controler.outputDirectory", utils.getOutputDirectory() , "--config:controler.lastIteration", "1" diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java index 4fdfd06b0fb..82e0f4a99e6 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java @@ -22,8 +22,8 @@ package org.matsim.freight.carriers.usecases.chessboard; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.testcases.MatsimTestUtils; @@ -32,8 +32,8 @@ public class RunPassengerAlongWithCarriersIT { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils() ; - @Test - public void runChessboard() { + @Test + void runChessboard() { try{ RunPassengerAlongWithCarriers abc = new RunPassengerAlongWithCarriers(); // --- diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java index d297d904034..1c19c0cde0d 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java @@ -28,8 +28,8 @@ import com.graphhopper.jsprit.core.util.Solutions; import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -178,7 +178,7 @@ public void setUp() { @Test - public void numberOfToursIsCorrect() { + void numberOfToursIsCorrect() { Assert.assertEquals(2, carrierWServices.getSelectedPlan().getScheduledTours().size()); Assert.assertEquals(1, carrierWShipments.getSelectedPlan().getScheduledTours().size()); Assert.assertEquals(1, carrierWShipmentsOnlyFromCarrierWServices.getSelectedPlan().getScheduledTours().size()); @@ -190,7 +190,7 @@ public void numberOfToursIsCorrect() { * TODO Calculation of tour distance and duration are commented out, because ...tour.getEnd() has no values -> need for fixing in NetworkRouter or somewhere else kmt/okt18 */ @Test - public void toursInitialCarrierWServicesIsCorrect() { + void toursInitialCarrierWServicesIsCorrect() { Assert.assertEquals(-270.462, carrierWServices.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 // double tourDurationSum = 0; // for (ScheduledTour scheduledTour: carrierWServices.getSelectedPlan().getScheduledTours()){ @@ -212,7 +212,7 @@ public void toursInitialCarrierWServicesIsCorrect() { * TODO Calculation of tour distance and duration are commented out, because ...tour.getEnd() has no values -> need for fixing in NetworkRouter or somewhere else kmt/okt18 */ @Test - public void toursInitialCarrierWShipmentsIsCorrect() { + void toursInitialCarrierWShipmentsIsCorrect() { Assert.assertEquals(-136.87, carrierWShipments.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 // double tourDurationSum = 0; @@ -236,7 +236,7 @@ public void toursInitialCarrierWShipmentsIsCorrect() { * TODO Calculation of tour distance and duration are commented out, because ...tour.getEnd() has no values -> need for fixing in NetworkRouter or somewhere else kmt/okt18 */ @Test - public void toursCarrierWShipmentsOnlyFromCarrierWServicesIsCorrect() { + void toursCarrierWShipmentsOnlyFromCarrierWServicesIsCorrect() { Assert.assertEquals(-140.462, carrierWShipmentsOnlyFromCarrierWServices.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 // double tourDurationSum = 0; @@ -262,7 +262,7 @@ public void toursCarrierWShipmentsOnlyFromCarrierWServicesIsCorrect() { * TODO Calculation of tour distance and duration are commented out, because ...tour.getEnd() has no values -> need for fixing in NetworkRouter or somewhere else kmt/okt18 */ @Test - public void toursCarrierWShipmentsOnlyFromCarrierWShipmentsIsCorrect() { + void toursCarrierWShipmentsOnlyFromCarrierWShipmentsIsCorrect() { Assert.assertEquals(-136.87, carrierWShipmentsOnlyFromCarrierWShipments.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 // double tourDurationSum = 0; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java index 4253b81d269..7465db5d3d8 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java @@ -21,6 +21,8 @@ package org.matsim.freight.carriers.utils; +import static org.junit.jupiter.api.Assertions.assertThrows; + import com.graphhopper.jsprit.core.algorithm.VehicleRoutingAlgorithm; import com.graphhopper.jsprit.core.algorithm.box.SchrimpfFactory; import com.graphhopper.jsprit.core.problem.VehicleRoutingProblem; @@ -30,8 +32,8 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -164,8 +166,9 @@ public void setUp() { } - @Test //Should only have Services - public void numberOfInitalServicesIsCorrect() { + //Should only have Services + @Test + void numberOfInitalServicesIsCorrect() { Assert.assertEquals(2, carrierWServices.getServices().size()); int demandServices = 0; @@ -177,8 +180,9 @@ public void numberOfInitalServicesIsCorrect() { Assert.assertEquals(0, carrierWServices.getShipments().size()); } - @Test //Should only have Shipments - public void numberOfInitialShipmentsIsCorrect() { + //Should only have Shipments + @Test + void numberOfInitialShipmentsIsCorrect() { Assert.assertEquals(0, carrierWShipments.getServices().size()); Assert.assertEquals(2, carrierWShipments.getShipments().size()); @@ -190,7 +194,7 @@ public void numberOfInitialShipmentsIsCorrect() { } @Test - public void numberOfShipmentsFromCopiedShipmentsIsCorrect() { + void numberOfShipmentsFromCopiedShipmentsIsCorrect() { Assert.assertEquals(0, carrierWShipmentsOnlyFromCarrierWShipments.getServices().size()); Assert.assertEquals(2, carrierWShipmentsOnlyFromCarrierWShipments.getShipments().size()); @@ -202,7 +206,7 @@ public void numberOfShipmentsFromCopiedShipmentsIsCorrect() { } @Test - public void numberOfShipmentsFromConvertedServicesIsCorrect() { + void numberOfShipmentsFromConvertedServicesIsCorrect() { Assert.assertEquals(0, carrierWShipmentsOnlyFromCarrierWServices.getServices().size()); Assert.assertEquals(2, carrierWShipmentsOnlyFromCarrierWServices.getShipments().size()); @@ -214,7 +218,7 @@ public void numberOfShipmentsFromConvertedServicesIsCorrect() { } @Test - public void fleetAvailableAfterConvertingIsCorrect() { + void fleetAvailableAfterConvertingIsCorrect() { Assert.assertEquals(FleetSize.INFINITE, carrierWShipmentsOnlyFromCarrierWServices.getCarrierCapabilities().getFleetSize()); Assert.assertEquals(1, carrierWShipmentsOnlyFromCarrierWServices.getCarrierCapabilities().getVehicleTypes().size()); for ( VehicleType carrierVehicleType : carrierWShipmentsOnlyFromCarrierWServices.getCarrierCapabilities().getVehicleTypes()){ @@ -240,7 +244,7 @@ public void fleetAvailableAfterConvertingIsCorrect() { } @Test - public void copiingOfShipmentsIsDoneCorrectly() { + void copiingOfShipmentsIsDoneCorrectly() { boolean foundShipment1 = false; boolean foundShipment2 = false; CarrierShipment carrierShipment1 = CarriersUtils.getShipment(carrierWShipmentsOnlyFromCarrierWShipments, Id.create("shipment1", CarrierShipment.class)); @@ -279,7 +283,7 @@ public void copiingOfShipmentsIsDoneCorrectly() { @Test - public void convertionOfServicesIsDoneCorrectly() { + void convertionOfServicesIsDoneCorrectly() { boolean foundSercice1 = false; boolean foundService2 = false; CarrierShipment carrierShipment1 = CarriersUtils.getShipment(carrierWShipmentsOnlyFromCarrierWServices, Id.create("Service1", CarrierShipment.class)); @@ -314,22 +318,24 @@ public void convertionOfServicesIsDoneCorrectly() { Assert.assertTrue("Not found converted Service2 after converting", foundService2); } - /* Note: This test can be removed / modified when jsprit works properly with a combined Service and Shipment VRP. + /*Note: This test can be removed / modified when jsprit works properly with a combined Service and Shipment VRP. * Currently the capacity of the vehicle seems to be "ignored" in a way that the load within the tour is larger than the capacity; * Maybe it is because of the misunderstanding, that a Service is modeled as "Pickup" and not as thought before as "Delivery". KMT sep18 */ - @Test(expected=UnsupportedOperationException.class) - public void exceptionIsThrownWhenUsingMixedShipmentsAndServices() { - Carrier carrierMixedWServicesAndShipments = CarriersUtils.createCarrier(Id.create("CarrierMixed", Carrier.class ) ); - CarrierService service1 = createMatsimService("Service1", "i(3,9)", 2); - CarriersUtils.addService(carrierMixedWServicesAndShipments, service1); - CarrierShipment shipment1 = createMatsimShipment("shipment1", "i(1,0)", "i(7,6)R", 1); - CarriersUtils.addShipment(carrierMixedWServicesAndShipments, shipment1); - - Network network = NetworkUtils.createNetwork(); - new MatsimNetworkReader(network).readFile(testUtils.getPackageInputDirectory() + "grid-network.xml"); - - MatsimJspritFactory.createRoutingProblemBuilder(carrierMixedWServicesAndShipments, network); + @Test + void exceptionIsThrownWhenUsingMixedShipmentsAndServices() { + assertThrows(UnsupportedOperationException.class, () -> { + Carrier carrierMixedWServicesAndShipments = CarriersUtils.createCarrier(Id.create("CarrierMixed", Carrier.class)); + CarrierService service1 = createMatsimService("Service1", "i(3,9)", 2); + CarriersUtils.addService(carrierMixedWServicesAndShipments, service1); + CarrierShipment shipment1 = createMatsimShipment("shipment1", "i(1,0)", "i(7,6)R", 1); + CarriersUtils.addShipment(carrierMixedWServicesAndShipments, shipment1); + + Network network = NetworkUtils.createNetwork(); + new MatsimNetworkReader(network).readFile(testUtils.getPackageInputDirectory() + "grid-network.xml"); + + MatsimJspritFactory.createRoutingProblemBuilder(carrierMixedWServicesAndShipments, network); + }); } private static CarrierShipment createMatsimShipment(String id, String from, String to, int size) { @@ -361,7 +367,7 @@ private static CarrierService createMatsimService(String id, String to, int size } @Test - public void testAddVehicleTypeSkill(){ + void testAddVehicleTypeSkill(){ VehiclesFactory factory = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getVehicles().getFactory(); VehicleType type = factory.createVehicleType(Id.create("test", VehicleType.class)); Assert.assertFalse("Should not have skill.", CarriersUtils.hasSkill(type, "testSkill")); @@ -376,7 +382,7 @@ public void testAddVehicleTypeSkill(){ } @Test - public void testAddShipmentSkill(){ + void testAddShipmentSkill(){ CarrierShipment shipment = CarrierShipment.Builder.newInstance( Id.create("testShipment", CarrierShipment.class), Id.createLinkId("1"), Id.createLinkId("2"), 1) .build(); @@ -392,7 +398,7 @@ public void testAddShipmentSkill(){ } @Test - public void testAddServiceSkill(){ + void testAddServiceSkill(){ CarrierService service = CarrierService.Builder.newInstance( Id.create("testShipment", CarrierService.class), Id.createLinkId("2")) .build(); @@ -408,7 +414,7 @@ public void testAddServiceSkill(){ } @Test - public void testRunJsprit_allInformationGiven(){ + void testRunJsprit_allInformationGiven(){ Config config = prepareConfig(); config.controller().setOutputDirectory(utils.getOutputDirectory()); @@ -436,28 +442,30 @@ public void testRunJsprit_allInformationGiven(){ /** * This test should lead to an exception, because the NumberOfJspritIterations is not set for carriers. */ - @Test(expected = java.util.concurrent.ExecutionException.class) - public void testRunJsprit_NoOfJspritIterationsMissing() throws ExecutionException, InterruptedException { - Config config = prepareConfig(); - config.controller().setOutputDirectory(utils.getOutputDirectory()); - Scenario scenario = ScenarioUtils.loadScenario(config); - - CarriersUtils.loadCarriersAccordingToFreightConfig(scenario); - - //remove all attributes --> remove the NumberOfJspritIterations attribute to trigger exception - Carriers carriers = CarriersUtils.getCarriers(scenario); - for (Carrier carrier : carriers.getCarriers().values()) { - carrier.getAttributes().clear(); - } + @Test + void testRunJsprit_NoOfJspritIterationsMissing() throws ExecutionException, InterruptedException { + assertThrows(java.util.concurrent.ExecutionException.class, () -> { + Config config = prepareConfig(); + config.controller().setOutputDirectory(utils.getOutputDirectory()); + Scenario scenario = ScenarioUtils.loadScenario(config); + + CarriersUtils.loadCarriersAccordingToFreightConfig(scenario); + + //remove all attributes --> remove the NumberOfJspritIterations attribute to trigger exception + Carriers carriers = CarriersUtils.getCarriers(scenario); + for (Carrier carrier : carriers.getCarriers().values()) { + carrier.getAttributes().clear(); + } - CarriersUtils.runJsprit(scenario); + CarriersUtils.runJsprit(scenario); + }); } /** * Don't crash even if there is no algortihm file specified. */ @Test - public void testRunJsprit_NoAlgortihmFileGiven(){ + void testRunJsprit_NoAlgortihmFileGiven(){ Config config = prepareConfig(); config.controller().setOutputDirectory(utils.getOutputDirectory()); Scenario scenario = ScenarioUtils.loadScenario(config); diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverCostAllocationFixedTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverCostAllocationFixedTest.java index 6d9cbae17cb..bdb2f256853 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverCostAllocationFixedTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverCostAllocationFixedTest.java @@ -1,13 +1,13 @@ package org.matsim.contrib.freightreceiver; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.testcases.MatsimTestUtils; public class ReceiverCostAllocationFixedTest { @Test - public void getScore() { + void getScore() { Assert.assertEquals("Wrong cost.", -20.0, new ReceiverCostAllocationFixed(20.0).getScore(null, null), MatsimTestUtils.EPSILON); } } diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverPlanTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverPlanTest.java index 7a7107f1ca0..7c3a1691412 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverPlanTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverPlanTest.java @@ -17,17 +17,16 @@ * *********************************************************************** */ package org.matsim.contrib.freightreceiver; - +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.junit.Assert; -import org.junit.Test; public class ReceiverPlanTest { @Test - public void testBuilderTwo() { + void testBuilderTwo() { Receiver receiver = ReceiverUtils.newInstance( Id.create( "1", Receiver.class ) ); ReceiverPlan.Builder builder = ReceiverPlan.Builder.newInstance(receiver, true); ReceiverPlan plan = builder.build(); diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java index 6568d0d0bdd..70112f0895f 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java @@ -21,8 +21,8 @@ package org.matsim.contrib.freightreceiver; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.freight.carriers.Carrier; import org.matsim.freight.carriers.TimeWindow; @@ -41,7 +41,7 @@ public class ReceiversReaderTest { * from the original DFG code. */ @Test - public void testBasicV2(){ + void testBasicV2(){ Receivers receivers = new Receivers(); try { new ReceiversReader(receivers).readFile(utils.getClassInputDirectory() + "receivers_v2_basic.xml"); @@ -59,7 +59,7 @@ public void testBasicV2(){ } @Test - public void testV2() { + void testV2() { Receivers receivers = new Receivers(); try { new ReceiversReader(receivers).readFile(utils.getClassInputDirectory() + "receivers_v2_full.xml"); diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java index 9a1a34dd34a..ca5a5f02009 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java @@ -1,8 +1,8 @@ package org.matsim.contrib.freightreceiver; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.freightreceiver.run.chessboard.ReceiverChessboardScenario; @@ -22,8 +22,8 @@ public class ReceiversTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testSetupReceivers() { + @Test + void testSetupReceivers() { try { @SuppressWarnings("unused") Receivers receivers = setupReceivers(); @@ -33,8 +33,8 @@ public void testSetupReceivers() { } } - @Test - public void getReceivers() { + @Test + void getReceivers() { Receivers receivers = setupReceivers(); Map, Receiver> map = receivers.getReceivers(); Assert.assertNotNull("Map must exist.", map); @@ -50,8 +50,8 @@ public void getReceivers() { } } - @Test - public void getReceiver() { + @Test + void getReceiver() { Receivers receivers = setupReceivers(); Receiver receiverExists = receivers.getReceiver(Id.create("1", Receiver.class)); Assert.assertNotNull("Should find receiver.", receiverExists); @@ -59,8 +59,8 @@ public void getReceiver() { Assert.assertNull("Should not find receiver.", receiverDoesNotExist); } - @Test - public void addReceiver() { + @Test + void addReceiver() { Receivers receivers = setupReceivers(); Assert.assertEquals("Wrong number of receivers.", 5, receivers.getReceivers().size()); @@ -74,8 +74,8 @@ public void addReceiver() { /*TODO Should we maybe check if a receiver is NOT overwritten? */ } - @Test - public void createAndAddProductType() { + @Test + void createAndAddProductType() { Receivers receivers = setupReceivers(); Assert.assertEquals("Wrong number of product types.", 2, receivers.getAllProductTypes().size()); @@ -84,8 +84,8 @@ public void createAndAddProductType() { Assert.assertTrue("Should contain new product types", receivers.getAllProductTypes().contains(test)); } - @Test - public void getProductType() { + @Test + void getProductType() { Receivers receivers = setupReceivers(); try { ProductType p1 = receivers.getProductType(Id.create("P1", ProductType.class)); @@ -103,8 +103,8 @@ public void getProductType() { } } - @Test - public void getAllProductTypes() { + @Test + void getAllProductTypes() { Receivers receivers = setupReceivers(); Collection types = receivers.getAllProductTypes(); Assert.assertNotNull("Must have product types.", types); @@ -124,8 +124,8 @@ public void getAllProductTypes() { Assert.assertEquals("Wrong capacity", 2.0, p2.getRequiredCapacity(), MatsimTestUtils.EPSILON); } - @Test - public void getAttributes() { + @Test + void getAttributes() { Receivers receivers = setupReceivers(); Assert.assertNotNull("Should find attributed.", receivers.getAttributes()); Assert.assertEquals("Wrong number of attributes.", 0, receivers.getAttributes().size()); @@ -134,16 +134,16 @@ public void getAttributes() { Assert.assertEquals("Wrong number of attributes.", 1, receivers.getAttributes().size()); } - @Test - public void setDescription() { + @Test + void setDescription() { Receivers receivers = setupReceivers(); Assert.assertEquals("Wrong description.", "Chessboard", receivers.getDescription()); receivers.setDescription("Dummy"); Assert.assertEquals("Wrong description.", "Dummy", receivers.getDescription()); } - @Test - public void getDescription() { + @Test + void getDescription() { Receivers receivers = setupReceivers(); Assert.assertEquals("Wrong description.", "Chessboard", receivers.getDescription()); } diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java index aba05df627e..972ebf6e200 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java @@ -21,8 +21,8 @@ package org.matsim.contrib.freightreceiver; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.freightreceiver.run.chessboard.ReceiverChessboardScenario; import org.matsim.testcases.MatsimTestUtils; @@ -36,7 +36,7 @@ public class ReceiversWriterTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testV1() { + void testV1() { Scenario sc = ReceiverChessboardScenario.createChessboardScenario(1L, 5, utils.getOutputDirectory(), false ); ReceiverUtils.getReceivers(sc).getAttributes().putAttribute("date", new SimpleDateFormat("yyyy/MM/dd HH:mm:ss").format( Calendar.getInstance().getTime())); @@ -53,7 +53,7 @@ public void testV1() { } @Test - public void testV2() { + void testV2() { Scenario sc = ReceiverChessboardScenario.createChessboardScenario(1L, 5, utils.getOutputDirectory(), false ); ReceiverUtils.getReceivers(sc).getAttributes().putAttribute("date", new SimpleDateFormat("yyyy/MM/dd HH:mm:ss").format( Calendar.getInstance().getTime())); diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/SSReorderPolicyTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/SSReorderPolicyTest.java index 681b4f28777..9f51534e124 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/SSReorderPolicyTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/SSReorderPolicyTest.java @@ -22,13 +22,13 @@ import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.testcases.MatsimTestUtils; public class SSReorderPolicyTest { @Test - public void testCalculateOrderQuantity() { + void testCalculateOrderQuantity() { ReorderPolicy policy = ReceiverUtils.createSSReorderPolicy(5.0, 10.0); Assert.assertEquals("Wrong reorder quantity", 0.0, policy.calculateOrderQuantity(6.0), MatsimTestUtils.EPSILON); Assert.assertEquals("Wrong reorder quantity", 5.0, policy.calculateOrderQuantity(5.0), MatsimTestUtils.EPSILON); diff --git a/contribs/hybridsim/src/test/java/org/matsim/contrib/hybridsim/utils/IdIntMapperTest.java b/contribs/hybridsim/src/test/java/org/matsim/contrib/hybridsim/utils/IdIntMapperTest.java index 42bc58a0635..fad773395d3 100644 --- a/contribs/hybridsim/src/test/java/org/matsim/contrib/hybridsim/utils/IdIntMapperTest.java +++ b/contribs/hybridsim/src/test/java/org/matsim/contrib/hybridsim/utils/IdIntMapperTest.java @@ -15,7 +15,7 @@ import org.junit.After; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Node; @@ -43,8 +43,8 @@ public void tearDown() { this.mapper = null; } - @Test - public void testLinkIdIntMapper() { + @Test + void testLinkIdIntMapper() { int id1 = mapper.getIntLink(Id.createLinkId("l1")); assertThat(id1, is(0)); mapper.getIntLink(Id.createLinkId("l2")); @@ -55,8 +55,8 @@ public void testLinkIdIntMapper() { assertThat(id3, is(2)); } - @Test - public void testIntLinkIdMapper() { + @Test + void testIntLinkIdMapper() { Id linkId1 = mapper.getLinkId(10); assertThat(linkId1, is(nullValue())); mapper.getIntLink(Id.createLinkId("l1")); @@ -65,8 +65,8 @@ public void testIntLinkIdMapper() { } - @Test - public void testNodeIdIntMapper() { + @Test + void testNodeIdIntMapper() { int id1 = mapper.getIntNode(Id.createNodeId("l1")); assertThat(id1, is(0)); mapper.getIntNode(Id.createNodeId("l2")); @@ -77,8 +77,8 @@ public void testNodeIdIntMapper() { assertThat(id3, is(2)); } - @Test - public void testIntNodeIdMapper() { + @Test + void testIntNodeIdMapper() { Id nodeId1 = mapper.getNodeId(10); assertThat(nodeId1, is(nullValue())); mapper.getIntNode(Id.createNodeId("l1")); @@ -88,8 +88,8 @@ public void testIntNodeIdMapper() { } - @Test - public void testPersonIdIntMapper() throws Exception { + @Test + void testPersonIdIntMapper() throws Exception { int id1 = mapper.getIntPerson(Id.createPersonId("l1")); assertThat(id1, is(0)); mapper.getIntPerson(Id.createPersonId("l2")); @@ -100,8 +100,8 @@ public void testPersonIdIntMapper() throws Exception { assertThat(id3, is(2)); } - @Test - public void testIntPersonIdMapper() throws Exception { + @Test + void testIntPersonIdMapper() throws Exception { Id personId1 = mapper.getPersonId(10); assertThat(personId1, is(nullValue())); mapper.getIntPerson(Id.createPersonId("l1")); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java index 0b192d3bb83..fae4abb3ab1 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java @@ -2,8 +2,8 @@ import com.google.inject.Injector; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -42,7 +42,7 @@ public void setUp() throws Exception { } @Test - public void routing() { + void routing() { Map, ? extends Person> persons = controler.getScenario().getPopulation().getPersons(); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ModeChoiceWeightSchedulerTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ModeChoiceWeightSchedulerTest.java index b7a4d6cd386..4d9910b96bf 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ModeChoiceWeightSchedulerTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ModeChoiceWeightSchedulerTest.java @@ -1,7 +1,7 @@ package org.matsim.modechoice; import org.assertj.core.data.Offset; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.config.ConfigUtils; import org.matsim.core.controler.MatsimServices; import org.matsim.core.controler.events.IterationStartsEvent; @@ -12,7 +12,7 @@ public class ModeChoiceWeightSchedulerTest extends ScenarioTest { @Test - public void linear() { + void linear() { controler.getConfig().controller().setLastIteration(100); InformedModeChoiceConfigGroup imc = ConfigUtils.addOrGetModule(controler.getConfig(), InformedModeChoiceConfigGroup.class); @@ -38,7 +38,7 @@ public void linear() { } @Test - public void quadratic() { + void quadratic() { controler.getConfig().controller().setLastIteration(101); InformedModeChoiceConfigGroup imc = ConfigUtils.addOrGetModule(controler.getConfig(), InformedModeChoiceConfigGroup.class); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/commands/GenerateChoiceSetTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/commands/GenerateChoiceSetTest.java index f166bae8767..f94cd3f0c2d 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/commands/GenerateChoiceSetTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/commands/GenerateChoiceSetTest.java @@ -1,7 +1,7 @@ package org.matsim.modechoice.commands; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; import org.matsim.modechoice.TestScenario; @@ -17,7 +17,7 @@ public class GenerateChoiceSetTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void command() throws URISyntaxException { + void command() throws URISyntaxException { Path out = Path.of(utils.getOutputDirectory()); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedMassConservationConstraintTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedMassConservationConstraintTest.java index ea1120653c7..abd2614acbb 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedMassConservationConstraintTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedMassConservationConstraintTest.java @@ -1,7 +1,7 @@ package org.matsim.modechoice.constraints; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -30,7 +30,7 @@ public void setUp() throws Exception { @Test - public void cycle() { + void cycle() { Person person = f.createPerson(Id.createPersonId(0)); @@ -75,7 +75,7 @@ public void cycle() { } @Test - public void open() { + void open() { Person person = f.createPerson(Id.createPersonId(0)); @@ -101,7 +101,7 @@ public void open() { } @Test - public void openEnd() { + void openEnd() { Person person = f.createPerson(Id.createPersonId(0)); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java index 04e889ca2ed..30153229e58 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java @@ -1,7 +1,7 @@ package org.matsim.modechoice.constraints; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -33,7 +33,7 @@ public void setUp() throws Exception { } @Test - public void cycle() { + void cycle() { Person person = f.createPerson(Id.createPersonId(0)); @@ -75,7 +75,7 @@ public void cycle() { } @Test - public void open() { + void open() { Person person = f.createPerson(Id.createPersonId(0)); @@ -101,7 +101,7 @@ public void open() { } @Test - public void openEnd() { + void openEnd() { Person person = f.createPerson(Id.createPersonId(0)); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/ComplexEstimatorTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/ComplexEstimatorTest.java index 497e69a631c..ae9bcfc238e 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/ComplexEstimatorTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/ComplexEstimatorTest.java @@ -1,7 +1,7 @@ package org.matsim.modechoice.estimators; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.application.MATSimApplication; import org.matsim.core.config.Config; import org.matsim.core.controler.Controler; @@ -17,7 +17,7 @@ public class ComplexEstimatorTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void bindings() { + void bindings() { Config config = TestScenario.loadConfig(utils); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/DefaultActivityEstimatorTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/DefaultActivityEstimatorTest.java index 5ca25cf9a3d..53ba481d56c 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/DefaultActivityEstimatorTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/estimators/DefaultActivityEstimatorTest.java @@ -1,7 +1,7 @@ package org.matsim.modechoice.estimators; import org.assertj.core.data.Offset; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Activity; import org.matsim.api.core.v01.population.Person; import org.matsim.core.router.TripStructureUtils; @@ -19,7 +19,7 @@ public class DefaultActivityEstimatorTest extends ScenarioTest { @Test - public void person() { + void person() { ScoringParametersForPerson p = injector.getInstance(ScoringParametersForPerson.class); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/MultinomialLogitSelectorTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/MultinomialLogitSelectorTest.java index 2cc40d188ce..44658a957bb 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/MultinomialLogitSelectorTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/MultinomialLogitSelectorTest.java @@ -2,7 +2,7 @@ import org.assertj.core.data.Offset; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.modechoice.PlanCandidate; import java.util.List; @@ -22,7 +22,7 @@ public void setUp() throws Exception { } @Test - public void selection() { + void selection() { List candidates = List.of( new PlanCandidate(new String[]{"car"}, -1), @@ -62,7 +62,7 @@ public void selection() { } @Test - public void invariance() { + void invariance() { List candidates = List.of( new PlanCandidate(new String[]{"car"}, -1), @@ -99,7 +99,7 @@ public void invariance() { } @Test - public void best() { + void best() { selector = new MultinomialLogitSelector(0, new Random(0)); @@ -116,7 +116,7 @@ public void best() { } @Test - public void sameScore() { + void sameScore() { selector = new MultinomialLogitSelector(0.01, new Random(0)); @@ -132,7 +132,7 @@ public void sameScore() { } @Test - public void single() { + void single() { selector = new MultinomialLogitSelector(1, new Random(0)); @@ -148,7 +148,7 @@ public void single() { } @Test - public void precision() { + void precision() { selector = new MultinomialLogitSelector(0.01, new Random(0)); @@ -165,7 +165,7 @@ public void precision() { } @Test - public void inf() { + void inf() { selector = new MultinomialLogitSelector(10000, new Random(0)); @@ -184,7 +184,7 @@ public void inf() { } @Test - public void random() { + void random() { selector = new MultinomialLogitSelector(Double.POSITIVE_INFINITY, new Random(0)); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/RandomSubtourModeStrategyTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/RandomSubtourModeStrategyTest.java index 02ccaff9008..7103598e1a8 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/RandomSubtourModeStrategyTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/RandomSubtourModeStrategyTest.java @@ -2,7 +2,7 @@ import com.google.inject.Key; import com.google.inject.name.Names; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Person; import org.matsim.core.controler.PrepareForMobsim; import org.matsim.core.replanning.PlanStrategy; @@ -18,7 +18,7 @@ protected String[] getArgs() { } @Test - public void person() { + void person() { PrepareForMobsim prepare = injector.getInstance(PrepareForMobsim.class); prepare.run(); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/SelectSingleTripModeStrategyTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/SelectSingleTripModeStrategyTest.java index 7ae3ffca08f..a421036bb16 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/SelectSingleTripModeStrategyTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/SelectSingleTripModeStrategyTest.java @@ -2,7 +2,7 @@ import com.google.inject.Key; import com.google.inject.name.Names; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Person; import org.matsim.application.MATSimApplication; import org.matsim.core.config.Config; @@ -20,7 +20,7 @@ public class SelectSingleTripModeStrategyTest extends ScenarioTest { @Test - public void selectSingleTrip() { + void selectSingleTrip() { Config config = TestScenario.loadConfig(utils); @@ -42,7 +42,7 @@ public void selectSingleTrip() { } @Test - public void person() { + void person() { PlanStrategy strategy = injector.getInstance(Key.get(PlanStrategy.class, Names.named(InformedModeChoiceModule.SELECT_SINGLE_TRIP_MODE_STRATEGY))); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/SelectSubtourModeStrategyTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/SelectSubtourModeStrategyTest.java index d201dae0cfa..7536fe5f8de 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/SelectSubtourModeStrategyTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/SelectSubtourModeStrategyTest.java @@ -3,7 +3,7 @@ import com.google.inject.Key; import com.google.inject.name.Names; import org.assertj.core.data.Offset; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Person; import org.matsim.core.controler.PrepareForMobsim; @@ -25,7 +25,7 @@ protected String[] getArgs() { } @Test - public void person() { + void person() { PrepareForMobsim prepare = injector.getInstance(PrepareForMobsim.class); prepare.run(); @@ -44,7 +44,7 @@ public void person() { } @Test - public void constraint() { + void constraint() { TopKChoicesGenerator generator = injector.getInstance(TopKChoicesGenerator.class); @@ -68,7 +68,7 @@ public void constraint() { } @Test - public void allowedModes() { + void allowedModes() { TopKChoicesGenerator generator = injector.getInstance(TopKChoicesGenerator.class); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/BestChoiceGeneratorTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/BestChoiceGeneratorTest.java index a1180f40a0a..1ea195cd8ad 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/BestChoiceGeneratorTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/BestChoiceGeneratorTest.java @@ -1,6 +1,6 @@ package org.matsim.modechoice.search; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Person; import org.matsim.modechoice.PlanCandidate; import org.matsim.modechoice.PlanModel; @@ -14,7 +14,7 @@ public class BestChoiceGeneratorTest extends ScenarioTest { @Test - public void choices() { + void choices() { BestChoiceGenerator generator = injector.getInstance(BestChoiceGenerator.class); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/DifferentModesTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/DifferentModesTest.java index 6e363136228..d4ec3a62f36 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/DifferentModesTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/DifferentModesTest.java @@ -1,6 +1,6 @@ package org.matsim.modechoice.search; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Person; import org.matsim.core.config.Config; import org.matsim.modechoice.PlanCandidate; @@ -17,7 +17,7 @@ public class DifferentModesTest extends ScenarioTest { @Test - public void topK() { + void topK() { group.setTopK(1024); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/ModeChoiceSearchTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/ModeChoiceSearchTest.java index 485d0535aaf..6c1ab6e7a7e 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/ModeChoiceSearchTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/ModeChoiceSearchTest.java @@ -1,7 +1,7 @@ package org.matsim.modechoice.search; import it.unimi.dsi.fastutil.doubles.DoubleIterator; -import org.junit.Test; +import org.junit.jupiter.api.Test; import static org.assertj.core.api.Assertions.assertThat; @@ -9,7 +9,7 @@ public class ModeChoiceSearchTest { @Test - public void order() { + void order() { ModeChoiceSearch search = new ModeChoiceSearch(3, 3); @@ -43,7 +43,7 @@ public void order() { @Test - public void negative() { + void negative() { ModeChoiceSearch search = new ModeChoiceSearch(3, 3); @@ -68,7 +68,7 @@ public void negative() { @Test - public void nullValues() { + void nullValues() { ModeChoiceSearch search = new ModeChoiceSearch(3, 3); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/SingleTripChoicesGeneratorTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/SingleTripChoicesGeneratorTest.java index d10942e71f4..f9896ac0c2f 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/SingleTripChoicesGeneratorTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/SingleTripChoicesGeneratorTest.java @@ -1,6 +1,6 @@ package org.matsim.modechoice.search; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Person; import org.matsim.modechoice.PlanCandidate; @@ -17,7 +17,7 @@ public class SingleTripChoicesGeneratorTest extends ScenarioTest { @Test - public void choices() { + void choices() { SingleTripChoicesGenerator generator = injector.getInstance(SingleTripChoicesGenerator.class); @@ -37,7 +37,7 @@ public void choices() { @Test - public void unavailable() { + void unavailable() { SingleTripChoicesGenerator generator = injector.getInstance(SingleTripChoicesGenerator.class); @@ -55,7 +55,7 @@ public void unavailable() { } @Test - public void subset() { + void subset() { SingleTripChoicesGenerator generator = injector.getInstance(SingleTripChoicesGenerator.class); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKChoicesGeneratorTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKChoicesGeneratorTest.java index 3a1ba610aea..e2a750f4214 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKChoicesGeneratorTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKChoicesGeneratorTest.java @@ -1,6 +1,6 @@ package org.matsim.modechoice.search; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Leg; import org.matsim.api.core.v01.population.Person; @@ -20,7 +20,7 @@ public class TopKChoicesGeneratorTest extends ScenarioTest { @Test - public void choices() { + void choices() { TopKChoicesGenerator generator = injector.getInstance(TopKChoicesGenerator.class); @@ -44,7 +44,7 @@ public void choices() { } @Test - public void person() { + void person() { TopKChoicesGenerator generator = injector.getInstance(TopKChoicesGenerator.class); @@ -59,7 +59,7 @@ public void person() { @Test - public void invariance() { + void invariance() { TopKChoicesGenerator generator = injector.getInstance(TopKChoicesGenerator.class); @@ -87,7 +87,7 @@ public void invariance() { } @Test - public void predefined() { + void predefined() { TopKChoicesGenerator generator = injector.getInstance(TopKChoicesGenerator.class); @@ -122,7 +122,7 @@ public void predefined() { } @Test - public void threshold() { + void threshold() { TopKChoicesGenerator generator = injector.getInstance(TopKChoicesGenerator.class); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java index 166a19d9aac..a32fc12df0c 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java @@ -6,8 +6,8 @@ import org.assertj.core.api.InstanceOfAssertFactories; import org.assertj.core.data.Offset; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -78,7 +78,7 @@ public void setUp() throws Exception { } @Test - public void minmax() { + void minmax() { Person person = create(); @@ -115,7 +115,7 @@ public void minmax() { } @Test - public void subset() { + void subset() { Person person = create(); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKSubtourGeneratorTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKSubtourGeneratorTest.java index cdb71445fb1..904fc57a7e9 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKSubtourGeneratorTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKSubtourGeneratorTest.java @@ -1,6 +1,6 @@ package org.matsim.modechoice.search; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Person; import org.matsim.core.controler.PrepareForMobsim; @@ -18,7 +18,7 @@ public class TopKSubtourGeneratorTest extends ScenarioTest { @Test - public void subtours() { + void subtours() { // Subtours need mapped locations PrepareForMobsim prepare = injector.getInstance(PrepareForMobsim.class); diff --git a/contribs/integration/src/test/java/org/matsim/integration/daily/SomeDailyTest.java b/contribs/integration/src/test/java/org/matsim/integration/daily/SomeDailyTest.java index c37fca96283..2cf8b0c6d75 100644 --- a/contribs/integration/src/test/java/org/matsim/integration/daily/SomeDailyTest.java +++ b/contribs/integration/src/test/java/org/matsim/integration/daily/SomeDailyTest.java @@ -1,12 +1,12 @@ package org.matsim.integration.daily; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; public class SomeDailyTest { @Test - public void doTest() { + void doTest() { System.out.println("RUN TEST DAILY"); System.out.println("available ram: " + (Runtime.getRuntime().maxMemory() / 1024/1024)); diff --git a/contribs/integration/src/test/java/org/matsim/integration/weekly/SomeWeeklyTest.java b/contribs/integration/src/test/java/org/matsim/integration/weekly/SomeWeeklyTest.java index 61d0673e8ed..87c4be20dac 100644 --- a/contribs/integration/src/test/java/org/matsim/integration/weekly/SomeWeeklyTest.java +++ b/contribs/integration/src/test/java/org/matsim/integration/weekly/SomeWeeklyTest.java @@ -1,11 +1,11 @@ package org.matsim.integration.weekly; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; public class SomeWeeklyTest { @Test - public void doTest() { + void doTest() { System.out.println("RUN TEST WEEKLY"); System.out.println("available ram: " + (Runtime.getRuntime().maxMemory() / 1024/1024)); Assert.assertTrue(true); diff --git a/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java b/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java index 0a99e7e8054..a2bcc7ed20b 100644 --- a/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java +++ b/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java @@ -43,8 +43,8 @@ import org.jfree.chart.renderer.xy.XYLineAndShapeRenderer; import org.jfree.data.xy.XYSeries; import org.jfree.data.xy.XYSeriesCollection; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -125,23 +125,23 @@ public static Collection createFds() { } @Test - public void fdsCarTruck(){ + void fdsCarTruck(){ this.travelModes = new String [] {"car","truck"}; run(false); } @Test - public void fdsCarBike(){ + void fdsCarBike(){ run(false); } @Test - public void fdsCarBikeFastCapacityUpdate(){ + void fdsCarBikeFastCapacityUpdate(){ run(true); } @Test - public void fdsCarOnly(){ + void fdsCarOnly(){ this.travelModes = new String [] {"car"}; run(false); } diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/BestReplyLocationChoicePlanStrategyTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/BestReplyLocationChoicePlanStrategyTest.java index a22dd55b20a..6a299b6d62d 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/BestReplyLocationChoicePlanStrategyTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/BestReplyLocationChoicePlanStrategyTest.java @@ -19,9 +19,8 @@ * *********************************************************************** */ package org.matsim.contrib.locationchoice; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.replanning.ReplanningContext; @@ -41,7 +40,7 @@ public class BestReplyLocationChoicePlanStrategyTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testOne() { + void testOne() { // Config config = ConfigUtils.loadConfig(this.utils.getPackageInputDirectory() + "config.xml"); // Scenario scenario = ScenarioUtils.loadScenario(config); diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java index 3ef0156f7dc..3ea1d36e21b 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java @@ -23,9 +23,8 @@ import static org.junit.Assert.*; import jakarta.inject.Provider; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -77,12 +76,12 @@ public class LocationChoiceIT { private MatsimTestUtils utils = new MatsimTestUtils(); - /** * This is, as far as I can see, testing the {@link LocationChoicePlanStrategy}. It will use the algo from the config, which is "random". It is thus not using the frozen * epsilon approach. kai, mar'19 */ - @Test public void testLocationChoice() { + @Test + void testLocationChoice() { final Config config = localCreateConfig( utils.getPackageInputDirectory() + "config2.xml"); diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/BestReplyIT.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/BestReplyIT.java index e76efbcf390..b08315560aa 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/BestReplyIT.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/BestReplyIT.java @@ -1,7 +1,7 @@ package org.matsim.contrib.locationchoice.frozenepsilons; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -18,7 +18,7 @@ public class BestReplyIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testRunControler() { + void testRunControler() { // load chessboard scenario config: Config config = utils.loadConfig( IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("chessboard"), "config.xml"), diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FacilityPenaltyTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FacilityPenaltyTest.java index 6e89db73e30..eac967476eb 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FacilityPenaltyTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FacilityPenaltyTest.java @@ -4,21 +4,21 @@ import java.lang.reflect.Method; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.locationchoice.DestinationChoiceConfigGroup; import org.matsim.testcases.MatsimTestUtils; public class FacilityPenaltyTest { @Test - public void testGetPenalty() { + void testGetPenalty() { FacilityPenalty facilitypenalty = new FacilityPenalty(0.0, new DestinationChoiceConfigGroup()); Assert.assertEquals(facilitypenalty.getCapacityPenaltyFactor(0.0, 1.0), 0.0, MatsimTestUtils.EPSILON); } @Test - public void testcalculateCapPenaltyFactor() throws SecurityException, NoSuchMethodException, IllegalArgumentException, - IllegalAccessException, InvocationTargetException { + void testcalculateCapPenaltyFactor() throws SecurityException, NoSuchMethodException, IllegalArgumentException, + IllegalAccessException, InvocationTargetException { FacilityPenalty facilitypenalty = new FacilityPenalty(0.0, new DestinationChoiceConfigGroup()); diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java index a09f75758c9..dbbac69569f 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java @@ -15,8 +15,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -91,7 +91,7 @@ public class FrozenEpsilonLocaChoiceIT{ * Confirmed: This tests fails when called AFTER BestReplyIT, michalm/mar'20 */ @Test - public void testLocationChoiceJan2013() { + void testLocationChoiceJan2013() { // CONFIG: final Config config = localCreateConfig( this.utils.getPackageInputDirectory() + "../config2.xml"); @@ -169,7 +169,7 @@ public void install() { } @Test - public void testLocationChoiceFeb2013NegativeScores() { + void testLocationChoiceFeb2013NegativeScores() { // config: final Config config = localCreateConfig( utils.getPackageInputDirectory() + "../config2.xml"); @@ -231,7 +231,8 @@ public void install() { enum RunType { shortRun, medRun, longRun } - @Test public void testFacilitiesAlongALine() { + @Test + void testFacilitiesAlongALine() { RunType runType = RunType.shortRun ; Config config = ConfigUtils.createConfig() ; switch( runType ) { diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java index eee860fb1a1..268466e0215 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java @@ -23,8 +23,8 @@ package org.matsim.contrib.locationchoice.frozenepsilons; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -53,8 +53,8 @@ public void setUp() throws Exception { this.context.init(); } - @Test - public void testSampler() { + @Test + void testSampler() { DestinationSampler sampler = new DestinationSampler( context.getPersonsKValuesArray(), context.getFacilitiesKValuesArray(), ConfigUtils.addOrGetModule( scenario.getConfig(), FrozenTastesConfigGroup.class ) ) ; assertTrue(sampler.sample(context.getFacilityIndex(Id.create(1, ActivityFacility.class)), context.getPersonIndex(Id.create(1, Person.class)))); diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/ScoringPenaltyTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/ScoringPenaltyTest.java index 43c0182c5fb..5a4ce413fb9 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/ScoringPenaltyTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/ScoringPenaltyTest.java @@ -1,14 +1,14 @@ package org.matsim.contrib.locationchoice.frozenepsilons; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.locationchoice.DestinationChoiceConfigGroup; import org.matsim.testcases.MatsimTestUtils; public class ScoringPenaltyTest { @Test - public void testGetPenalty() { + void testGetPenalty() { FacilityPenalty facilityPenalty = new FacilityPenalty(0.0, new DestinationChoiceConfigGroup()); ScoringPenalty scoringpenalty = new ScoringPenalty(0.0, 1.0, facilityPenalty, 1.0); Assert.assertEquals(scoringpenalty.getPenalty(), 0.0, MatsimTestUtils.EPSILON); diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java index 960cca8b706..c17601dbc4b 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java @@ -24,8 +24,8 @@ import java.util.List; import java.util.Random; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -50,14 +50,16 @@ private RecursiveLocationMutator initialize() { return new RecursiveLocationMutator(scenario, initializer.getControler().getTripRouterProvider().get(), TimeInterpretation.create(initializer.getControler().getScenario().getConfig()), new Random(4711)); } - @Test public void testConstructor() { + @Test + void testConstructor() { RecursiveLocationMutator locationmutator = this.initialize(); assertEquals(locationmutator.getMaxRecursions(), 10); assertEquals(locationmutator.getRecursionTravelSpeedChange(), 0.1, MatsimTestUtils.EPSILON); } - @Test public void testHandlePlan() { + @Test + void testHandlePlan() { RecursiveLocationMutator locationmutator = this.initialize(); Plan plan = scenario.getPopulation().getPersons().get(Id.create("1", Person.class)).getSelectedPlan(); locationmutator.run(plan); @@ -65,7 +67,8 @@ private RecursiveLocationMutator initialize() { assertEquals(PopulationUtils.getNextLeg(((Plan) plan), PopulationUtils.getFirstActivity( ((Plan) plan) )).getRoute(), null); } - @Test public void testCalcActChains() { + @Test + void testCalcActChains() { RecursiveLocationMutator locationmutator = this.initialize(); Plan plan = scenario.getPopulation().getPersons().get(Id.create("1", Person.class)).getSelectedPlan(); List list = locationmutator.calcActChains(plan); diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java index d1c4aa34efc..1085935abf6 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java @@ -21,8 +21,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; import org.matsim.api.core.v01.population.Leg; @@ -38,7 +38,8 @@ public class ManageSubchainsTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testPrimarySecondaryActivityFound() { + @Test + void testPrimarySecondaryActivityFound() { Initializer initializer = new Initializer(); initializer.init(utils); ManageSubchains manager = new ManageSubchains(); diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/RandomLocationMutatorTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/RandomLocationMutatorTest.java index 351ca1c1da1..0a19814e847 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/RandomLocationMutatorTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/RandomLocationMutatorTest.java @@ -21,8 +21,8 @@ import java.util.Random; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.contrib.locationchoice.Initializer; @@ -48,7 +48,8 @@ private RandomLocationMutator initialize() { /* * TODO: Construct scenario with knowledge to compare plans before and after loc. choice */ - @Test public void testHandlePlan() { + @Test + void testHandlePlan() { RandomLocationMutator randomlocationmutator = this.initialize(); randomlocationmutator.run(scenario.getPopulation().getPersons().get(Id.create("1", Person.class)).getSelectedPlan()); } diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java index 16fccf1abd0..c13f5995a67 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java @@ -2,8 +2,8 @@ import static org.junit.Assert.assertNotNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class SubChainTest { @@ -12,7 +12,8 @@ public class SubChainTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testConstructorandGetSlActs() { + @Test + void testConstructorandGetSlActs() { SubChain subchain = new SubChain(); assertNotNull(subchain.getSlActs()); } diff --git a/contribs/locationchoice/src/test/java/org/matsim/core/router/BackwardFastMultiNodeTest.java b/contribs/locationchoice/src/test/java/org/matsim/core/router/BackwardFastMultiNodeTest.java index 844fdbe02ef..beb768be82e 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/core/router/BackwardFastMultiNodeTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/core/router/BackwardFastMultiNodeTest.java @@ -21,7 +21,7 @@ package org.matsim.core.router; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -48,7 +48,7 @@ public class BackwardFastMultiNodeTest { @Test - public void testBackwardsFastMultiNodeDijkstra_OneToOne() { + void testBackwardsFastMultiNodeDijkstra_OneToOne() { runTestBackwardsFastMultiNodeDijkstra_OneToOne(true); runTestBackwardsFastMultiNodeDijkstra_OneToOne(false); } @@ -113,7 +113,7 @@ private void runTestBackwardsFastMultiNodeDijkstra_OneToOne(boolean searchAllEnd * Search only cheapest to node. n5 should not be found. */ @Test - public void testBackwardsFastMultiNodeDijkstra_OneToMany() { + void testBackwardsFastMultiNodeDijkstra_OneToMany() { Config config = ConfigUtils.createConfig(); config.routing().setRoutingRandomness(0.); @@ -203,7 +203,7 @@ public void testBackwardsFastMultiNodeDijkstra_OneToMany() { } @Test - public void testBackwardsFastMultiNodeDijkstra_OneToMany_SearchAllNodes() { + void testBackwardsFastMultiNodeDijkstra_OneToMany_SearchAllNodes() { Config config = ConfigUtils.createConfig(); config.routing().setRoutingRandomness(0.); diff --git a/contribs/locationchoice/src/test/java/org/matsim/core/router/FastMultiNodeTest.java b/contribs/locationchoice/src/test/java/org/matsim/core/router/FastMultiNodeTest.java index 1dc5a2a4650..56c804c9cc9 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/core/router/FastMultiNodeTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/core/router/FastMultiNodeTest.java @@ -21,7 +21,7 @@ package org.matsim.core.router; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -50,7 +50,7 @@ public class FastMultiNodeTest { @Test - public void testFastMultiNodeDijkstra_OneToOne() { + void testFastMultiNodeDijkstra_OneToOne() { Config config = ConfigUtils.createConfig(); config.routing().setRoutingRandomness( 0. ); @@ -108,7 +108,7 @@ public void testFastMultiNodeDijkstra_OneToOne() { } @Test - public void testFastMultiNodeDijkstra_OneToMany() { + void testFastMultiNodeDijkstra_OneToMany() { Config config = ConfigUtils.createConfig(); config.routing().setRoutingRandomness( 0. ); @@ -199,7 +199,7 @@ public void testFastMultiNodeDijkstra_OneToMany() { } @Test - public void testFastMultiNodeDijkstra_OneToMany_SearchAllNodes() { + void testFastMultiNodeDijkstra_OneToMany_SearchAllNodes() { Config config = ConfigUtils.createConfig(); config.routing().setRoutingRandomness( 0. ); diff --git a/contribs/locationchoice/src/test/java/org/matsim/core/router/MultiNodeDijkstraTest.java b/contribs/locationchoice/src/test/java/org/matsim/core/router/MultiNodeDijkstraTest.java index 4dc03887cdd..283b90b0218 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/core/router/MultiNodeDijkstraTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/core/router/MultiNodeDijkstraTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -56,9 +56,9 @@ private MultiNodeDijkstra makeMultiNodeDikstra(Network network, TravelDisutility return (MultiNodeDijkstra) new FastMultiNodeDijkstraFactory().createPathCalculator(network, travelDisutility, travelTime); } else return (MultiNodeDijkstra) new MultiNodeDijkstraFactory().createPathCalculator(network, travelDisutility, travelTime); } - + @Test - public void testMultipleStarts() { + void testMultipleStarts() { testMultipleStarts(true); testMultipleStarts(false); } @@ -116,7 +116,7 @@ public void testMultipleStarts(boolean fastRouter) { } @Test - public void testMultipleEnds() { + void testMultipleEnds() { testMultipleEnds(true); testMultipleEnds(false); } @@ -174,7 +174,7 @@ public void testMultipleEnds(boolean fastRouter) { } @Test - public void testMultipleStartsAndEnds() { + void testMultipleStartsAndEnds() { testMultipleStartsAndEnds(true); testMultipleStartsAndEnds(false); } @@ -235,7 +235,7 @@ public void testMultipleStartsAndEnds(boolean fastRouter) { } @Test - public void testStartViaFaster() { + void testStartViaFaster() { testStartViaFaster(true); testStartViaFaster(false); } @@ -278,7 +278,7 @@ public void testStartViaFaster(boolean fastRouter) { } @Test - public void testEndViaFaster() { + void testEndViaFaster() { testEndViaFaster(true); testEndViaFaster(false); } @@ -323,7 +323,7 @@ public void testEndViaFaster(boolean fastRouter) { } @Test - public void testOnlyFromToSameNode() { + void testOnlyFromToSameNode() { testOnlyFromToSameNode(true); testOnlyFromToSameNode(false); } @@ -358,7 +358,7 @@ public void testOnlyFromToSameNode(boolean fastRouter) { } @Test - public void testSameNodeInFromToSetCheapest() { + void testSameNodeInFromToSetCheapest() { testSameNodeInFromToSetCheapest(true); testSameNodeInFromToSetCheapest(false); } @@ -400,7 +400,7 @@ public void testSameNodeInFromToSetCheapest(boolean fastRouter) { } @Test - public void testSameNodeInFromToSetNotCheapest() { + void testSameNodeInFromToSetNotCheapest() { testSameNodeInFromToSetNotCheapest(true); testSameNodeInFromToSetNotCheapest(false); } @@ -443,7 +443,7 @@ public void testSameNodeInFromToSetNotCheapest(boolean fastRouter) { } @Test - public void testSomeEndNodesNotReachable() { + void testSomeEndNodesNotReachable() { testSomeEndNodesNotReachable(true); testSomeEndNodesNotReachable(false); } @@ -484,7 +484,7 @@ public void testSomeEndNodesNotReachable(boolean fastRouter) { } @Test - public void testSomeStartNodesNotUseable() { + void testSomeStartNodesNotUseable() { testSomeStartNodesNotUseable(true); testSomeStartNodesNotUseable(false); } @@ -525,7 +525,7 @@ public void testSomeStartNodesNotUseable(boolean fastRouter) { } @Test - public void testImpossibleRoute() { + void testImpossibleRoute() { testImpossibleRoute(true); testImpossibleRoute(false); } @@ -561,7 +561,7 @@ public void testImpossibleRoute(boolean fastRouter) { * account in the path. */ @Test - public void testInitialValuesCorrection() { + void testInitialValuesCorrection() { testInitialValuesCorrection(true); testInitialValuesCorrection(false); } diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java index b8529245eff..9f56650dc64 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java @@ -26,8 +26,8 @@ import java.io.IOException; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Coord; @@ -66,7 +66,7 @@ public class MatrixBasedPtRouterIT { * the travel time computed by the PtMatrix are compared (should be equal). */ @Test - public void testIntegration() throws IOException { + void testIntegration() throws IOException { String path = utils.getOutputDirectory(); diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java index 9296f93e9ef..39a0ba2fa6c 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java @@ -31,8 +31,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Coord; @@ -89,7 +89,7 @@ public void setUp() throws Exception { * @throws IOException */ @Test - public void testPtMatrixStops() throws IOException{ + void testPtMatrixStops() throws IOException{ log.info("Start testing the pt matrix with information about the pt stops."); long start = System.currentTimeMillis(); @@ -192,7 +192,7 @@ else if( (origin + 1) % 4 == destination || (origin + 3) % 4 == destination){ * @throws IOException */ @Test - public void testPtMatrixTimesAndDistances() throws IOException{ + void testPtMatrixTimesAndDistances() throws IOException{ log.info("Start testing the pt matrix with information about the pt stops, pt travel times and distances."); long start = System.currentTimeMillis(); diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/TestQuadTree.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/TestQuadTree.java index c9fc807c0de..fb284ae2911 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/TestQuadTree.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/TestQuadTree.java @@ -26,8 +26,7 @@ import java.util.Iterator; import org.junit.Assert; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.collections.QuadTree; @@ -124,7 +123,7 @@ private void determineNearestPtStation(){ } @Test - public void test() { + void test() { TestQuadTree tc = new TestQuadTree(); tc.determineNearestPtStation(); } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java index 4436fb790ae..9e13c9d134d 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java @@ -20,8 +20,7 @@ package org.matsim.contrib.minibus.genericUtils; import java.util.ArrayList; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.config.ConfigUtils; import org.matsim.core.scenario.ScenarioUtils; @@ -42,9 +41,9 @@ public class TerminusStopFinderTest { TransitSchedule schedule; TransitScheduleFactory stopFactory; - + @Test - public void testFindSecondTerminusStop() { + void testFindSecondTerminusStop() { /* * straight line * diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java index 7ea50ed1e8e..85b2ae5dc77 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java @@ -25,8 +25,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.minibus.PConfigGroup; import org.matsim.contrib.minibus.hook.PModule; @@ -53,7 +53,7 @@ public class PControlerTestIT implements TabularFileHandler{ @Test - public final void testPControler() { + final void testPControler() { final String scenarioName = "corr_s1_0"; final int numberOfIterations = 10; diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java index 3c22dcac81e..e83d57955aa 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java @@ -26,8 +26,8 @@ import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.minibus.PConfigGroup; import org.matsim.contrib.minibus.hook.PModule; @@ -58,7 +58,7 @@ public class SubsidyContextTestIT implements TabularFileHandler { @Ignore @Test - public final void testDefaultPControler() { + final void testDefaultPControler() { Config config1 = ConfigUtils.loadConfig( utils.getClassInputDirectory() + "config.xml", new PConfigGroup() ) ; @@ -117,7 +117,7 @@ public final void testDefaultPControler() { @Ignore @Test - public final void testSubsidyPControler() { + final void testSubsidyPControler() { Config config2 = ConfigUtils.loadConfig( utils.getClassInputDirectory() + "config.xml", new PConfigGroup() ) ; diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java index 33af461049a..07e2e05c0e7 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java @@ -25,8 +25,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.minibus.PConfigGroup; import org.matsim.contrib.minibus.hook.PModule; @@ -54,7 +54,7 @@ public class SubsidyTestIT implements TabularFileHandler { private final ArrayList pStatsResults = new ArrayList<>(); @Test - public final void testSubsidyPControler() { + final void testSubsidyPControler() { Config config = ConfigUtils.loadConfig( utils.getClassInputDirectory() + "config.xml", new PConfigGroup() ) ; diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java index d2a097f60bf..f0d42a75dd7 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.minibus.replanning; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.minibus.PConstants; import org.matsim.contrib.minibus.hook.Operator; import org.matsim.contrib.minibus.hook.PPlan; @@ -36,7 +36,7 @@ public class EndRouteExtensionTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testRun() { + final void testRun() { Operator coop = PScenarioHelper.createCoop2111to2333(); @@ -98,7 +98,7 @@ public final void testRun() { } @Test - public final void testRunVShapedRoute() { + final void testRunVShapedRoute() { Operator coop = PScenarioHelper.createCoopRouteVShaped(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java index af6b404c1a2..dfae9e35570 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.minibus.replanning; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.minibus.hook.Operator; import org.matsim.contrib.minibus.hook.PPlan; import org.matsim.contrib.minibus.routeProvider.PScenarioHelper; @@ -34,7 +34,7 @@ public class MaxRandomEndTimeAllocatorTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testRun() { + final void testRun() { Operator coop = PScenarioHelper.createTestCooperative(utils.getOutputDirectory()); ArrayList param = new ArrayList<>(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java index d3086cf9ced..0c51695020c 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.minibus.replanning; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.minibus.hook.Operator; import org.matsim.contrib.minibus.hook.PPlan; import org.matsim.contrib.minibus.routeProvider.PScenarioHelper; @@ -34,7 +34,7 @@ public class MaxRandomStartTimeAllocatorTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testRun() { + final void testRun() { Operator coop = PScenarioHelper.createTestCooperative(utils.getOutputDirectory()); ArrayList param = new ArrayList<>(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java index 615ef2f3412..d9a58f4ce0b 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.minibus.replanning; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.minibus.PConstants; import org.matsim.contrib.minibus.hook.Operator; import org.matsim.contrib.minibus.hook.PPlan; @@ -47,7 +47,7 @@ public class SidewaysRouteExtensionTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testRun() { + final void testRun() { Operator coop = PScenarioHelper.createCoop2414to3444(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java index 61744081b5d..d4cda9b24d9 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java @@ -22,8 +22,8 @@ import java.io.File; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.network.Link; @@ -39,7 +39,7 @@ public class TimeProviderTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testGetRandomTimeInIntervalOneTimeSlot() { + final void testGetRandomTimeInIntervalOneTimeSlot() { new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); @@ -56,7 +56,7 @@ public final void testGetRandomTimeInIntervalOneTimeSlot() { } @Test - public final void testGetRandomTimeInIntervalOneSameStartEndTime() { + final void testGetRandomTimeInIntervalOneSameStartEndTime() { new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); @@ -73,7 +73,7 @@ public final void testGetRandomTimeInIntervalOneSameStartEndTime() { } @Test - public final void testGetRandomTimeInIntervalDifferentStartEndTime() { + final void testGetRandomTimeInIntervalDifferentStartEndTime() { new File(utils.getOutputDirectory() + PConstants.statsOutputFolder).mkdir(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java index ba4fb39e8d8..9ece4bc8d4a 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java @@ -23,8 +23,8 @@ import java.util.ArrayList; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.network.Link; @@ -43,7 +43,7 @@ public class WeightedEndTimeExtensionTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testRun() { + final void testRun() { Operator coop = PScenarioHelper.createTestCooperative(utils.getOutputDirectory()); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java index 8c2dd102cd7..38505c684cc 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java @@ -23,8 +23,8 @@ import java.util.ArrayList; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.network.Link; @@ -43,7 +43,7 @@ public class WeightedStartTimeExtensionTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testRun() { + final void testRun() { Operator coop = PScenarioHelper.createTestCooperative(utils.getOutputDirectory()); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java index 70a363892ed..173983379c2 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java @@ -22,8 +22,8 @@ import java.util.ArrayList; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -45,7 +45,7 @@ public class ComplexCircleScheduleProviderTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testCreateTransitLineLikeSimpleCircleScheduleProvider() { + final void testCreateTransitLineLikeSimpleCircleScheduleProvider() { Scenario scenario = PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); @@ -104,7 +104,7 @@ public final void testCreateTransitLineLikeSimpleCircleScheduleProvider() { } @Test - public final void testCreateTransitLineWithMoreStops() { + final void testCreateTransitLineWithMoreStops() { Scenario scenario = PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); @@ -172,7 +172,7 @@ public final void testCreateTransitLineWithMoreStops() { } @Test - public final void testGetRandomTransitStop() { + final void testGetRandomTransitStop() { MutableScenario scenario = (MutableScenario) PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); @@ -188,7 +188,7 @@ public final void testGetRandomTransitStop() { } @Test - public final void testCreateEmptyLine() { + final void testCreateEmptyLine() { MutableScenario scenario = (MutableScenario) PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java index 4b09480162c..5d73e3a7e8d 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java @@ -22,8 +22,8 @@ import java.util.ArrayList; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -45,7 +45,7 @@ public class SimpleCircleScheduleProviderTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testCreateTransitLine() { + final void testCreateTransitLine() { Scenario scenario = PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); @@ -104,7 +104,7 @@ public final void testCreateTransitLine() { } @Test - public final void testGetRandomTransitStop() { + final void testGetRandomTransitStop() { MutableScenario scenario = (MutableScenario) PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); @@ -120,7 +120,7 @@ public final void testGetRandomTransitStop() { } @Test - public final void testCreateEmptyLine() { + final void testCreateEmptyLine() { MutableScenario scenario = (MutableScenario) PScenarioHelper.createTestNetwork(); PConfigGroup pC = new PConfigGroup(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java index 260a6a7d7f1..8c174734f6f 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.minibus.schedule; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -42,7 +42,7 @@ public class CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testPScenarioHelperTestNetwork() { + final void testPScenarioHelperTestNetwork() { Network net = PScenarioHelper.createTestNetwork().getNetwork(); PConfigGroup pC = new PConfigGroup(); @@ -107,7 +107,7 @@ public final void testPScenarioHelperTestNetwork() { /** {@link org.matsim.core.network.algorithms.intersectionSimplifier.IntersectionSimplifierTest} */ @Test - public final void testComplexIntersection() { + final void testComplexIntersection() { Network network = buildComplexIntersection(); PConfigGroup pC = new PConfigGroup(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java index 50453286821..38a447f0a74 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.minibus.schedule; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -39,7 +39,7 @@ public class CreateStopsForAllCarLinksTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testCreateStopsForAllCarLinks() { + final void testCreateStopsForAllCarLinks() { Network net = PScenarioHelper.createTestNetwork().getNetwork(); PConfigGroup pC = new PConfigGroup(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java index 8693c46df4f..8c4e676cfeb 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java @@ -24,7 +24,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -63,9 +63,9 @@ public void setUp() { scenario = ScenarioUtils.loadScenario(ConfigUtils.createConfig()); factory = scenario.getTransitSchedule().getFactory(); } - + @Test - public void testRectangularLine() { + void testRectangularLine() { ArrayList stopsToBeServed = new ArrayList<>(); ArrayList stops = new ArrayList<>(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java index efcd8818e98..1cd63090a0e 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java @@ -24,7 +24,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.minibus.PConfigGroup; @@ -65,9 +65,9 @@ public void setUp() { scenario = ScenarioUtils.loadScenario(ConfigUtils.createConfig()); factory = scenario.getTransitSchedule().getFactory(); } - + @Test - public void testRectangularLine() { + void testRectangularLine() { ArrayList stopsToBeServed = new ArrayList<>(); ArrayList stops = new ArrayList<>(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java index dfd86935ab5..88c2217c9a6 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java @@ -23,7 +23,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.minibus.PConfigGroup; @@ -59,9 +59,9 @@ public void setUp() { scenario = ScenarioUtils.loadScenario(ConfigUtils.createConfig()); factory = scenario.getTransitSchedule().getFactory(); } - + @Test - public void testRouteServingSameStopTwice() { + void testRouteServingSameStopTwice() { ArrayList stopsToBeServed = new ArrayList<>(); ArrayList stops = new ArrayList<>(); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java index fc160716cfb..5d7d6647979 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.minibus.stats; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.minibus.stats.RecursiveStatsApproxContainer; import org.matsim.testcases.MatsimTestUtils; @@ -30,7 +30,7 @@ public class RecursiveStatsApproxContainerTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testRecursiveStatsContainer() { + final void testRecursiveStatsContainer() { RecursiveStatsApproxContainer stats = new RecursiveStatsApproxContainer(0.1, 3); diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java index 5b51ce6808d..60afd38171d 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.minibus.stats; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.minibus.stats.RecursiveStatsContainer; import org.matsim.testcases.MatsimTestUtils; @@ -30,7 +30,7 @@ public class RecursiveStatsContainerTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testRecursiveStatsContainer() { + final void testRecursiveStatsContainer() { RecursiveStatsContainer stats = new RecursiveStatsContainer(); diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java index f64a3d0d57c..158a897f8d9 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java @@ -25,7 +25,9 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.*; +import org.junit.Assert; +import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -75,7 +77,7 @@ public class MultiModalControlerListenerTest { @SuppressWarnings("static-method") @Test - public void testSimpleScenario() { + void testSimpleScenario() { log.info("Run test single threaded..."); runSimpleScenario(1); @@ -185,23 +187,23 @@ static void runSimpleScenario(int numberOfThreads) { Assert.assertEquals(8, linkModeChecker.linkLeftCount); } - @Ignore("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm + @Ignore("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm @Test - public void testBerlinScenario_singleThreaded() { + void testBerlinScenario_singleThreaded() { log.info("Run test single threaded..."); runBerlinScenario(1); } @Ignore("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm @Test - public void testBerlinScenario_multiThreaded_2() { + void testBerlinScenario_multiThreaded_2() { log.info("Run test multi threaded with 2 threads..."); runBerlinScenario(2); } - @Ignore("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm + @Ignore("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm @Test - public void testBerlinScenario_multiThreaded_4() { + void testBerlinScenario_multiThreaded_4() { log.info("Run test multi threaded with 4 threads..."); runBerlinScenario(4); } diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalTripRouterTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalTripRouterTest.java index 45c6e6ece37..f7edb1a21c8 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalTripRouterTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalTripRouterTest.java @@ -22,7 +22,7 @@ import com.google.inject.name.Names; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -65,7 +65,7 @@ public class MultiModalTripRouterTest { @Test - public void testRouteLeg() { + void testRouteLeg() { final Config config = ConfigUtils.createConfig(); config.routing().addParam("teleportedModeSpeed_bike", "6.01"); diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java index 99407837927..7e2f7edc25f 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java @@ -3,8 +3,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; @@ -16,7 +16,7 @@ public class RunMultimodalExampleTest{ @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void main(){ + void main(){ URL url = IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "berlin" ), "config_multimodal.xml" );; String [] args = { url.toString(), diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java index 52aa33e2fc2..3b224c976f0 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java @@ -26,8 +26,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -73,7 +73,7 @@ public class MultiModalPTCombinationTest { * probably no longer very useful, there is no more special walk mode for pt agents - gl-nov'19 */ @Test - public void testMultiModalPtCombination() { + void testMultiModalPtCombination() { Fixture f = new Fixture(); f.init(); diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java index 9f2cfda7ee0..a8d88a3b193 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java @@ -28,8 +28,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -52,7 +52,8 @@ public class BikeTravelTimeTest { private static final Logger log = LogManager.getLogger(BikeTravelTimeTest.class); - @Test public void testLinkTravelTimeCalculation() { + @Test + void testLinkTravelTimeCalculation() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Node node1 = scenario.getNetwork().getFactory().createNode(Id.create("n1", Node.class), new Coord(0.0, 0.0)); @@ -185,7 +186,8 @@ private void printInfo(Person p, double expected, double calculated, double slop log.info(sb.toString()); } - @Test public void testThreadLocals() { + @Test + void testThreadLocals() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java index 2136ca6a756..b5ec67bb8a5 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java @@ -28,8 +28,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -52,7 +52,8 @@ public class WalkTravelTimeTest { private static final Logger log = LogManager.getLogger(WalkTravelTimeTest.class); - @Test public void testLinkTravelTimeCalculation() { + @Test + void testLinkTravelTimeCalculation() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Node node1 = scenario.getNetwork().getFactory().createNode(Id.create("n1", Node.class), new Coord(0.0, 0.0)); @@ -166,7 +167,8 @@ private void printInfo(Person p, double expected, double calculated, double slop log.info(sb.toString()); } - @Test public void testThreadLocals() { + @Test + void testThreadLocals() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java index d7d87c67e8d..082b470276f 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -66,7 +66,7 @@ public class StuckAgentTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testStuckEvents() { + void testStuckEvents() { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(utils.getOutputDirectory()); diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java index 0862fe22736..2e28c957bdb 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java @@ -22,17 +22,17 @@ */ package org.matsim.contrib.noise; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.controler.Controler; import org.matsim.core.controler.OutputDirectoryHierarchy; import org.matsim.core.scenario.ScenarioUtils; -import org.matsim.testcases.MatsimTestUtils; - +import org.matsim.testcases.MatsimTestUtils; + /** * @author ikaddoura * @@ -41,10 +41,10 @@ public class NoiseConfigGroupIT { @RegisterExtension - private MatsimTestUtils testUtils = new MatsimTestUtils(); - - @Test - public final void test0(){ + private MatsimTestUtils testUtils = new MatsimTestUtils(); + + @Test + final void test0(){ String configFile = testUtils.getPackageInputDirectory() + "NoiseConfigGroupTest/config0.xml"; Config config = ConfigUtils.loadConfig(configFile, new NoiseConfigGroup()); @@ -69,10 +69,10 @@ public final void test0(){ String tunnelLinkIds = noiseParameters.getTunnelLinkIDsSet().toArray()[0] + "," + noiseParameters.getTunnelLinkIDsSet().toArray()[1]; Assert.assertEquals("wrong config parameter", "link1,link2", tunnelLinkIds); - } - - @Test - public final void test1(){ + } + + @Test + final void test1(){ String configFile = testUtils.getPackageInputDirectory() + "NoiseConfigGroupTest/config1.xml"; Config config = ConfigUtils.loadConfig(configFile, new NoiseConfigGroup()); diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java index 5d8569ad0e9..50b7321388a 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java @@ -30,8 +30,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -77,7 +77,7 @@ public class NoiseIT { // Tests the NoisSpatialInfo functionality separately for each function @Test - public final void test1(){ + final void test1(){ String configFile = testUtils.getPackageInputDirectory() + "NoiseTest/config1.xml"; @@ -150,7 +150,7 @@ public final void test1(){ // tests the noise emissions, immissions, considered agent units, damages (receiver points), damages (per link), damages (per vehicle) based on the generated *.csv output // tests the noise events applying the average cost allocation approach @Test - public final void test2a(){ + final void test2a(){ // start a simple MATSim run with a single iteration String configFile = testUtils.getPackageInputDirectory() + "NoiseTest/config2.xml"; Config config = ConfigUtils.loadConfig(configFile ) ; @@ -158,8 +158,9 @@ public final void test2a(){ config.routing().setAccessEgressType(RoutingConfigGroup.AccessEgressType.none); runTest2a( config ) ; } + @Test - public final void test2aWAccessEgress(){ + final void test2aWAccessEgress(){ // start a simple MATSim run with a single iteration String configFile = testUtils.getPackageInputDirectory() + "NoiseTest/config2.xml"; Config config = ConfigUtils.loadConfig(configFile ) ; @@ -948,7 +949,7 @@ else if(event.getActType().equals("work")){ // same test as before, but using the marginal cost approach @Test - public final void test2b(){ + final void test2b(){ String runDirectory = null; int lastIteration = -1; @@ -1047,7 +1048,7 @@ public final void test2b(){ // same test as 2a, but using the actual speed level @Test - public final void test2c(){ + final void test2c(){ // start a simple MATSim run with a single iteration String configFile = testUtils.getPackageInputDirectory() + "NoiseTest/config2.xml"; @@ -1174,7 +1175,7 @@ public void handleEvent(ActivityEndEvent event) { // tests the static methods within class "noiseEquations" @Test - public final void test3(){ + final void test3(){ double p = 0; double pInPercent = 0; @@ -1369,7 +1370,7 @@ else if( nHgvs == 2){ // tests the static methods within class "noiseEquations" @Test - public final void test4(){ + final void test4(){ double vCar = 0.0496757749985181; double vHGV = 0.0478758773550055; @@ -1417,7 +1418,7 @@ public final void test4(){ // tests the static methods within class "noiseEquations" - other speed levels @Test - public final void test5(){ + final void test5(){ double vCar = 30; double vHGV = 30; diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java index fa0e8c0c1e5..969ec85aef0 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java @@ -26,8 +26,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.analysis.XYTRecord; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -58,7 +58,7 @@ public class NoiseOnlineExampleIT { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public final void test0(){ + final void test0(){ String configFile = testUtils.getPackageInputDirectory() + "config.xml"; Config config = ConfigUtils.loadConfig(configFile, new NoiseConfigGroup()); @@ -80,7 +80,7 @@ public final void test0(){ } @Test - public final void testOnTheFlyAggregationTerms() { + final void testOnTheFlyAggregationTerms() { String configFile = testUtils.getPackageInputDirectory() + "config.xml"; Config config = ConfigUtils.loadConfig(configFile, new NoiseConfigGroup()); config.controller().setLastIteration(1); @@ -180,7 +180,7 @@ public final void testOnTheFlyAggregationTerms() { } @Test - public final void testNoiseListener(){ + final void testNoiseListener(){ Config config = ConfigUtils.loadConfig( testUtils.getPackageInputDirectory() + "config.xml", new NoiseConfigGroup() ); config.controller().setLastIteration(1); diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java index 096250d46d4..41c3ebb8836 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java @@ -23,8 +23,8 @@ package org.matsim.contrib.noise; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; import org.locationtech.jts.geom.GeometryFactory; @@ -54,7 +54,7 @@ public class NoiseRLS19IT { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testShielding() { + void testShielding() { final RLS19ShieldingCorrection shieldingCorrection = new RLS19ShieldingCorrection(); @@ -94,8 +94,8 @@ public void testShielding() { } - @Test - public void testEmission() { + @Test + void testEmission() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); Node from = NetworkUtils.createAndAddNode(network, Id.createNodeId("from"), new Coord(0, 0)); @@ -127,8 +127,8 @@ public void testEmission() { Assert.assertEquals("Wrong final noise link emission!", 84.23546653306667, noiseLink.getEmission(), MatsimTestUtils.EPSILON); } - @Test - public void testImmission() { + @Test + void testImmission() { final RLS19ShieldingCorrection shieldingCorrection = new RLS19ShieldingCorrection(); diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/LinkPropertiesTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/LinkPropertiesTest.java index 2f8c4c442bb..30e886f88d8 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/LinkPropertiesTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/LinkPropertiesTest.java @@ -1,14 +1,14 @@ package org.matsim.contrib.osm.networkReader; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.network.Link; import static org.junit.Assert.assertEquals; public class LinkPropertiesTest { - @Test - public void calculateSpeedIfNoTag_excludedHierarchy() { + @Test + void calculateSpeedIfNoTag_excludedHierarchy() { var motorwayProperties = new LinkProperties(LinkProperties.LEVEL_MOTORWAY, 1, 50 / 3.6, 1000, false); var residentialProperties = new LinkProperties(LinkProperties.LEVEL_RESIDENTIAL, 1, 50 / 3.6, 1000, false); @@ -17,8 +17,8 @@ public void calculateSpeedIfNoTag_excludedHierarchy() { assertEquals(residentialProperties.freespeed, LinkProperties.calculateSpeedIfNoSpeedTag(200, residentialProperties), 0.0); } - @Test - public void calculateSpeedIfNoTag_longLink() { + @Test + void calculateSpeedIfNoTag_longLink() { var properties = new LinkProperties(LinkProperties.LEVEL_PRIMARY, 1, 50 / 3.6, 1000, false); var linkLength = 350; // longer than the threshold @@ -28,8 +28,8 @@ public void calculateSpeedIfNoTag_longLink() { assertEquals(properties.freespeed, result, 0.0); } - @Test - public void calculateSpeedIfNoTag_shortLink() { + @Test + void calculateSpeedIfNoTag_shortLink() { var properties = new LinkProperties(LinkProperties.LEVEL_PRIMARY, 1, 50 / 3.6, 1000, false); var linkLength = 1; // very shor link @@ -39,22 +39,22 @@ public void calculateSpeedIfNoTag_shortLink() { assertEquals(10 / 3.6, result, 0.1); // should be pretty much 10 km/h } - @Test - public void calculateSpeedIfSpeedTag_withoutUrbanFactor() { + @Test + void calculateSpeedIfSpeedTag_withoutUrbanFactor() { var maxSpeed = 100 / 3.6; assertEquals(maxSpeed, LinkProperties.calculateSpeedIfSpeedTag(maxSpeed), 0.0); } - @Test - public void calculateSpeedIfSpeedTag_withUrbanFactor() { + @Test + void calculateSpeedIfSpeedTag_withUrbanFactor() { var maxSpeed = 50 / 3.6; assertEquals(maxSpeed * 0.9, LinkProperties.calculateSpeedIfSpeedTag(maxSpeed), Double.MIN_VALUE); } - @Test - public void getLaneCapacity_withIncrease() { + @Test + void getLaneCapacity_withIncrease() { var linkLength = 40; var properties = new LinkProperties(LinkProperties.LEVEL_PRIMARY, 1, 50 / 3.6, 1000, false); @@ -62,8 +62,8 @@ public void getLaneCapacity_withIncrease() { assertEquals(properties.laneCapacity * 2, LinkProperties.getLaneCapacity(linkLength, properties), Double.MIN_VALUE); } - @Test - public void getLaneCapacity_withoutIncrease() { + @Test + void getLaneCapacity_withoutIncrease() { var linkLength = 101; var properties = new LinkProperties(LinkProperties.LEVEL_PRIMARY, 1, 50 / 3.6, 1000, false); diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderIT.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderIT.java index e5a9f4558e9..5e023e1fff0 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderIT.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderIT.java @@ -1,7 +1,7 @@ package org.matsim.contrib.osm.networkReader; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.network.Network; import org.matsim.core.network.NetworkUtils; import org.matsim.core.utils.geometry.CoordinateTransformation; @@ -19,7 +19,7 @@ public class OsmBicycleReaderIT { private MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); @Test - public void test_andorra() { + void test_andorra() { final Path inputFile = Paths.get(matsimTestUtils.getPackageInputDirectory()).resolve("andorra-latest.osm.pbf"); diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java index bc7b8479342..788c58bf779 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java @@ -2,8 +2,8 @@ import de.topobyte.osm4j.core.model.iface.OsmTag; import de.topobyte.osm4j.core.model.impl.Tag; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -27,7 +27,7 @@ public class OsmBicycleReaderTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void test_singleLinkWithAttributes() { + void test_singleLinkWithAttributes() { final String surface = "surface-value"; final String smoothness = "smoothness-value"; @@ -62,7 +62,7 @@ public void test_singleLinkWithAttributes() { } @Test - public void test_singleLinkPrimaryWithSurfaceAsphalt() { + void test_singleLinkPrimaryWithSurfaceAsphalt() { List tags = Collections.singletonList( new Tag(OsmTags.HIGHWAY, OsmTags.PRIMARY)); @@ -85,7 +85,7 @@ public void test_singleLinkPrimaryWithSurfaceAsphalt() { } @Test - public void test_singleLinkWithBicycleNotAllowed() { + void test_singleLinkWithBicycleNotAllowed() { List tags = Collections.singletonList( new Tag(OsmTags.HIGHWAY, OsmTags.MOTORWAY)); @@ -109,7 +109,7 @@ public void test_singleLinkWithBicycleNotAllowed() { } @Test - public void test_singleLinkWithOnlyBicycleAllowed() { + void test_singleLinkWithOnlyBicycleAllowed() { List tags = Collections.singletonList( new Tag(OsmTags.HIGHWAY, OsmTags.PEDESTRIAN)); @@ -133,7 +133,7 @@ public void test_singleLinkWithOnlyBicycleAllowed() { } @Test - public void test_singleOnewayLinkOneWayBikeNo() { + void test_singleOnewayLinkOneWayBikeNo() { final String surface = "surface-value"; @@ -166,7 +166,7 @@ public void test_singleOnewayLinkOneWayBikeNo() { } @Test - public void test_singleOnewayLinkOppositeBike() { + void test_singleOnewayLinkOppositeBike() { final String surface = "surface-value"; @@ -199,7 +199,7 @@ public void test_singleOnewayLinkOppositeBike() { } @Test - public void test_singleReverseOnewayLinkOneWayBikeNo() { + void test_singleReverseOnewayLinkOneWayBikeNo() { final String surface = "surface-value"; @@ -233,7 +233,7 @@ public void test_singleReverseOnewayLinkOneWayBikeNo() { } @Test - public void test_builderDoesntOverrideLinkProperties() { + void test_builderDoesntOverrideLinkProperties() { var osmFile = Paths.get(testUtils.getOutputDirectory()).resolve("osm-data.osm.pbf"); diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java index 03be0ed6ca9..ec2aadb4cc5 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java @@ -4,8 +4,8 @@ import de.topobyte.osm4j.core.model.iface.OsmWay; import org.junit.After; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.geometry.CoordinateTransformation; import org.matsim.core.utils.geometry.transformations.AtlantisToWGS84; @@ -34,7 +34,7 @@ public void shutDownExecutor() { } @Test - public void parse_singleLink() { + void parse_singleLink() { Utils.OsmData singleLink = Utils.createSingleLink(); Path file = Paths.get(matsimUtils.getOutputDirectory(), "parser_single-link.pbf"); @@ -66,7 +66,7 @@ public void parse_singleLink() { } @Test - public void parse_twoIntersectingWays() { + void parse_twoIntersectingWays() { Utils.OsmData twoIntersectingLinks = Utils.createTwoIntersectingLinksWithDifferentLevels(); Path file = Paths.get(matsimUtils.getOutputDirectory(), "parser_two-intersecting-ways.pbf"); @@ -92,7 +92,7 @@ else if (node.getId() == 9L || node.getId() == 1L || node.getId() == 10L || node } @Test - public void parse_intersectingLinksOneDoesNotMatchFilter() { + void parse_intersectingLinksOneDoesNotMatchFilter() { Utils.OsmData twoIntersectingLinks = Utils.createTwoIntersectingLinksWithDifferentLevels(); @@ -121,7 +121,7 @@ public void parse_intersectingLinksOneDoesNotMatchFilter() { } @Test - public void parse_singleLink_withTransformation() { + void parse_singleLink_withTransformation() { final CoordinateTransformation atlantis = new AtlantisToWGS84(); diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java index c5ba94aab22..9aed196716b 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java @@ -7,8 +7,8 @@ import de.topobyte.osm4j.core.model.impl.Tag; import org.junit.After; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.utils.geometry.CoordinateTransformation; import org.matsim.core.utils.geometry.transformations.IdentityTransformation; import org.matsim.core.utils.geometry.transformations.TransformationFactory; @@ -40,7 +40,7 @@ public void shutDownExecutor() { } @Test - public void parse_singleLinkWithCrossing() { + void parse_singleLinkWithCrossing() { Path file = Paths.get(utils.getOutputDirectory()).resolve("tmp.pbf"); Utils.OsmData data = Utils.createSingleLink(); @@ -74,7 +74,7 @@ public void parse_singleLinkWithCrossing() { } @Test - public void parse_singleLinkWithTrafficSignals() { + void parse_singleLinkWithTrafficSignals() { Path file = Paths.get(utils.getOutputDirectory()).resolve("tmp.pbf"); Utils.OsmData data = Utils.createSingleLink(); @@ -108,7 +108,7 @@ public void parse_singleLinkWithTrafficSignals() { } @Test - public void parse_singleLinkWithNonHighwayNode() { + void parse_singleLinkWithNonHighwayNode() { Path file = Paths.get(utils.getOutputDirectory()).resolve("tmp.pbf"); Utils.OsmData data = Utils.createSingleLink(); @@ -138,7 +138,7 @@ public void parse_singleLinkWithNonHighwayNode() { } @Test - public void parse_singleLinkWithNodeNotReferencedByWay() { + void parse_singleLinkWithNodeNotReferencedByWay() { Path file = Paths.get(utils.getOutputDirectory()).resolve("tmp.pbf"); Utils.OsmData data = Utils.createSingleLink(); @@ -158,7 +158,7 @@ public void parse_singleLinkWithNodeNotReferencedByWay() { } @Test - public void parse_intersectingWaysWithProhibitiveRestriction() { + void parse_intersectingWaysWithProhibitiveRestriction() { Path file = Paths.get(utils.getOutputDirectory()).resolve("tmp.pbf"); Utils.OsmData data = Utils.createTwoIntersectingLinksWithDifferentLevels(); @@ -185,7 +185,7 @@ public void parse_intersectingWaysWithProhibitiveRestriction() { } @Test - public void parse_intersectingWaysWithImperativeRestriction() { + void parse_intersectingWaysWithImperativeRestriction() { Path file = Paths.get(utils.getOutputDirectory()).resolve("tmp.pbf"); Utils.OsmData data = Utils.createTwoIntersectingLinksWithDifferentLevels(); diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderIT.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderIT.java index 423233c2079..be2996b5c08 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderIT.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderIT.java @@ -2,8 +2,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.network.Network; import org.matsim.core.network.NetworkUtils; import org.matsim.core.utils.geometry.CoordinateTransformation; @@ -21,7 +21,7 @@ public class SupersonicOsmNetworkReaderIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void test_andorra() { + void test_andorra() { Network network = new SupersonicOsmNetworkReader.Builder() .setCoordinateTransformation(coordinateTransformation) diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java index 95f68fad504..0a8771b6649 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java @@ -9,8 +9,8 @@ import de.topobyte.osm4j.pbf.seq.PbfWriter; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -62,7 +62,7 @@ private static void writeOsmData(Collection nodes, Collection w @SuppressWarnings("ConstantConditions") @Test - public void singleLink() { + void singleLink() { Utils.OsmData singleLink = Utils.createSingleLink(); @@ -108,7 +108,7 @@ public void singleLink() { @SuppressWarnings("ConstantConditions") @Test - public void singleLinkPreserveMiddleNodes() { + void singleLinkPreserveMiddleNodes() { Utils.OsmData singleLink = Utils.createSingleLink(); @@ -144,7 +144,7 @@ public void singleLinkPreserveMiddleNodes() { } @Test - public void singleLink_withMaxSpeedTag() { + void singleLink_withMaxSpeedTag() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 10, 10); @@ -170,7 +170,7 @@ public void singleLink_withMaxSpeedTag() { } @Test - public void singleLink_withMaxSpeedTag_milesPerHour() { + void singleLink_withMaxSpeedTag_milesPerHour() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 10, 10); TLongArrayList nodeReference = new TLongArrayList(new long[]{node1.getId(), node2.getId()}); @@ -194,7 +194,7 @@ public void singleLink_withMaxSpeedTag_milesPerHour() { } @Test - public void singleLink_withMaxSpeedTag_urbanLink() { + void singleLink_withMaxSpeedTag_urbanLink() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 10, 10); TLongArrayList nodeReference = new TLongArrayList(new long[]{node1.getId(), node2.getId()}); @@ -221,7 +221,7 @@ public void singleLink_withMaxSpeedTag_urbanLink() { } @Test - public void singleLink_withMaxSpeedTag_cantParseMaxSpeed() { + void singleLink_withMaxSpeedTag_cantParseMaxSpeed() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 10, 10); TLongArrayList nodeReference = new TLongArrayList(new long[]{node1.getId(), node2.getId()}); @@ -246,7 +246,7 @@ public void singleLink_withMaxSpeedTag_cantParseMaxSpeed() { } @Test - public void singleLink_noMaxSpeedTag_ruralLink() { + void singleLink_noMaxSpeedTag_ruralLink() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 1000, 1000); @@ -272,7 +272,7 @@ public void singleLink_noMaxSpeedTag_ruralLink() { } @Test - public void singleLink_noMaxSpeedTag_urbanLink() { + void singleLink_noMaxSpeedTag_urbanLink() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 10, 10); @@ -300,7 +300,7 @@ public void singleLink_noMaxSpeedTag_urbanLink() { } @Test - public void singleLink_noLanesTag() { + void singleLink_noLanesTag() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 10, 10); @@ -325,7 +325,7 @@ public void singleLink_noLanesTag() { } @Test - public void singleLink_withLanesTag() { + void singleLink_withLanesTag() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 10, 10); @@ -351,7 +351,7 @@ public void singleLink_withLanesTag() { } @Test - public void singleLink_lanesTagOneWay() { + void singleLink_lanesTagOneWay() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 10, 10); TLongArrayList nodeReference = new TLongArrayList(new long[]{node1.getId(), node2.getId()}); @@ -376,7 +376,7 @@ public void singleLink_lanesTagOneWay() { } @Test - public void singleLink_lanesForwardAndBackwardTag() { + void singleLink_lanesForwardAndBackwardTag() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 10, 10); TLongArrayList nodeReference = new TLongArrayList(new long[]{node1.getId(), node2.getId()}); @@ -403,7 +403,7 @@ public void singleLink_lanesForwardAndBackwardTag() { } @Test - public void singleLink_capacityLongLink() { + void singleLink_capacityLongLink() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 100, 100); @@ -427,7 +427,7 @@ public void singleLink_capacityLongLink() { } @Test - public void singleLink_capacityShortLink() { + void singleLink_capacityShortLink() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 10, 10); @@ -451,7 +451,7 @@ public void singleLink_capacityShortLink() { } @Test - public void singleLink_overridingLinkProperties() { + void singleLink_overridingLinkProperties() { Node node1 = new Node(1, 0, 0); Node node2 = new Node(2, 100, 100); @@ -480,7 +480,7 @@ public void singleLink_overridingLinkProperties() { } @Test - public void twoIntersectingLinks() { + void twoIntersectingLinks() { var twoLinks = Utils.createTwoIntersectingLinksWithDifferentLevels(); var file = Paths.get(matsimTestUtils.getOutputDirectory(), "two-intersecting-links.pbf"); @@ -527,7 +527,7 @@ public void twoIntersectingLinks() { } @Test - public void twoIntersectingLinks_withAfterLinkCreatedHook() { + void twoIntersectingLinks_withAfterLinkCreatedHook() { final List tags = Collections.singletonList(new Tag("highway", MOTORWAY)); final List nodes = Arrays.asList(new Node(1, 0, 0), new Node(2, 1, 1), new Node(3, 2, 2), @@ -574,7 +574,7 @@ public void twoIntersectingLinks_withAfterLinkCreatedHook() { } @Test - public void twoIntersectingLinks_oneShouldBeSimplified() { + void twoIntersectingLinks_oneShouldBeSimplified() { final List tags = Collections.singletonList(new Tag("highway", MOTORWAY)); final List nodes = Arrays.asList(new Node(1, 0, 0), @@ -601,7 +601,7 @@ public void twoIntersectingLinks_oneShouldBeSimplified() { } @Test - public void linkGrid_oneWayNotInFilter() { + void linkGrid_oneWayNotInFilter() { Utils.OsmData grid = Utils.createGridWithDifferentLevels(); final Path file = Paths.get(matsimTestUtils.getOutputDirectory(), "grid-with-filter.pbf"); @@ -632,7 +632,7 @@ public void linkGrid_oneWayNotInFilter() { } @Test - public void twoIntersectingLinks_oneWithLoop() { + void twoIntersectingLinks_oneWithLoop() { final List tags = Collections.singletonList(new Tag("highway", MOTORWAY)); final List nodes = Arrays.asList(new Node(1, 0, 0), new Node(2, 1, 1), new Node(3, 2, 2), @@ -667,7 +667,7 @@ public void twoIntersectingLinks_oneWithLoop() { } @Test - public void simplifiedLinksWithPreservedOriginalGeometry() { + void simplifiedLinksWithPreservedOriginalGeometry() { var file = Paths.get(matsimTestUtils.getOutputDirectory() + "file.osm.bbf"); var osmData = Utils.createSingleLink(List.of(new Tag(OsmTags.HIGHWAY, OsmTags.LIVING_STREET))); diff --git a/contribs/osm/src/test/java/otherPackage/SupersonicOsmNetworkReaderBuilderTest.java b/contribs/osm/src/test/java/otherPackage/SupersonicOsmNetworkReaderBuilderTest.java index 410c7e47756..e408f441573 100644 --- a/contribs/osm/src/test/java/otherPackage/SupersonicOsmNetworkReaderBuilderTest.java +++ b/contribs/osm/src/test/java/otherPackage/SupersonicOsmNetworkReaderBuilderTest.java @@ -1,6 +1,6 @@ package otherPackage; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.osm.networkReader.SupersonicOsmNetworkReader; import org.matsim.core.utils.geometry.transformations.IdentityTransformation; @@ -9,7 +9,7 @@ public class SupersonicOsmNetworkReaderBuilderTest { @Test - public void testPublicApi() { + void testPublicApi() { SupersonicOsmNetworkReader reader = new SupersonicOsmNetworkReader.Builder() .setCoordinateTransformation(new IdentityTransformation()) diff --git a/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java b/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java index b16a6a5d01d..d54fb3ef32e 100644 --- a/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java +++ b/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java @@ -24,8 +24,8 @@ package org.matsim.contrib.otfvis; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.config.groups.QSimConfigGroup; @@ -52,7 +52,7 @@ public class OTFVisIT { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testConvert() { + void testConvert() { String networkFilename = "test/scenarios/equil/network.xml"; String eventsFilename = "test/scenarios/equil/events.xml"; String mviFilename = testUtils.getOutputDirectory()+"/events.mvi"; @@ -65,7 +65,7 @@ public void testConvert() { } @Test - public void testOTFVisSnapshotWriterOnQSim() { + void testOTFVisSnapshotWriterOnQSim() { final Config config = ConfigUtils.loadConfig("test/scenarios/equil/config_plans1.xml"); config.controller().setLastIteration(2); config.controller().setWriteEventsInterval(0); diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/GeneralLibTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/GeneralLibTest.java index 0ba50eed4c5..23663b17e77 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/GeneralLibTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/GeneralLibTest.java @@ -2,13 +2,13 @@ import static org.junit.Assert.*; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.parking.parkingchoice.lib.GeneralLib; public class GeneralLibTest { @Test - public void testProjectTimeWithin24Hours() { + void testProjectTimeWithin24Hours() { assertEquals(10.0, GeneralLib.projectTimeWithin24Hours(10.0), 0); assertEquals(0.0, GeneralLib.projectTimeWithin24Hours(60 * 60 * 24.0), 0); assertEquals(1.0, GeneralLib.projectTimeWithin24Hours(60 * 60 * 24.0 + 1), 0.1); @@ -16,13 +16,13 @@ public void testProjectTimeWithin24Hours() { } @Test - public void testGetIntervalDuration() { + void testGetIntervalDuration() { assertEquals(10.0, GeneralLib.getIntervalDuration(0.0, 10.0), 0); assertEquals(11.0, GeneralLib.getIntervalDuration(60 * 60 * 24.0 - 1.0, 10.0), 0); } @Test - public void testIsIn24HourInterval() { + void testIsIn24HourInterval() { assertTrue(GeneralLib.isIn24HourInterval(0.0, 10.0, 9.0)); assertFalse(GeneralLib.isIn24HourInterval(0.0, 10.0, 11.0)); assertTrue(GeneralLib.isIn24HourInterval(0.0, 10.0, 0.0)); diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/DoubleValueHashMapTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/DoubleValueHashMapTest.java index d87fef93398..896c5cd8849 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/DoubleValueHashMapTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/DoubleValueHashMapTest.java @@ -2,12 +2,13 @@ import static org.junit.Assert.assertEquals; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.parking.parkingchoice.lib.obj.DoubleValueHashMap; public class DoubleValueHashMapTest { - @Test public void testBasic(){ + @Test + void testBasic(){ DoubleValueHashMap dhm=new DoubleValueHashMap(); dhm.put(0, 5.2); diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/LinkedListValueHashMapTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/LinkedListValueHashMapTest.java index ddaf58a845b..99f18824563 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/LinkedListValueHashMapTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/LinkedListValueHashMapTest.java @@ -4,13 +4,14 @@ import java.util.HashMap; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.parking.parkingchoice.lib.obj.HashMapInverter; import org.matsim.contrib.parking.parkingchoice.lib.obj.LinkedListValueHashMap; public class LinkedListValueHashMapTest { - @Test public void testInteger(){ + @Test + void testInteger(){ LinkedListValueHashMap hm1=new LinkedListValueHashMap(); hm1.put(1, 1); @@ -19,7 +20,8 @@ public class LinkedListValueHashMapTest { assertEquals(1, (int) hm1.get(1).get(0)); } - @Test public void testStrings(){ + @Test + void testStrings(){ LinkedListValueHashMap hm1=new LinkedListValueHashMap(); hm1.put("1", "1"); @@ -28,7 +30,8 @@ public class LinkedListValueHashMapTest { assertEquals("1", hm1.get("1").get(0)); } - @Test public void testHashMapInverter(){ + @Test + void testHashMapInverter(){ HashMap hashMap=new HashMap(); hashMap.put("0", "1"); diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/ParkingCostVehicleTrackerTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/ParkingCostVehicleTrackerTest.java index b186334bb59..ba933fa274b 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/ParkingCostVehicleTrackerTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/ParkingCostVehicleTrackerTest.java @@ -21,7 +21,7 @@ import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -52,7 +52,7 @@ public class ParkingCostVehicleTrackerTest { @Test - public void testParkingCostEvents() { + void testParkingCostEvents() { Fixture f = new Fixture(); f.events.addHandler(new EventsLogger()); diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RideParkingCostTrackerTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RideParkingCostTrackerTest.java index b51b9996f21..98e4f56a9b7 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RideParkingCostTrackerTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RideParkingCostTrackerTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.parking.parkingcost.eventhandling; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -50,7 +50,7 @@ public class RideParkingCostTrackerTest { @Test - public void testPersonMoneyEvents() { + void testPersonMoneyEvents() { Fixture f = new Fixture(); f.events.addHandler(new EventsLogger()); diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RunParkingCostsExampleTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RunParkingCostsExampleTest.java index f4ea4e0db2b..7e65a26f421 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RunParkingCostsExampleTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RunParkingCostsExampleTest.java @@ -19,13 +19,13 @@ package org.matsim.contrib.parking.parkingcost.eventhandling; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.parking.parkingcost.RunParkingCostExample; public class RunParkingCostsExampleTest { @Test - public void testRunParkingCostsExample() { + void testRunParkingCostsExample() { RunParkingCostExample.main(new String[]{}); } } diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java index fcbc247bd76..abd3e9a34d0 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java @@ -21,8 +21,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; import org.matsim.core.events.EventsUtils; @@ -36,9 +36,9 @@ public class RunWithParkingProxyIT { private static final Logger log = LogManager.getLogger(RunWithParkingProxyIT.class); @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test - @Ignore - public void testMain(){ + @Test + @Ignore + void testMain(){ RunWithParkingProxy.main( new String []{ IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "chessboard" ), "config.xml" ).toString() , "--config:controler.outputDirectory=" + utils.getOutputDirectory() , "--config:controler.lastIteration=2" diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingChoiceExampleIT.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingChoiceExampleIT.java index 483a118e22e..c084bf7a434 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingChoiceExampleIT.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingChoiceExampleIT.java @@ -18,8 +18,8 @@ * *********************************************************************** */ package org.matsim.contrib.parking.run; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.parking.parkingchoice.run.RunParkingChoiceExample; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -36,7 +36,7 @@ public class RunParkingChoiceExampleIT { * Test method for {@link org.matsim.contrib.parking.parkingchoice.run.RunParkingChoiceExample#run(org.matsim.core.config.Config)}. */ @Test - public final void testRun() { + final void testRun() { Config config = ConfigUtils.loadConfig("./src/main/resources/parkingchoice/config.xml"); config.controller().setOutputDirectory( utils.getOutputDirectory() ); config.controller().setLastIteration(0); diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java index 16f1a7f8525..d614a1edd4c 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java @@ -20,8 +20,8 @@ package org.matsim.contrib.parking.run; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Population; @@ -43,7 +43,7 @@ public class RunParkingSearchScenarioIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testRunParkingBenesonStrategy() { + void testRunParkingBenesonStrategy() { try { String configFile = "./src/main/resources/parkingsearch/config.xml"; Config config = ConfigUtils.loadConfig(configFile, new ParkingSearchConfigGroup()); @@ -62,7 +62,7 @@ public void testRunParkingBenesonStrategy() { } @Test - public void testRunParkingRandomStrategy() { + void testRunParkingRandomStrategy() { String configFile = "./src/main/resources/parkingsearch/config.xml"; Config config = ConfigUtils.loadConfig(configFile, new ParkingSearchConfigGroup()); config.controller().setLastIteration(0); @@ -80,7 +80,7 @@ public void testRunParkingRandomStrategy() { } @Test - public void testRunParkingDistanceMemoryStrategy() { + void testRunParkingDistanceMemoryStrategy() { try { String configFile = "./src/main/resources/parkingsearch/config.xml"; Config config = ConfigUtils.loadConfig(configFile, new ParkingSearchConfigGroup()); @@ -118,7 +118,7 @@ public void testRunParkingDistanceMemoryStrategy() { } @Test - public void testRunParkingNearestParkingSpotStrategy() { + void testRunParkingNearestParkingSpotStrategy() { try { String configFile = "./src/main/resources/parkingsearch/config.xml"; Config config = ConfigUtils.loadConfig(configFile, new ParkingSearchConfigGroup()); diff --git a/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java b/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java index 5941d7c17dd..6c90bffb6cd 100644 --- a/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java +++ b/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java @@ -3,8 +3,8 @@ import com.google.protobuf.Descriptors; import org.assertj.core.api.Assertions; import org.assertj.core.api.Condition; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; @@ -30,8 +30,8 @@ public class EventWriterPBTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void writer() throws IOException { + @Test + void writer() throws IOException { // File file = tmp.newFile("output.pb"); File file = new File( utils.getOutputDirectory() + "events.pb" ); @@ -85,8 +85,8 @@ public void writer() throws IOException { } - @Test - public void convertEvent() { + @Test + void convertEvent() { // test few sample events GenericEvent event = new GenericEvent("test", 10.0); @@ -107,8 +107,8 @@ public void convertEvent() { .has(new Condition<>(e -> e.getPersonId().getId().equals("15") && e.getLinkId().getId().equals("20"), "Ids correct")); } - @Test - public void convertId() { + @Test + void convertId() { Id id = Id.createVehicleId(123); diff --git a/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java b/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java index 9e7f626e248..98b6c1fa889 100644 --- a/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java +++ b/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java @@ -5,8 +5,8 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.FixMethodOrder; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runners.MethodSorters; import org.matsim.analysis.ScoreStatsControlerListener; import org.matsim.api.core.v01.population.Population; @@ -44,7 +44,7 @@ public class RunPSimTest { * Run 1 normal qsim iteration, a couple of psim iterations and a final 2nd qsim iteration. */ @Test - public void testA() { + void testA() { config.controller().setCreateGraphs(false); PSimConfigGroup pSimConfigGroup = new PSimConfigGroup(); @@ -115,7 +115,7 @@ public void install() { * in testA() was 134.52369453719413 and qsim score in testB was 131.84309487251033). */ @Test - public void testB() { + void testB() { config.controller().setOutputDirectory(utils.getOutputDirectory()); config.controller().setLastIteration(2); config.controller().setCreateGraphs(false); diff --git a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java index 3fe816aff64..ec938145c09 100644 --- a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java +++ b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java @@ -23,8 +23,8 @@ import ch.sbb.matsim.contrib.railsim.events.RailsimTrainStateEvent; import ch.sbb.matsim.contrib.railsim.qsimengine.RailsimQSimModule; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -62,12 +62,12 @@ public class RailsimIntegrationTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testMicroSimpleBiDirectionalTrack() { + void testMicroSimpleBiDirectionalTrack() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microSimpleBiDirectionalTrack")); } @Test - public void testMesoUniDirectionalVaryingCapacities() { + void testMesoUniDirectionalVaryingCapacities() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "mesoUniDirectionalVaryingCapacities")); // print events of train1 for debugging @@ -174,33 +174,33 @@ public void testMesoUniDirectionalVaryingCapacities() { } @Test - public void testMicroTrackOppositeTraffic() { + void testMicroTrackOppositeTraffic() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microTrackOppositeTraffic")); } @Test - public void testMicroTrackOppositeTrafficMany() { + void testMicroTrackOppositeTrafficMany() { // multiple trains, one slow train EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microTrackOppositeTrafficMany")); } @Test - public void testMesoTwoSources() { + void testMesoTwoSources() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "mesoTwoSources")); } @Test - public void testMesoTwoSourcesComplex() { + void testMesoTwoSourcesComplex() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "mesoTwoSourcesComplex")); } @Test - public void testScenarioMesoGenfBernAllTrains() { + void testScenarioMesoGenfBernAllTrains() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "scenarioMesoGenfBern")); } @Test - public void testScenarioMesoGenfBernOneTrain() { + void testScenarioMesoGenfBernOneTrain() { // Remove vehicles except the first one Consumer filter = scenario -> { @@ -228,58 +228,58 @@ public void testScenarioMesoGenfBernOneTrain() { } @Test - public void testMicroThreeUniDirectionalTracks() { + void testMicroThreeUniDirectionalTracks() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microThreeUniDirectionalTracks")); } @Test - public void testMicroTrainFollowingConstantSpeed() { + void testMicroTrainFollowingConstantSpeed() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microTrainFollowingConstantSpeed")); } // This test is similar to testMicroTrainFollowingConstantSpeed but with varying speed levels along the corridor. @Test - public void testMicroTrainFollowingVaryingSpeed() { + void testMicroTrainFollowingVaryingSpeed() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microTrainFollowingVaryingSpeed")); } @Test - public void testMicroStationSameLink() { + void testMicroStationSameLink() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microStationSameLink")); } @Test - public void testMicroStationDifferentLink() { + void testMicroStationDifferentLink() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microStationDifferentLink")); } @Test - public void testMicroJunctionCross() { + void testMicroJunctionCross() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microJunctionCross")); } @Test - public void testMicroJunctionY() { + void testMicroJunctionY() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microJunctionY")); } @Test - public void testMesoStationCapacityOne() { + void testMesoStationCapacityOne() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "mesoStationCapacityOne")); } @Test - public void testMesoStationCapacityTwo() { + void testMesoStationCapacityTwo() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "mesoStationCapacityTwo")); } @Test - public void testMesoStations() { + void testMesoStations() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "mesoStations")); } @Test - public void testMicroSimpleUniDirectionalTrack() { + void testMicroSimpleUniDirectionalTrack() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microSimpleUniDirectionalTrack")); for (Event event : collector.getEvents()) { @@ -296,7 +296,7 @@ public void testMicroSimpleUniDirectionalTrack() { } @Test - public void testMicroStationRerouting() { + void testMicroStationRerouting() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "microStationRerouting")); collector.getEvents().forEach(System.out::println); // Checks end times @@ -309,7 +309,7 @@ public void testMicroStationRerouting() { } @Test - public void testMicroStationReroutingConcurrent() { + void testMicroStationReroutingConcurrent() { Consumer filter = scenario -> { TransitScheduleFactory f = scenario.getTransitSchedule().getFactory(); @@ -335,7 +335,7 @@ public void testMicroStationReroutingConcurrent() { } @Test - public void testScenarioKelheim() { + void testScenarioKelheim() { URL base = ExamplesUtils.getTestScenarioURL("kelheim"); @@ -373,7 +373,7 @@ public void testScenarioKelheim() { } @Test - public void testScenarioMicroMesoCombination() { + void testScenarioMicroMesoCombination() { EventsCollector collector = runSimulation(new File(utils.getPackageInputDirectory(), "scenarioMicroMesoCombination")); } diff --git a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimCalcTest.java b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimCalcTest.java index e969aa3cb2c..bf7b63411e9 100644 --- a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimCalcTest.java +++ b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimCalcTest.java @@ -20,14 +20,14 @@ package ch.sbb.matsim.contrib.railsim.qsimengine; import org.assertj.core.data.Offset; -import org.junit.Test; +import org.junit.jupiter.api.Test; import static org.assertj.core.api.Assertions.assertThat; public class RailsimCalcTest { @Test - public void testCalcAndSolveTraveledDist() { + void testCalcAndSolveTraveledDist() { assertThat(RailsimCalc.calcTraveledDist(5, 2, 0)) .isEqualTo(10); @@ -47,7 +47,7 @@ public void testCalcAndSolveTraveledDist() { } @Test - public void testCalcAndSolveTraveledDistNegative() { + void testCalcAndSolveTraveledDistNegative() { double d = RailsimCalc.calcTraveledDist(5, 5, -1); @@ -64,7 +64,7 @@ public void testCalcAndSolveTraveledDistNegative() { } @Test - public void testMaxSpeed() { + void testMaxSpeed() { double dist = 1000; @@ -86,7 +86,7 @@ public void testMaxSpeed() { } @Test - public void testCalcTargetDecel() { + void testCalcTargetDecel() { double d = RailsimCalc.calcTargetDecel(1000, 0, 10); @@ -101,7 +101,7 @@ public void testCalcTargetDecel() { } @Test - public void testCalcTargetSpeed() { + void testCalcTargetSpeed() { RailsimCalc.SpeedTarget target = RailsimCalc.calcTargetSpeed(100, 0.5, 0.5, 0, 23, 0); @@ -134,7 +134,7 @@ public void testCalcTargetSpeed() { } @Test - public void testCalcTargetSpeedForStop() { + void testCalcTargetSpeedForStop() { double v = RailsimCalc.calcTargetSpeedForStop(1000, 0.5, 0.5, 0); diff --git a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java index 922fbb513e5..c2bb085c360 100644 --- a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java +++ b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java @@ -24,8 +24,8 @@ import ch.sbb.matsim.contrib.railsim.qsimengine.disposition.SimpleDisposition; import ch.sbb.matsim.contrib.railsim.qsimengine.router.TrainRouter; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; import org.matsim.core.api.experimental.events.EventsManager; @@ -76,7 +76,7 @@ private RailsimTestUtils.Holder getTestEngine(String network) { } @Test - public void testSimple() { + void testSimple() { RailsimTestUtils.Holder test = getTestEngine("networkMicroBi.xml"); RailsimTestUtils.createDeparture(test, TestVehicle.Regio, "train", 0, "l1-2", "l5-6"); @@ -101,7 +101,7 @@ public void testSimple() { } @Test - public void testCongested() { + void testCongested() { RailsimTestUtils.Holder test = getTestEngine("networkMicroBi.xml"); @@ -117,7 +117,7 @@ public void testCongested() { } @Test - public void testCongestedWithHeadway() { + void testCongestedWithHeadway() { RailsimTestUtils.Holder test = getTestEngine("networkMicroBi.xml", l -> RailsimUtils.setMinimumHeadwayTime(l, 60)); @@ -134,7 +134,7 @@ public void testCongestedWithHeadway() { @Test - public void testOpposite() { + void testOpposite() { RailsimTestUtils.Holder test = getTestEngine("networkMicroBi.xml"); @@ -162,7 +162,7 @@ public void testOpposite() { } @Test - public void testVaryingSpeedOne() { + void testVaryingSpeedOne() { RailsimTestUtils.Holder test = getTestEngine("networkMesoUni.xml"); @@ -187,7 +187,7 @@ public void testVaryingSpeedOne() { } @Test - public void testVaryingSpeedMany() { + void testVaryingSpeedMany() { RailsimTestUtils.Holder test = getTestEngine("networkMesoUni.xml"); @@ -220,7 +220,7 @@ public void testVaryingSpeedMany() { } @Test - public void testTrainFollowing() { + void testTrainFollowing() { RailsimTestUtils.Holder test = getTestEngine("networkMicroUni.xml"); RailsimTestUtils.createDeparture(test, TestVehicle.Regio, "regio1", 0, "1-2", "20-21"); @@ -244,7 +244,7 @@ public void testTrainFollowing() { } @Test - public void testMicroTrainFollowingVaryingSpeed() { + void testMicroTrainFollowingVaryingSpeed() { RailsimTestUtils.Holder test = getTestEngine("networkMicroVaryingSpeed.xml"); diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java index e9877f905ca..d7661de699c 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java @@ -25,9 +25,9 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.LinkLeaveEvent; @@ -37,8 +37,8 @@ import org.matsim.core.config.ConfigUtils; import org.matsim.core.controler.Controler; import org.matsim.core.scenario.ScenarioUtils; -import org.matsim.testcases.MatsimTestUtils; - +import org.matsim.testcases.MatsimTestUtils; + /** * * Tests the integration of the roadpricing-package into the Controler. @@ -52,10 +52,10 @@ public class AvoidTolledRouteTest { @RegisterExtension - private MatsimTestUtils testUtils = new MatsimTestUtils(); - - @Test - public final void test1(){ + private MatsimTestUtils testUtils = new MatsimTestUtils(); + + @Test + final void test1(){ String configFile = testUtils.getClassInputDirectory() + "/config.xml"; diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java index 2ca1f243fff..63ac002412e 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java @@ -25,8 +25,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -56,7 +56,7 @@ public class CalcPaidTollTest { static private final Logger log = LogManager.getLogger(CalcPaidTollTest.class); @Test - public void testDistanceToll() { + void testDistanceToll() { Config config = ConfigUtils.loadConfig(utils.getClassInputDirectory() + "config.xml"); final String tollFile = utils.getClassInputDirectory() + "/roadpricing1.xml"; @@ -92,7 +92,7 @@ public void testDistanceToll() { } @Test - public void testAreaToll() { + void testAreaToll() { Config config = ConfigUtils.loadConfig(utils.getClassInputDirectory() + "config.xml"); final String tollFile = utils.getClassInputDirectory() + "/roadpricing2.xml"; @@ -143,7 +143,7 @@ public void testAreaToll() { } @Test - public void testCordonToll() { + void testCordonToll() { Config config = ConfigUtils.loadConfig(utils.getClassInputDirectory() + "config.xml"); final String tollFile = utils.getClassInputDirectory() + "/roadpricing3.xml"; diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/ModuleTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/ModuleTest.java index 912a2cff00b..2bbe59e82d8 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/ModuleTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/ModuleTest.java @@ -22,8 +22,10 @@ package org.matsim.contrib.roadpricing; +import static org.junit.jupiter.api.Assertions.assertThrows; + +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.controler.Controler; @@ -35,17 +37,21 @@ public class ModuleTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Test(expected = RuntimeException.class) - public void testControlerWithoutRoadPricingDoesntWork() { - Config config = utils.loadConfig(utils.getClassInputDirectory() + "/config.xml"); - Controler controler = new Controler(config); - controler.run(); - // config has a roadpricing config group, but controler does not know about - // road pricing. - } + @Test + void testControlerWithoutRoadPricingDoesntWork() { + assertThrows(RuntimeException.class, () -> { + Config config = utils.loadConfig(utils.getClassInputDirectory() + "/config.xml"); + Controler controler = new Controler(config); + controler.run(); + // config has a roadpricing config group, but controler does not know about + // road pricing. + }); + // config has a roadpricing config group, but controler does not know about + // road pricing. + } - @Test - public void testControlerWithRoadPricingWorks() { + @Test + void testControlerWithRoadPricingWorks() { Config config = utils.loadConfig(utils.getClassInputDirectory() + "/config.xml"); Controler controler = new Controler(config); // controler.setModules(new RoadPricingModuleDefaults()); @@ -53,8 +59,8 @@ public void testControlerWithRoadPricingWorks() { controler.run(); } - @Test - public void testControlerWithRoadPricingByScenarioWorks() { + @Test + void testControlerWithRoadPricingByScenarioWorks() { Config config = utils.loadConfig(utils.getClassInputDirectory() + "/config.xml"); Scenario scenario = ScenarioUtils.loadScenario(config); Controler controler = new Controler(scenario); @@ -64,8 +70,8 @@ public void testControlerWithRoadPricingByScenarioWorks() { } - @Test - public void testControlerWithRoadPricingByScenarioWorksTwice() { + @Test + void testControlerWithRoadPricingByScenarioWorksTwice() { Config config = utils.loadConfig(utils.getClassInputDirectory() + "/config.xml"); config.controller().setOutputDirectory(utils.getOutputDirectory()+"/1"); Scenario scenario = ScenarioUtils.loadScenario(config); diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/PlansCalcRouteWithTollOrNotTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/PlansCalcRouteWithTollOrNotTest.java index 339abde2d1e..e75ed598afa 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/PlansCalcRouteWithTollOrNotTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/PlansCalcRouteWithTollOrNotTest.java @@ -26,8 +26,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -72,7 +72,7 @@ public class PlansCalcRouteWithTollOrNotTest { * toll or not. */ @Test - public void testBestAlternatives() { + void testBestAlternatives() { Config config = matsimTestUtils.createConfig(); config.controller().setOverwriteFileSetting(OutputDirectoryHierarchy.OverwriteFileSetting.overwriteExistingFiles); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); @@ -178,7 +178,7 @@ private PlansCalcRouteWithTollOrNot testee(final Scenario scenario, final RoadPr * Tests cases where the agent must pay the toll because one of its activities is on a tolled link */ @Test - public void testTolledActLink() { + void testTolledActLink() { Config config = matsimTestUtils.createConfig(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); RoadPricingTestUtils.createNetwork2(scenario); @@ -204,7 +204,7 @@ public void testTolledActLink() { * to the next include tolled links */ @Test - public void testAllAlternativesTolled() { + void testAllAlternativesTolled() { Config config = matsimTestUtils.createConfig(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); RoadPricingTestUtils.createNetwork2(scenario); @@ -243,7 +243,7 @@ private static Leg getLeg3(Config config, Population population, Id id1) } @Test - public void testOutsideTollTime() { + void testOutsideTollTime() { Config config = matsimTestUtils.createConfig(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); RoadPricingTestUtils.createNetwork2(scenario); diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java index ca59e1d482f..a22f0d46b39 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java @@ -1,8 +1,8 @@ package org.matsim.contrib.roadpricing; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; @@ -12,13 +12,13 @@ public class RoadPricingConfigGroupTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void getTollLinksFile() { + void getTollLinksFile() { RoadPricingConfigGroup cg = new RoadPricingConfigGroup(); Assert.assertNull("Default roadpricing file is not set.", cg.getTollLinksFile()); } @Test - public void setTollLinksFile() { + void setTollLinksFile() { String file = "./test.xml.gz"; RoadPricingConfigGroup cg = new RoadPricingConfigGroup(); cg.setTollLinksFile(file); @@ -26,7 +26,7 @@ public void setTollLinksFile() { } @Test - public void getEnforcementProbability() { + void getEnforcementProbability() { RoadPricingConfigGroup cg = new RoadPricingConfigGroup(); Assert.assertEquals("Default probability should be 1.0", 1.0, cg.getEnforcementProbability(), MatsimTestUtils.EPSILON); @@ -36,7 +36,7 @@ public void getEnforcementProbability() { } @Test - public void setEnforcementProbability() { + void setEnforcementProbability() { RoadPricingConfigGroup cg = new RoadPricingConfigGroup(); try{ cg.setEnforcementProbability(1.2); diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java index b4d8412ea5c..98260925936 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java @@ -21,8 +21,8 @@ package org.matsim.contrib.roadpricing; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.core.config.Config; @@ -43,7 +43,7 @@ public class RoadPricingControlerIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testPaidTollsEndUpInScores() { + void testPaidTollsEndUpInScores() { // first run basecase Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil-extended"), "config.xml")); config.controller().setLastIteration(0); diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java index a93960aeb94..012e8117b2d 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java @@ -25,8 +25,8 @@ import java.io.File; import java.util.Iterator; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.core.config.ConfigUtils; @@ -48,7 +48,8 @@ public class RoadPricingIOTest { /** * Tests reader and writer to ensure that reading and writing does not modify the schemes. */ - @Test public void testWriteReadWrite() { + @Test + void testWriteReadWrite() { final String origFile = utils.getClassInputDirectory() + "roadpricing1.xml"; final String tmpFile1 = utils.getOutputDirectory() + "roadpricing1.xml"; final String tmpFile2 = utils.getOutputDirectory() + "roadpricing2.xml"; diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java index 6407bf1136d..8f41e3d40ab 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java @@ -26,9 +26,8 @@ import java.util.List; import jakarta.inject.Provider; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -73,7 +72,7 @@ public class TollTravelCostCalculatorTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testDisutilityResults() { + void testDisutilityResults() { Config config = ConfigUtils.createConfig() ; Scenario scenario = ScenarioUtils.createScenario(config) ; @@ -123,7 +122,7 @@ public void testDisutilityResults() { } @Test - public void testDistanceTollRouter() { + void testDistanceTollRouter() { Config config = utils.createConfig(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); RoadPricingTestUtils.createNetwork2(scenario); @@ -208,7 +207,7 @@ public void testDistanceTollRouter() { } @Test - public void testLinkTollRouter() { + void testLinkTollRouter() { Config config = utils.createConfig(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); RoadPricingTestUtils.createNetwork2(scenario); @@ -303,7 +302,7 @@ public void testLinkTollRouter() { } @Test - public void testCordonTollRouter() { + void testCordonTollRouter() { Config config = utils.createConfig(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); RoadPricingTestUtils.createNetwork2(scenario); diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java index 98ce6fec965..1869561d3b8 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java @@ -21,8 +21,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; import org.matsim.core.events.EventsUtils; @@ -44,7 +44,7 @@ public class RoadPricingByConfigfileTest { private static final Logger log = LogManager.getLogger( RoadPricingByConfigfileTest.class ); @Test - public final void testMain() { + final void testMain() { try{ RunRoadPricingExample.main( new String []{ diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java index b73a1169381..263b07483bd 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java @@ -1,8 +1,8 @@ package org.matsim.contrib.roadpricing.run; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class RunRoadPricingExampleIT { @@ -11,7 +11,7 @@ public class RunRoadPricingExampleIT { private static final String TEST_CONFIG = "./test/input/org/matsim/contrib/roadpricing/AvoidTolledRouteTest/config.xml"; @Test - public void testRunToadPricingExample() { + void testRunToadPricingExample() { String[] args = new String[]{TEST_CONFIG , "--config:controler.outputDirectory=" + utils.getOutputDirectory() }; diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingFromCodeIT.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingFromCodeIT.java index ad85cf62146..6f29178e7e8 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingFromCodeIT.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingFromCodeIT.java @@ -3,7 +3,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.io.File; @@ -12,7 +12,7 @@ public class RunRoadPricingFromCodeIT { private static final String TEST_CONFIG = "./test/input/org/matsim/contrib/roadpricing/AvoidTolledRouteTest/config.xml"; @Test - public void testRunRoadPricingFromCode(){ + void testRunRoadPricingFromCode(){ try{ LOG.info("Run context: " + new File("./").getAbsolutePath()); String[] args = new String[]{TEST_CONFIG}; diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingUsingTollFactorExampleIT.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingUsingTollFactorExampleIT.java index f43f85002f1..6431c4dab75 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingUsingTollFactorExampleIT.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingUsingTollFactorExampleIT.java @@ -1,13 +1,13 @@ package org.matsim.contrib.roadpricing.run; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; public class RunRoadPricingUsingTollFactorExampleIT { private static final String TEST_CONFIG = "./test/input/org/matsim/contrib/roadpricing/AvoidTolledRouteTest/config.xml"; @Test - public void testRunRoadPRicingUsingTollFactorExample() { + void testRunRoadPRicingUsingTollFactorExample() { String[] args = new String[]{TEST_CONFIG}; try { RunRoadPricingUsingTollFactorExample.main(args); diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/FloatMatrixIOTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/FloatMatrixIOTest.java index 1eb96dd4e35..8ee80d8a82b 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/FloatMatrixIOTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/FloatMatrixIOTest.java @@ -25,15 +25,15 @@ import java.util.HashSet; import java.util.Set; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author mrieser / SBB */ public class FloatMatrixIOTest { - @Test - public void testIO() throws IOException { + @Test + void testIO() throws IOException { Set zoneIds = new HashSet<>(); zoneIds.add("un"); zoneIds.add("dos"); diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/RooftopUtilsTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/RooftopUtilsTest.java index 7f42f0b8f0b..77d95e9430a 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/RooftopUtilsTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/RooftopUtilsTest.java @@ -24,7 +24,7 @@ import java.util.List; import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.misc.Time; /** @@ -32,8 +32,8 @@ */ public class RooftopUtilsTest { - @Test - public void testSortAndFilterConnections() { + @Test + void testSortAndFilterConnections() { List connections = new ArrayList<>(); // we'll misuse the transferCount as a connection identifier @@ -65,8 +65,8 @@ public void testSortAndFilterConnections() { Assert.assertEquals(4, connections.get(4).transferCount, 0.0); } - @Test - public void testCalcAverageAdaptionTime_1() { + @Test + void testCalcAverageAdaptionTime_1() { List connections = new ArrayList<>(); // 15-min headway, starting at 07:50, so the first rooftop is short and the last rooftop is cut @@ -106,8 +106,8 @@ public void testCalcAverageAdaptionTime_1() { // the frequency would be 3600 / 219 / 4 = 4.1096 } - @Test - public void testCalcAverageAdaptionTime_2() { + @Test + void testCalcAverageAdaptionTime_2() { List connections = new ArrayList<>(); // 15-min headway, starting at 07:59 (so the first rooftop is cut, and the last is short) @@ -124,8 +124,8 @@ public void testCalcAverageAdaptionTime_2() { // the frequency would be 3600 / 225 / 4 = 4.0 } - @Test - public void testCalcAverageAdaptionTime_noEarlierDeparture() { + @Test + void testCalcAverageAdaptionTime_noEarlierDeparture() { List connections = new ArrayList<>(); ODConnection c0, c1; @@ -143,8 +143,8 @@ public void testCalcAverageAdaptionTime_noEarlierDeparture() { Assert.assertEquals(1000.0, adaptionTime, 1e-7); } - @Test - public void testCalcAverageAdaptionTime_noLaterDeparture() { + @Test + void testCalcAverageAdaptionTime_noLaterDeparture() { List connections = new ArrayList<>(); ODConnection c0, c1; @@ -160,8 +160,8 @@ public void testCalcAverageAdaptionTime_noLaterDeparture() { Assert.assertEquals(900.0, adaptionTime, 1e-7); } - @Test - public void testCalcAverageAdaptionTime_noDepartureInRange() { + @Test + void testCalcAverageAdaptionTime_noDepartureInRange() { List connections = new ArrayList<>(); ODConnection c0, c1; @@ -177,8 +177,8 @@ public void testCalcAverageAdaptionTime_noDepartureInRange() { Assert.assertEquals(2600.0, adaptionTime, 1e-7); } - @Test - public void testCalcAverageAdaptionTime_singleDepartureEarly() { + @Test + void testCalcAverageAdaptionTime_singleDepartureEarly() { List connections = new ArrayList<>(); ODConnection c0, c1; @@ -193,8 +193,8 @@ public void testCalcAverageAdaptionTime_singleDepartureEarly() { Assert.assertEquals(4800.0, adaptionTime, 1e-7); } - @Test - public void testCalcAverageAdaptionTime_singleDepartureInRange() { + @Test + void testCalcAverageAdaptionTime_singleDepartureInRange() { List connections = new ArrayList<>(); ODConnection c0; @@ -209,8 +209,8 @@ public void testCalcAverageAdaptionTime_singleDepartureInRange() { Assert.assertEquals(1300.0, adaptionTime, 1e-7); } - @Test - public void testCalcAverageAdaptionTime_singleDepartureLate() { + @Test + void testCalcAverageAdaptionTime_singleDepartureLate() { List connections = new ArrayList<>(); ODConnection c0; @@ -225,8 +225,8 @@ public void testCalcAverageAdaptionTime_singleDepartureLate() { Assert.assertEquals(2400.0, adaptionTime, 1e-7); } - @Test - public void testCalcConnectionShares() { + @Test + void testCalcConnectionShares() { List connections = new ArrayList<>(); // 15-min headway @@ -283,8 +283,8 @@ public void testCalcConnectionShares() { Assert.assertEquals(2.0 / 60.0, shares.get(c5), 1e-7); } - @Test - public void testCalculationShares_noEarlierDeparture() { + @Test + void testCalculationShares_noEarlierDeparture() { List connections = new ArrayList<>(); ODConnection c0, c1; @@ -310,8 +310,8 @@ public void testCalculationShares_noEarlierDeparture() { Assert.assertEquals(0.0, shares.get(c1), 1e-7); } - @Test - public void testCalculationShares_noEarlierDeparture2() { + @Test + void testCalculationShares_noEarlierDeparture2() { List connections = new ArrayList<>(); ODConnection c0, c1; @@ -339,8 +339,8 @@ public void testCalculationShares_noEarlierDeparture2() { Assert.assertEquals(1.0 / 3.0, shares.get(c1), 1e-7); } - @Test - public void testCalculationShares_noLaterDeparture() { + @Test + void testCalculationShares_noLaterDeparture() { List connections = new ArrayList<>(); ODConnection c0, c1; @@ -368,8 +368,8 @@ public void testCalculationShares_noLaterDeparture() { Assert.assertEquals(5.0 / 6.0, shares.get(c1), 1e-7); } - @Test - public void testCalculationShares_noDepartureInRange() { + @Test + void testCalculationShares_noDepartureInRange() { List connections = new ArrayList<>(); ODConnection c0, c1; @@ -397,8 +397,8 @@ public void testCalculationShares_noDepartureInRange() { Assert.assertEquals(1.0 / 3.0, shares.get(c1), 1e-7); } - @Test - public void testCalculationShares_singleDepartureEarly() { + @Test + void testCalculationShares_singleDepartureEarly() { List connections = new ArrayList<>(); ODConnection c0, c1; @@ -408,8 +408,8 @@ public void testCalculationShares_singleDepartureEarly() { Assert.assertEquals(1.0, shares.get(c0), 1e-7); } - @Test - public void testCalculationShares_singleDepartureInRange() { + @Test + void testCalculationShares_singleDepartureInRange() { List connections = new ArrayList<>(); ODConnection c0, c1; @@ -419,8 +419,8 @@ public void testCalculationShares_singleDepartureInRange() { Assert.assertEquals(1.0, shares.get(c0), 1e-7); } - @Test - public void testCalculationShares_singleDepartureLate() { + @Test + void testCalculationShares_singleDepartureLate() { List connections = new ArrayList<>(); ODConnection c0, c1; diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/config/SBBTransitConfigGroupTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/config/SBBTransitConfigGroupTest.java index 5624833ef10..e78c20f85e2 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/config/SBBTransitConfigGroupTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/config/SBBTransitConfigGroupTest.java @@ -24,7 +24,7 @@ import java.io.OutputStreamWriter; import java.util.Collections; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigReader; import org.matsim.core.config.ConfigUtils; @@ -35,8 +35,8 @@ */ public class SBBTransitConfigGroupTest { - @Test - public void testConfigIO() { + @Test + void testConfigIO() { System.setProperty("matsim.preferLocalDtds", "true"); SBBTransitConfigGroup ptConfig1 = new SBBTransitConfigGroup(); diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java index f40c02b6b02..5c0b3452454 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java @@ -26,8 +26,8 @@ import java.nio.charset.StandardCharsets; import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigReader; @@ -51,9 +51,9 @@ public void setUp() { System.setProperty("matsim.preferLocalDtds", "true"); } - // https://github.com/SchweizerischeBundesbahnen/matsim-sbb-extensions/issues/3 - @Test - public void testIntegration() { + // https://github.com/SchweizerischeBundesbahnen/matsim-sbb-extensions/issues/3 + @Test + void testIntegration() { String xmlConfig = "\n" + "\n" + "\n" + diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java index 54dcc62891c..7a06e85d0ed 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java @@ -25,8 +25,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.controler.Controler; import org.matsim.core.mobsim.framework.Mobsim; import org.matsim.core.mobsim.qsim.QSim; @@ -42,8 +42,8 @@ public class SBBTransitQSimEngineIntegrationTest { private static final Logger log = LogManager.getLogger(SBBTransitQSimEngineIntegrationTest.class); @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testIntegration() { + @Test + void testIntegration() { TestFixture f = new TestFixture(); f.config.controller().setOutputDirectory(this.utils.getOutputDirectory()); @@ -67,8 +67,8 @@ public void testIntegration() { Assert.assertFalse(components.hasNamedComponent(TransitEngineModule.TRANSIT_ENGINE_NAME)); } - @Test - public void testIntegration_misconfiguration() { + @Test + void testIntegration_misconfiguration() { TestFixture f = new TestFixture(); Set mainModes = new HashSet<>(); diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineTest.java index d80dc5793d5..f176c763bd0 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -69,8 +69,8 @@ private static void assertEqualEvent(Class eventClass, double t Assert.assertEquals(time, event.getTime(), 1e-7); } - @Test - public void testDriver() { + @Test + void testDriver() { TestFixture f = new TestFixture(); EventsManager eventsManager = EventsUtils.createEventsManager(f.config); @@ -117,8 +117,8 @@ private void assertNextStop(SBBTransitDriverAgent driver, TransitRouteStop stop, driver.depart(f, routeDepTime + depOffset); } - @Test - public void testEvents_withoutPassengers_withoutLinks() { + @Test + void testEvents_withoutPassengers_withoutLinks() { TestFixture f = new TestFixture(); EventsManager eventsManager = EventsUtils.createEventsManager(f.config); @@ -159,11 +159,11 @@ public void testEvents_withoutPassengers_withoutLinks() { assertEqualEvent(PersonArrivalEvent.class, 30720, allEvents.get(14)); } - /** - * This test also checks that the passenger boarding/leaving times are correctly taken into account - */ - @Test - public void testEvents_withPassengers_withoutLinks() { + /** + * This test also checks that the passenger boarding/leaving times are correctly taken into account + */ + @Test + void testEvents_withPassengers_withoutLinks() { TestFixture f = new TestFixture(); f.addSingleTransitDemand(); @@ -214,8 +214,8 @@ public void testEvents_withPassengers_withoutLinks() { assertEqualEvent(PersonArrivalEvent.class, 30720, allEvents.get(21)); // driver } - @Test - public void testEvents_withThreePassengers_withoutLinks() { + @Test + void testEvents_withThreePassengers_withoutLinks() { TestFixture f = new TestFixture(); f.addTripleTransitDemand(); @@ -280,8 +280,8 @@ public void testEvents_withThreePassengers_withoutLinks() { assertEqualEvent(PersonArrivalEvent.class, 30720, allEvents.get(35)); // driver } - @Test - public void testEvents_withoutPassengers_withLinks() { + @Test + void testEvents_withoutPassengers_withLinks() { TestFixture f = new TestFixture(); f.sbbConfig.setCreateLinkEventsInterval(1); @@ -331,8 +331,8 @@ public void testEvents_withoutPassengers_withLinks() { assertEqualEvent(PersonArrivalEvent.class, 30720, allEvents.get(22)); } - @Test - public void testEvents_withoutPassengers_withLinks_Sesselbahn() { + @Test + void testEvents_withoutPassengers_withLinks_Sesselbahn() { TestFixture f = new TestFixture(); f.addSesselbahn(true, false); f.sbbConfig.setCreateLinkEventsInterval(1); @@ -373,13 +373,13 @@ public void testEvents_withoutPassengers_withLinks_Sesselbahn() { assertEqualEvent(PersonArrivalEvent.class, 35120, allEvents.get(12)); } - /** - * during development, I had a case where the traveltime-offset between two stops was 0 seconds. This resulted in the 2nd stop being immediately handled, and only after that the - * linkLeave/linkEnter-Events were generated. As the 2nd stop happened to be the last one, the driver already left the vehicle, which then resulted in an exception in some event handler trying to - * figure out the driver of the vehicle driving around. This tests reproduces this situation in order to check that the code can correctly cope with such a situation. - */ - @Test - public void testEvents_withoutPassengers_withLinks_SesselbahnMalformed() { + /** + * during development, I had a case where the traveltime-offset between two stops was 0 seconds. This resulted in the 2nd stop being immediately handled, and only after that the + * linkLeave/linkEnter-Events were generated. As the 2nd stop happened to be the last one, the driver already left the vehicle, which then resulted in an exception in some event handler trying to + * figure out the driver of the vehicle driving around. This tests reproduces this situation in order to check that the code can correctly cope with such a situation. + */ + @Test + void testEvents_withoutPassengers_withLinks_SesselbahnMalformed() { TestFixture f = new TestFixture(); f.addSesselbahn(true, true); f.sbbConfig.setCreateLinkEventsInterval(1); @@ -420,12 +420,12 @@ public void testEvents_withoutPassengers_withLinks_SesselbahnMalformed() { assertEqualEvent(PersonArrivalEvent.class, 35000, allEvents.get(12)); } - /** - * During first tests, some events were out-of-order in time, leading to an exception, due to the first stop on a route having a departure offset > 0. This tests reproduces this situation in order - * to check that the code can correctly cope with such a situation. - */ - @Test - public void testEvents_withoutPassengers_withLinks_DelayedFirstDeparture() { + /** + * During first tests, some events were out-of-order in time, leading to an exception, due to the first stop on a route having a departure offset > 0. This tests reproduces this situation in order + * to check that the code can correctly cope with such a situation. + */ + @Test + void testEvents_withoutPassengers_withLinks_DelayedFirstDeparture() { TestFixture f = new TestFixture(); f.delayDepartureAtFirstStop(); f.sbbConfig.setCreateLinkEventsInterval(1); @@ -476,11 +476,11 @@ public void testEvents_withoutPassengers_withLinks_DelayedFirstDeparture() { assertEqualEvent(PersonArrivalEvent.class, 30720, allEvents.get(22)); } - /** - * During tests, the travel time between two stops was not correctly calculated when the two stops were connected with a single direct link, and each of the stops is on a zero-length loop link. - */ - @Test - public void testEvents_withoutPassengers_withLinks_FromToLoopLink() { + /** + * During tests, the travel time between two stops was not correctly calculated when the two stops were connected with a single direct link, and each of the stops is on a zero-length loop link. + */ + @Test + void testEvents_withoutPassengers_withLinks_FromToLoopLink() { TestFixture f = new TestFixture(); f.addLoopyRoute(true); f.sbbConfig.setCreateLinkEventsInterval(1); @@ -531,8 +531,8 @@ public void testEvents_withoutPassengers_withLinks_FromToLoopLink() { assertEqualEvent(PersonArrivalEvent.class, 30570, allEvents.get(22)); } - @Test - public void testMisconfiguration() { + @Test + void testMisconfiguration() { TestFixture f = new TestFixture(); f.config.transit().setTransitModes(CollectionUtils.stringToSet("pt,train,bus")); f.sbbConfig.setDeterministicServiceModes(CollectionUtils.stringToSet("train,tram,ship")); @@ -557,8 +557,8 @@ public void testMisconfiguration() { } - @Test - public void testCreateEventsInterval() { + @Test + void testCreateEventsInterval() { TestFixture f = new TestFixture(); f.sbbConfig.setCreateLinkEventsInterval(3); diff --git a/contribs/shared_mobility/src/test/java/org/matsim/contrib/shared_mobility/RunIT.java b/contribs/shared_mobility/src/test/java/org/matsim/contrib/shared_mobility/RunIT.java index 4afd46b468d..5e6a5d0cd48 100644 --- a/contribs/shared_mobility/src/test/java/org/matsim/contrib/shared_mobility/RunIT.java +++ b/contribs/shared_mobility/src/test/java/org/matsim/contrib/shared_mobility/RunIT.java @@ -10,7 +10,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.events.handler.PersonDepartureEventHandler; import org.matsim.contrib.shared_mobility.run.SharingConfigGroup; import org.matsim.contrib.shared_mobility.run.SharingModule; @@ -38,7 +38,7 @@ public class RunIT { @Test - public final void test() throws UncheckedIOException, ConfigurationException, URISyntaxException { + final void test() throws UncheckedIOException, ConfigurationException, URISyntaxException { URL scenarioUrl = ExamplesUtils.getTestScenarioURL("siouxfalls-2014"); diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/adaptiveSignals/AdaptiveSignalsExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/adaptiveSignals/AdaptiveSignalsExampleTest.java index a8f3454f627..2ea82346bc0 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/adaptiveSignals/AdaptiveSignalsExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/adaptiveSignals/AdaptiveSignalsExampleTest.java @@ -20,8 +20,8 @@ */ package org.matsim.codeexamples.adaptiveSignals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -33,7 +33,7 @@ public class AdaptiveSignalsExampleTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testAdaptiveSignalsExample() { + void testAdaptiveSignalsExample() { String configFileName = "./examples/tutorial/singleCrossingScenario/config.xml"; RunAdaptiveSignalsExample.run(configFileName, testUtils.getOutputDirectory() + "/", false); } diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java index 3068410bbba..f49b8bb8cca 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java @@ -23,12 +23,12 @@ import java.io.IOException; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.utils.misc.CRCChecksum; -import org.matsim.testcases.MatsimTestUtils; - +import org.matsim.testcases.MatsimTestUtils; + /** * @author tthunig * @@ -37,10 +37,10 @@ public class CreateIntergreensExampleTest { private static final String DIR_TO_COMPARE_WITH = "./examples/tutorial/example90TrafficLights/useSignalInput/"; - @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); - - @Test - public void testIntergreenExample(){ + @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); + + @Test + void testIntergreenExample(){ try { String[] args = {testUtils.getOutputDirectory()}; CreateIntergreensExample.main(args); diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java index c52847d338b..bd97d5c2c26 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java @@ -25,12 +25,12 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.utils.misc.CRCChecksum; -import org.matsim.testcases.MatsimTestUtils; - +import org.matsim.testcases.MatsimTestUtils; + /** * @author tthunig * @@ -40,10 +40,10 @@ public class CreateSignalInputExampleTest { private static final String DIR_TO_COMPARE_WITH = "./examples/tutorial/example90TrafficLights/useSignalInput/woLanes/"; - @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); - - @Test - public void testCreateSignalInputExample(){ + @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); + + @Test + void testCreateSignalInputExample(){ try { (new CreateSignalInputExample()).run(testUtils.getOutputDirectory()); } catch (IOException e) { diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java index fd10d568b5c..f76efe99da2 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java @@ -23,12 +23,12 @@ import java.io.IOException; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.utils.misc.CRCChecksum; -import org.matsim.testcases.MatsimTestUtils; - +import org.matsim.testcases.MatsimTestUtils; + /** * @author tthunig * @@ -37,10 +37,10 @@ public class CreateSignalInputExampleWithLanesTest { private static final String DIR_TO_COMPARE_WITH = "./examples/tutorial/example90TrafficLights/useSignalInput/withLanes/"; - @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); - - @Test - public void testCreateSignalInputExampleWithLanes(){ + @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); + + @Test + void testCreateSignalInputExampleWithLanes(){ try { (new CreateSignalInputWithLanesExample()).run(testUtils.getOutputDirectory()); } catch (IOException e) { diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java index 0b63f1b71a0..9da52c5d00a 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java @@ -19,8 +19,8 @@ package org.matsim.codeexamples.fixedTimeSignals; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.controler.OutputDirectoryHierarchy.OverwriteFileSetting; @@ -35,7 +35,7 @@ public class RunSignalSystemsExampleTest { @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public final void testExampleWithHoles() { + final void testExampleWithHoles() { boolean usingOTFVis = false ; try { RunSignalSystemsExampleWithHoles.run(usingOTFVis); @@ -46,7 +46,7 @@ public final void testExampleWithHoles() { } @Test - public final void testMinimalExample() { + final void testMinimalExample() { try { Config config = ConfigUtils.loadConfig("./examples/tutorial/example90TrafficLights/useSignalInput/withLanes/config.xml"); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunVisualizeSignalScenarioWithLanesGUITest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunVisualizeSignalScenarioWithLanesGUITest.java index 799610d8faf..c40f531b26f 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunVisualizeSignalScenarioWithLanesGUITest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunVisualizeSignalScenarioWithLanesGUITest.java @@ -1,7 +1,7 @@ package org.matsim.codeexamples.fixedTimeSignals; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * Tests otfvis for signals with/ without lanes. @@ -25,15 +25,15 @@ public static void main(String[] args) { Assert.fail("something went wrong") ; } } - + @Test - public void testSignalExampleVisualizationWithLanes(){ + void testSignalExampleVisualizationWithLanes(){ String[] startOtfvis = {"false"}; main(startOtfvis); } - + @Test - public void testSignalExampleVisualizationWoLanes(){ + void testSignalExampleVisualizationWoLanes(){ try { VisualizeSignalScenario.run(false); } catch (Exception ee) { diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java b/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java index 486848880db..ce1989f66de 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java @@ -25,9 +25,9 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.data.SignalsData; import org.matsim.contrib.signals.data.signalcontrol.v20.SignalGroupSettingsData; @@ -36,9 +36,9 @@ import org.matsim.contrib.signals.model.SignalGroup; import org.matsim.contrib.signals.model.SignalPlan; import org.matsim.contrib.signals.model.SignalSystem; -import org.matsim.testcases.MatsimTestUtils; - - +import org.matsim.testcases.MatsimTestUtils; + + /** * @author tthunig * @@ -48,10 +48,10 @@ public class FixResponsiveSignalResultsIT { private static final Logger LOG = LogManager.getLogger(FixResponsiveSignalResultsIT.class); @RegisterExtension - private MatsimTestUtils testUtils = new MatsimTestUtils(); - - @Test - public void testOneCrossingExample() { + private MatsimTestUtils testUtils = new MatsimTestUtils(); + + @Test + void testOneCrossingExample() { LOG.info("Fix the results from the simple one-crossing-example in RunSimpleResponsiveSignalExample."); RunSimpleResponsiveSignalExample responsiveSignal = new RunSimpleResponsiveSignalExample(); responsiveSignal.run(); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/io/MatsimFileTypeGuesserSignalsTest.java b/contribs/signals/src/test/java/org/matsim/contrib/io/MatsimFileTypeGuesserSignalsTest.java index 9eca26c9a54..7bd326a50b0 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/io/MatsimFileTypeGuesserSignalsTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/io/MatsimFileTypeGuesserSignalsTest.java @@ -25,7 +25,7 @@ import java.io.IOException; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.signals.data.MatsimSignalSystemsReader; import org.matsim.core.utils.io.MatsimFileTypeGuesser; @@ -34,18 +34,18 @@ * */ public class MatsimFileTypeGuesserSignalsTest { - + @Test - public void testSignalSystemsV20XML() throws IOException { + void testSignalSystemsV20XML() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/contrib/signals/data/signalsystems/v20/testSignalSystems_v2.0.xml"); assertEquals(MatsimFileTypeGuesser.FileType.SignalSystems, g.getGuessedFileType()); assertNull(g.getPublicId()); assertNotNull(g.getSystemId()); assertEquals(MatsimSignalSystemsReader.SIGNALSYSTEMS20, g.getSystemId()); } - + @Test - public void testSignalGroupsV20XML() throws IOException { + void testSignalGroupsV20XML() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/contrib/signals/data/signalgroups/v20/testSignalGroups_v2.0.xml"); assertEquals(MatsimFileTypeGuesser.FileType.SignalGroups, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -54,7 +54,7 @@ public void testSignalGroupsV20XML() throws IOException { } @Test - public void testSignalControlV20XML() throws IOException { + void testSignalControlV20XML() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/contrib/signals/data/signalcontrol/v20/testSignalControl_v2.0.xml"); assertEquals(MatsimFileTypeGuesser.FileType.SignalControl, g.getGuessedFileType()); assertNull(g.getPublicId()); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java index d8ffa385400..196d6674661 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java @@ -5,9 +5,9 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -21,9 +21,9 @@ import org.matsim.core.network.io.MatsimNetworkReader; import org.matsim.core.scenario.MutableScenario; import org.matsim.core.scenario.ScenarioUtils; -import org.matsim.testcases.MatsimTestUtils; - - +import org.matsim.testcases.MatsimTestUtils; + + /** * @author aneumann * @author dgrether @@ -32,13 +32,13 @@ public class CalculateAngleTest { private static final Logger log = LogManager.getLogger(CalculateAngleTest.class); - @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - - /** - * @author aneumann - */ - @Test - public void testGetLeftLane() { + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); + + /** + * @author aneumann + */ + @Test + void testGetLeftLane() { Config conf = utils.loadConfig(utils.getClassInputDirectory() + "config.xml"); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(conf); new MatsimNetworkReader(scenario.getNetwork()).parse(conf.network().getInputFileURL(conf.getContext())); @@ -61,13 +61,13 @@ public void testGetLeftLane() { Assert.assertEquals( scenario.getNetwork().getLinks().get(Id.create("5", Link.class)), NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("3", Link.class)))); - } - - /** - * @author dgrether - */ - @Test - public void testGetOutLinksSortedByAngle(){ + } + + /** + * @author dgrether + */ + @Test + void testGetOutLinksSortedByAngle(){ Scenario scenario; double twicePi = Math.PI * 2; double piStep = Math.PI / 180.0; diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/SignalUtilsTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/SignalUtilsTest.java index 22d76808d68..69a06a655fd 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/SignalUtilsTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/SignalUtilsTest.java @@ -21,9 +21,8 @@ import java.util.Map; -import org.junit.Assert; - -import org.junit.Test; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.data.SignalsDataImpl; import org.matsim.contrib.signals.utils.SignalUtils; @@ -36,13 +35,13 @@ import org.matsim.contrib.signals.data.signalsystems.v20.SignalSystemsDataFactory; import org.matsim.contrib.signals.model.Signal; import org.matsim.contrib.signals.model.SignalGroup; -import org.matsim.contrib.signals.model.SignalSystem; - - -public class SignalUtilsTest { - - @Test - public final void testCreateAndAddSignalGroups4Signals() { +import org.matsim.contrib.signals.model.SignalSystem; + + +public class SignalUtilsTest { + + @Test + final void testCreateAndAddSignalGroups4Signals() { Id id1 = Id.create("1", SignalSystem.class); Id idSg1 = Id.create("1", SignalGroup.class); Id idSg3 = Id.create("3", SignalGroup.class); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java index 468f9e7f376..a733aaac266 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java @@ -4,8 +4,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -67,7 +67,7 @@ public class DelayAnalysisToolTest { private static final int NUMBER_OF_PERSONS = 5; @Test - public void testGetTotalDelayOnePerson(){ + void testGetTotalDelayOnePerson(){ Scenario scenario = prepareTest(1); EventsManager events = EventsUtils.createEventsManager(); @@ -95,7 +95,7 @@ public void handleEvent(Event event) { } @Test - public void testGetTotalDelaySeveralPerson(){ + void testGetTotalDelaySeveralPerson(){ Scenario scenario = prepareTest(NUMBER_OF_PERSONS); EventsManager events = EventsUtils.createEventsManager(); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java index 62d0078f7c3..d46a231d78e 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java @@ -19,11 +19,13 @@ * *********************************************************************** */ package org.matsim.contrib.signals.builder; +import static org.junit.jupiter.api.Assertions.assertThrows; + import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.LinkEnterEvent; import org.matsim.api.core.v01.events.handler.LinkEnterEventHandler; @@ -66,7 +68,7 @@ public class QSimSignalTest implements * Tests the setup with a traffic light that shows all the time green */ @Test - public void testTrafficLightIntersection2arms1AgentV20() { + void testTrafficLightIntersection2arms1AgentV20() { // configure and load standard scenario Scenario scenario = fixture.createAndLoadTestScenarioOneSignal(false ); @@ -79,7 +81,7 @@ public void testTrafficLightIntersection2arms1AgentV20() { * Tests the setup with a traffic light that shows red up to second 99 then in sec 100 green. */ @Test - public void testSignalSystems1AgentGreenAtSec100() { + void testSignalSystems1AgentGreenAtSec100() { // configure and load standard scenario Scenario scenario = fixture.createAndLoadTestScenarioOneSignal(false ); // modify scenario @@ -101,33 +103,35 @@ public void testSignalSystems1AgentGreenAtSec100() { /** * Tests the setup with a traffic light that shows red less than the specified intergreen time of five seconds. */ - @Test(expected = RuntimeException.class) - public void testIntergreensAbortOneAgentDriving() { - //configure and load standard scenario - Scenario scenario = fixture.createAndLoadTestScenarioOneSignal(true ); - // modify scenario - SignalsData signalsData = (SignalsData) scenario.getScenarioElement(SignalsData.ELEMENT_NAME); - SignalSystemControllerData controllerData = signalsData.getSignalControlData().getSignalSystemControllerDataBySystemId().get( - fixture.signalSystemId2 ); - SignalPlanData planData = controllerData.getSignalPlanData().get( fixture.signalPlanId2 ); - planData.setStartTime(0.0); - planData.setEndTime(0.0); - planData.setCycleTime(60); - SignalGroupSettingsData groupData = planData.getSignalGroupSettingsDataByGroupId().get( fixture.signalGroupId100 ); - groupData.setOnset(0); - groupData.setDropping(59); - - runQSimWithSignals(scenario, false); - - // if this code is reached, no exception has been thrown - Assert.fail("The simulation should abort because of intergreens violation."); + @Test + void testIntergreensAbortOneAgentDriving() { + assertThrows(RuntimeException.class, () -> { + //configure and load standard scenario + Scenario scenario = fixture.createAndLoadTestScenarioOneSignal(true); + // modify scenario + SignalsData signalsData = (SignalsData) scenario.getScenarioElement(SignalsData.ELEMENT_NAME); + SignalSystemControllerData controllerData = signalsData.getSignalControlData().getSignalSystemControllerDataBySystemId().get( + fixture.signalSystemId2); + SignalPlanData planData = controllerData.getSignalPlanData().get(fixture.signalPlanId2); + planData.setStartTime(0.0); + planData.setEndTime(0.0); + planData.setCycleTime(60); + SignalGroupSettingsData groupData = planData.getSignalGroupSettingsDataByGroupId().get(fixture.signalGroupId100); + groupData.setOnset(0); + groupData.setDropping(59); + + runQSimWithSignals(scenario, false); + + // if this code is reached, no exception has been thrown + Assert.fail("The simulation should abort because of intergreens violation."); + }); } /** * Tests the setup with a traffic light which red time corresponds to the specified intergreen time of five seconds. */ @Test - public void testIntergreensNoAbortOneAgentDriving() { + void testIntergreensNoAbortOneAgentDriving() { //configure and load standard scenario Scenario scenario = fixture.createAndLoadTestScenarioOneSignal(true ); // modify scenario @@ -149,22 +153,24 @@ public void testIntergreensNoAbortOneAgentDriving() { /** * Tests the setup with two conflicting directions showing green together */ - @Test(expected = RuntimeException.class) - public void testConflictingDirectionsAbortOneAgentDriving() { - //configure and load test scenario with data about conflicting directions - Scenario scenario = fixture.createAndLoadTestScenarioTwoSignals(true ); + @Test + void testConflictingDirectionsAbortOneAgentDriving() { + assertThrows(RuntimeException.class, () -> { + //configure and load test scenario with data about conflicting directions + Scenario scenario = fixture.createAndLoadTestScenarioTwoSignals(true); - runQSimWithSignals(scenario, false); + runQSimWithSignals(scenario, false); - // if this code is reached, no exception has been thrown - Assert.fail("The simulation should abort because of intergreens violation."); + // if this code is reached, no exception has been thrown + Assert.fail("The simulation should abort because of intergreens violation."); + }); } /** * Tests the setup with two conflicting directions not showing green together */ @Test - public void testConflictingDirectionsNoAbortOneAgentDriving() { + void testConflictingDirectionsNoAbortOneAgentDriving() { //configure and load test scenario with data about conflicting directions Scenario scenario = fixture.createAndLoadTestScenarioTwoSignals(true ); SignalsData signalsData = (SignalsData) scenario.getScenarioElement(SignalsData.ELEMENT_NAME); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java index 350093c5ec6..30c81f963c2 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java @@ -21,8 +21,8 @@ package org.matsim.contrib.signals.builder; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.signals.SignalSystemsConfigGroup; import org.matsim.contrib.signals.data.SignalsData; @@ -53,7 +53,7 @@ public class TravelTimeFourWaysTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testTrafficLightIntersection4arms() { + void testTrafficLightIntersection4arms() { Scenario scenario = this.createTestScenario(); scenario.getConfig().plans().setInputFile("plans.xml.gz"); ScenarioUtils.loadScenario(scenario); @@ -62,7 +62,7 @@ public void testTrafficLightIntersection4arms() { } @Test - public void testTrafficLightIntersection4armsWithUTurn() { + void testTrafficLightIntersection4armsWithUTurn() { Scenario scenario = this.createTestScenario(); scenario.getConfig().plans().setInputFile("plans_uturn.xml.gz"); ScenarioUtils.loadScenario(scenario); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java index 0dc9ba78923..958b2b252c4 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.LinkEnterEvent; @@ -70,22 +70,22 @@ public class TravelTimeOneWayTestIT { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testSignalOutflow_withLanes() { + void testSignalOutflow_withLanes() { runAndTestDifferentGreensplitSignals(this.loadAllGreenScenario(true)); } @Test - public void testSignalOutflow_woLanes() { + void testSignalOutflow_woLanes() { runAndTestDifferentGreensplitSignals(this.loadAllGreenScenario(false)); } @Test - public void testAllGreenSignalVsNoSignal_withLanes() { + void testAllGreenSignalVsNoSignal_withLanes() { runAndCompareAllGreenWithNoSignals(this.loadAllGreenScenario(true)); } @Test - public void testAllGreenSignalVsNoSignal_woLanes() { + void testAllGreenSignalVsNoSignal_woLanes() { runAndCompareAllGreenWithNoSignals(this.loadAllGreenScenario(false)); } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java index b7498921eae..8fc875966e6 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -85,7 +85,7 @@ public class DefaultPlanbasedSignalSystemControllerIT { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void test2SequentialPlansCompleteDay(){ + void test2SequentialPlansCompleteDay(){ ScenarioRunner runner = new ScenarioRunner(0.0, 3600*1.0, 3600*1.0, 3600*24.0); runner.setNoSimHours(1); SignalEventAnalyzer signalAnalyzer = runner.run(); @@ -109,7 +109,7 @@ public void test2SequentialPlansCompleteDay(){ } @Test - public void test2SequentialPlansUncompleteDayEnd(){ + void test2SequentialPlansUncompleteDayEnd(){ SignalEventAnalyzer signalAnalyzer = (new ScenarioRunner(0.0, 3600*1.0, 3600*1.0, 3600*2.0)).run(); log.info("First signal event at time " + signalAnalyzer.getFirstSignalEventTime()); @@ -137,7 +137,7 @@ public void test2SequentialPlansUncompleteDayEnd(){ } @Test - public void test2SequentialPlansUncompleteDayStart(){ + void test2SequentialPlansUncompleteDayStart(){ SignalEventAnalyzer signalAnalyzer = (new ScenarioRunner(3600*1.0, 3600*2.0, 3600*2.0, 3600*24.0)).run(); log.info("First signal event at time " + signalAnalyzer.getFirstSignalEventTime()); @@ -165,7 +165,7 @@ public void test2SequentialPlansUncompleteDayStart(){ } @Test - public void test2SequentialPlans1SecGap(){ + void test2SequentialPlans1SecGap(){ ScenarioRunner runner = new ScenarioRunner(0.0, 3600*1.0, 3600*1.0+1, 3600*24.0); runner.setNoSimHours(1); SignalEventAnalyzer signalAnalyzer = runner.run(); @@ -189,7 +189,7 @@ public void test2SequentialPlans1SecGap(){ } @Test - public void test2SequentialPlans1HourGap(){ + void test2SequentialPlans1HourGap(){ SignalEventAnalyzer signalAnalyzer = (new ScenarioRunner(3600*0.0, 3600*1.0, 3600*2.0, 3600*24.0)).run(); log.info("First signal event at time " + signalAnalyzer.getFirstSignalEventTime()); @@ -218,7 +218,7 @@ public void test2SequentialPlans1HourGap(){ } @Test - public void test2SequentialPlans1HourGap2TimesOff(){ + void test2SequentialPlans1HourGap2TimesOff(){ ScenarioRunner runner = new ScenarioRunner(3600*0.0, 3600*1.0, 3600*2.0, 3600*3.0); runner.setNoSimHours(3); SignalEventAnalyzer signalAnalyzer = runner.run(); @@ -251,7 +251,7 @@ public void test2SequentialPlans1HourGap2TimesOff(){ } @Test - public void test2SequentialPlansOverMidnight(){ + void test2SequentialPlansOverMidnight(){ SignalEventAnalyzer signalAnalyzer = (new ScenarioRunner(3600*22.0, 3600*1.0, 3600*1.0, 3600*22.0)).run(); log.info("First signal event at time " + signalAnalyzer.getFirstSignalEventTime()); @@ -273,7 +273,7 @@ public void test2SequentialPlansOverMidnight(){ } @Test - public void test1SignalPlanUncompleteDay(){ + void test1SignalPlanUncompleteDay(){ SignalEventAnalyzer signalAnalyzer = (new ScenarioRunner(3600*1.0, 3600*2.0, null, null)).run(); log.info("First signal event at time " + signalAnalyzer.getFirstSignalEventTime()); @@ -307,7 +307,7 @@ public void test1SignalPlanUncompleteDay(){ * 2. all day signal plan starts again/ is still active, when simulation time exceeds 12pm */ @Test - public void test1AllDaySignalPlanOverMidnightLateStart(){ + void test1AllDaySignalPlanOverMidnightLateStart(){ ScenarioRunner runner = new ScenarioRunner(null, null, null, null); // i.e. new ScenarioRunner(0.0, 0.0, null, null); runner.setSimStart_h(23); SignalEventAnalyzer signalAnalyzer = runner.run(); @@ -336,7 +336,7 @@ public void test1AllDaySignalPlanOverMidnightLateStart(){ * 2. should directly start at time 0.0 */ @Test - public void test1AllDaySignalPlanMidnightStart(){ + void test1AllDaySignalPlanMidnightStart(){ SignalEventAnalyzer signalAnalyzer = (new ScenarioRunner(null, null, null, null)).run(); // i.e. new ScenarioRunner(0.0, 0.0, null, null); log.info("First signal event at time " + signalAnalyzer.getFirstSignalEventTime()); @@ -356,7 +356,7 @@ public void test1AllDaySignalPlanMidnightStart(){ } @Test - public void test2SignalPlanFor25h(){ + void test2SignalPlanFor25h(){ ScenarioRunner runner = new ScenarioRunner(3600*0.0, 3600*12.0, 3600*12.0, 3600*24.0); runner.setNoSimHours(25); SignalEventAnalyzer signalAnalyzer = runner.run(); @@ -382,7 +382,7 @@ public void test2SignalPlanFor25h(){ } @Test - public void testSimStartAfterFirstDayPlan(){ + void testSimStartAfterFirstDayPlan(){ ScenarioRunner runner = new ScenarioRunner(3600*0.0, 3600*1.0, 3600*23.0, 3600*24.0); runner.setSimStart_h(23); runner.setNoSimHours(3); @@ -419,7 +419,7 @@ public void testSimStartAfterFirstDayPlan(){ * 1. overlapping signal plans (uncomplete day) result in an exception */ @Test - public void test2PlansSameTimesUncompleteDay(){ + void test2PlansSameTimesUncompleteDay(){ final String exceptionMessageOverlapping21 = "Signal plans SignalPlan2 and SignalPlan1 of signal system SignalSystem-3 overlap."; try{ @@ -436,7 +436,7 @@ public void test2PlansSameTimesUncompleteDay(){ * 1. overlapping signal plans (complete day) result in an exception */ @Test - public void test2PlansSameTimesCompleteDay(){ + void test2PlansSameTimesCompleteDay(){ final String exceptionMessageHoleDay = "Signal system SignalSystem-3 has multiple plans but at least one of them covers the hole day. " + "If multiple signal plans are used, they are not allowed to overlap."; @@ -451,7 +451,7 @@ public void test2PlansSameTimesCompleteDay(){ } @Test - public void test2OverlappingPlans(){ + void test2OverlappingPlans(){ final String exceptionMessageOverlapping12 = "Signal plans SignalPlan1 and SignalPlan2 of signal system SignalSystem-3 overlap."; try{ @@ -464,7 +464,7 @@ public void test2OverlappingPlans(){ } @Test - public void testNegativeOffset() { + void testNegativeOffset() { //plan1 is valid all day ScenarioRunner sr = new ScenarioRunner(0.0, 0.0, null, null); int offset1 = -3; @@ -479,7 +479,7 @@ public void testNegativeOffset() { } @Test - public void testNegativeOffsetEqualCycleTime() { + void testNegativeOffsetEqualCycleTime() { //plan1 is valid all day ScenarioRunner sr = new ScenarioRunner(0.0, 0.0, null, null); int offset1 = -120; @@ -494,7 +494,7 @@ public void testNegativeOffsetEqualCycleTime() { } @Test - public void testTwoPlansWithNegativeOffsets(){ + void testTwoPlansWithNegativeOffsets(){ ScenarioRunner sr = new ScenarioRunner(0.0*3600, 1.0*3600, 1.0*3600, 2.*3600 ); int offset1 = -3; @@ -516,7 +516,7 @@ public void testTwoPlansWithNegativeOffsets(){ } @Test - public void testTwoPlansWithNegativeOffsetsEqualCycleTime(){ + void testTwoPlansWithNegativeOffsetsEqualCycleTime(){ ScenarioRunner sr = new ScenarioRunner(0.0*3600, 1.0*3600, 1.0*3600, 2.*3600 ); int offset1 = -3; diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java index 570bb7374d4..8ce61447ac4 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java @@ -26,8 +26,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -78,7 +78,7 @@ public class LaemmerIT { * single intersection with demand (equals flow capacity) only in NS-direction. signals should show green only for the NS-direction. */ @Test - public void testSingleCrossingScenarioDemandNS() { + void testSingleCrossingScenarioDemandNS() { Fixture fixture = new Fixture(1800, 0, 5.0, Regime.COMBINED); SignalAnalysisTool signalAnalyzer = new SignalAnalysisTool(); DelayAnalysisTool generalAnalyzer = fixture.run(signalAnalyzer); @@ -107,7 +107,7 @@ public void testSingleCrossingScenarioDemandNS() { * single intersection with high demand in WE-direction, very low demand in NS-direction but minimum green time. I.e. the NS-signal should show green for exactly this 5 seconds per cycle. */ @Test - public void testSingleCrossingScenarioLowVsHighDemandWithMinG(){ + void testSingleCrossingScenarioLowVsHighDemandWithMinG(){ Fixture fixture = new Fixture(90, 1800, 5.0, Regime.COMBINED); SignalAnalysisTool signalAnalyzer = new SignalAnalysisTool(); DelayAnalysisTool generalAnalyzer = fixture.run(signalAnalyzer); @@ -140,7 +140,7 @@ public void testSingleCrossingScenarioLowVsHighDemandWithMinG(){ * single intersection with high demand in WE-direction, very low demand in NS-direction. No minimum green time! I.e. the NS-signal should show green for less than 5 seconds per cycle. */ @Test - public void testSingleCrossingScenarioLowVsHighDemandWoMinG(){ + void testSingleCrossingScenarioLowVsHighDemandWoMinG(){ Fixture fixture = new Fixture(90, 1800, 0.0, Regime.COMBINED); SignalAnalysisTool signalAnalyzer = new SignalAnalysisTool(); DelayAnalysisTool generalAnalyzer = fixture.run(signalAnalyzer); @@ -171,7 +171,7 @@ public void testSingleCrossingScenarioLowVsHighDemandWoMinG(){ * directions with the same demand-capacity-ration should get green for more or less the same time */ @Test - public void testSingleCrossingScenarioEqualDemandCapacityRatio(){ + void testSingleCrossingScenarioEqualDemandCapacityRatio(){ Fixture fixture = new Fixture(900, 1800, 0.0, Regime.COMBINED); SignalAnalysisTool signalAnalyzer = new SignalAnalysisTool(); DelayAnalysisTool generalAnalyzer = fixture.run(signalAnalyzer); @@ -206,7 +206,7 @@ public void testSingleCrossingScenarioEqualDemandCapacityRatio(){ * for low demand, i.e. an occupancy rate of 0.5 in the example of nico kuehnel's master thesis, the optimizing regime should be better than the stabilizing regime. */ @Test - public void testSingleCrossingScenarioStabilizingVsOptimizingRegimeLowDemand(){ + void testSingleCrossingScenarioStabilizingVsOptimizingRegimeLowDemand(){ Fixture fixtureStab = new Fixture(360, 1440, 0.0, Regime.STABILIZING); SignalAnalysisTool signalAnalyzerStab = new SignalAnalysisTool(); DelayAnalysisTool generalAnalyzerStab = fixtureStab.run(signalAnalyzerStab); @@ -293,7 +293,7 @@ public void testSingleCrossingScenarioStabilizingVsOptimizingRegimeLowDemand(){ * no standard cycle pattern). The stabilizing regime should still be stable, the combined regime should be the best. */ @Test - public void testSingleCrossingScenarioStabilizingVsOptimizingRegimeHighDemand(){ + void testSingleCrossingScenarioStabilizingVsOptimizingRegimeHighDemand(){ Fixture fixtureStab = new Fixture(360, 1800, 0.0, Regime.STABILIZING); SignalAnalysisTool signalAnalyzerStab = new SignalAnalysisTool(); DelayAnalysisTool generalAnalyzerStab = fixtureStab.run(signalAnalyzerStab); @@ -374,7 +374,7 @@ public void testSingleCrossingScenarioStabilizingVsOptimizingRegimeHighDemand(){ * exactly doubled (same departure times). */ @Test - public void testSingleCrossingScenarioWithDifferentFlowCapacityFactors(){ + void testSingleCrossingScenarioWithDifferentFlowCapacityFactors(){ Fixture fixtureFlowCap1 = new Fixture(360, 1800, 0.0, Regime.COMBINED); SignalAnalysisTool signalAnalyzerFlowCap1 = new SignalAnalysisTool(); DelayAnalysisTool generalAnalyzerFlowCap1 = fixtureFlowCap1.run(signalAnalyzerFlowCap1); @@ -431,7 +431,7 @@ public void testSingleCrossingScenarioWithDifferentFlowCapacityFactors(){ * Test Laemmer with multiple iterations (some variables have to be reset after iterations). */ @Test - public void testMultipleIterations() { + void testMultipleIterations() { Fixture fixture0It = new Fixture(500, 2000, 5.0, Regime.COMBINED); fixture0It.setLastIteration(0); fixture0It.addLeftTurnTraffic(); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java index 2d083c75e07..21c110b666a 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -103,7 +103,7 @@ public class SylviaIT { * priority over the second. */ @Test - public void testDemandABPrioA() { + void testDemandABPrioA() { double[] noPersons = { 3600, 3600 }; SignalAnalysisTool signalAnalyzer = runScenario(noPersons, 0); @@ -141,7 +141,7 @@ public void testDemandABPrioA() { * priority over the second. */ @Test - public void testDemandABPrioB() { + void testDemandABPrioB() { double[] noPersons = { 3600, 3600 }; // change the priority (i.e. order in the plan) by using an offset of 5 seconds SignalAnalysisTool signalAnalyzer = runScenario(noPersons, 5); @@ -169,7 +169,7 @@ public void testDemandABPrioB() { * test sylvia with demand crossing only in east-west direction */ @Test - public void testDemandA() { + void testDemandA() { double[] noPersons = { 3600, 0 }; SignalAnalysisTool signalAnalyzer = runScenario(noPersons, 0); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java index 5cccb0ced12..55e3b0ff974 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java @@ -22,8 +22,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.model.Signal; import org.matsim.contrib.signals.model.SignalSystem; @@ -49,7 +49,7 @@ public class AmberTimesData10ReaderWriterTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testParser() throws IOException, JAXBException, SAXException, + void testParser() throws IOException, JAXBException, SAXException, ParserConfigurationException { AmberTimesData atd = new AmberTimesDataImpl(); AmberTimesReader10 reader = new AmberTimesReader10(atd); @@ -59,7 +59,7 @@ public void testParser() throws IOException, JAXBException, SAXException, } @Test - public void testWriter() throws JAXBException, SAXException, ParserConfigurationException, + void testWriter() throws JAXBException, SAXException, ParserConfigurationException, IOException { String testoutput = this.testUtils.getOutputDirectory() + "testAtdOutput.xml"; log.debug("reading file..."); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java index 6513066495f..295e85c40eb 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java @@ -23,8 +23,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Node; @@ -44,7 +44,7 @@ public class SignalConflictDataReaderWriterTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testReaderAndWriter() { + void testReaderAndWriter() { LOG.info("create conflict data"); ConflictData conflictData = createConflictDataForTestCase(); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java index 92eef4f43c2..e1c44259dab 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java @@ -21,8 +21,8 @@ package org.matsim.contrib.signals.data.conflicts; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.signals.SignalSystemsConfigGroup; import org.matsim.contrib.signals.SignalSystemsConfigGroup.IntersectionLogic; @@ -45,7 +45,7 @@ public class UnprotectedLeftTurnLogicTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testSingleIntersectionScenarioWithLeftTurns() { + void testSingleIntersectionScenarioWithLeftTurns() { // run scenarios from files AnalyzeSingleIntersectionLeftTurnDelays restrictedLeftTurns = runSimulation(IntersectionLogic.CONFLICTING_DIRECTIONS_AND_TURN_RESTRICTIONS); AnalyzeSingleIntersectionLeftTurnDelays unrestrictedLeftTurns = runSimulation(IntersectionLogic.CONFLICTING_DIRECTIONS_NO_TURN_RESTRICTIONS); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java index 794b36a3482..9ac1b9ff35e 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.model.SignalGroup; import org.matsim.contrib.signals.model.SignalSystem; @@ -56,7 +56,7 @@ public class IntergreenTimesData10ReaderWriterTest { private Id systemId42 = Id.create("42", SignalSystem.class); @Test - public void testParser() throws IOException, JAXBException, SAXException, + void testParser() throws IOException, JAXBException, SAXException, ParserConfigurationException { IntergreenTimesData atd = new IntergreenTimesDataImpl(); IntergreenTimesReader10 reader = new IntergreenTimesReader10(atd); @@ -66,7 +66,7 @@ public void testParser() throws IOException, JAXBException, SAXException, } @Test - public void testWriter() throws JAXBException, SAXException, ParserConfigurationException, + void testWriter() throws JAXBException, SAXException, ParserConfigurationException, IOException { String testoutput = this.testUtils.getOutputDirectory() + "testAtdOutput.xml"; log.debug("reading file..."); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java index 7decd766c3a..283af98f161 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.data.signalsystems.v20.SignalSystemControllerData; import org.matsim.contrib.signals.model.SignalGroup; @@ -63,15 +63,15 @@ public class SignalControlData20ReaderWriterTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testReader() throws JAXBException, SAXException, ParserConfigurationException, IOException{ + void testReader() throws JAXBException, SAXException, ParserConfigurationException, IOException{ SignalControlData controlData = new SignalControlDataImpl(); SignalControlReader20 reader = new SignalControlReader20(controlData); reader.readFile(this.testUtils.getPackageInputDirectory() + TESTXML); checkContent(controlData); } - @Test - public void testWriter() throws JAXBException, SAXException, ParserConfigurationException, IOException { + @Test + void testWriter() throws JAXBException, SAXException, ParserConfigurationException, IOException { String testoutput = this.testUtils.getOutputDirectory() + "testSignalControlOutput.xml"; log.debug("reading file..."); //read the test file diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java index a6d27f26127..1086d595d2a 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java @@ -30,8 +30,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.model.Signal; import org.matsim.contrib.signals.model.SignalGroup; @@ -63,7 +63,7 @@ public class SignalGroups20ReaderWriterTest { @Test - public void testParser() throws IOException, JAXBException, SAXException, + void testParser() throws IOException, JAXBException, SAXException, ParserConfigurationException { SignalGroupsData sgd = new SignalGroupsDataImpl(); SignalGroupsReader20 reader = new SignalGroupsReader20(sgd); @@ -73,7 +73,7 @@ public void testParser() throws IOException, JAXBException, SAXException, } @Test - public void testWriter() throws JAXBException, SAXException, ParserConfigurationException, + void testWriter() throws JAXBException, SAXException, ParserConfigurationException, IOException { String testoutput = this.testUtils.getOutputDirectory() + "testSgOutput.xml"; log.debug("reading file..."); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java index 88fa1c1e46d..1fb40b18f1b 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java @@ -25,11 +25,10 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; - +import org.junit.jupiter.api.Test; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.signals.model.Signal; @@ -66,8 +65,8 @@ public class SignalSystemsData20ReaderWriterTest { private Id linkId4 = Id.create("4", Link.class); - @Test - public void testParser() throws IOException, JAXBException, SAXException, ParserConfigurationException { + @Test + void testParser() throws IOException, JAXBException, SAXException, ParserConfigurationException { SignalSystemsData lss = new SignalSystemsDataImpl(); SignalSystemsReader20 reader = new SignalSystemsReader20(lss); reader.readFile(this.testUtils.getPackageInputDirectory() + TESTXML); @@ -75,8 +74,8 @@ public void testParser() throws IOException, JAXBException, SAXException, Parser checkContent(lss); } - @Test - public void testWriter() throws JAXBException, SAXException, ParserConfigurationException, IOException { + @Test + void testWriter() throws JAXBException, SAXException, ParserConfigurationException, IOException { String testoutput = this.testUtils.getOutputDirectory() + "testLssOutput.xml"; log.debug("reading file..."); //read the test file diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java index c3be6656303..3091d160258 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java @@ -20,8 +20,8 @@ package org.matsim.contrib.signals.integration; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.signals.builder.Signals; import org.matsim.contrib.signals.data.SignalsData; @@ -52,7 +52,7 @@ public class SignalSystemsIT { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testSignalSystems() { + void testSignalSystems() { Config config = testUtils.loadConfig(testUtils.getClassInputDirectory() + CONFIG_FILE_NAME); config.plans().setActivityDurationInterpretation(PlansConfigGroup.ActivityDurationInterpretation.minOfDurationAndEndTime); String controlerOutputDir = testUtils.getOutputDirectory() + "controlerOutput/"; @@ -148,7 +148,7 @@ public void testSignalSystems() { } @Test - public void testSignalSystemsWTryEndTimeThenDuration() { + void testSignalSystemsWTryEndTimeThenDuration() { Config config = testUtils.loadConfig(testUtils.getClassInputDirectory() + CONFIG_FILE_NAME); // tryEndTimeThenDuration currently is the default config.plans().setActivityDurationInterpretation(PlansConfigGroup.ActivityDurationInterpretation.tryEndTimeThenDuration); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java index 643e89a87b8..3cbb0e162d2 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java @@ -20,8 +20,8 @@ package org.matsim.contrib.signals.integration.invertednetworks; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.signals.builder.Signals; @@ -47,7 +47,7 @@ public class InvertedNetworksSignalsIT { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public final void testSignalsInvertedNetworkRouting() { + final void testSignalsInvertedNetworkRouting() { InvertedNetworkRoutingSignalsFixture f = new InvertedNetworkRoutingSignalsFixture(false, false, true); f.scenario.getConfig().controller().setOutputDirectory(testUtils.getOutputDirectory()); Controler c = new Controler(f.scenario); @@ -67,7 +67,7 @@ public void notifyStartup(StartupEvent event) { } @Test - public final void testSignalsInvertedNetworkRoutingIterations() { + final void testSignalsInvertedNetworkRoutingIterations() { InvertedNetworkRoutingSignalsFixture f = new InvertedNetworkRoutingSignalsFixture(false, false, true); f.scenario.getConfig().controller().setOutputDirectory(testUtils.getOutputDirectory()); f.scenario.getConfig().controller().setLastIteration(1); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java index f2dd03ed0a0..297db365105 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java @@ -14,8 +14,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Coord; @@ -176,10 +176,9 @@ public OsmData constructSignalisedJunction(){ } - // @SuppressWarnings("ConstantConditions") - @Test - public void singleJunction(){ + @Test + void singleJunction(){ OsmData osmData = constructSignalisedJunction(); Path file = Paths.get(matsimTestUtils.getOutputDirectory(), "singleJunction.xml"); writeOsmData(osmData.getNodes(),osmData.getWays(),file); @@ -242,8 +241,8 @@ public void singleJunction(){ Assert.assertEquals("Assert number of Signals", 8, signals); } - @Test - public void singleJunctionWithBoundingBox(){ + @Test + void singleJunctionWithBoundingBox(){ OsmData osmData = constructSignalisedJunction(); Path file = Paths.get(matsimTestUtils.getOutputDirectory(), "singleJunction.xml"); writeOsmData(osmData.getNodes(),osmData.getWays(),file); @@ -308,8 +307,8 @@ public void singleJunctionWithBoundingBox(){ Assert.assertEquals("Assert number of Signals", 8, signals); } - @Test - public void singleJunctionBadBoundingBox(){ + @Test + void singleJunctionBadBoundingBox(){ OsmData osmData = constructSignalisedJunction(); Path file = Paths.get(matsimTestUtils.getOutputDirectory(), "singleJunction.xml"); writeOsmData(osmData.getNodes(),osmData.getWays(),file); @@ -367,8 +366,8 @@ public void singleJunctionBadBoundingBox(){ } } - @Test - public void berlinSnippet(){ + @Test + void berlinSnippet(){ Path inputfile = Paths.get(matsimTestUtils.getClassInputDirectory()); inputfile = Paths.get(inputfile.toString(),"berlinSnippet.osm.gz"); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java index 8f1d630c363..79d7a09eb7c 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java @@ -20,9 +20,8 @@ package org.matsim.contrib.signals.oneagent; import org.junit.Assert; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.LinkEnterEvent; @@ -59,7 +58,7 @@ public class ControlerTest { * the signal should be red in sec [0,99] and green in [100,2000] */ @Test - public void testModifySignalControlDataOnsetOffset() { + void testModifySignalControlDataOnsetOffset() { //configure and load standard scenario Fixture fixture = new Fixture(); Scenario scenario = fixture.createAndLoadTestScenarioOneSignal(false); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LaneSensorTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LaneSensorTest.java index 01cc49e43bc..837ae251427 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LaneSensorTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LaneSensorTest.java @@ -3,13 +3,13 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertTrue; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.api.experimental.events.LaneEnterEvent; public class LaneSensorTest { @Test - public void testGetAvgVehiclesPerSecondAfterBucketCollection() { + void testGetAvgVehiclesPerSecondAfterBucketCollection() { //test if average is working for constant flow LaneSensor sensor = new LaneSensor(null, null); sensor.registerAverageVehiclesPerSecondToMonitor(60, 15); @@ -22,9 +22,9 @@ public void testGetAvgVehiclesPerSecondAfterBucketCollection() { assertEquals(1.0/3.0, sensor.getAvgVehiclesPerSecond(time), 0.04); } } - + @Test - public void testGetAvgVehiclesPerSecondDuringBucketCollection() { + void testGetAvgVehiclesPerSecondDuringBucketCollection() { //test if average is working for constant flow LaneSensor sensor = new LaneSensor(null, null); sensor.registerAverageVehiclesPerSecondToMonitor(60, 15); @@ -37,9 +37,9 @@ public void testGetAvgVehiclesPerSecondDuringBucketCollection() { assertEquals(1.0/3.0, sensor.getAvgVehiclesPerSecond(time), 0.04); } } - + @Test - public void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucket() { + void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucket() { //test if average is working for constant flow LaneSensor sensor = new LaneSensor(null, null); sensor.registerAverageVehiclesPerSecondToMonitor(60, 15); @@ -58,9 +58,9 @@ public void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucket() { assertEquals((1.0/3.0), sensor.getAvgVehiclesPerSecond(time), 0.02); } } - + @Test - public void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucketWhileHavingNotEnoughBuckets() { + void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucketWhileHavingNotEnoughBuckets() { //test if average is working for constant flow LaneSensor sensor = new LaneSensor(null, null); sensor.registerAverageVehiclesPerSecondToMonitor(60, 15); @@ -83,9 +83,9 @@ public void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucketWhileHavingNotEn assertEquals((1.0/3.0), sensor.getAvgVehiclesPerSecond(time), 0.02); } } - + @Test - public void testClassicBehaviour() { + void testClassicBehaviour() { LaneSensor sensor = new LaneSensor(null, null); sensor.registerAverageVehiclesPerSecondToMonitor(); for (int time = 0; time <= 3600; time++) { diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LinkSensorTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LinkSensorTest.java index c7d9db8f858..66e78addeb7 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LinkSensorTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LinkSensorTest.java @@ -4,7 +4,7 @@ import static org.junit.Assert.assertTrue; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -25,7 +25,7 @@ public class LinkSensorTest { @Test - public void testGetAvgVehiclesPerSecondAfterBucketCollection() { + void testGetAvgVehiclesPerSecondAfterBucketCollection() { //test if average is working for constant flow LinkSensor sensor = new LinkSensor(null); sensor.registerAverageVehiclesPerSecondToMonitor(60, 15); @@ -38,9 +38,9 @@ public void testGetAvgVehiclesPerSecondAfterBucketCollection() { assertEquals(1.0/3.0, sensor.getAvgVehiclesPerSecond(time), 0.04); } } - + @Test - public void testGetAvgVehiclesPerSecondDuringBucketCollection() { + void testGetAvgVehiclesPerSecondDuringBucketCollection() { //test if average is working for constant flow LinkSensor sensor = new LinkSensor(null); sensor.registerAverageVehiclesPerSecondToMonitor(60, 15); @@ -53,9 +53,9 @@ public void testGetAvgVehiclesPerSecondDuringBucketCollection() { assertEquals(1.0/3.0, sensor.getAvgVehiclesPerSecond(time), 0.04); } } - + @Test - public void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucket() { + void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucket() { //test if average is working for constant flow LinkSensor sensor = new LinkSensor(null); sensor.registerAverageVehiclesPerSecondToMonitor(60, 15); @@ -74,9 +74,9 @@ public void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucket() { assertEquals((1.0/3.0), sensor.getAvgVehiclesPerSecond(time), 0.02); } } - + @Test - public void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucketWhileHavingNotEnoughBuckets() { + void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucketWhileHavingNotEnoughBuckets() { //test if average is working for constant flow LinkSensor sensor = new LinkSensor(null); sensor.registerAverageVehiclesPerSecondToMonitor(60, 15); @@ -99,9 +99,9 @@ public void testGetAvgVehiclesPerSecondWithNoTrafficForTwoBucketWhileHavingNotEn assertEquals((1.0/3.0), sensor.getAvgVehiclesPerSecond(time), 0.02); } } - + @Test - public void testClassicBehaviour() { + void testClassicBehaviour() { LinkSensor sensor = new LinkSensor(null); sensor.registerAverageVehiclesPerSecondToMonitor(); for (int time = 0; time <= 3600; time++) { @@ -147,10 +147,10 @@ private Scenario createScenario(){ l.setFreespeed(6.0); return sc; } - - + + @Test - public void testSensorNumberOfCarsMonitoring(){ + void testSensorNumberOfCarsMonitoring(){ Scenario sc = this.createScenario(); Link link = sc.getNetwork().getLinks().get(Id.create(1, Link.class)); LinkSensor sensor = new LinkSensor(link); @@ -200,9 +200,9 @@ public void testSensorNumberOfCarsMonitoring(){ numberOfCars = sensor.getNumberOfCarsOnLink(); Assert.assertEquals(0, numberOfCars); } - + @Test - public void testSensorDistanceMonitoring(){ + void testSensorDistanceMonitoring(){ Scenario sc = this.createScenario(); Link link = sc.getNetwork().getLinks().get(Id.create(1, Link.class)); LinkSensor sensor = new LinkSensor(link); diff --git a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/DefaultAnnealingAcceptorTest.java b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/DefaultAnnealingAcceptorTest.java index 656b2757262..0fc9099c9b0 100644 --- a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/DefaultAnnealingAcceptorTest.java +++ b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/DefaultAnnealingAcceptorTest.java @@ -10,7 +10,7 @@ import org.apache.commons.lang3.mutable.MutableInt; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.controler.IterationCounter; import org.matsim.contrib.simulatedannealing.acceptor.DefaultAnnealingAcceptor; import org.matsim.contrib.simulatedannealing.temperature.TemperatureFunction; @@ -23,7 +23,7 @@ public class DefaultAnnealingAcceptorTest { private final SimulatedAnnealingConfigGroup simAnCfg = new SimulatedAnnealingConfigGroup(); @Test - public void testAcceptor() { + void testAcceptor() { MutableInt iteration = new MutableInt(0); IterationCounter iterationCounter = iteration::getValue; diff --git a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java index f9fd687abc1..4596d83435c 100644 --- a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java +++ b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java @@ -9,8 +9,8 @@ package org.matsim.contrib.simulatedannealing; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.matsim.core.config.Config; @@ -52,7 +52,7 @@ private static Path writeConfig(final File tempFolder) throws IOException { } @Test - public void loadConfigGroupTest() throws IOException { + void loadConfigGroupTest() throws IOException { /* Test that exported values are correct imported again */ Path configFile = writeConfig(tempFolder); @@ -66,7 +66,7 @@ public void loadConfigGroupTest() throws IOException { @Test - public void perturbationParamsTest() { + void perturbationParamsTest() { Config config = createConfig(); SimulatedAnnealingConfigGroup saConfig = ConfigUtils.addOrGetModule(config, SimulatedAnnealingConfigGroup.class); diff --git a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingIT.java b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingIT.java index 87e9026ec3e..9312b06d731 100644 --- a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingIT.java +++ b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingIT.java @@ -1,8 +1,8 @@ package org.matsim.contrib.simulatedannealing; import com.google.inject.TypeLiteral; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkLeaveEvent; import org.matsim.api.core.v01.events.handler.LinkLeaveEventHandler; @@ -35,7 +35,7 @@ public class SimulatedAnnealingIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testIntegratedAnnealingInQSim() { + void testIntegratedAnnealingInQSim() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); diff --git a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingTest.java b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingTest.java index 3fde6d85fa1..020a184d6ef 100644 --- a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingTest.java +++ b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingTest.java @@ -17,7 +17,7 @@ import org.apache.logging.log4j.core.config.Configuration; import org.apache.logging.log4j.core.config.LoggerConfig; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.simulatedannealing.acceptor.Acceptor; import org.matsim.contrib.simulatedannealing.acceptor.DefaultAnnealingAcceptor; import org.matsim.contrib.simulatedannealing.cost.CostCalculator; @@ -37,7 +37,7 @@ public class SimulatedAnnealingTest { private final Random r = new Random(42); @Test - public void testSimulatedAnnealing() { + void testSimulatedAnnealing() { MatsimRandom.reset(); LoggerContext ctx = (LoggerContext) LogManager.getContext(false); diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperConfigGroupTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperConfigGroupTest.java index 9d3f59ae4e8..c58576d8cf4 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperConfigGroupTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperConfigGroupTest.java @@ -1,8 +1,8 @@ package org.matsim.simwrapper; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.testcases.MatsimTestUtils; @@ -14,7 +14,7 @@ public class SimWrapperConfigGroupTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void config() { + void config() { Config config = ConfigUtils.createConfig(); SimWrapperConfigGroup sw = ConfigUtils.addOrGetModule(config, SimWrapperConfigGroup.class); diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperModuleTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperModuleTest.java index 8a6cdeba974..1c008e9bb17 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperModuleTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperModuleTest.java @@ -1,7 +1,7 @@ package org.matsim.simwrapper; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.controler.Controler; @@ -17,7 +17,7 @@ public class SimWrapperModuleTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void runScenario() { + void runScenario() { URL equil = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml"); diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperTest.java index b9e985f1fee..9784387d6d1 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/SimWrapperTest.java @@ -1,8 +1,8 @@ package org.matsim.simwrapper; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.simwrapper.viz.*; import org.matsim.testcases.MatsimTestUtils; @@ -18,7 +18,7 @@ public class SimWrapperTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void vizElementsTest() throws IOException { + void vizElementsTest() throws IOException { SimWrapper simWrapper = SimWrapper.create(); diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/DashboardTests.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/DashboardTests.java index 1b103bdd313..cdf392f38df 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/DashboardTests.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/DashboardTests.java @@ -1,8 +1,8 @@ package org.matsim.simwrapper.dashboard; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.application.MATSimApplication; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -37,7 +37,7 @@ private void run(Dashboard... dashboards) { } @Test - public void defaults() { + void defaults() { Path out = Path.of(utils.getOutputDirectory(), "analysis", "population"); @@ -49,7 +49,7 @@ public void defaults() { } @Test - public void stuckAgents() { + void stuckAgents() { Path out = Path.of(utils.getOutputDirectory(), "analysis", "population"); @@ -61,7 +61,7 @@ public void stuckAgents() { } @Test - public void trip() { + void trip() { Path out = Path.of(utils.getOutputDirectory(), "analysis", "population"); @@ -72,7 +72,7 @@ public void trip() { } @Test - public void tripRef() { + void tripRef() { Path out = Path.of(utils.getOutputDirectory(), "analysis", "population"); @@ -84,7 +84,7 @@ public void tripRef() { } @Test - public void populationAttribute() { + void populationAttribute() { Path out = Path.of(utils.getOutputDirectory(), "analysis", "population"); @@ -98,7 +98,7 @@ public void populationAttribute() { } @Test - public void traffic() { + void traffic() { Path out = Path.of(utils.getOutputDirectory(), "analysis", "traffic"); diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java index c14a93d3d82..4cbd29d9e7d 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java @@ -3,8 +3,8 @@ import com.google.common.collect.Iterables; import org.assertj.core.api.Assertions; import org.junit.Assume; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; import org.matsim.application.MATSimApplication; @@ -37,7 +37,7 @@ public class EmissionsDashboardTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void generate() { + void generate() { // This test can only run if the password is set Assume.assumeTrue(System.getenv("MATSIM_DECRYPTION_PASSWORD") != null); diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/TrafficCountsDashboardTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/TrafficCountsDashboardTest.java index 8078e9c6e44..29d99561d98 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/TrafficCountsDashboardTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/TrafficCountsDashboardTest.java @@ -1,8 +1,8 @@ package org.matsim.simwrapper.dashboard; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -32,7 +32,7 @@ public class TrafficCountsDashboardTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void generate() { + void generate() { Config config = TestScenario.loadConfig(utils); diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java index 6fc28108a5b..7d03f3966ae 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java @@ -2,8 +2,8 @@ import com.fasterxml.jackson.databind.ObjectWriter; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import tech.tablesaw.api.IntColumn; import tech.tablesaw.api.StringColumn; @@ -38,7 +38,7 @@ public void setUp() throws Exception { } @Test - public void pie() throws IOException { + void pie() throws IOException { String[] modes = {"car", "bike", "pt", "ride", "walk"}; double[] shares = {0.2, 0.15, 0.25, 0.1, 0.3}; @@ -52,7 +52,7 @@ public void pie() throws IOException { @Test - public void timeSeries() throws IOException { + void timeSeries() throws IOException { Table bush = Table.read().csv(new File(utils.getClassInputDirectory(), "bush.csv")); Figure figure = TimeSeriesPlot.create("George W. Bush approval ratings", bush, "date", "approval", "who"); @@ -63,7 +63,7 @@ public void timeSeries() throws IOException { } @Test - public void hist() throws IOException { + void hist() throws IOException { Table test = Table.create( StringColumn.create("type").append("apples").append("apples").append("apples").append("oranges").append("bananas"), @@ -81,7 +81,7 @@ public void hist() throws IOException { } @Test - public void heatmap() throws IOException { + void heatmap() throws IOException { Table table = Table.read().csv(new File(utils.getClassInputDirectory(), "bush.csv")); @@ -99,7 +99,7 @@ public void heatmap() throws IOException { } @Test - public void scatter() throws IOException { + void scatter() throws IOException { final double[] x = {1, 2, 3, 4, 5, 6}; final double[] y = {0, 1, 6, 14, 25, 39}; diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java index 987f1464e0b..3956c9d505c 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java @@ -11,8 +11,8 @@ import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule; import org.assertj.core.api.Assertions; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.simwrapper.ComponentMixin; import org.matsim.testcases.MatsimTestUtils; import tech.tablesaw.plotly.components.Line; @@ -54,7 +54,7 @@ public void setUp() throws Exception { } @Test - public void inline() throws IOException { + void inline() throws IOException { Object[] x = {"sheep", "cows", "fish", "tree sloths"}; double[] y = {1, 4, 9, 16}; @@ -73,7 +73,7 @@ public void inline() throws IOException { } @Test - public void data() throws IOException { + void data() throws IOException { ScatterTrace.ScatterBuilder trace = ScatterTrace.builder(Plotly.INPUT, Plotly.INPUT) .text(Plotly.TEXT_INPUT) @@ -98,7 +98,7 @@ public void data() throws IOException { } @Test - public void multiple() throws IOException { + void multiple() throws IOException { ScatterTrace scatter = ScatterTrace.builder(Plotly.INPUT, Plotly.INPUT) diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/events/CourtesyEventsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/events/CourtesyEventsTest.java index 49a64a48325..63c5ecc5a71 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/events/CourtesyEventsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/events/CourtesyEventsTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -53,7 +53,7 @@ public class CourtesyEventsTest { public static final String TYPE = "type"; @Test - public void testFullOverlap() { + void testFullOverlap() { testEvents( 4, // 1:|------------------| @@ -85,7 +85,7 @@ public void testFullOverlap() { } @Test - public void testPartialOverlap() { + void testPartialOverlap() { testEvents( 4, // 1:|------------------| // 2: |-------------------| @@ -116,7 +116,7 @@ public void testPartialOverlap() { } @Test - public void testNoOverlap() { + void testNoOverlap() { testEvents( 0, // 1:|-----| // 2: |------------| @@ -147,7 +147,7 @@ public void testNoOverlap() { } @Test - public void testStartTogether() { + void testStartTogether() { testEvents( 4, // 1:|-----| // 2:|------------------------| @@ -178,7 +178,7 @@ public void testStartTogether() { } @Test - public void testEndTogether() { + void testEndTogether() { testEvents( 4, // 1:|------------------------| // 2: |------------| diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanFactoryTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanFactoryTest.java index 7e34b17358a..6e2bd112d94 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanFactoryTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanFactoryTest.java @@ -24,7 +24,7 @@ import java.util.LinkedHashMap; import java.util.Map; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -35,7 +35,7 @@ */ public class JointPlanFactoryTest { @Test - public void testAddAtIndividualLevel() throws Exception { + void testAddAtIndividualLevel() throws Exception { final Id id1 = Id.createPersonId( 1 ); final Person person1 = PopulationUtils.getFactory().createPerson(id1); @@ -64,7 +64,7 @@ public void testAddAtIndividualLevel() throws Exception { } @Test - public void testDoNotAddAtIndividualLevel() throws Exception { + void testDoNotAddAtIndividualLevel() throws Exception { final Id id1 = Id.createPersonId( 1 ); final Person person1 = PopulationUtils.getFactory().createPerson((Id) id1); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java index 56cf258be11..cf248036757 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java @@ -27,8 +27,8 @@ import java.util.Random; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -50,7 +50,7 @@ public class JointPlanIOTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testDumpAndRead() throws Exception { + void testDumpAndRead() throws Exception { final JointPlans jointPlans = new JointPlans(); final Scenario scenario = createScenario( jointPlans ); final Population population = scenario.getPopulation(); @@ -94,7 +94,7 @@ public void testDumpAndRead() throws Exception { } @Test - public void testPlansOrderIsStableInCoreIO() throws Exception { + void testPlansOrderIsStableInCoreIO() throws Exception { final JointPlans jointPlans = new JointPlans(); final Scenario scenario = createScenario( jointPlans ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlansTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlansTest.java index ae28697cf8b..b8898723c03 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlansTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlansTest.java @@ -23,7 +23,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -34,12 +34,12 @@ */ public class JointPlansTest { @Test - public void testExceptionAddWithCache( ) throws Exception { + void testExceptionAddWithCache() throws Exception { testExceptionAdd( true ); } @Test - public void testExceptionAddWithoutCache( ) throws Exception { + void testExceptionAddWithoutCache() throws Exception { testExceptionAdd( false ); } @@ -74,12 +74,12 @@ private static void testExceptionAdd( final boolean withCache ) throws Exception } @Test - public void testExceptionRemoveWithCache( ) throws Exception { + void testExceptionRemoveWithCache() throws Exception { testExceptionRemove( true ); } @Test - public void testExceptionRemoveWithoutCache( ) throws Exception { + void testExceptionRemoveWithoutCache() throws Exception { testExceptionRemove( false ); } @@ -115,12 +115,12 @@ private static void testExceptionRemove( final boolean withCache ) throws Except } @Test - public void testAddAndGetSeveralInstancesWithCache( ) { + void testAddAndGetSeveralInstancesWithCache() { testAddAndGetSeveralInstances( true ); } @Test - public void testAddAndGetSeveralInstancesWithoutCache( ) { + void testAddAndGetSeveralInstancesWithoutCache() { testAddAndGetSeveralInstances( false ); } @@ -200,12 +200,12 @@ private static void testAddAndGetSeveralInstances( final boolean withCache ) { @Test - public void testClearWithoutCache( ) { + void testClearWithoutCache() { testClear( false ); } @Test - public void testClearWithCache( ) { + void testClearWithCache() { testClear( true ); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java index 9bc61d77eee..0a44ae0fd97 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java @@ -25,8 +25,8 @@ import java.util.Set; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -43,12 +43,12 @@ public class SocialNetworkIOTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testReinputReflective() { + void testReinputReflective() { testReinput( true ); } @Test - public void testReinputNonReflective() { + void testReinputNonReflective() { testReinput( false ); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkTest.java index ab70f3630c3..4728c8d94fb 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkTest.java @@ -24,7 +24,9 @@ import java.util.HashSet; import org.junit.Assert; -import org.junit.Test; + +import static org.junit.jupiter.api.Assertions.assertThrows; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -32,14 +34,16 @@ * @author thibautd */ public class SocialNetworkTest { - @Test( expected=IllegalStateException.class ) - public void testFailsIfAddingDirectedTieInReflectiveNetwork() { - final SocialNetwork sn = new SocialNetworkImpl( true ); - sn.addMonodirectionalTie( Id.create( 1 , Person.class ) , Id.create( 2 , Person.class ) ); + @Test + void testFailsIfAddingDirectedTieInReflectiveNetwork() { + assertThrows(IllegalStateException.class, () -> { + final SocialNetwork sn = new SocialNetworkImpl( true ); + sn.addMonodirectionalTie(Id.create(1, Person.class), Id.create(2, Person.class)); + }); } @Test - public void testMonodirectionalTie() { + void testMonodirectionalTie() { final Id ego = Id.create( 1 , Person.class ); final Id alter = Id.create( 2 , Person.class ); @@ -65,7 +69,7 @@ public void testMonodirectionalTie() { } @Test - public void testBidirectionalTie() { + void testBidirectionalTie() { final Id ego = Id.create( 1 , Person.class ); final Id alter = Id.create( 2 , Person.class ); @@ -91,7 +95,7 @@ public void testBidirectionalTie() { } @Test - public void testRemoveEgo() { + void testRemoveEgo() { final SocialNetworkImpl sn = new SocialNetworkImpl( true ); final Id ego = Id.create( "ego" , Person.class ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/DynamicGroupIdentifierTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/DynamicGroupIdentifierTest.java index ec936cb6b2e..1b992c0a25b 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/DynamicGroupIdentifierTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/DynamicGroupIdentifierTest.java @@ -24,7 +24,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -42,7 +42,7 @@ public class DynamicGroupIdentifierTest { @Test - public void testNGroupsNoJointPlansNoSocialNet() { + void testNGroupsNoJointPlansNoSocialNet() { final Scenario scenario = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); scenario.addScenarioElement( JointPlans.ELEMENT_NAME , new JointPlans() ); @@ -62,7 +62,7 @@ public void testNGroupsNoJointPlansNoSocialNet() { } @Test - public void testNGroupsNoJointPlansCompleteSocialNet() { + void testNGroupsNoJointPlansCompleteSocialNet() { //LogManager.getLogger( DynamicGroupIdentifier.class ).setLevel( Level.TRACE ); final Scenario scenario = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); scenario.addScenarioElement( JointPlans.ELEMENT_NAME , new JointPlans() ); @@ -92,7 +92,7 @@ public void testNGroupsNoJointPlansCompleteSocialNet() { } @Test - public void testNGroupsWithJointPlansNoSocialNet() { + void testNGroupsWithJointPlansNoSocialNet() { //LogManager.getLogger( DynamicGroupIdentifier.class ).setLevel( Level.TRACE ); final Scenario scenario = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); @@ -139,7 +139,7 @@ public void testNGroupsWithJointPlansNoSocialNet() { } @Test - public void testNGroupsWithJointPlansCompleteSocialNet() { + void testNGroupsWithJointPlansCompleteSocialNet() { //LogManager.getLogger( DynamicGroupIdentifier.class ).setLevel( Level.TRACE ); final Scenario scenario = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java index 80a234c05fe..8e521b385ec 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java @@ -22,8 +22,8 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -50,7 +50,7 @@ public class FixedGroupsIT { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testIterationOrderIsDeterministic() throws Exception { + void testIterationOrderIsDeterministic() throws Exception { final String configFile = new File( utils.getPackageInputDirectory() ).getParentFile().getParentFile().getParentFile()+"/config.xml"; final Config config = JointScenarioUtils.loadConfig( configFile ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java index 56e8fd3cc30..3893c8cb2ba 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java @@ -31,7 +31,7 @@ import org.junit.After; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -86,7 +86,7 @@ public void clear() { } @Test - public void testGetters() throws Exception { + void testGetters() throws Exception { final List indivPlans = new ArrayList(); final List jointPlans = new ArrayList(); @@ -133,7 +133,7 @@ public void testGetters() throws Exception { } @Test - public void testCopyLooksValid() throws Exception { + void testCopyLooksValid() throws Exception { for (GroupPlans plans : testPlans) { GroupPlans copy = GroupPlans.copyPlans( factory , plans ); @@ -150,7 +150,7 @@ public void testCopyLooksValid() throws Exception { } @Test - public void testCopyIsNotSame() throws Exception { + void testCopyIsNotSame() throws Exception { for (GroupPlans plans : testPlans) { GroupPlans copy = GroupPlans.copyPlans( factory , plans ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/ActivitySequenceMutatorAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/ActivitySequenceMutatorAlgorithmTest.java index c7a84036acc..2b80b22c47e 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/ActivitySequenceMutatorAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/ActivitySequenceMutatorAlgorithmTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.socnetsim.framework.replanning.modules; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.Activity; @@ -37,7 +37,7 @@ */ public class ActivitySequenceMutatorAlgorithmTest { @Test - public void testTwoActivities() throws Exception { + void testTwoActivities() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("somebody", Person.class))); plan.addActivity( PopulationUtils.createActivityFromLinkId("h", Id.create( "h" , Link.class )) ); @@ -69,7 +69,7 @@ public void testTwoActivities() throws Exception { } @Test - public void testOneActivities() throws Exception { + void testOneActivities() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("somebody", Person.class))); plan.addActivity( PopulationUtils.createActivityFromLinkId("h", Id.create( "h" , Link.class )) ); @@ -95,7 +95,7 @@ public void testOneActivities() throws Exception { } @Test - public void testZeroActivities() throws Exception { + void testZeroActivities() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("somebody", Person.class))); plan.addActivity( PopulationUtils.createActivityFromLinkId("h", Id.create( "h" , Link.class )) ); @@ -115,7 +115,7 @@ public void testZeroActivities() throws Exception { } @Test - public void testStage() throws Exception { + void testStage() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("somebody", Person.class))); plan.addActivity( PopulationUtils.createActivityFromLinkId("h", Id.create( "h" , Link.class )) ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java index d03ca09ae4b..93de284d592 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java @@ -30,7 +30,7 @@ import org.junit.After; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -89,7 +89,7 @@ public void allJoints() { // tests // ///////////////////////////////////////////////////////////////////////// @Test - public void testProbOne() throws Exception { + void testProbOne() throws Exception { JointPlanMergingAlgorithm algo = new JointPlanMergingAlgorithm( jointPlans.getFactory(), @@ -116,7 +116,7 @@ public void testProbOne() throws Exception { } @Test - public void testProbZero() throws Exception { + void testProbZero() throws Exception { JointPlanMergingAlgorithm algo = new JointPlanMergingAlgorithm( jointPlans.getFactory(), diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/TourModeUnifierAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/TourModeUnifierAlgorithmTest.java index b32c958f6f6..d76f7cb58f8 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/TourModeUnifierAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/TourModeUnifierAlgorithmTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.*; @@ -45,7 +45,7 @@ public class TourModeUnifierAlgorithmTest { private static final Logger log = LogManager.getLogger( TourModeUnifierAlgorithmTest.class ); @Test - public void testPlanWithOneSingleTour() throws Exception { + void testPlanWithOneSingleTour() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("jojo", Person.class))); final Id anchorLink1 = Id.create( "anchor1" , Link.class ); @@ -138,7 +138,7 @@ public void testPlanWithOneSingleTour() throws Exception { } @Test - public void testPlanWithTwoToursOnOpenTour() throws Exception { + void testPlanWithTwoToursOnOpenTour() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("jojo", Person.class))); final Id entranceLink = Id.create( "entrance" , Link.class ); @@ -238,7 +238,7 @@ public void testPlanWithTwoToursOnOpenTour() throws Exception { } @Test - public void testPlanWithTwoHomeBasedTours() throws Exception { + void testPlanWithTwoHomeBasedTours() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("jojo", Person.class))); final Id anchorLink = Id.create( "anchor" , Link.class ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/removers/LexicographicRemoverTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/removers/LexicographicRemoverTest.java index 8a6ba4fbd90..84a31fab439 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/removers/LexicographicRemoverTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/removers/LexicographicRemoverTest.java @@ -24,7 +24,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -41,7 +41,7 @@ public class LexicographicRemoverTest { @Test - public void testOnlyIndividualPlans() { + void testOnlyIndividualPlans() { final Map, Plan> toRemove = new LinkedHashMap< >(); final ReplanningGroup group = new ReplanningGroup(); final JointPlans jointPlans = new JointPlans(); @@ -67,7 +67,7 @@ public void testOnlyIndividualPlans() { } @Test - public void testOnlyOneComposition() { + void testOnlyOneComposition() { final ReplanningGroup group = new ReplanningGroup(); for ( int i=0; i < 4; i++ ) { @@ -101,7 +101,7 @@ public void testOnlyOneComposition() { } @Test - public void testOneCompositionAndOneExcedentaryPlan() { + void testOneCompositionAndOneExcedentaryPlan() { final ReplanningGroup group = new ReplanningGroup(); for ( int i=0; i < 4; i++ ) { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java index 5bc566bb884..e541b2ac672 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.population.Plan; import org.matsim.core.utils.collections.Tuple; import org.matsim.core.utils.misc.Counter; @@ -48,19 +48,19 @@ public class FullExplorationVsCuttoffTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testFullExplorationVsCuttoffNonBlocking() throws Exception { + void testFullExplorationVsCuttoffNonBlocking() throws Exception { log.info( "test: testFullExplorationVsCuttoffNonBlocking()" ); testFullExplorationVsCuttoff( new EmptyIncompatiblePlansIdentifierFactory() , false ); } @Test - public void testFullExplorationVsCuttoffBlocking() throws Exception { + void testFullExplorationVsCuttoffBlocking() throws Exception { log.info( "test: testFullExplorationVsCuttoffBlocking()" ); testFullExplorationVsCuttoff( new EmptyIncompatiblePlansIdentifierFactory() , true ); } @Test - public void testFullExplorationVsCuttoffIncompatibility() throws Exception { + void testFullExplorationVsCuttoffIncompatibility() throws Exception { log.info( "test: testFullExplorationVsCuttoffIncompatibility()" ); testFullExplorationVsCuttoff( new FewGroupsIncompatibilityFactory(), @@ -68,7 +68,7 @@ public void testFullExplorationVsCuttoffIncompatibility() throws Exception { } @Test - public void testFullExplorationVsCuttoffIncompatibilityBlocking() throws Exception { + void testFullExplorationVsCuttoffIncompatibilityBlocking() throws Exception { log.info( "test: testFullExplorationVsCuttoffIncompatibilityBlocking()" ); testFullExplorationVsCuttoff( new FewGroupsIncompatibilityFactory(), diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java index c730ba9b0af..a1a9b606c00 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java @@ -33,7 +33,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Id; @@ -1233,17 +1233,17 @@ public void setupLogging() { // Tests // ///////////////////////////////////////////////////////////////////////// @Test - public void testSelectedPlansNonBlocking() throws Exception { + void testSelectedPlansNonBlocking() throws Exception { testSelectedPlans( false , false ); } @Test - public void testSelectedPlansForbidding() throws Exception { + void testSelectedPlansForbidding() throws Exception { testSelectedPlans( false , true ); } @Test - public void testSelectedPlansBlocking() throws Exception { + void testSelectedPlansBlocking() throws Exception { testSelectedPlans( true , false ); } @@ -1252,7 +1252,7 @@ public void testSelectedPlansBlocking() throws Exception { * particularly when pruning unplausible plans. */ @Test - public void testNoSideEffects() throws Exception { + void testNoSideEffects() throws Exception { HighestScoreSumSelector selector = new HighestScoreSumSelector( new EmptyIncompatiblePlansIdentifierFactory(), diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java index 185776cd819..13628424eaa 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java @@ -22,7 +22,10 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.*; +import org.junit.After; +import org.junit.Assert; +import org.junit.Before; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -382,7 +385,7 @@ public void createRandomFixtures() { } @Test - public void testDeterminism() throws Exception { + void testDeterminism() throws Exception { final int seed = 1264; final Counter count = new Counter( "selection # " ); @@ -412,7 +415,7 @@ public void testDeterminism() throws Exception { } @Test - public void testNoFailuresWithVariousSeeds() throws Exception { + void testNoFailuresWithVariousSeeds() throws Exception { final RandomGroupLevelSelector selector = new RandomGroupLevelSelector( new Random( 123 ), new EmptyIncompatiblePlansIdentifierFactory()); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java index cc1674f91c8..f9215f4ac9c 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java @@ -28,7 +28,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Id; @@ -215,7 +215,7 @@ private static Collection toArgList(final FixtureFactory... ar // Tests // ///////////////////////////////////////////////////////////////////////// @Test - public void testSelectedPlans() { + void testSelectedPlans() { final Fixture fixture = fixtureFactory.create(); final CoalitionSelector selector = new CoalitionSelector(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastAverageWeightJointPlanPruningConflictSolverTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastAverageWeightJointPlanPruningConflictSolverTest.java index 8d191571488..dc1a38d25bf 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastAverageWeightJointPlanPruningConflictSolverTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastAverageWeightJointPlanPruningConflictSolverTest.java @@ -23,7 +23,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -38,7 +38,7 @@ public class LeastAverageWeightJointPlanPruningConflictSolverTest { @Test - public void testPruneBiggestPlanWithHigherSum() { + void testPruneBiggestPlanWithHigherSum() { final JointPlans jointPlans = new JointPlans(); // two joint plans, biggest has a higher total weight, diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastPointedPlanPruningConflictSolverTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastPointedPlanPruningConflictSolverTest.java index 39c6c169dac..0626ebe295c 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastPointedPlanPruningConflictSolverTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastPointedPlanPruningConflictSolverTest.java @@ -22,8 +22,7 @@ import java.util.HashMap; import java.util.Map; import org.junit.Assert; -import org.junit.Test; - +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -38,7 +37,7 @@ public class LeastPointedPlanPruningConflictSolverTest { @Test - public void testPruneSmallestJointPlan() { + void testPruneSmallestJointPlan() { final JointPlans jointPlans = new JointPlans(); final Map, Plan> smallJp = new HashMap< >(); final Map, Plan> bigJp = new HashMap< >(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java index 5317fbb7542..fbbbfe0018c 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java @@ -34,7 +34,7 @@ import org.junit.Assert; import org.junit.Before; import org.junit.Ignore; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -55,7 +55,7 @@ public class WhoIsTheBossSelectorTest { @Test - public void testOnePlanSelectedForEachAgent() throws Exception { + void testOnePlanSelectedForEachAgent() throws Exception { final WhoIsTheBossSelector testee = new WhoIsTheBossSelector( new Random( 9087 ), @@ -120,8 +120,8 @@ private Set getGroupIds(final ReplanningGroup group) { } @Test - @Ignore( "TODO" ) - public void testBestPlanIsSelectedIfPossible() throws Exception { + @Ignore("TODO") + void testBestPlanIsSelectedIfPossible() throws Exception { throw new UnsupportedOperationException( "TODO" ); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java index 491b12a31a3..b653e3a7ec9 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -61,32 +61,32 @@ public class GroupCompositionPenalizerTest { private final double utilAlone = -1; @Test - public void testFullOverlap() { + void testFullOverlap() { test( new double[]{10 , 20} , new double[]{5 , 25} ); } @Test - public void testInnerOverlap() { + void testInnerOverlap() { test( new double[]{5 , 25} , new double[]{10 , 20} ); } @Test - public void testPartialOverlap() { + void testPartialOverlap() { test( new double[]{5 , 20 } , new double[]{10 , 25} ); } @Test - public void testExactOverlap() { + void testExactOverlap() { test( new double[]{10 , 20} , new double[]{10 , 20} ); } @Test - public void testComeAndGo() { + void testComeAndGo() { test( new double[]{10 , 11 , 15 , 20} , new double[]{10 , 20} ); } @Test - public void testInstantaneousComeAndGo() { + void testInstantaneousComeAndGo() { test( new double[]{10 , 15 , 15 , 20} , new double[]{5 , 20} ); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/RecomposeJointPlanAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/RecomposeJointPlanAlgorithmTest.java index ceb2f58628d..9551650254f 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/RecomposeJointPlanAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/RecomposeJointPlanAlgorithmTest.java @@ -32,7 +32,7 @@ import java.util.Random; import java.util.Set; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -257,22 +257,22 @@ public boolean areLinked(final Plan p1, final Plan p2) { } @Test - public void testIndividualPlans() throws Exception { + void testIndividualPlans() throws Exception { test( createRandomFixtureWithIndividualPlans( new Random( 1234 ) ) ); } @Test - public void testUniqueJointPlan() throws Exception { + void testUniqueJointPlan() throws Exception { test( createRandomFixtureWithOneBigJointPlan( new Random( 1234 ) ) ); } @Test - public void testJointAndIndividualPlans() throws Exception { + void testJointAndIndividualPlans() throws Exception { test( createRandomFixtureWithJointAndIndividualPlans( new Random( 1234 ) ) ); } @Test - public void testIncompleteLinks() throws Exception { + void testIncompleteLinks() throws Exception { test( createRandomFixtureWithIncompleteLinks( new Random( 1234 ) ) ); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/randomlocationchoice/RandomJointLocationChoiceTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/randomlocationchoice/RandomJointLocationChoiceTest.java index 1b807ae4e58..e6cab996be9 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/randomlocationchoice/RandomJointLocationChoiceTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/randomlocationchoice/RandomJointLocationChoiceTest.java @@ -25,7 +25,7 @@ import java.util.Random; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; @@ -48,7 +48,7 @@ public class RandomJointLocationChoiceTest { // tests of individual critical methods // ///////////////////////////////////////////////////////////////////////// @Test - public void testBarycenterCalculation() { + void testBarycenterCalculation() { final ActivityFacilities facilities = new ActivityFacilitiesImpl(); final List activities = new ArrayList(); @@ -108,7 +108,7 @@ private static void addActivityAndFacility( } @Test - public void testFacilityRetrieval() { + void testFacilityRetrieval() { final ActivityFacilities facilities = new ActivityFacilitiesImpl(); final List activities = new ArrayList(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java index 78a1d811e63..5943c16f8f6 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java @@ -22,7 +22,7 @@ import org.junit.After; import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -802,7 +802,7 @@ public void initOnePassengerTwoTripsInconsistentSequenceFixture() { } @Test - public void testExtractJointTrips() throws Exception { + void testExtractJointTrips() throws Exception { for ( Fixture f : fixtures ) { JointTravelStructure struct = JointTravelUtils.analyseJointTravel(f.plan); @@ -816,7 +816,7 @@ public void testExtractJointTrips() throws Exception { } @Test - public void testParseDriverTrips() throws Exception { + void testParseDriverTrips() throws Exception { for ( Fixture f : fixtures ) { List trips = JointTravelUtils.parseDriverTrips(f.plan); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java index 9a86bd3f1bb..395e7cce92b 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java @@ -23,8 +23,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -110,7 +110,7 @@ private static enum RouteType { private static final String DESTINATION_ACT = "stress"; @Test - public void testAgentsArriveTogetherWithoutDummies() throws Exception { + void testAgentsArriveTogetherWithoutDummies() throws Exception { testAgentsArriveTogether( createFixture( false, @@ -118,7 +118,7 @@ public void testAgentsArriveTogetherWithoutDummies() throws Exception { } @Test - public void testAgentsArriveTogetherWithDummies() throws Exception { + void testAgentsArriveTogetherWithDummies() throws Exception { testAgentsArriveTogether( createFixture( true, @@ -126,7 +126,7 @@ public void testAgentsArriveTogetherWithDummies() throws Exception { } @Test - public void testAgentsArriveTogetherWithDummiesAndDoAtPu() throws Exception { + void testAgentsArriveTogetherWithDummiesAndDoAtPu() throws Exception { testAgentsArriveTogether( createFixture( true, @@ -134,7 +134,7 @@ public void testAgentsArriveTogetherWithDummiesAndDoAtPu() throws Exception { } @Test - public void testAgentsArriveTogetherWithoutDummiesAndDoAtPu() throws Exception { + void testAgentsArriveTogetherWithoutDummiesAndDoAtPu() throws Exception { testAgentsArriveTogether( createFixture( false, @@ -142,7 +142,7 @@ public void testAgentsArriveTogetherWithoutDummiesAndDoAtPu() throws Exception { } @Test - public void testAgentsArriveTogetherWithDummiesAndDoAtPuFullCycle() throws Exception { + void testAgentsArriveTogetherWithDummiesAndDoAtPuFullCycle() throws Exception { testAgentsArriveTogether( createFixture( true, @@ -150,7 +150,7 @@ public void testAgentsArriveTogetherWithDummiesAndDoAtPuFullCycle() throws Excep } @Test - public void testAgentsArriveTogetherWithoutDummiesAndDoAtPuFullCycle() throws Exception { + void testAgentsArriveTogetherWithoutDummiesAndDoAtPuFullCycle() throws Exception { testAgentsArriveTogether( createFixture( false, @@ -158,7 +158,7 @@ public void testAgentsArriveTogetherWithoutDummiesAndDoAtPuFullCycle() throws Ex } @Test - public void testAgentsArriveTogetherWithDummiesAndEverythingAtOrigin() throws Exception { + void testAgentsArriveTogetherWithDummiesAndEverythingAtOrigin() throws Exception { testAgentsArriveTogether( createFixture( true, @@ -166,7 +166,7 @@ public void testAgentsArriveTogetherWithDummiesAndEverythingAtOrigin() throws Ex } @Test - public void testAgentsArriveTogetherWithoutDummiesAndEverythingAtOrigin() throws Exception { + void testAgentsArriveTogetherWithoutDummiesAndEverythingAtOrigin() throws Exception { testAgentsArriveTogether( createFixture( false, @@ -276,22 +276,22 @@ private static void logFinalQSimState(final QSim qsim) { } @Test - public void testNumberOfEnterLeaveVehicle() { + void testNumberOfEnterLeaveVehicle() { testNumberOfEnterLeaveVehicle( RouteType.normal ); } @Test - public void testNumberOfEnterLeaveVehicleEverythingAtOrigin() { + void testNumberOfEnterLeaveVehicleEverythingAtOrigin() { testNumberOfEnterLeaveVehicle( RouteType.everythingAtOrigin ); } @Test - public void testNumberOfEnterLeaveVehiclePuAtDo() { + void testNumberOfEnterLeaveVehiclePuAtDo() { testNumberOfEnterLeaveVehicle( RouteType.puAtDo ); } @Test - public void testNumberOfEnterLeaveVehiclePuAtDoFullCycle() { + void testNumberOfEnterLeaveVehiclePuAtDoFullCycle() { testNumberOfEnterLeaveVehicle( RouteType.puAtDoFullCycle ); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java index 6da1f83b85e..9e55848cf9a 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -66,7 +66,7 @@ public void init() { } @Test - public void testRemoverIgnorance() throws Exception { + void testRemoverIgnorance() throws Exception { final JointTripRemoverAlgorithm algo = new JointTripRemoverAlgorithm( random , new MainModeIdentifierImpl() ); JointPlan jointPlan = createPlanWithJointTrips(); @@ -78,7 +78,7 @@ public void testRemoverIgnorance() throws Exception { } @Test - public void testInsertorIgnorance() throws Exception { + void testInsertorIgnorance() throws Exception { final JointTripInsertorAlgorithm algo = new JointTripInsertorAlgorithm( random, diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java index 01d9e49d7d9..01b85aa8a57 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java @@ -30,7 +30,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -71,7 +71,7 @@ public void init() { } @Test - public void testNonIterativeRemoval() throws Exception { + void testNonIterativeRemoval() throws Exception { JointTripInsertorAndRemoverAlgorithm algo = new JointTripInsertorAndRemoverAlgorithm( ScenarioUtils.createScenario( config ), @@ -114,7 +114,7 @@ public void testNonIterativeRemoval() throws Exception { } @Test - public void testIterativeRemoval() throws Exception { + void testIterativeRemoval() throws Exception { JointTripInsertorAndRemoverAlgorithm algo = new JointTripInsertorAndRemoverAlgorithm( ScenarioUtils.createScenario( config ), @@ -157,7 +157,7 @@ public void testIterativeRemoval() throws Exception { } @Test - public void testNonIterativeInsertion() throws Exception { + void testNonIterativeInsertion() throws Exception { JointTripInsertorAndRemoverAlgorithm algo = new JointTripInsertorAndRemoverAlgorithm( ScenarioUtils.createScenario( config ), @@ -216,7 +216,7 @@ public void testNonIterativeInsertion() throws Exception { } @Test - public void testIterativeInsertion() throws Exception { + void testIterativeInsertion() throws Exception { JointTripInsertorAndRemoverAlgorithm algo = new JointTripInsertorAndRemoverAlgorithm( ScenarioUtils.createScenario( config ), diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripInsertionWithSocialNetworkTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripInsertionWithSocialNetworkTest.java index 68ade2ea095..45ece5211d0 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripInsertionWithSocialNetworkTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripInsertionWithSocialNetworkTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -58,7 +58,7 @@ public class JointTripInsertionWithSocialNetworkTest { LogManager.getLogger(JointTripInsertionWithSocialNetworkTest.class); @Test - public void testJointTripsGeneratedOnlyAlongSocialTies() { + void testJointTripsGeneratedOnlyAlongSocialTies() { final Random random = new Random( 123 ); for ( int i=0; i < 10; i++ ) { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java index ef8dc3e6d50..bc43d9c3a50 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java @@ -36,7 +36,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -935,7 +935,7 @@ private Fixture createTwoDriversFixture(final boolean removeFirst) { // tests // ///////////////////////////////////////////////////////////////////////// @Test - public void testRemoval() throws Exception { + void testRemoval() throws Exception { // TODO: test driver and passenger removal separately for ( Fixture f : fixtures ) { log.info( "testing removal on fixture "+f.name ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java index 7904a3c5473..acce4c6faef 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java @@ -27,7 +27,7 @@ import org.junit.After; import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -321,7 +321,7 @@ public Fixture build() { // tests // ///////////////////////////////////////////////////////////////////////// @Test - public void testDepartureTimes() throws Exception { + void testDepartureTimes() throws Exception { final SynchronizeCoTravelerPlansAlgorithm testee = new SynchronizeCoTravelerPlansAlgorithm(TimeInterpretation.create(ConfigUtils.createConfig())); for ( Fixture fixture : fixtures ) { testee.run( fixture.jointPlan ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointPlanRouterTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointPlanRouterTest.java index 2107c271413..28203a5ed4a 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointPlanRouterTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointPlanRouterTest.java @@ -25,7 +25,7 @@ import java.util.Collection; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -56,7 +56,7 @@ */ public class JointPlanRouterTest { @Test - public void testDriverIdIsKept() throws Exception { + void testDriverIdIsKept() throws Exception { final Config config = ConfigUtils.createConfig(); final PopulationFactory populationFactory = ScenarioUtils.createScenario( @@ -111,7 +111,7 @@ public void testDriverIdIsKept() throws Exception { } @Test - public void testPassengerIdIsKept() throws Exception { + void testPassengerIdIsKept() throws Exception { final Config config = ConfigUtils.createConfig(); final PopulationFactory populationFactory = ScenarioUtils.createScenario( diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java index 440691922b9..dbad52eb7e5 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -202,7 +202,7 @@ public void install() { } @Test - public void testPassengerRoute() throws Exception { + void testPassengerRoute() throws Exception { final PlanAlgorithm planRouter = new JointPlanRouterFactory( (ActivityFacilities) null, TimeInterpretation.create(ConfigUtils.createConfig()) ).createPlanRoutingAlgorithm( factory.get() ); @@ -239,7 +239,7 @@ public void testPassengerRoute() throws Exception { } @Test - public void testDriverRoute() throws Exception { + void testDriverRoute() throws Exception { final PlanAlgorithm planRouter = new JointPlanRouterFactory( (ActivityFacilities) null, TimeInterpretation.create(ConfigUtils.createConfig()) ).createPlanRoutingAlgorithm( factory.get() ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/HouseholdBasedVehicleRessourcesTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/HouseholdBasedVehicleRessourcesTest.java index 9e5facbac6b..eaf2b1b5e08 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/HouseholdBasedVehicleRessourcesTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/HouseholdBasedVehicleRessourcesTest.java @@ -26,7 +26,7 @@ import java.util.HashSet; import java.util.Set; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.households.Household; @@ -41,7 +41,7 @@ public class HouseholdBasedVehicleRessourcesTest { @Test - public void testVehiclesIdsAreCorrect() throws Exception { + void testVehiclesIdsAreCorrect() throws Exception { final Households households = createHouseholds(); final VehicleRessources testee = new HouseholdBasedVehicleRessources( households ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/PlanRouterWithVehicleRessourcesTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/PlanRouterWithVehicleRessourcesTest.java index 28c317816cc..a05a6cf60eb 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/PlanRouterWithVehicleRessourcesTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/PlanRouterWithVehicleRessourcesTest.java @@ -25,7 +25,7 @@ import java.util.Collections; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -56,7 +56,7 @@ public class PlanRouterWithVehicleRessourcesTest { @Test - public void testVehicleIdsAreKeptIfSomething() throws Exception { + void testVehicleIdsAreKeptIfSomething() throws Exception { final Config config = ConfigUtils.createConfig(); final PopulationFactory factory = ScenarioUtils.createScenario(config).getPopulation().getFactory(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/qsim/PopulationAgentSourceWithVehiclesTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/qsim/PopulationAgentSourceWithVehiclesTest.java index f563bfb185c..dad937c6e08 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/qsim/PopulationAgentSourceWithVehiclesTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/qsim/PopulationAgentSourceWithVehiclesTest.java @@ -24,7 +24,7 @@ import java.util.Collections; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -55,7 +55,7 @@ public class PopulationAgentSourceWithVehiclesTest { //TODO: test that vehicles added where they should be @Test - public void testFailsIfOnlySomeRoutesHaveAVehicle() throws Exception { + void testFailsIfOnlySomeRoutesHaveAVehicle() throws Exception { final Config config = ConfigUtils.createConfig(); final Scenario scenario = ScenarioUtils.createScenario( config ); @@ -123,12 +123,12 @@ public void testFailsIfOnlySomeRoutesHaveAVehicle() throws Exception { } @Test - public void testNoFailIfAllHaveVehicles() throws Exception { + void testNoFailIfAllHaveVehicles() throws Exception { testNoFail( true ); } @Test - public void testNoFailIfNoneHaveVehicles() throws Exception { + void testNoFailIfNoneHaveVehicles() throws Exception { testNoFail( false ); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java index c91632f15f7..37f66567b28 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java @@ -32,7 +32,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Leg; @@ -119,7 +119,7 @@ private GroupPlans createTestPlan() { } @Test - public void testEnoughVehiclesForEverybody() { + void testEnoughVehiclesForEverybody() { // tests that one vehicle is allocated to each one if possible final Random random = new Random( 1234 ); @@ -147,7 +147,7 @@ public void testEnoughVehiclesForEverybody() { } @Test - public void testOneVehiclePerTwoPersons() { + void testOneVehiclePerTwoPersons() { // tests that the allocation minimizes overlaps final Random random = new Random( 1234 ); @@ -181,7 +181,7 @@ public void testOneVehiclePerTwoPersons() { } @Test - public void testRandomness() { + void testRandomness() { final Random random = new Random( 1234 ); final Map allocations = new HashMap(); @@ -222,7 +222,7 @@ else if ( !oldV.equals( v ) ) { } @Test - public void testDeterminism() { + void testDeterminism() { final Map allocations = new HashMap(); final Set agentsWithSeveralVehicles = new HashSet(); for ( int i = 0; i < 50 ; i++ ) { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java index 4db1b102a6f..a5b3a7367bc 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java @@ -28,7 +28,7 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.Activity; @@ -102,13 +102,13 @@ private void fillPlan( } @Test - @Ignore( "TODO" ) - public void testVehiclesAreAllocatedAtTheTourLevel() throws Exception { + @Ignore("TODO") + void testVehiclesAreAllocatedAtTheTourLevel() throws Exception { throw new UnsupportedOperationException( "TODO" ); } @Test - public void testCannotFindBetterAllocationRandomly() throws Exception { + void testCannotFindBetterAllocationRandomly() throws Exception { Set stages = new HashSet<>();// formerly EmptyStageActivityTypes.INSTANCE; for ( int i = 0; i < 5; i++ ) { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java index 47ed3d7ce2a..203bec54de6 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java @@ -30,7 +30,7 @@ import java.util.List; import java.util.Map; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -56,7 +56,7 @@ public class GroupPlanStrategyTest { private static final int N_INITIALLY_INDIV_PLANS = 8; @Test - public void testNewPlanIsSelected() throws Exception { + void testNewPlanIsSelected() throws Exception { final JointPlans jointPlans = new JointPlans(); final GroupPlanStrategy strategy = new GroupPlanStrategy( new HighestScoreSumSelector( @@ -88,7 +88,7 @@ public void testNewPlanIsSelected() throws Exception { } @Test - public void testNumberOfPlans() throws Exception { + void testNumberOfPlans() throws Exception { final JointPlans jointPlans = new JointPlans(); final GroupPlanStrategy strategy = new GroupPlanStrategy( new HighestScoreSumSelector( @@ -106,7 +106,7 @@ public void testNumberOfPlans() throws Exception { } @Test - public void testNumberOfSelectedJointPlans() throws Exception { + void testNumberOfSelectedJointPlans() throws Exception { final JointPlans jointPlans = new JointPlans(); final GroupPlanStrategy strategy = new GroupPlanStrategy( new HighestScoreSumSelector( @@ -140,7 +140,7 @@ public void testNumberOfSelectedJointPlans() throws Exception { } @Test - public void testNumberOfNonSelectedJointPlans() throws Exception { + void testNumberOfNonSelectedJointPlans() throws Exception { final JointPlans jointPlans = new JointPlans(); final GroupPlanStrategy strategy = new GroupPlanStrategy( new HighestScoreSumSelector( diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/JoinableActivitiesPlanLinkIdentifierTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/JoinableActivitiesPlanLinkIdentifierTest.java index fc58468165b..67e5fe79763 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/JoinableActivitiesPlanLinkIdentifierTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/JoinableActivitiesPlanLinkIdentifierTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.socnetsim.usage.replanning; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.Activity; @@ -44,7 +44,7 @@ public class JoinableActivitiesPlanLinkIdentifierTest { ConfigUtils.createConfig() ).getPopulation().getFactory(); @Test - public void testOpenPlansSamePlaceSameType() { + void testOpenPlansSamePlaceSameType() { final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class); @@ -58,7 +58,7 @@ public void testOpenPlansSamePlaceSameType() { } @Test - public void testOpenPlansSamePlaceDifferentType() { + void testOpenPlansSamePlaceDifferentType() { final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class ); @@ -76,7 +76,7 @@ public void testOpenPlansSamePlaceDifferentType() { } @Test - public void testOpenPlansDifferentPlaceSameType() { + void testOpenPlansDifferentPlaceSameType() { final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class ); final Id facility2 = Id.create( "fa2" , ActivityFacility.class ); @@ -95,7 +95,7 @@ public void testOpenPlansDifferentPlaceSameType() { } @Test - public void testOpenPlansSamePlaceSameWrongType() { + void testOpenPlansSamePlaceSameWrongType() { final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class); @@ -127,7 +127,7 @@ private static Plan createOpenPlan( } @Test - public void testSingleTourOverlaping() { + void testSingleTourOverlaping() { final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class); @@ -158,7 +158,7 @@ public void testSingleTourOverlaping() { } @Test - public void testSingleTourPlansNonOverlaping() { + void testSingleTourPlansNonOverlaping() { //LogManager.getLogger( JoinableActivitiesPlanLinkIdentifier.class ).setLevel( Level.TRACE ); final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class ); @@ -190,7 +190,7 @@ public void testSingleTourPlansNonOverlaping() { } @Test - public void testSingleTourPlansZeroDurationAct() { + void testSingleTourPlansZeroDurationAct() { //LogManager.getLogger( JoinableActivitiesPlanLinkIdentifier.class ).setLevel( Level.TRACE ); final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class); @@ -222,7 +222,7 @@ public void testSingleTourPlansZeroDurationAct() { } @Test - public void testSingleTourPlansZeroDurationBegin() { + void testSingleTourPlansZeroDurationBegin() { //LogManager.getLogger( JoinableActivitiesPlanLinkIdentifier.class ).setLevel( Level.TRACE ); final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class); @@ -254,7 +254,7 @@ public void testSingleTourPlansZeroDurationBegin() { } @Test - public void testSingleTourPlansZeroDurationEnd() { + void testSingleTourPlansZeroDurationEnd() { //LogManager.getLogger( JoinableActivitiesPlanLinkIdentifier.class ).setLevel( Level.TRACE ); final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class ); @@ -286,7 +286,7 @@ public void testSingleTourPlansZeroDurationEnd() { } @Test - public void testDoubleTourPlansZeroDurationEnd() { + void testDoubleTourPlansZeroDurationEnd() { //LogManager.getLogger( JoinableActivitiesPlanLinkIdentifier.class ).setLevel( Level.TRACE ); final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class ); @@ -323,7 +323,7 @@ public void testDoubleTourPlansZeroDurationEnd() { } @Test - public void testSingleTourPlansInconsistentDurationAct() { + void testSingleTourPlansInconsistentDurationAct() { //LogManager.getLogger( JoinableActivitiesPlanLinkIdentifier.class ).setLevel( Level.TRACE ); final String type = "type"; final Id facility = Id.create( "fac" , ActivityFacility.class ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/VehicularPlanLinkIdentifierTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/VehicularPlanLinkIdentifierTest.java index 60ac4a28f42..9cdb9bd5e83 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/VehicularPlanLinkIdentifierTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/VehicularPlanLinkIdentifierTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.socnetsim.usage.replanning; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Leg; @@ -42,7 +42,7 @@ */ public class VehicularPlanLinkIdentifierTest { @Test - public void testNotLinkedWhenNoVehicleDefined() { + void testNotLinkedWhenNoVehicleDefined() { final Plan plan1 = createVehicularPlan( Id.create( 1 , Person.class ) , null ); final Plan plan2 = createVehicularPlan( Id.create( 2 , Person.class ) , null ); @@ -54,7 +54,7 @@ public void testNotLinkedWhenNoVehicleDefined() { } @Test - public void testDifferentVehiclesAreNotLinked() { + void testDifferentVehiclesAreNotLinked() { final Plan plan1 = createVehicularPlan( Id.create( 1 , Person.class ) , Id.create( 1 , Vehicle.class ) ); final Plan plan2 = createVehicularPlan( Id.create( 2 , Person.class ) , Id.create( 2 , Vehicle.class ) ); @@ -65,7 +65,7 @@ public void testDifferentVehiclesAreNotLinked() { } @Test - public void testSameVehiclesAreLinked() { + void testSameVehiclesAreLinked() { final Plan plan1 = createVehicularPlan( Id.create( 1 , Person.class ) , Id.create( "car" , Vehicle.class ) ); final Plan plan2 = createVehicularPlan( Id.create( 2 , Person.class ) , Id.create( "car" , Vehicle.class ) ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java index ceeca695ac9..96cd50a3de0 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java @@ -23,8 +23,8 @@ import java.util.Collection; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -51,7 +51,7 @@ public class JointScenarioUtilsTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testJointTripsImport() throws Exception { + void testJointTripsImport() throws Exception { final Population dumpedPopulation = createPopulation(); final String popFile = utils.getOutputDirectory()+"/pop.xml"; diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/ObjectPoolTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/ObjectPoolTest.java index 511d1721315..22dcdc2bd7e 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/ObjectPoolTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/ObjectPoolTest.java @@ -19,16 +19,16 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.utils; -import org.junit.Test; - import static org.junit.Assert.*; +import org.junit.jupiter.api.Test; + /** * @author thibautd */ public class ObjectPoolTest { @Test - public void testInstanceIsPooled() throws Exception { + void testInstanceIsPooled() throws Exception { final ObjectPool pool = new ObjectPool(); final String instance1 = new String( "jojo" ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/QuadTreeRebuilderTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/QuadTreeRebuilderTest.java index b9c5001cc89..f8f8da6d46c 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/QuadTreeRebuilderTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/QuadTreeRebuilderTest.java @@ -1,13 +1,13 @@ package org.matsim.contrib.socnetsim.utils; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.collections.QuadTree; public class QuadTreeRebuilderTest { @Test - public void testGrowingQuadTree() { + void testGrowingQuadTree() { final QuadTreeRebuilder rebuilder = new QuadTreeRebuilder<>(); Assert.assertEquals( diff --git a/contribs/sumo/src/test/java/org/matsim/contrib/sumo/SumoNetworkConverterTest.java b/contribs/sumo/src/test/java/org/matsim/contrib/sumo/SumoNetworkConverterTest.java index 05af1565cae..2738f2927b7 100644 --- a/contribs/sumo/src/test/java/org/matsim/contrib/sumo/SumoNetworkConverterTest.java +++ b/contribs/sumo/src/test/java/org/matsim/contrib/sumo/SumoNetworkConverterTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.sumo; import com.google.common.io.Resources; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -22,8 +22,8 @@ public class SumoNetworkConverterTest { - @Test - public void convert() throws Exception { + @Test + void convert() throws Exception { Path input = Files.createTempFile("sumo", ".xml"); Path output = Files.createTempFile("matsim", ".xml"); diff --git a/contribs/sumo/src/test/java/org/matsim/contrib/sumo/SumoNetworkHandlerTest.java b/contribs/sumo/src/test/java/org/matsim/contrib/sumo/SumoNetworkHandlerTest.java index 9f1a81ce7bd..170d248e00f 100644 --- a/contribs/sumo/src/test/java/org/matsim/contrib/sumo/SumoNetworkHandlerTest.java +++ b/contribs/sumo/src/test/java/org/matsim/contrib/sumo/SumoNetworkHandlerTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.sumo; import com.google.common.io.Resources; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.io.File; import java.net.URL; @@ -9,8 +9,8 @@ public class SumoNetworkHandlerTest { - @Test - public void read() throws Exception { + @Test + void read() throws Exception { URL resource = Resources.getResource("osm.net.xml"); diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiBenchmarkTest.java b/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiBenchmarkTest.java index 364bbb5a39a..71591180d86 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiBenchmarkTest.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiBenchmarkTest.java @@ -22,8 +22,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; @@ -38,7 +38,7 @@ public class RunETaxiBenchmarkTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testRuleBased() { + void testRuleBased() { String configPath = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "one_etaxi_benchmark_config.xml").toString(); String[] args = { configPath, "--config:controler.outputDirectory", utils.getOutputDirectory() }; // the config file suppresses most writing of output. Presumably, since it is to be run as a benchmark. One can override it here, but it is again overwritten later. So diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java index 218ca340f49..12572b18dcc 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java @@ -19,8 +19,8 @@ package org.matsim.contrib.etaxi.run; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; @@ -39,19 +39,19 @@ public class RunETaxiScenarioIT { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testOneTaxi() { + void testOneTaxi() { String configPath = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "one_etaxi_config.xml").toString(); runScenario(configPath); } @Test - public void testRuleBased() { + void testRuleBased() { String configPath = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_etaxi_config.xml").toString(); runScenario(configPath); } @Test - public void testAssignment() { + void testAssignment() { String configPath = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_etaxi_config.xml").toString(); runScenario(configPath); } diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/benchmark/RunTaxiBenchmarkTest.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/benchmark/RunTaxiBenchmarkTest.java index 0c2b1047bcd..ea8934332dc 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/benchmark/RunTaxiBenchmarkTest.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/benchmark/RunTaxiBenchmarkTest.java @@ -21,13 +21,13 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; public class RunTaxiBenchmarkTest { @Test - public void testRunOneTaxi() { + void testRunOneTaxi() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "one_taxi_benchmark_config.xml"); RunTaxiBenchmark.run(configUrl, 3); } diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/assignment/AssignmentTaxiOptimizerIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/assignment/AssignmentTaxiOptimizerIT.java index baae47ffdb2..71970ec6316 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/assignment/AssignmentTaxiOptimizerIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/assignment/AssignmentTaxiOptimizerIT.java @@ -21,8 +21,8 @@ import static org.matsim.contrib.taxi.optimizer.TaxiOptimizerTests.runBenchmark; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.taxi.optimizer.assignment.TaxiToRequestAssignmentCostProvider.Mode; import org.matsim.testcases.MatsimTestUtils; @@ -31,7 +31,7 @@ public class AssignmentTaxiOptimizerIT { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testAssignment_arrivalTime() { + void testAssignment_arrivalTime() { AssignmentTaxiOptimizerParams params = new AssignmentTaxiOptimizerParams(); params.mode = Mode.ARRIVAL_TIME; params.vehPlanningHorizonOversupply = 99999; @@ -42,7 +42,7 @@ public void testAssignment_arrivalTime() { } @Test - public void testAssignment_pickupTime() { + void testAssignment_pickupTime() { AssignmentTaxiOptimizerParams params = new AssignmentTaxiOptimizerParams(); params.mode = Mode.PICKUP_TIME; params.vehPlanningHorizonOversupply = 120; @@ -54,7 +54,7 @@ public void testAssignment_pickupTime() { } @Test - public void testAssignment_dse() { + void testAssignment_dse() { AssignmentTaxiOptimizerParams params = new AssignmentTaxiOptimizerParams(); params.mode = Mode.DSE; params.vehPlanningHorizonOversupply = 120; @@ -66,7 +66,7 @@ public void testAssignment_dse() { } @Test - public void testAssignment_totalWaitTime() { + void testAssignment_totalWaitTime() { AssignmentTaxiOptimizerParams params = new AssignmentTaxiOptimizerParams(); params.mode = Mode.TOTAL_WAIT_TIME; params.vehPlanningHorizonOversupply = 120; diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/fifo/FifoTaxiOptimizerIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/fifo/FifoTaxiOptimizerIT.java index 3e4b0ebefdf..14070c159db 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/fifo/FifoTaxiOptimizerIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/fifo/FifoTaxiOptimizerIT.java @@ -21,8 +21,8 @@ import static org.matsim.contrib.taxi.optimizer.TaxiOptimizerTests.runBenchmark; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class FifoTaxiOptimizerIT { @@ -30,7 +30,7 @@ public class FifoTaxiOptimizerIT { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testFifo() { + void testFifo() { runBenchmark(true, new FifoTaxiOptimizerParams(), utils); } } diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/rules/RuleBasedTaxiOptimizerIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/rules/RuleBasedTaxiOptimizerIT.java index 2d58410b364..f70fc0d0d97 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/rules/RuleBasedTaxiOptimizerIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/rules/RuleBasedTaxiOptimizerIT.java @@ -21,8 +21,8 @@ import static org.matsim.contrib.taxi.optimizer.TaxiOptimizerTests.runBenchmark; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.taxi.optimizer.rules.RuleBasedRequestInserter.Goal; import org.matsim.testcases.MatsimTestUtils; @@ -31,7 +31,7 @@ public class RuleBasedTaxiOptimizerIT { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testRuleBased_dse() { + void testRuleBased_dse() { RuleBasedTaxiOptimizerParams params = new RuleBasedTaxiOptimizerParams(); params.goal = Goal.DEMAND_SUPPLY_EQUIL; params.nearestRequestsLimit = 99999; @@ -41,7 +41,7 @@ public void testRuleBased_dse() { } @Test - public void testRuleBased_minWaitTime() { + void testRuleBased_minWaitTime() { RuleBasedTaxiOptimizerParams params = new RuleBasedTaxiOptimizerParams(); params.goal = Goal.MIN_WAIT_TIME; params.nearestRequestsLimit = 10; @@ -51,7 +51,7 @@ public void testRuleBased_minWaitTime() { } @Test - public void testRuleBased_minPickupTime() { + void testRuleBased_minPickupTime() { RuleBasedTaxiOptimizerParams params = new RuleBasedTaxiOptimizerParams(); params.goal = Goal.MIN_PICKUP_TIME; params.nearestRequestsLimit = 1; diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/zonal/ZonalTaxiOptimizerIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/zonal/ZonalTaxiOptimizerIT.java index 370a7f37e3a..575f26a4603 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/zonal/ZonalTaxiOptimizerIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/zonal/ZonalTaxiOptimizerIT.java @@ -22,8 +22,8 @@ import static org.matsim.contrib.taxi.optimizer.TaxiOptimizerTests.runBenchmark; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.taxi.optimizer.rules.RuleBasedRequestInserter.Goal; import org.matsim.contrib.taxi.optimizer.rules.RuleBasedTaxiOptimizerParams; import org.matsim.contrib.zone.ZonalSystemParams; @@ -34,7 +34,7 @@ public class ZonalTaxiOptimizerIT { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testZonal_dse() { + void testZonal_dse() { RuleBasedTaxiOptimizerParams rbParams = new RuleBasedTaxiOptimizerParams(); rbParams.goal = Goal.DEMAND_SUPPLY_EQUIL; rbParams.nearestRequestsLimit = 99999; @@ -54,7 +54,7 @@ public void testZonal_dse() { } @Test - public void testZonal_minWaitTime() { + void testZonal_minWaitTime() { RuleBasedTaxiOptimizerParams rbParams = new RuleBasedTaxiOptimizerParams(); rbParams.goal = Goal.MIN_WAIT_TIME; rbParams.nearestRequestsLimit = 10; diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTest.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTest.java index ceb59015f11..4d0e7cbcaf3 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTest.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTest.java @@ -21,13 +21,13 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; public class RunTaxiScenarioTest { @Test - public void testRunOneTaxi() { + void testRunOneTaxi() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "one_taxi_config.xml"); RunTaxiScenario.run(configUrl, false); } diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTestIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTestIT.java index 714104455e7..00906216e35 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTestIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/RunTaxiScenarioTestIT.java @@ -21,8 +21,8 @@ import java.net.URL; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.contrib.dvrp.run.DvrpConfigGroup; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -36,12 +36,12 @@ public class RunTaxiScenarioTestIT { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testRunMielecLowDemandLowSupply() { + void testRunMielecLowDemandLowSupply() { runMielec("plans_taxi_1.0.xml.gz", "taxis-25.xml"); } @Test - public void testRunMielecHighDemandLowSupply() { + void testRunMielecHighDemandLowSupply() { runMielec("plans_taxi_4.0.xml.gz", "taxis-25.xml"); } diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/examples/RunMultiModeTaxiExampleTestIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/examples/RunMultiModeTaxiExampleTestIT.java index e685a9c25c8..c450c0290a4 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/examples/RunMultiModeTaxiExampleTestIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/examples/RunMultiModeTaxiExampleTestIT.java @@ -22,13 +22,13 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; public class RunMultiModeTaxiExampleTestIT { @Test - public void testRun() { + void testRun() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "multi_mode_one_taxi_config.xml"); RunMultiModeTaxiExample.run(configUrl, false, 1); } diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/examples/RunTaxiExampleTestIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/examples/RunTaxiExampleTestIT.java index 9b18d237fcf..7e4b7bdb416 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/examples/RunTaxiExampleTestIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/run/examples/RunTaxiExampleTestIT.java @@ -21,13 +21,13 @@ import java.net.URL; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; public class RunTaxiExampleTestIT { @Test - public void testRun() { + void testRun() { URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("mielec"), "mielec_taxi_config.xml"); RunTaxiExample.run(configUrl, false, 0); } diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/TaxiEventsReadersTest.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/TaxiEventsReadersTest.java index eba9e7a1c4b..0840511996e 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/TaxiEventsReadersTest.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/TaxiEventsReadersTest.java @@ -27,7 +27,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; import org.matsim.api.core.v01.network.Link; @@ -71,7 +71,7 @@ public class TaxiEventsReadersTest { ); @Test - public void testReader() { + void testReader() { var outputStream = new ByteArrayOutputStream(); EventWriterXML writer = new EventWriterXML(outputStream); taxiEvents.forEach(writer::handleEvent); diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/stats/DurationStatsTest.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/stats/DurationStatsTest.java index 0c80e3f5f6c..afea968c590 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/stats/DurationStatsTest.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/stats/DurationStatsTest.java @@ -28,7 +28,7 @@ import java.util.SortedMap; import java.util.stream.Stream; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.contrib.taxi.util.stats.DurationStats.State; /** @@ -36,20 +36,20 @@ */ public class DurationStatsTest { @Test - public void totalStateDurationByTimeBinAndType_empty() { + void totalStateDurationByTimeBinAndType_empty() { SortedMap> durations = stateDurationByTimeBinAndState(Stream.of(), 100); assertThat(durations).isEmpty(); } @Test - public void totalStateDurationByTimeBinAndType_oneType_manyBins() { + void totalStateDurationByTimeBinAndType_oneType_manyBins() { SortedMap> durations = stateDurationByTimeBinAndState( Stream.of(sample(0, "A", 10, 300), sample(1, "A", 10, 300), sample(2, "A", 10, 300)), 100); assertThat(durations).containsExactly(entry(0, Map.of("A", 90.)), entry(1, Map.of("A", 100.)), entry(2, Map.of("A", 100.))); } @Test - public void totalStateDurationByTimeBinAndType_manyTypes_oneBin() { + void totalStateDurationByTimeBinAndType_manyTypes_oneBin() { SortedMap> durations = stateDurationByTimeBinAndState( Stream.of(sample(1, "A", 10, 300), sample(1, "B", 150, 300), sample(1, "C", 100, 120)), 100); assertThat(durations).containsExactly(entry(1, Map.of("A", 100., "B", 50., "C", 20.))); diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/stats/TimeBinSamplesTest.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/stats/TimeBinSamplesTest.java index b297b59fb90..6a97a94d2aa 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/stats/TimeBinSamplesTest.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/util/stats/TimeBinSamplesTest.java @@ -23,7 +23,7 @@ import static org.assertj.core.api.Assertions.assertThat; import static org.matsim.contrib.taxi.util.stats.TimeBinSamples.taskSamples; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.dvrp.analysis.ExecutedTask; import org.matsim.contrib.dvrp.schedule.Task; @@ -34,25 +34,25 @@ */ public class TimeBinSamplesTest { @Test - public void taskSamples_zeroDuration() { + void taskSamples_zeroDuration() { var task = task(10, 10); assertThat(taskSamples(task, 100)).isEmpty(); } @Test - public void taskSamples_oneSample() { + void taskSamples_oneSample() { var task = task(110, 190); assertThat(taskSamples(task, 100)).containsExactly(new TimeBinSample<>(1, task)); } @Test - public void taskSamples_threeSamples() { + void taskSamples_threeSamples() { var task = task(110, 390); assertThat(taskSamples(task, 100)).containsExactly(new TimeBinSample<>(1, task), new TimeBinSample<>(2, task), new TimeBinSample<>(3, task)); } @Test - public void taskSamples_taskEndEqualToTimeBinEnd() { + void taskSamples_taskEndEqualToTimeBinEnd() { var task = task(110, 300); assertThat(taskSamples(task, 100)).containsExactly(new TimeBinSample<>(1, task), new TimeBinSample<>(2, task)); } diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java index 3ed9158cf9f..26908ea89bc 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java @@ -20,8 +20,8 @@ package org.matsim.core.scoring.functions; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Person; @@ -44,9 +44,9 @@ public class PersonScoringParametersFromPersonAttributesIT { @RegisterExtension public MatsimTestUtils testUtils = new MatsimTestUtils(); - @SuppressWarnings("unchecked") - @Test - public void testSetAttributeAndRunEquil(){ + @SuppressWarnings("unchecked") + @Test + void testSetAttributeAndRunEquil(){ Config config = testUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); config.controller().setOutputDirectory(testUtils.getOutputDirectory()); config.controller().setLastIteration(0); diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java index 2db28b64006..70434051a10 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java @@ -21,8 +21,8 @@ import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.*; @@ -124,7 +124,7 @@ public void setUp() { } @Test - public void testPersonWithNegativeIncome(){ + void testPersonWithNegativeIncome(){ Id id = Id.createPersonId("negativeIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); //person's attribute says it has negative income which is considered invalid and therefore the subpopulation's mgnUtilityOfMoney is taken (which is 1) @@ -132,7 +132,7 @@ public void testPersonWithNegativeIncome(){ } @Test - public void testPersonWithNoIncome(){ + void testPersonWithNoIncome(){ Id id = Id.createPersonId("zeroIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); //person's attribute says it has 0 income which is considered invalid and therefore the subpopulation's mgnUtilityOfMoney is taken (which is 1) @@ -140,7 +140,7 @@ public void testPersonWithNoIncome(){ } @Test - public void testPersonWithLowIncomeLowCarAsc(){ + void testPersonWithLowIncomeLowCarAsc(){ Id id = Id.createPersonId("lowIncomeLowCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 0.5d, 0.5d); @@ -149,7 +149,7 @@ public void testPersonWithLowIncomeLowCarAsc(){ } @Test - public void testPersonWithHighIncomeLowCarAsc(){ + void testPersonWithHighIncomeLowCarAsc(){ Id id = Id.createPersonId("highIncomeLowCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 1.5d, 0.5d); @@ -158,7 +158,7 @@ public void testPersonWithHighIncomeLowCarAsc(){ } @Test - public void testPersonWithMediumIncomeHighCarAsc(){ + void testPersonWithMediumIncomeHighCarAsc(){ Id id = Id.createPersonId("mediumIncomeHighCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 1d, 0.5d); @@ -168,7 +168,7 @@ public void testPersonWithMediumIncomeHighCarAsc(){ } @Test - public void testMoneyScore(){ + void testMoneyScore(){ ScoringParameters paramsRich = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("highIncomeLowCarAsc"))); CharyparNagelMoneyScoring moneyScoringRich = new CharyparNagelMoneyScoring(paramsRich); moneyScoringRich.addMoney(100); @@ -183,7 +183,7 @@ public void testMoneyScore(){ } @Test - public void testPersonSpecificAscScoring(){ + void testPersonSpecificAscScoring(){ ScoringParameters paramsRich = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("highIncomeLowCarAsc"))); CharyparNagelLegScoring legScoringRichCarLeg = new CharyparNagelLegScoring(paramsRich, NetworkUtils.createNetwork(), Set.of(TransportMode.pt)); Leg carLegZeroDistanceTenSeconds = createLeg(TransportMode.car, 0.0d, 10.0d ); diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java index f7cd61abd9c..9ead6090cb8 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java @@ -21,8 +21,8 @@ import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.*; @@ -146,7 +146,7 @@ public void setUp() { } @Test - public void testPersonWithNegativeIncome(){ + void testPersonWithNegativeIncome(){ Id id = Id.createPersonId("negativeIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); //person's attribute says it has negative income which is considered invalid and therefore the subpopulation's mgnUtilityOfMoney is taken (which is 1) @@ -154,7 +154,7 @@ public void testPersonWithNegativeIncome(){ } @Test - public void testPersonWithNoIncome(){ + void testPersonWithNoIncome(){ Id id = Id.createPersonId("zeroIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); //person's attribute says it has 0 income which is considered invalid and therefore the subpopulation's mgnUtilityOfMoney is taken (which is 1) @@ -162,7 +162,7 @@ public void testPersonWithNoIncome(){ } @Test - public void testPersonWithLowIncomeLowCarAsc(){ + void testPersonWithLowIncomeLowCarAsc(){ Id id = Id.createPersonId("lowIncomeLowCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 0.5d, 0.5d); @@ -171,7 +171,7 @@ public void testPersonWithLowIncomeLowCarAsc(){ } @Test - public void testPersonWithHighIncomeLowCarAsc(){ + void testPersonWithHighIncomeLowCarAsc(){ Id id = Id.createPersonId("highIncomeLowCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 1.5d, 0.5d); @@ -180,7 +180,7 @@ public void testPersonWithHighIncomeLowCarAsc(){ } @Test - public void testPersonWithMediumIncomeHighCarAsc(){ + void testPersonWithMediumIncomeHighCarAsc(){ Id id = Id.createPersonId("mediumIncomeHighCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 1d, 0.5d); @@ -190,7 +190,7 @@ public void testPersonWithMediumIncomeHighCarAsc(){ } @Test - public void testPersonFreight(){ + void testPersonFreight(){ Id id = Id.createPersonId("freight"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); //freight agent has no income attribute set, so it should use the marginal utility of money that is set in its subpopulation scoring parameters! @@ -198,7 +198,7 @@ public void testPersonFreight(){ } @Test - public void testFreightWithIncome(){ + void testFreightWithIncome(){ Id id = Id.createPersonId("freightWithIncome1"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 1.5/444d, 1d); @@ -208,7 +208,7 @@ public void testFreightWithIncome(){ } @Test - public void testMoneyScore(){ + void testMoneyScore(){ ScoringParameters paramsRich = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("highIncomeLowCarAsc"))); CharyparNagelMoneyScoring moneyScoringRich = new CharyparNagelMoneyScoring(paramsRich); moneyScoringRich.addMoney(100); @@ -223,7 +223,7 @@ public void testMoneyScore(){ } @Test - public void testPersonSpecificAscScoring(){ + void testPersonSpecificAscScoring(){ ScoringParameters paramsRich = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("highIncomeLowCarAsc"))); CharyparNagelLegScoring legScoringRichCarLeg = new CharyparNagelLegScoring(paramsRich, NetworkUtils.createNetwork(), Set.of(TransportMode.pt)); Leg carLegZeroDistanceTenSeconds = createLeg(TransportMode.car, 0.0d, 10.0d ); diff --git a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/FreightAnalysisEventBasedTest.java b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/FreightAnalysisEventBasedTest.java index da7035be7e5..75986b3e94c 100644 --- a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/FreightAnalysisEventBasedTest.java +++ b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/FreightAnalysisEventBasedTest.java @@ -21,8 +21,8 @@ package org.matsim.freight.carriers.analysis; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import java.io.IOException; @@ -33,7 +33,7 @@ public class FreightAnalysisEventBasedTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void runFreightAnalysisEventBasedTest() throws IOException { + void runFreightAnalysisEventBasedTest() throws IOException { RunFreightAnalysisEventBased analysisEventBased = new RunFreightAnalysisEventBased(testUtils.getClassInputDirectory(), testUtils.getOutputDirectory(),null); analysisEventBased.runAnalysis(); diff --git a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java index 6ef803c9a77..5839ac4e77c 100644 --- a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java +++ b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java @@ -21,7 +21,9 @@ package org.matsim.freight.carriers.analysis; -import org.junit.*; +import org.junit.Assert; +import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Network; @@ -51,7 +53,7 @@ public void runAnalysis(){ } @Test - public void compareResults() { + void compareResults() { //some generale stats checkFile("carrierStats.tsv"); checkFile("freightVehicleStats.tsv"); @@ -74,7 +76,7 @@ private void checkFile(String filename) { } @Test - public void runVehicleTrackerTest(){ + void runVehicleTrackerTest(){ final String inputPath = testUtils.getClassInputDirectory(); File networkFile = new File(inputPath + "/output_network.xml.gz"); File carrierFile = new File(inputPath + "/output_carriers.xml"); @@ -204,7 +206,7 @@ public void runVehicleTrackerTest(){ } @Test - public void runServiceTrackerTest(){ + void runServiceTrackerTest(){ final String inputPath = testUtils.getClassInputDirectory(); File networkFile = new File(inputPath + "/output_network.xml.gz"); diff --git a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java index 6a60941db1f..c96930e1f1f 100644 --- a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java +++ b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java @@ -22,8 +22,8 @@ package org.matsim.freight.carriers.analysis; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -47,8 +47,8 @@ public class RunFreightAnalysisWithShipmentTest { @RegisterExtension public MatsimTestUtils testUtils = new MatsimTestUtils(); - @Test - public void runShipmentTrackerTest(){ + @Test + void runShipmentTrackerTest(){ final String inputPath = testUtils.getClassInputDirectory(); File networkFile = new File(inputPath + "/shipment/output_network.xml.gz"); File carrierFile = new File(inputPath + "/shipment/output_carriers.xml"); diff --git a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java index c42b548f626..8bd5209f135 100644 --- a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java +++ b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java @@ -11,8 +11,8 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -96,7 +96,7 @@ enum DrtMode {none, teleportBeeline, teleportBasedOnNetworkRoute, full, withPreb // !! otfvis does not run within parameterized test :-( !! @Test - public void testPtAlongALineWithRaptorAndDrtServiceArea() { + void testPtAlongALineWithRaptorAndDrtServiceArea() { // Towards some understanding of what is going on here: // * In many situations, a good solution is that drt drives to some transit stop, and from there directly to the destination. The swiss rail // raptor will return a cost "infinity" of such a solution, in which case the calling method falls back onto transit_walk. @@ -570,7 +570,7 @@ public void install() { } @Test - public void intermodalAccessEgressPicksWrongVariant() { + void intermodalAccessEgressPicksWrongVariant() { // outdated comment: // this test fails because it picks a // drt-nonNetworkWalk-nonNetworkWalk-drt @@ -745,9 +745,10 @@ public void install() { controler.run(); } + // this test is failing because raptor treats "walk" in a special way. kai, jul'19 @Test - @Ignore // this test is failing because raptor treats "walk" in a special way. kai, jul'19 - public void networkWalkDoesNotWorkWithRaptor() { + @Ignore + void networkWalkDoesNotWorkWithRaptor() { // test fails with null pointer exception Config config = PtAlongALineTest.createConfig(utils.getOutputDirectory()); diff --git a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java index d8736f176fc..6c315ddf84b 100644 --- a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java +++ b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java @@ -4,8 +4,8 @@ import java.util.Set; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -53,7 +53,7 @@ public class PtAlongALineTest { @Ignore @Test - public void testPtAlongALine() { + void testPtAlongALine() { Config config = createConfig(utils.getOutputDirectory()); @@ -70,7 +70,7 @@ public void testPtAlongALine() { */ @Ignore @Test - public void testPtAlongALineWithRaptorAndBike() { + void testPtAlongALineWithRaptorAndBike() { Config config = createConfig(utils.getOutputDirectory()); @@ -93,7 +93,7 @@ public void testPtAlongALineWithRaptorAndBike() { */ @Ignore @Test - public void testDrtAlongALine() { + void testDrtAlongALine() { Config config = ConfigUtils.createConfig(); @@ -204,7 +204,7 @@ public void testDrtAlongALine() { @Ignore @Test - public void testPtAlongALineWithRaptorAndDrtStopFilterAttribute() { + void testPtAlongALineWithRaptorAndDrtStopFilterAttribute() { Config config = PtAlongALineTest.createConfig(utils.getOutputDirectory()); config.qsim().setSimStarttimeInterpretation(QSimConfigGroup.StarttimeInterpretation.onlyUseStarttime); diff --git a/contribs/vsp/src/test/java/playground/vsp/airPollution/flatEmissions/EmissionCostFactorsTest.java b/contribs/vsp/src/test/java/playground/vsp/airPollution/flatEmissions/EmissionCostFactorsTest.java index 40f2a30e8d1..ed62c664a9f 100644 --- a/contribs/vsp/src/test/java/playground/vsp/airPollution/flatEmissions/EmissionCostFactorsTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/airPollution/flatEmissions/EmissionCostFactorsTest.java @@ -1,25 +1,28 @@ package playground.vsp.airPollution.flatEmissions; import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.assertThrows; import static playground.vsp.airPollution.flatEmissions.EmissionCostFactors.NOx; -import org.junit.Test; +import org.junit.jupiter.api.Test; public class EmissionCostFactorsTest{ - @Test - public void test() { + @Test + void test() { System.out.println( "name=" + NOx.name() + "; factor=" + NOx.getCostFactor() ); System.out.println( "noxFactor=" + EmissionCostFactors.getCostFactor( "NOx" ) ) ; } - @Test(expected = IllegalArgumentException.class) - public void test_unknownParameter() { + @Test + void test_unknownParameter() { + assertThrows(IllegalArgumentException.class, () -> { - EmissionCostFactors.getCostFactor("does-not-exist"); - fail("Unknown pollutant should cause exception"); + EmissionCostFactors.getCostFactor("does-not-exist"); + fail("Unknown pollutant should cause exception"); + }); } } diff --git a/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestColdEmissionHandler.java b/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestColdEmissionHandler.java index ad8418126c7..a0c00826bc0 100644 --- a/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestColdEmissionHandler.java +++ b/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestColdEmissionHandler.java @@ -24,7 +24,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.Person; @@ -47,7 +47,7 @@ public class TestColdEmissionHandler { @Test - public final void testEmissionPerPersonColdEventHandler(){ + final void testEmissionPerPersonColdEventHandler(){ //vehicle=person. this handler counts the cold emission events per vehicle id EmissionsPerPersonColdEventHandler handler = new EmissionsPerPersonColdEventHandler(); diff --git a/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestWarmEmissionHandler.java b/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestWarmEmissionHandler.java index 9892396fa5c..de5e284c121 100644 --- a/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestWarmEmissionHandler.java +++ b/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestWarmEmissionHandler.java @@ -24,7 +24,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.Person; @@ -47,7 +47,7 @@ public class TestWarmEmissionHandler { @Test - public final void testEmissionPerPersonWarmEventHandler(){ + final void testEmissionPerPersonWarmEventHandler(){ EmissionsPerPersonWarmEventHandler handler = new EmissionsPerPersonWarmEventHandler(); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapDataTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapDataTest.java index 58d50e18d78..f63bcbb2fd4 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapDataTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapDataTest.java @@ -1,7 +1,7 @@ package playground.vsp.andreas.bvgAna.level1; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.PersonDepartureEvent; @@ -13,11 +13,10 @@ import playground.vsp.andreas.bvgAna.level1.AgentId2DepartureDelayAtStopMapData; public class AgentId2DepartureDelayAtStopMapDataTest { - - + @Test - public void testAgentId2DepartureDelayAtStopMapData() { + void testAgentId2DepartureDelayAtStopMapData() { // assign Ids to routes, vehicles and agents to be used in Test diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapTest.java index 2dc4d31fc58..c50c5e0c285 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapTest.java @@ -4,7 +4,7 @@ import java.util.TreeSet; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.PersonDepartureEvent; @@ -16,7 +16,7 @@ public class AgentId2DepartureDelayAtStopMapTest { @Test - public void testAgentId2DepartureDelayAtStopMap() { + void testAgentId2DepartureDelayAtStopMap() { Set> idSet = new TreeSet<>(); for (int ii=0; ii<15; ii++){ diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2EnterLeaveVehicleEventHandlerTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2EnterLeaveVehicleEventHandlerTest.java index f873bb1ecda..e82f75ca5ec 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2EnterLeaveVehicleEventHandlerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2EnterLeaveVehicleEventHandlerTest.java @@ -4,7 +4,7 @@ import java.util.TreeSet; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonEntersVehicleEvent; import org.matsim.api.core.v01.events.PersonLeavesVehicleEvent; @@ -15,12 +15,11 @@ public class AgentId2EnterLeaveVehicleEventHandlerTest { - /** - * Test method for {@link playground.vsp.andreas.bvgAna.level1.AgentId2EnterLeaveVehicleEventHandler#AgentId2EnterLeaveVehicleEventHandler(java.util.Set)}. - */ - @Test - - public void testAgentId2EnterLeaveVehicleEventHandler() { + /** + * Test method for {@link playground.vsp.andreas.bvgAna.level1.AgentId2EnterLeaveVehicleEventHandler#AgentId2EnterLeaveVehicleEventHandler(java.util.Set)}. + */ + @Test + void testAgentId2EnterLeaveVehicleEventHandler() { Set> idSet = new TreeSet<>(); for (int ii=0; ii<9; ii++){ diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapDataTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapDataTest.java index cd86ac00a41..3559c2d3082 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapDataTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapDataTest.java @@ -23,7 +23,7 @@ import java.util.TreeSet; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -38,7 +38,7 @@ public class AgentId2PtTripTravelTimeMapDataTest { @Test - public void testAgentId2PtTripTravelTimeMapData() { + void testAgentId2PtTripTravelTimeMapData() { Set> idSet = new TreeSet<>(); for (int ii=0; ii<15; ii++){ diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapTest.java index b83a7e3c7e4..2adbd8450ef 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapTest.java @@ -6,7 +6,7 @@ import java.util.TreeSet; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -30,8 +30,7 @@ public class AgentId2PtTripTravelTimeMapTest { * Test method for {@link playground.vsp.andreas.bvgAna.level1.AgentId2PtTripTravelTimeMap#AgentId2PtTripTravelTimeMap(java.util.Set)}. */ @Test - - public void testAgentId2PtTripTravelTimeMap() { + void testAgentId2PtTripTravelTimeMap() { Set> idSet = new TreeSet<>(); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkDataTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkDataTest.java index e4a774082cf..34da2196a5f 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkDataTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkDataTest.java @@ -1,11 +1,11 @@ package playground.vsp.andreas.bvgAna.level1; -import org.junit.Test; +import org.junit.jupiter.api.Test; public class StopId2LineId2PulkDataTest { - + @Test - public void testStopId2LineId2PulkData() { + void testStopId2LineId2PulkData() { // to be implemented diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java index 0c6cab2dd42..5160fbce497 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java @@ -2,7 +2,7 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; import org.matsim.api.core.v01.population.Person; @@ -15,8 +15,9 @@ public class StopId2LineId2PulkTest { - @Test @Ignore - public void testStopId2LineId2Pulk() { + @Test + @Ignore + void testStopId2LineId2Pulk() { // assign Ids to routes, vehicles and agents to be used in Test diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2RouteId2DelayAtStopMapTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2RouteId2DelayAtStopMapTest.java index 00e0ca04df9..6205ab72888 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2RouteId2DelayAtStopMapTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2RouteId2DelayAtStopMapTest.java @@ -1,7 +1,7 @@ package playground.vsp.andreas.bvgAna.level1; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; import org.matsim.api.core.v01.population.Person; @@ -15,7 +15,7 @@ public class StopId2RouteId2DelayAtStopMapTest { @Test - public void testStopId2RouteId2DelayAtStopMap() { + void testStopId2RouteId2DelayAtStopMap() { // assign Ids to routes, vehicles and agents to be used in Test diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapDataTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapDataTest.java index 2c1d406dcf9..720bf61b615 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapDataTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapDataTest.java @@ -1,7 +1,7 @@ package playground.vsp.andreas.bvgAna.level1; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; import org.matsim.api.core.v01.population.Person; @@ -17,7 +17,7 @@ public class VehId2DelayAtStopMapDataTest { @Test - public void testVehId2DelayAtStopMapData() { + void testVehId2DelayAtStopMapData() { // assign Ids to routes, vehicles and agents to be used in Test diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapTest.java index a3df217d43a..3621a8081cd 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapTest.java @@ -4,7 +4,7 @@ import java.util.TreeMap; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; import org.matsim.api.core.v01.population.Person; @@ -18,7 +18,7 @@ public class VehId2DelayAtStopMapTest { @Test - public void testVehId2DelayAtStopMap() { + void testVehId2DelayAtStopMap() { TreeMap> data = new TreeMap>(); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2OccupancyHandlerTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2OccupancyHandlerTest.java index fc9248d4705..de708843b22 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2OccupancyHandlerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2OccupancyHandlerTest.java @@ -3,14 +3,13 @@ import static org.junit.Assert.*; import org.junit.Assert; -import org.junit.Test; - +import org.junit.jupiter.api.Test; import playground.vsp.andreas.bvgAna.level1.VehId2OccupancyHandler; public class VehId2OccupancyHandlerTest { @Test - public void testVehId2OccupancyHandler() { + void testVehId2OccupancyHandler() { VehId2OccupancyHandler test = new VehId2OccupancyHandler(); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2PersonEnterLeaveVehicleMapTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2PersonEnterLeaveVehicleMapTest.java index 53f3fa8d302..26a36b3e80b 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2PersonEnterLeaveVehicleMapTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2PersonEnterLeaveVehicleMapTest.java @@ -4,7 +4,7 @@ import java.util.TreeMap; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonEntersVehicleEvent; import org.matsim.api.core.v01.events.PersonLeavesVehicleEvent; @@ -17,7 +17,7 @@ public class VehId2PersonEnterLeaveVehicleMapTest { TreeMap> leave = new TreeMap>(); @Test - public void testVehId2PersonEnterLeaveVehicleMap() { + void testVehId2PersonEnterLeaveVehicleMap() { // assign Ids to routes, vehicles and agents to be used in Test diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java index d549920130b..e2eb11c4d0b 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java @@ -24,8 +24,8 @@ import java.util.TreeSet; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -45,7 +45,8 @@ public class PTCountsNetworkSimplifierTest { * Test simple network */ - @Test public void testSimplifyEmptyNetwork(){ + @Test + void testSimplifyEmptyNetwork(){ String inputPath = utils.getClassInputDirectory(); String outputPath = utils.getOutputDirectory(); @@ -84,7 +85,8 @@ public class PTCountsNetworkSimplifierTest { * Test pt link */ - @Test public void testSimplifyPTNetwork(){ + @Test + void testSimplifyPTNetwork(){ String inputPath = utils.getClassInputDirectory(); String outputPath = utils.getOutputDirectory(); @@ -127,7 +129,8 @@ public class PTCountsNetworkSimplifierTest { * Test links with count stations */ - @Test public void testSimplifyCountsNetwork(){ + @Test + void testSimplifyCountsNetwork(){ String inputPath = utils.getClassInputDirectory(); String outputPath = utils.getOutputDirectory(); @@ -172,7 +175,8 @@ public class PTCountsNetworkSimplifierTest { * Test PT and Counts at once */ - @Test public void testSimplifyPTCountsNetwork(){ + @Test + void testSimplifyPTCountsNetwork(){ String inputPath = utils.getClassInputDirectory(); String outputPath = utils.getOutputDirectory(); @@ -220,7 +224,8 @@ public class PTCountsNetworkSimplifierTest { * Test additional links marked as blocked */ - @Test public void testSimplifyElseNetwork(){ + @Test + void testSimplifyElseNetwork(){ String inputPath = utils.getClassInputDirectory(); String outputPath = utils.getOutputDirectory(); @@ -272,7 +277,8 @@ public class PTCountsNetworkSimplifierTest { * Test all at once */ - @Test public void testSimplifyAllNetwork(){ + @Test + void testSimplifyAllNetwork(){ String inputPath = utils.getClassInputDirectory(); String outputPath = utils.getOutputDirectory(); diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java index db7023afb6a..104fcd8f336 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java @@ -1,7 +1,6 @@ package playground.vsp.cadyts.marginals; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Coord; @@ -254,7 +253,7 @@ private static Plan createPlan(String mode, String endLink, Network network, Pop * is set to have an equal share of car and bike users. The accepted error in the test is 5%, due to stochastic fuzziness */ @Test - public void test() { + void test() { Config config = createConfig(); CadytsConfigGroup cadytsConfigGroup = new CadytsConfigGroup(); diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java index ad2500ce36f..90a70f545a2 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java @@ -1,7 +1,6 @@ package playground.vsp.cadyts.marginals; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -52,7 +51,7 @@ public class ModalDistanceCadytsMultipleDistancesIT { * is set to have an equal share of car and bike users. The accepted error in the test is 5%, due to stochastic fuzziness */ @Test - public void test() { + void test() { Config config = createConfig(); CadytsConfigGroup cadytsConfigGroup = new CadytsConfigGroup(); diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java index 94c68a9d5bd..c2dfaf70610 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java @@ -18,9 +18,8 @@ * *********************************************************************** */ package playground.vsp.cadyts.marginals; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -61,13 +60,13 @@ public class ModalDistanceCadytsSingleDistanceIT { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - /** - * This test runs a population of 1000 agents which have the same home and work place. All agents start with two plans. - * One with mode car and one with mode bike. The selected plan is the car plan. Now, the desired distance distribution - * is set to have an equal share of car and bike users. The accepted error in the test is 5%, due to stochastic fuzziness - */ - @Test - public void test() { + /** + * This test runs a population of 1000 agents which have the same home and work place. All agents start with two plans. + * One with mode car and one with mode bike. The selected plan is the car plan. Now, the desired distance distribution + * is set to have an equal share of car and bike users. The accepted error in the test is 5%, due to stochastic fuzziness + */ + @Test + void test() { Config config = createConfig(); CadytsConfigGroup cadytsConfigGroup = new CadytsConfigGroup(); diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java index e0c7d42e18a..8cccb793c66 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java @@ -1,7 +1,7 @@ package playground.vsp.cadyts.marginals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -40,7 +40,7 @@ public class TripEventHandlerTest { * @throws MalformedURLException another stupid api */ @Test - public void test() throws MalformedURLException { + void test() throws MalformedURLException { // url is such a weird api URL ptTutorial = URI.create(ExamplesUtils.getTestScenarioURL("pt-tutorial").toString() + "0.config.xml").toURL(); diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java b/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java index 22b9e50abc3..12089da0739 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java @@ -29,8 +29,8 @@ import jakarta.inject.Provider; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -76,7 +76,7 @@ public class AdvancedMarginalCongestionPricingIT { // test normal activities @Test - public final void test0a(){ + final void test0a(){ ScoringConfigGroup plansCalcScoreConfigGroup = new ScoringConfigGroup(); ActivityParams activityParams = new ActivityParams("work"); @@ -141,7 +141,7 @@ public final void test0a(){ // test overnight activities with first and last activity of the same type @Test - public final void test0b(){ + final void test0b(){ ScoringConfigGroup plansCalcScoreConfigGroup = new ScoringConfigGroup(); ActivityParams activityParams = new ActivityParams("overnightActivity"); @@ -189,7 +189,7 @@ public final void test0b(){ // test overnight activities with first and last activity of different types @Test - public final void test0c(){ + final void test0c(){ ScoringConfigGroup plansCalcScoreConfigGroup = new ScoringConfigGroup(); @@ -236,7 +236,7 @@ public final void test0c(){ // test if the delayed arrival at a normal activity (not the first or last activity) results in the right monetary amount @Test - public final void test1(){ + final void test1(){ String configFile = testUtils.getPackageInputDirectory() + "AdvancedMarginalCongestionPricingTest/config1.xml"; @@ -318,7 +318,7 @@ public ControlerListener get() { // test if a delayed arrival at the last activity results in the right monetary amount @Test - public final void test2(){ + final void test2(){ String configFile = testUtils.getPackageInputDirectory() + "AdvancedMarginalCongestionPricingTest/config2.xml"; @@ -404,7 +404,7 @@ public ControlerListener get() { // test if the right number of money events are thrown @Test - public final void test3(){ + final void test3(){ String configFile = testUtils.getPackageInputDirectory() + "AdvancedMarginalCongestionPricingTest/config3.xml"; @@ -472,7 +472,7 @@ public ControlerListener get() { // test if the right number of money events are thrown @Test - public final void test4(){ + final void test4(){ String configFile = testUtils.getPackageInputDirectory() + "AdvancedMarginalCongestionPricingTest/config4.xml"; diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java index 792eb498409..a7406ecae28 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java @@ -22,8 +22,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -75,7 +75,7 @@ public class CombinedFlowAndStorageDelayTest { * agents are stored to charge later if required. */ @Test - public final void implV4Test(){ + final void implV4Test(){ /* * In the test, two routes (1-2-3-4 and 5-3-4) are assigned to agents. First two agents (1,2) start on first route and next two (3,4) on * other route. After agent 1 leave the link 2 (marginal flow delay =100), agent 2 is delayed. Mean while, before agent 2 can move to next link, diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/CorridorNetworkTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/CorridorNetworkTest.java index 7486ec1c9eb..e583e5441de 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/CorridorNetworkTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/CorridorNetworkTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -65,7 +65,7 @@ public class CorridorNetworkTest { @Test - public void v3Test(){ + void v3Test(){ CorridorNetworkAndPlans inputs = new CorridorNetworkAndPlans(); Scenario sc = inputs.getDesiredScenario(); @@ -112,7 +112,7 @@ public void v3Test(){ } @Test - public void v4Test(){ + void v4Test(){ CorridorNetworkAndPlans inputs = new CorridorNetworkAndPlans(); Scenario sc = inputs.getDesiredScenario(); diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java index 06b51cf1a47..b34e2adbf6d 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java @@ -28,8 +28,8 @@ import java.util.Set; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -101,7 +101,7 @@ public class MarginalCongestionHandlerFlowQueueQsimTest { * V3 */ @Test - public final void testFlowCongestion_3agents_V3(){ + final void testFlowCongestion_3agents_V3(){ Scenario sc = loadScenario1(); setPopulation1(sc); @@ -140,7 +140,7 @@ public void handleEvent(CongestionEvent event) { * V7 */ @Test - public final void testFlowCongestion_3agents_V7(){ + final void testFlowCongestion_3agents_V7(){ Scenario sc = loadScenario1(); setPopulation1(sc); @@ -191,7 +191,7 @@ public void handleEvent(CongestionEvent event) { * V8 */ @Test - public final void testFlowCongestion_3agents_V8(){ + final void testFlowCongestion_3agents_V8(){ Scenario sc = loadScenario1(); setPopulation1(sc); diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java index 6a545ed494e..3029eda9921 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java @@ -34,8 +34,8 @@ import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -131,9 +131,9 @@ public class MarginalCongestionHandlerFlowSpillbackQueueQsimTest { * V3 * */ - @Ignore("Temporarily ignoring")//TODO for Amit - @Test - public final void testFlowAndStorageCongestion_3agents(){ + @Ignore("Temporarily ignoring")//TODO for Amit + @Test + final void testFlowAndStorageCongestion_3agents(){ Scenario sc = loadScenario1(); setPopulation1(sc); @@ -178,7 +178,7 @@ public void handleEvent(CongestionEvent event) { * */ @Test - public final void testFlowAndStorageCongestion_3agents_V9() { + final void testFlowAndStorageCongestion_3agents_V9() { Scenario sc = loadScenario1(); setPopulation1(sc); @@ -219,7 +219,7 @@ public void handleEvent(CongestionEvent event) { * */ @Test - public final void testFlowAndStorageCongestion_3agents_V8() { + final void testFlowAndStorageCongestion_3agents_V8() { Scenario sc = loadScenario1(); setPopulation1(sc); @@ -259,9 +259,9 @@ public void handleEvent(CongestionEvent event) { * V10 * */ - @Ignore("Temporarily ignoring")//TODO for Amit + @Ignore("Temporarily ignoring")//TODO for Amit @Test - public final void testFlowAndStorageCongestion_3agents_V10() { + final void testFlowAndStorageCongestion_3agents_V10() { Scenario sc = loadScenario1(); setPopulation1(sc); @@ -309,9 +309,9 @@ public void handleEvent(CongestionEvent event) { // in both iterations the "toll" and the "tollOldValue" should be the same // // 3 iterations are necessary to check the equality of the "toll" and the "tollOldValue" - @Ignore("Temporarily ignoring")//TODO for Amit + @Ignore("Temporarily ignoring")//TODO for Amit @Test - public final void testRouting(){ + final void testRouting(){ String configFile = testUtils.getPackageInputDirectory()+"MarginalCongestionHandlerV3QsimTest/configTestRouting.xml"; @@ -449,9 +449,9 @@ else if(((event.getServices().getConfig().controller().getLastIteration())-(even } // setInsertingWaitingVehiclesBeforeDrivingVehicles = false - @Ignore("Temporarily ignoring")//TODO for Amit + @Ignore("Temporarily ignoring")//TODO for Amit @Test - public final void testInsertingWaitingVehicles_01(){ + final void testInsertingWaitingVehicles_01(){ Scenario sc = loadScenario4(); setPopulation4(sc); @@ -508,9 +508,9 @@ public void handleEvent(LinkLeaveEvent event) { // setInsertingWaitingVehiclesBeforeDrivingVehicles = true // to compare - @Ignore("Temporarily ignoring")//TODO for Amit + @Ignore("Temporarily ignoring")//TODO for Amit @Test - public final void testInsertingWaitingVehicles_02(){ + final void testInsertingWaitingVehicles_02(){ Scenario sc = loadScenario5(); setPopulation5(sc); @@ -569,9 +569,9 @@ public void handleEvent(LinkLeaveEvent event) { // setInsertingWaitingVehiclesBeforeDrivingVehicles = false // agent 2 is already on link 2 when agent 3 ends his activity, // therefore agent 3 has to wait until agent 2 has left the link - @Ignore("Temporarily ignoring")//TODO for Amit + @Ignore("Temporarily ignoring")//TODO for Amit @Test - public final void testInsertingWaitingVehicles_03(){ + final void testInsertingWaitingVehicles_03(){ Scenario sc = loadScenario4(); setPopulation6(sc); @@ -627,9 +627,9 @@ public void handleEvent(LinkLeaveEvent event) { } - @Ignore("Temporarily ignoring")//TODO for Amit + @Ignore("Temporarily ignoring")//TODO for Amit @Test - public final void testStuckTimePeriod(){ + final void testStuckTimePeriod(){ Scenario sc = loadScenario1b(); setPopulation1(sc); diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java index 52ba06a0f54..c43f9c44301 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java @@ -31,8 +31,8 @@ import jakarta.inject.Provider; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -64,7 +64,7 @@ public class MarginalCongestionHandlerV3Test { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public final void testCongestionExample(){ + final void testCongestionExample(){ String configFile = testUtils.getPackageInputDirectory()+"MarginalCongestionHandlerV3Test/config.xml"; final List congestionEvents = new ArrayList(); diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java index b3633c5a13b..ae8e105e244 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java @@ -24,8 +24,8 @@ import java.util.Set; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -67,7 +67,7 @@ public class MarginalCongestionPricingTest { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public final void implV4Test(){ + final void implV4Test(){ int numberOfPersonInPlan = 10; createPseudoInputs pseudoInputs = new createPseudoInputs(); diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java index c6ae3343755..ff9518ca966 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java @@ -22,8 +22,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -69,7 +69,7 @@ public class MultipleSpillbackCausingLinksTest { * (2) an agent may have two different links as next link in the route and therefore correct one should be adopted. */ @Test - public final void multipleSpillBackTest(){ + final void multipleSpillBackTest(){ /* * 10 agents diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java b/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java index 7b4be2a2cf1..46cbb7a5ebc 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java @@ -22,8 +22,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -64,7 +64,7 @@ public class TestForEmergenceTime { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public final void emergenceTimeTest_v4(){ + final void emergenceTimeTest_v4(){ String [] congestionPricingImpl = {"v4"}; diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java b/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java index 330e4bff5ad..28fca80e271 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java @@ -24,8 +24,8 @@ import java.util.Map; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.contrib.ev.fleet.ElectricFleetUtils; @@ -49,7 +49,7 @@ public class TransferFinalSocToNextIterTest { private MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); @Test - public void test() { + void test() { //adapt scenario scenario.getConfig().controller().setLastIteration(LAST_ITERATION); scenario.getConfig().controller().setOutputDirectory("test/output/playground/vsp/ev/FinalSoc2VehicleTypeTest/"); diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java index b35592a42ca..c267b09bb17 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java @@ -2,8 +2,8 @@ import org.apache.logging.log4j.LogManager; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.population.Population; import org.matsim.core.config.ConfigUtils; import org.matsim.core.events.EventsUtils; @@ -18,7 +18,8 @@ public class UrbanEVIT { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void run() { + @Test + void run() { try { // final URL baseUrl = ExamplesUtils.getTestScenarioURL( "equil" ); diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java index aa1e6143b24..2611efa158e 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java @@ -8,7 +8,7 @@ import org.junit.Assert; import org.junit.BeforeClass; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -100,7 +100,7 @@ public void install() { } @Test - public void testAgentsExecuteSameNumberOfActsAsPlanned() { + void testAgentsExecuteSameNumberOfActsAsPlanned() { boolean fail = false; String personsWithDifferingActCount = ""; @@ -123,7 +123,7 @@ public void testAgentsExecuteSameNumberOfActsAsPlanned() { } @Test - public void testCarAndBikeAgent() { + void testCarAndBikeAgent() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Charge during leisure + bike"), List.of()); Assert.assertEquals(1, plugins.size(), 0); @@ -142,7 +142,7 @@ public void testCarAndBikeAgent() { } @Test - public void testTripleCharger() { + void testTripleCharger() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Triple Charger"), List.of()); Assert.assertEquals(plugins.size(), 3., 0); ActivityStartEvent pluginActStart = plugins.get(0); @@ -169,7 +169,7 @@ public void testTripleCharger() { } @Test - public void testChargerSelectionShopping() { + void testChargerSelectionShopping() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Charging during shopping"), List.of()); Assert.assertEquals(1, plugins.size(), 0); @@ -187,7 +187,7 @@ public void testChargerSelectionShopping() { } @Test - public void testLongDistance() { + void testLongDistance() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Charger Selection long distance leg"), List.of()); Assert.assertEquals(1, plugins.size(), 0); @@ -207,7 +207,7 @@ public void testLongDistance() { } @Test - public void testTwin() { + void testTwin() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Charger Selection long distance twin"), List.of()); Assert.assertEquals(1, plugins.size(), 0); @@ -226,7 +226,7 @@ public void testTwin() { } @Test - public void testDoubleCharger() { + void testDoubleCharger() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Double Charger"), List.of()); Assert.assertEquals(1, plugins.size(), 0); ActivityStartEvent pluginActStart = plugins.get(0); @@ -243,7 +243,7 @@ public void testDoubleCharger() { } @Test - public void testNotEnoughTimeCharger() { + void testNotEnoughTimeCharger() { //TODO this test succeeds if the corresponding agents is deleted List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Not enough time so no charge"), List.of()); Assert.assertTrue(plugins.isEmpty()); @@ -253,7 +253,7 @@ public void testNotEnoughTimeCharger() { } @Test - public void testEarlyCharger() { + void testEarlyCharger() { //this guy starts with more energy than the others, exceeds the threshold at the 3rd leg but can only charge during first non-home-act. charge is lasting long enough so no additional charge is needed List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Not enough time so charging early"), @@ -274,7 +274,7 @@ public void testEarlyCharger() { } @Test - public void testHomeCharger() { + void testHomeCharger() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Home Charger"), List.of()); Assert.assertEquals(1, plugins.size(), 0); ActivityStartEvent pluginActStart = plugins.get(0); @@ -288,7 +288,7 @@ public void testHomeCharger() { } @Test - public void testNoRoundTripSoNoHomeCharge() { + void testNoRoundTripSoNoHomeCharge() { //TODO this test succeeds if the corresponding agents is deleted List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("No Round Trip So No Home Charge"), List.of()); @@ -301,7 +301,7 @@ public void testNoRoundTripSoNoHomeCharge() { } @Test - public void testDoubleChargerHomeCharger() { + void testDoubleChargerHomeCharger() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Double Charger Home Charger"), List.of()); Assert.assertEquals(plugins.size(), 2, 0); ActivityStartEvent pluginActStart = plugins.get(0); diff --git a/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java b/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java index dc6fc153dbc..07a9345c92c 100644 --- a/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java @@ -3,8 +3,8 @@ import com.google.inject.Provides; import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -66,7 +66,7 @@ public class HierarchicalFLowEfficiencyCalculatorTest { private FlowEfficiencyHandler handler; @Test - public void testThatDrtAVMoveFaster(){ + void testThatDrtAVMoveFaster(){ Assert.assertTrue(handler.lastArrivalsPerLink.get(Id.createLinkId(258)) > handler.lastArrivalsPerLink.get(Id.createLinkId(259))); Assert.assertTrue(handler.lastArrivalsPerLink.get(Id.createLinkId(258)) > handler.lastArrivalsPerLink.get(Id.createLinkId(260))); diff --git a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java index 524f1f3816e..56816559ba1 100644 --- a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java @@ -1,8 +1,8 @@ package playground.vsp.openberlinscenario.cemdap.input; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Population; import org.matsim.testcases.MatsimTestUtils; @@ -23,7 +23,7 @@ public class SynPopCreatorTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void TestGenerateDemand() { + void TestGenerateDemand() { // Input and output files String commuterFileOutgoingTest = utils.getInputDirectory() + "Teil1BR2009Ga_Test_kurz.txt"; diff --git a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java index f8dedea8aa3..7f96e4d5879 100644 --- a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java @@ -2,7 +2,9 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.*; +import org.junit.Assert; +import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -57,8 +59,8 @@ public void initializeTestPopulations() { modifiedPopulationCase2 = readPopulationFromFile(outputPlansFile2); } - @Test - public void testSelectionProbability() { + @Test + void testSelectionProbability() { LOG.info("OriginalPopulationCase1 size: " + originalPopulationCase.getPersons().size()); LOG.info("ModifiedPopulationCase1 size: " + modifiedPopulationCase1.getPersons().size()); @@ -70,8 +72,8 @@ public void testSelectionProbability() { MatsimTestUtils.EPSILON); } - @Test - public void testEveryPersonCopiedExistsInOriginal() { + @Test + void testEveryPersonCopiedExistsInOriginal() { for (Person copy : modifiedPopulationCase1.getPersons().values()) { Person original = originalPopulationCase.getPersons().get(copy.getId()); @@ -80,8 +82,8 @@ public void testEveryPersonCopiedExistsInOriginal() { } } - @Test - public void testOnlyTransferSelectedPlan() { + @Test + void testOnlyTransferSelectedPlan() { for (Person copy : modifiedPopulationCase2.getPersons().values()) { Person original = originalPopulationCase.getPersons().get(copy.getId()); @@ -90,8 +92,8 @@ public void testOnlyTransferSelectedPlan() { } } - @Test - public void testNotOnlyTransferSelectedPlan() { + @Test + void testNotOnlyTransferSelectedPlan() { //also tests if all plans were copied correctly for (Person copy : modifiedPopulationCase1.getPersons().values()) { @@ -107,8 +109,8 @@ public void testNotOnlyTransferSelectedPlan() { } } - @Test - public void testConsiderHomeStayingAgents() { + @Test + void testConsiderHomeStayingAgents() { boolean atLeastOneHomeStayingPerson = false; for (Person copy : modifiedPopulationCase2.getPersons().values()) { @@ -118,8 +120,8 @@ public void testConsiderHomeStayingAgents() { Assert.assertTrue("No home staying person found", atLeastOneHomeStayingPerson); } - @Test - public void testNotConsiderHomeStayingAgents() { + @Test + void testNotConsiderHomeStayingAgents() { for (Person copy : modifiedPopulationCase1.getPersons().values()) { Assert.assertTrue("No home staying agents allowed", @@ -127,8 +129,8 @@ public void testNotConsiderHomeStayingAgents() { } } - @Test - public void testIncludeStayHomePlans() { + @Test + void testIncludeStayHomePlans() { boolean atLeastOneHomeStayingPlan = false; for (Person copy : modifiedPopulationCase1.getPersons().values()) { @@ -139,8 +141,8 @@ public void testIncludeStayHomePlans() { Assert.assertTrue("No home staying plan found", atLeastOneHomeStayingPlan); } - @Test - public void testNotIncludeStayHomePlans() { + @Test + void testNotIncludeStayHomePlans() { for (Person copy : modifiedPopulationCase2.getPersons().values()) { for (Plan plan : copy.getPlans()) @@ -150,8 +152,8 @@ public void testNotIncludeStayHomePlans() { } } - @Test - public void testOnlyConsiderPeopleAlwaysGoingByCar() { + @Test + void testOnlyConsiderPeopleAlwaysGoingByCar() { for (Person copy : modifiedPopulationCase2.getPersons().values()) { for (Plan plan : copy.getPlans()) @@ -164,8 +166,8 @@ public void testOnlyConsiderPeopleAlwaysGoingByCar() { } } - @Test - public void testNotOnlyConsiderPeopleAlwaysGoingByCar() { + @Test + void testNotOnlyConsiderPeopleAlwaysGoingByCar() { boolean otherModeThanCarConsidered = false; for (Person copy : modifiedPopulationCase1.getPersons().values()) { @@ -179,8 +181,8 @@ public void testNotOnlyConsiderPeopleAlwaysGoingByCar() { Assert.assertTrue("There should be other modes than car", otherModeThanCarConsidered); } - @Test - public void testRemoveLinksAndRoutes() { + @Test + void testRemoveLinksAndRoutes() { for (Person copy : modifiedPopulationCase2.getPersons().values()) { for (Plan plan : copy.getPlans()) @@ -193,8 +195,8 @@ public void testRemoveLinksAndRoutes() { } } - @Test - public void testNotRemoveLinksAndRoutes() { + @Test + void testNotRemoveLinksAndRoutes() { boolean routeFound = false; for (Person copy : modifiedPopulationCase1.getPersons().values()) { diff --git a/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java b/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java index 2d5797dc1b8..875a03eb3ae 100644 --- a/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java @@ -5,8 +5,8 @@ import org.assertj.core.api.InstanceOfAssertFactories; import org.assertj.core.data.Offset; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Leg; @@ -110,7 +110,7 @@ private List estimateAgent(Id personId) { } @Test - public void fare() { + void fare() { List est = estimateAgent(TestScenario.Agents.get(1)); System.out.println(est); @@ -123,7 +123,7 @@ public void fare() { } @Test - public void all() { + void all() { for (Id agent : TestScenario.Agents) { List est = estimateAgent(agent); @@ -135,7 +135,7 @@ public void all() { } @Test - public void planEstimate() { + void planEstimate() { Person person = controler.getScenario().getPopulation().getPersons().get(TestScenario.Agents.get(2)); Plan plan = person.getSelectedPlan(); diff --git a/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java b/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java index 341ad741a91..8ea37d7d2df 100644 --- a/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java @@ -33,8 +33,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -114,7 +114,7 @@ public class EditTripsTest { * Case 1.1.1 */ @Test - public void testAgentStaysAtStop() { + void testAgentStaysAtStop() { HashMap, Double> arrivalTimes = new HashMap<>(); HashMap, List> trips = new HashMap<>(); Config config = ConfigUtils @@ -148,13 +148,12 @@ public void testAgentStaysAtStop() { } - /** * Case 1.1.2 Looks awkward in otfvis, because after replanning there suddenly * are 2 testAgents at different places, but events are fine :-/ */ @Test - public void testAgentLeavesStop() { + void testAgentLeavesStop() { HashMap, Double> arrivalTimes = new HashMap<>(); HashMap, List> trips = new HashMap<>(); Config config = ConfigUtils.loadConfig(configURL); @@ -187,7 +186,7 @@ public void testAgentLeavesStop() { * Case 1.2.1 */ @Test - public void testAgentStaysInVehicle() { + void testAgentStaysInVehicle() { HashMap, Double> arrivalTimes = new HashMap<>(); HashMap, List> trips = new HashMap<>(); Config config = ConfigUtils @@ -224,7 +223,7 @@ public void testAgentStaysInVehicle() { * Case 1.2.2 */ @Test - public void testAgentLeavesVehicleAtNextStop() { + void testAgentLeavesVehicleAtNextStop() { HashMap, Double> arrivalTimes = new HashMap<>(); HashMap, List> trips = new HashMap<>(); Config config = ConfigUtils @@ -268,7 +267,7 @@ public void testAgentLeavesVehicleAtNextStop() { * This is due to the utility params for walk, pt_wait and pt being equal/indifferent. */ @Test - public void testAgentIsAtTeleportLegAndLeavesStop() { + void testAgentIsAtTeleportLegAndLeavesStop() { HashMap, Double> arrivalTimes = new HashMap<>(); HashMap, List> trips = new HashMap<>(); Config config = ConfigUtils.loadConfig(configURL); @@ -306,7 +305,7 @@ public void testAgentIsAtTeleportLegAndLeavesStop() { * pt_wait and pt. Strangely only works with walk being significantly worse, does not work with small differences. */ @Test - public void testAgentIsAtTeleportLegAndWaitsAtStop_walkUnattractive() { + void testAgentIsAtTeleportLegAndWaitsAtStop_walkUnattractive() { HashMap, Double> arrivalTimes = new HashMap<>(); HashMap, List> trips = new HashMap<>(); Config config = ConfigUtils @@ -346,7 +345,7 @@ public void testAgentIsAtTeleportLegAndWaitsAtStop_walkUnattractive() { * Case 2.2 */ @Test - public void testAgentIsAtTeleportLegAndWaitsAtStop() { + void testAgentIsAtTeleportLegAndWaitsAtStop() { HashMap, Double> arrivalTimes = new HashMap<>(); HashMap, List> trips = new HashMap<>(); Config config = ConfigUtils.loadConfig(configURL); @@ -383,7 +382,7 @@ public void testAgentIsAtTeleportLegAndWaitsAtStop() { * Simulates 900 agents so this case should include every possible state of an agent. Current and future trips are replanned. */ @Test - public void testOneAgentEveryFourSeconds() { + void testOneAgentEveryFourSeconds() { HashMap, Double> arrivalTimes = new HashMap<>(); HashMap, List> trips = new HashMap<>(); Config config = ConfigUtils diff --git a/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java b/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java index 549528ceb83..def2f9bebad 100644 --- a/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java @@ -23,7 +23,7 @@ import javafx.util.Pair; import org.junit.Assert; import org.junit.Ignore; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.prep.PreparedGeometry; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -89,16 +89,16 @@ public enum routeType { } - /* + /* Part 1: these tests check whether the three route types are actually configured as described above */ - /** - * In the allIn scenario, the transitRoute in question should have all stops within zone. - */ - @Ignore - @Test - public void test_AllIn() { + /** + * In the allIn scenario, the transitRoute in question should have all stops within zone. + */ + @Ignore + @Test + void test_AllIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -122,13 +122,13 @@ public void test_AllIn() { assertEquals("All stops should be inside the zone", stopsTotal, stopsInZoneCnt); } - /** - * In the halfIn scenario, the transitRoute in question begins outside of the zone and - * ends within the zone. - */ - @Ignore - @Test - public void test_HalfIn() { + /** + * In the halfIn scenario, the transitRoute in question begins outside of the zone and + * ends within the zone. + */ + @Ignore + @Test + void test_HalfIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -150,13 +150,13 @@ public void test_HalfIn() { } - /** - * In the MiddleIn scenario, the transitRoute in question begins outside of the zone then dips - * into the zone, and finally leaves the zone once again - */ - @Ignore - @Test - public void test_MiddleIn() { + /** + * In the MiddleIn scenario, the transitRoute in question begins outside of the zone then dips + * into the zone, and finally leaves the zone once again + */ + @Ignore + @Test + void test_MiddleIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -178,19 +178,19 @@ public void test_MiddleIn() { } - /* + /* Part 2: These tests check functionality of all four trimming methods. For each trimming method, all three route types are checked. */ - /** - * trimming method: DeleteRoutesEntirelyInsideZone. - * route scenario: AllIn - * The testRoute should be deleted since all stops are within the zone. - */ - @Ignore - @Test - public void testDeleteRoutesEntirelyInsideZone_AllIn() { + /** + * trimming method: DeleteRoutesEntirelyInsideZone. + * route scenario: AllIn + * The testRoute should be deleted since all stops are within the zone. + */ + @Ignore + @Test + void testDeleteRoutesEntirelyInsideZone_AllIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -218,15 +218,15 @@ public void testDeleteRoutesEntirelyInsideZone_AllIn() { } - /** - * trimming method: DeleteRoutesEntirelyInsideZone. - * route scenario: HalfIn - * The testRoute should be retained and left unmodified, - * since some stops are outside the zone. - */ - @Ignore - @Test - public void testDeleteRoutesEntirelyInsideZone_HalfIn() { + /** + * trimming method: DeleteRoutesEntirelyInsideZone. + * route scenario: HalfIn + * The testRoute should be retained and left unmodified, + * since some stops are outside the zone. + */ + @Ignore + @Test + void testDeleteRoutesEntirelyInsideZone_HalfIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -266,15 +266,15 @@ public void testDeleteRoutesEntirelyInsideZone_HalfIn() { } - /** - * trimming method: DeleteRoutesEntirelyInsideZone. - * route scenario: MiddleIn - * The testRoute should be retained and left unmodified, - * since some stops are outside the zone. - */ - @Ignore - @Test - public void testDeleteRoutesEntirelyInsideZone_MiddleIn() { + /** + * trimming method: DeleteRoutesEntirelyInsideZone. + * route scenario: MiddleIn + * The testRoute should be retained and left unmodified, + * since some stops are outside the zone. + */ + @Ignore + @Test + void testDeleteRoutesEntirelyInsideZone_MiddleIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -314,14 +314,14 @@ public void testDeleteRoutesEntirelyInsideZone_MiddleIn() { } - /** - * trimming method: TrimEnds. - * route scenario: AllIn - * The testRoute should be deleted since all stops are within the zone. - */ - @Ignore - @Test - public void testTrimEnds_AllIn() { + /** + * trimming method: TrimEnds. + * route scenario: AllIn + * The testRoute should be deleted since all stops are within the zone. + */ + @Ignore + @Test + void testTrimEnds_AllIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -349,14 +349,14 @@ public void testTrimEnds_AllIn() { } - /** - * trimming method: TrimEnds. - * route scenario: HalfIn - * The second half of the route is outside the zone and should be trimmed - */ - @Ignore - @Test - public void testTrimEnds_HalfIn() { + /** + * trimming method: TrimEnds. + * route scenario: HalfIn + * The second half of the route is outside the zone and should be trimmed + */ + @Ignore + @Test + void testTrimEnds_HalfIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -406,14 +406,14 @@ public void testTrimEnds_HalfIn() { vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); } - /** - * trimming method: TrimEnds. - * route scenario: MiddleIn - * Since the ends are both outside of zone, route should not be modified - */ - @Ignore - @Test - public void testTrimEnds_MiddleIn() { + /** + * trimming method: TrimEnds. + * route scenario: MiddleIn + * Since the ends are both outside of zone, route should not be modified + */ + @Ignore + @Test + void testTrimEnds_MiddleIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -454,14 +454,14 @@ public void testTrimEnds_MiddleIn() { } - /** - * trimming method: SkipStops. - * route scenario: AllIn - * New route should be empty - */ - @Ignore - @Test - public void testSkipStops_AllIn() { + /** + * trimming method: SkipStops. + * route scenario: AllIn + * New route should be empty + */ + @Ignore + @Test + void testSkipStops_AllIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -486,14 +486,14 @@ public void testSkipStops_AllIn() { } - /** - * trimming method: SkipStops. - * route scenario: HalfIn - * Stops outside zone should be skipped - */ - @Ignore - @Test - public void testSkipStops_HalfIn() { + /** + * trimming method: SkipStops. + * route scenario: HalfIn + * Stops outside zone should be skipped + */ + @Ignore + @Test + void testSkipStops_HalfIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -538,14 +538,14 @@ public void testSkipStops_HalfIn() { } - /** - * trimming method: SkipStops. - * route scenario: MiddleIn - * New route should have less stops than old route, but same amount of links - */ - @Ignore - @Test - public void testSkipStops_MiddleIn() { + /** + * trimming method: SkipStops. + * route scenario: MiddleIn + * New route should have less stops than old route, but same amount of links + */ + @Ignore + @Test + void testSkipStops_MiddleIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -588,14 +588,14 @@ public void testSkipStops_MiddleIn() { vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); } - /** - * trimming method: SplitRoutes. - * route scenario: AllIn - * route will be deleted - */ - @Ignore - @Test - public void testSplitRoutes_AllIn() { + /** + * trimming method: SplitRoutes. + * route scenario: AllIn + * route will be deleted + */ + @Ignore + @Test + void testSplitRoutes_AllIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -623,14 +623,14 @@ public void testSplitRoutes_AllIn() { vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); } - /** - * trimming method: SplitRoutes. - * route scenario: HalfIn - * New route should have less stops than old route - */ - @Ignore - @Test - public void testSplitRoutes_HalfIn() { + /** + * trimming method: SplitRoutes. + * route scenario: HalfIn + * New route should have less stops than old route + */ + @Ignore + @Test + void testSplitRoutes_HalfIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -674,14 +674,14 @@ public void testSplitRoutes_HalfIn() { vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); } - /** - * trimming method: SplitRoutes. - * route scenario: MiddleIn - * Two routes should be created, each with only one stop within zone - */ - @Ignore - @Test - public void testSplitRoutes_MiddleIn() { + /** + * trimming method: SplitRoutes. + * route scenario: MiddleIn + * Two routes should be created, each with only one stop within zone + */ + @Ignore + @Test + void testSplitRoutes_MiddleIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -732,22 +732,22 @@ public void testSplitRoutes_MiddleIn() { } - /* - Part 3: tests hub functionality for SplitRoutes trimming method (using route type "middleIn") - Hubs allow route to extend into zone to reach a import transit stop (like a major transfer point) - */ + /* + Part 3: tests hub functionality for SplitRoutes trimming method (using route type "middleIn") + Hubs allow route to extend into zone to reach a import transit stop (like a major transfer point) + */ - /** - * Test Hub functionality - * trimming method: SplitRoutes. - * route scenario: MiddleIn - * tests reach of hubs. Left hub should be included in route 1, while right hub should not be - * included in route 2, due to lacking reach - */ - @Ignore - @Test - public void testSplitRoutes_MiddleIn_Hub_ValidateReach() { + /** + * Test Hub functionality + * trimming method: SplitRoutes. + * route scenario: MiddleIn + * tests reach of hubs. Left hub should be included in route 1, while right hub should not be + * included in route 2, due to lacking reach + */ + @Ignore + @Test + void testSplitRoutes_MiddleIn_Hub_ValidateReach() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -808,16 +808,16 @@ public void testSplitRoutes_MiddleIn_Hub_ValidateReach() { vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); } - /** - * Test Hub functionality - * trimming method: SplitRoutes. - * route scenario: MiddleIn - * tests parameter to include first nearest hub, even if reach is insufficient. - * Right hub should be included, even though reach is too low. - */ - @Ignore - @Test - public void testSplitRoutes_MiddleIn_Hub_IncludeFirstHubInZone() { + /** + * Test Hub functionality + * trimming method: SplitRoutes. + * route scenario: MiddleIn + * tests parameter to include first nearest hub, even if reach is insufficient. + * Right hub should be included, even though reach is too low. + */ + @Ignore + @Test + void testSplitRoutes_MiddleIn_Hub_IncludeFirstHubInZone() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); Id transitLineId = routeType.middleIn.transitLineId; @@ -886,15 +886,15 @@ public void testSplitRoutes_MiddleIn_Hub_IncludeFirstHubInZone() { vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); } - /** - * Test Hub functionality - * trimming method: SplitRoutes. - * route scenario: MiddleIn - * if multiple hubs are within reach of route, the route should go to further one - */ - @Ignore - @Test - public void testSplitRoutes_MiddleIn_Hub_MultipleHubs() { + /** + * Test Hub functionality + * trimming method: SplitRoutes. + * route scenario: MiddleIn + * if multiple hubs are within reach of route, the route should go to further one + */ + @Ignore + @Test + void testSplitRoutes_MiddleIn_Hub_MultipleHubs() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -954,16 +954,16 @@ public void testSplitRoutes_MiddleIn_Hub_MultipleHubs() { } - /** - * Test Hub functionality - * trimming method: SplitRoutes. - * route scenario: MiddleIn - * if two new routes overlap (because they both reach to same hub) - * then they should be combined into one route - */ - @Ignore - @Test - public void testSplitRoutes_MiddleIn_Hub_OverlapRoutes() { + /** + * Test Hub functionality + * trimming method: SplitRoutes. + * route scenario: MiddleIn + * if two new routes overlap (because they both reach to same hub) + * then they should be combined into one route + */ + @Ignore + @Test + void testSplitRoutes_MiddleIn_Hub_OverlapRoutes() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); @@ -1006,20 +1006,20 @@ public void testSplitRoutes_MiddleIn_Hub_OverlapRoutes() { } - /* - Part 4: Tests individual user-defined parameters - */ - - /** - * Test parameter allowableStopsWithinZone - * trimming method: SplitRoutes. - * route scenario: MiddleIn - * route should not be split, since the parameter allowableStopsWithinZone is equal to the number - * of stops within zone + /* + Part 4: Tests individual user-defined parameters */ - @Ignore - @Test - public void testSplitRoutes_MiddleIn_AllowableStopsWithin() { + + /** + * Test parameter allowableStopsWithinZone + * trimming method: SplitRoutes. + * route scenario: MiddleIn + * route should not be split, since the parameter allowableStopsWithinZone is equal to the number + * of stops within zone + */ + @Ignore + @Test + void testSplitRoutes_MiddleIn_AllowableStopsWithin() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); Id transitLineId = routeType.middleIn.transitLineId; @@ -1059,9 +1059,9 @@ public void testSplitRoutes_MiddleIn_AllowableStopsWithin() { } - @Ignore - @Test - public void testDeparturesAndOffsetsAndDescription() { + @Ignore + @Test + void testDeparturesAndOffsetsAndDescription() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); Set> stopsInZone = getStopsInZone(scenario.getTransitSchedule(), inZoneShpFile); diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java index 42fd52d8119..ba7aac9976a 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java @@ -2,8 +2,8 @@ import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Population; @@ -75,7 +75,7 @@ public void setUp() { } @Test - public void testPersonWithNegativeIncome(){ + void testPersonWithNegativeIncome(){ Id id = Id.createPersonId("negativeIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); //person's attribute says it has negative income which is considered invalid and therefore the subpopulation's mgnUtilityOfMoney is taken (which is 1) @@ -83,7 +83,7 @@ public void testPersonWithNegativeIncome(){ } @Test - public void testPersonWithNoIncome(){ + void testPersonWithNoIncome(){ Id id = Id.createPersonId("zeroIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); //person's attribute says it has 0 income which is considered invalid and therefore the subpopulation's mgnUtilityOfMoney is taken (which is 1) @@ -91,28 +91,28 @@ public void testPersonWithNoIncome(){ } @Test - public void testPersonWithLowIncome(){ + void testPersonWithLowIncome(){ Id id = Id.createPersonId("lowIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssert(params, 0.5d, 0.5d); } @Test - public void testPersonWithHighIncome(){ + void testPersonWithHighIncome(){ Id id = Id.createPersonId("highIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssert(params, 1.5d, 0.5d); } @Test - public void testPersonWithMediumIncome(){ + void testPersonWithMediumIncome(){ Id id = Id.createPersonId("mediumIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssert(params, 1d, 0.5d); } @Test - public void testMoneyScore(){ + void testMoneyScore(){ ScoringParameters paramsRich = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("highIncome"))); CharyparNagelMoneyScoring moneyScoringRich = new CharyparNagelMoneyScoring(paramsRich); moneyScoringRich.addMoney(100); diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java index d94fa19d64d..a6c9cdbb8d0 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java @@ -1,6 +1,8 @@ package playground.vsp.scoring; -import org.junit.*; +import org.junit.Assert; +import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -95,7 +97,7 @@ public void setUp() { } @Test - public void testPersonWithNegativeIncome(){ + void testPersonWithNegativeIncome(){ Id id = Id.createPersonId("negativeIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); //person's attribute says it has negative income which is considered invalid and therefore the subpopulation's mgnUtilityOfMoney is taken (which is 1) @@ -103,7 +105,7 @@ public void testPersonWithNegativeIncome(){ } @Test - public void testPersonWithNoIncome(){ + void testPersonWithNoIncome(){ Id id = Id.createPersonId("zeroIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); //person's attribute says it has 0 income which is considered invalid and therefore the subpopulation's mgnUtilityOfMoney is taken (which is 1) @@ -111,28 +113,28 @@ public void testPersonWithNoIncome(){ } @Test - public void testPersonWithLowIncome(){ + void testPersonWithLowIncome(){ Id id = Id.createPersonId("lowIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssert(params, 0.5d, 0.5d); } @Test - public void testPersonWithHighIncome(){ + void testPersonWithHighIncome(){ Id id = Id.createPersonId("highIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssert(params, 1.5d, 0.5d); } @Test - public void testPersonWithMediumIncome(){ + void testPersonWithMediumIncome(){ Id id = Id.createPersonId("mediumIncome"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssert(params, 1d, 0.5d); } @Test - public void testPersonFreight(){ + void testPersonFreight(){ Id id = Id.createPersonId("freight"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); //freight agent has no income attribute set, so it should use the marginal utility of money that is set in it's subpopulation scoring parameters! @@ -140,7 +142,7 @@ public void testPersonFreight(){ } @Test - public void testFreightWithIncome(){ + void testFreightWithIncome(){ Id id = Id.createPersonId("freightWithIncome1"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssert(params, 1.5/444d, 1d); @@ -150,7 +152,7 @@ public void testFreightWithIncome(){ } @Test - public void testMoneyScore(){ + void testMoneyScore(){ ScoringParameters paramsRich = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("highIncome"))); CharyparNagelMoneyScoring moneyScoringRich = new CharyparNagelMoneyScoring(paramsRich); moneyScoringRich.addMoney(100); diff --git a/contribs/vsp/src/test/java/playground/vsp/zzArchive/bvwpOld/BvwpTest.java b/contribs/vsp/src/test/java/playground/vsp/zzArchive/bvwpOld/BvwpTest.java index fe8cee1a096..ea0ef7f8974 100644 --- a/contribs/vsp/src/test/java/playground/vsp/zzArchive/bvwpOld/BvwpTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/zzArchive/bvwpOld/BvwpTest.java @@ -20,19 +20,19 @@ package playground.vsp.zzArchive.bvwpOld; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; - public class BvwpTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testOne() { + @Test + void testOne() { Values economicValues = EconomicValues.createEconomicValuesForTest1(); diff --git a/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java b/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java index 2db9c5610db..eb432ad08a5 100644 --- a/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java @@ -27,7 +27,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigReader; @@ -49,8 +49,8 @@ public void setup() { System.setProperty("matsim.preferLocalDtds", "true"); } - @Test - public void testConfigIO_general() { + @Test + void testConfigIO_general() { SwissRailRaptorConfigGroup config1 = new SwissRailRaptorConfigGroup(); { // prepare config1 @@ -69,8 +69,8 @@ public void testConfigIO_general() { Assert.assertEquals(0.0031 * 3600, config2.getTransferPenaltyCostPerTravelTimeHour(), 0.0); } - @Test - public void testConfigIO_rangeQuery() { + @Test + void testConfigIO_rangeQuery() { SwissRailRaptorConfigGroup config1 = new SwissRailRaptorConfigGroup(); { // prepare config1 @@ -108,8 +108,8 @@ public void testConfigIO_rangeQuery() { Assert.assertEquals(15*60, range2.getMaxLaterDeparture()); } - @Test - public void testConfigIO_routeSelector() { + @Test + void testConfigIO_routeSelector() { SwissRailRaptorConfigGroup config1 = new SwissRailRaptorConfigGroup(); { // prepare config1 @@ -150,8 +150,8 @@ public void testConfigIO_routeSelector() { Assert.assertEquals(1.2, selector2.getBetaTravelTime(), 0.0); } - @Test - public void testConfigIO_intermodalAccessEgress() { + @Test + void testConfigIO_intermodalAccessEgress() { SwissRailRaptorConfigGroup config1 = new SwissRailRaptorConfigGroup(); { // prepare config1 @@ -215,8 +215,8 @@ public void testConfigIO_intermodalAccessEgress() { Assert.assertEquals("hub", paramSet2.getStopFilterValue()); } - @Test - public void testConfigIO_modeMappings() { + @Test + void testConfigIO_modeMappings() { SwissRailRaptorConfigGroup config1 = new SwissRailRaptorConfigGroup(); { // prepare config1 diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/CapacityDependentScoringTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/CapacityDependentScoringTest.java index 31ebe0fa112..0518b08dcf2 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/CapacityDependentScoringTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/CapacityDependentScoringTest.java @@ -20,7 +20,7 @@ package ch.sbb.matsim.routing.pt.raptor; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -81,7 +81,7 @@ public class CapacityDependentScoringTest { @Test - public void testScoring() { + void testScoring() { double normalScore = calcScore(new Fixture(), false); double capDepScore = calcScore(new Fixture(), true); diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/OccupancyTrackerTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/OccupancyTrackerTest.java index 4e9b916dde4..809f316a4bd 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/OccupancyTrackerTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/OccupancyTrackerTest.java @@ -21,7 +21,7 @@ import ch.sbb.matsim.routing.pt.raptor.OccupancyData.DepartureData; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.PersonDepartureEvent; @@ -54,7 +54,7 @@ public class OccupancyTrackerTest { @Test - public void testGetNextDeparture() { + void testGetNextDeparture() { Fixture f = new Fixture(); EventsManager events = EventsUtils.createEventsManager(); @@ -131,7 +131,7 @@ public void testGetNextDeparture() { } @Test - public void testGetDepartureData() { + void testGetDepartureData() { Fixture f = new Fixture(); EventsManager events = EventsUtils.createEventsManager(); diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorStopFinderTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorStopFinderTest.java index 9f712b2edaf..1fe325b7801 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorStopFinderTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorStopFinderTest.java @@ -21,7 +21,7 @@ import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -66,21 +66,19 @@ public class RaptorStopFinderTest { private final Facility toFac = new FakeFacility(new Coord(100000, 0), Id.create("XX", Link.class)); // stop X - /** Empty Initial Search Radius - * Tests the how the StopFinder reacts when there are no public transit stops within the Initial_Search_Radius. - * The expected behaviour of the StopFinder is to find the closest public transit stop and set the new search - * radius as the sum of the distance to the nearest stop and the Search_Extension_Radius. However, if the general - * radius is smaller than this new search radius, then the StopFinder will only search to the extents of the general - * Radius. - * - * This functionality is tested for the two RaptorStopFinders: 1) DefaultStopFinder and 2) RandomAccessEgressModeRaptorStopFinder - * For each RaptorStopFinder there is one test where StopFilterAttributes are not used to exlclude stops, and one test - * where StopFilterAttributes are used. - */ - - - @Test - public void testDefaultStopFinder_EmptyInitialSearchRadius() { + /** Empty Initial Search Radius + * Tests the how the StopFinder reacts when there are no public transit stops within the Initial_Search_Radius. + * The expected behaviour of the StopFinder is to find the closest public transit stop and set the new search + * radius as the sum of the distance to the nearest stop and the Search_Extension_Radius. However, if the general + * radius is smaller than this new search radius, then the StopFinder will only search to the extents of the general + * Radius. + * + * This functionality is tested for the two RaptorStopFinders: 1) DefaultStopFinder and 2) RandomAccessEgressModeRaptorStopFinder + * For each RaptorStopFinder there is one test where StopFilterAttributes are not used to exlclude stops, and one test + * where StopFilterAttributes are used. + */ + @Test + void testDefaultStopFinder_EmptyInitialSearchRadius() { /* General Radius includes no stops. Search_Extension_Radius is 0 Expected: StopFinder will find no stops, since closest stop is outside of general radius. Therefore agent will use transit_walk to get from A to X. @@ -198,8 +196,8 @@ public void testDefaultStopFinder_EmptyInitialSearchRadius() { } - @Test - public void testDefaultStopFinder_EmptyInitialSearchRadius_StopFilterAttributes() { + @Test + void testDefaultStopFinder_EmptyInitialSearchRadius_StopFilterAttributes() { /* Initial_Search_Radius and General Radius contain only stop B. Stop B is not "walkAccessible"; all other stops are "walkAccessible" Search_Extension_Radius is 0 Expected: StopFinder will find no stops, since closest accessible stop is outside of general radius. Therefore @@ -395,8 +393,8 @@ Initial_Search_Radius includes B (not "walkAccessible") } - @Test - public void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius() { + @Test + void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius() { /* General Radius includes no stops. Search_Extension_Radius is 0 Expected: StopFinder will find no stops, since closest stop is outside of general radius. Therefore agent will use transit_walk to get from A to X. @@ -516,8 +514,8 @@ public void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius( } - @Test - public void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius_StopFilterAttributes() { + @Test + void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius_StopFilterAttributes() { /* Initial_Search_Radius and General Radius contain only stop B. Stop B is not "walkAccessible"; all other stops are "walkAccessible" Search_Extension_Radius is 0 Expected: StopFinder will find no stops, since closest accessible stop is outside of general radius. Therefore @@ -716,22 +714,22 @@ Initial_Search_Radius includes B (not "walkAccessible") } - // *********************************************************************************************************** - - /** Half Full Initial Search Radius - * Tests the how the StopFinder reacts when there is only one public transit stop within the Initial_Search_Radius. - * In this case, the Initial_Search_Radius will always contain stop B, but no other stops. - * The expected behaviour of the StopFinder define a new extended search radius, which is the sum of the distance - * to stop B and the Search_Extension_Radius. However, if the general - * radius is smaller than this new search radius, then the StopFinder will only search to the extents of the general - * Radius. - * - * This functionality is tested for the two RaptorStopFinders: 1) DefaultStopFinder and 2) RandomAccessEgressModeRaptorStopFinder - * For each RaptorStopFinder there is one test where StopFilterAttributes are not used to exlclude stops, and one test - * where StopFilterAttributes are used. - */ - @Test - public void testDefaultStopFinder_HalfFullInitialSearchRadius() { + // *********************************************************************************************************** + + /** Half Full Initial Search Radius + * Tests the how the StopFinder reacts when there is only one public transit stop within the Initial_Search_Radius. + * In this case, the Initial_Search_Radius will always contain stop B, but no other stops. + * The expected behaviour of the StopFinder define a new extended search radius, which is the sum of the distance + * to stop B and the Search_Extension_Radius. However, if the general + * radius is smaller than this new search radius, then the StopFinder will only search to the extents of the general + * Radius. + * + * This functionality is tested for the two RaptorStopFinders: 1) DefaultStopFinder and 2) RandomAccessEgressModeRaptorStopFinder + * For each RaptorStopFinder there is one test where StopFilterAttributes are not used to exlclude stops, and one test + * where StopFilterAttributes are used. + */ + @Test + void testDefaultStopFinder_HalfFullInitialSearchRadius() { /* Initial_Search_Radius includes B. Search_Extension_Radius is 0. General_Radius includes B, C, D and E Expected: Stop Finder will only find stop B, since the Search_Extension_Radius doesn't encompass more stops. @@ -867,8 +865,8 @@ public void testDefaultStopFinder_HalfFullInitialSearchRadius() { } - @Test - public void testDefaultStopFinder_HalfFullInitialSearchRadius_StopFilterAttributes() { + @Test + void testDefaultStopFinder_HalfFullInitialSearchRadius_StopFilterAttributes() { /* Initial_Search_Radius includes B and C. Search_Extension_Radius is 0. General_Radius includes B, C, D and E Stop B is not "walkAccessible", but all others are. @@ -973,8 +971,8 @@ public void testDefaultStopFinder_HalfFullInitialSearchRadius_StopFilterAttribut } - @Test - public void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadius() { + @Test + void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadius() { /* Initial_Search_Radius includes B. Search_Extension_Radius is 0. General_Radius includes B, C, D and E Expected: Stop Finder will only find stop B, since the Search_Extension_Radius doesn't encompass more stops. @@ -1113,8 +1111,8 @@ public void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadi } - @Test - public void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadius_StopFilterAttributes() { + @Test + void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadius_StopFilterAttributes() { /* Initial_Search_Radius includes B and C. Search_Extension_Radius is 0. General_Radius includes B, C, D and E Stop B is not "walkAccessible", but all others are. @@ -1221,21 +1219,21 @@ public void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadi } - // *********************************************************************************************************** + // *********************************************************************************************************** - /** Full Initial Search Radius - * Tests the how the StopFinder reacts when there are at least 2 stop within the Initial_Search_Radius. In the - * following tests, the Initial_Search_Radius includes stops B and C. - * The StopFinder should then not find stops outside of Initial_Search_Radius, even if the Search_Extension_Radius - * is initialized. If the general Radius is smaller than the Initial_Search_Radius, then the StopFinder should only - * search to the extents of the general radius. - * - * This functionality is tested for the two RaptorStopFinders: 1) DefaultStopFinder and 2) RandomAccessEgressModeRaptorStopFinder - * For each RaptorStopFinder there is one test where StopFilterAttributes are not used to exlclude stops, and one test - * where StopFilterAttributes are used. - */ - @Test - public void testDefaultStopFinder_FullInitialSearchRadius() { + /** Full Initial Search Radius + * Tests the how the StopFinder reacts when there are at least 2 stop within the Initial_Search_Radius. In the + * following tests, the Initial_Search_Radius includes stops B and C. + * The StopFinder should then not find stops outside of Initial_Search_Radius, even if the Search_Extension_Radius + * is initialized. If the general Radius is smaller than the Initial_Search_Radius, then the StopFinder should only + * search to the extents of the general radius. + * + * This functionality is tested for the two RaptorStopFinders: 1) DefaultStopFinder and 2) RandomAccessEgressModeRaptorStopFinder + * For each RaptorStopFinder there is one test where StopFilterAttributes are not used to exlclude stops, and one test + * where StopFilterAttributes are used. + */ + @Test + void testDefaultStopFinder_FullInitialSearchRadius() { /* Search_Extension_Radius includes D and E @@ -1331,8 +1329,8 @@ public void testDefaultStopFinder_FullInitialSearchRadius() { } - @Test - public void testDefaultStopFinder_FullInitialSearchRadius_StopFilterAttributes() { + @Test + void testDefaultStopFinder_FullInitialSearchRadius_StopFilterAttributes() { /* Initial_Search_Radius includes B, C, and D @@ -1445,8 +1443,8 @@ public void testDefaultStopFinder_FullInitialSearchRadius_StopFilterAttributes() } } - @Test - public void testRandomAccessEgressModeRaptorStopFinder_FullInitialSearchRadius() { + @Test + void testRandomAccessEgressModeRaptorStopFinder_FullInitialSearchRadius() { /* Search_Extension_Radius includes D and E @@ -1544,8 +1542,8 @@ public void testRandomAccessEgressModeRaptorStopFinder_FullInitialSearchRadius() } - @Test - public void testRandomAccessEgressModeRaptorStopFinder_FullInitialSearchRadius_StopFilterAttributes() { + @Test + void testRandomAccessEgressModeRaptorStopFinder_FullInitialSearchRadius_StopFilterAttributes() { /* Initial_Search_Radius includes B, C, and D @@ -1661,10 +1659,10 @@ public void testRandomAccessEgressModeRaptorStopFinder_FullInitialSearchRadius_S } - // *********************************************************************************************************** - @Deprecated - @Test - public void testDefaultStopFinder_testMultipleModes() { + // *********************************************************************************************************** + @Deprecated + @Test + void testDefaultStopFinder_testMultipleModes() { // Test 7: Test Stop Filter Attributes // Initial_Search_Radius includes B and C and D diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java index 2a6ee7b9abc..d401ec3ba52 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java @@ -22,7 +22,7 @@ import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigGroup; import org.matsim.core.config.ConfigReader; @@ -43,8 +43,8 @@ public void setup() { System.setProperty("matsim.preferLocalDtds", "true"); } - @Test - public void testConfigLoading() { + @Test + void testConfigLoading() { // prepare config SwissRailRaptorConfigGroup srrConfig = new SwissRailRaptorConfigGroup(); Config config1 = ConfigUtils.createConfig(srrConfig); diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorCapacitiesTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorCapacitiesTest.java index a986cb26763..eaa6c0ddfc6 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorCapacitiesTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorCapacitiesTest.java @@ -21,7 +21,7 @@ import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -70,7 +70,7 @@ public class SwissRailRaptorCapacitiesTest { @Test - public void testUseSlowerAlternative() { + void testUseSlowerAlternative() { Fixture f = new Fixture(); // default case diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorDataTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorDataTest.java index 5a0a4711a2f..6fbd90145a8 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorDataTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorDataTest.java @@ -20,7 +20,7 @@ package ch.sbb.matsim.routing.pt.raptor; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.pt.transitSchedule.api.TransitStopFacility; @@ -29,8 +29,8 @@ */ public class SwissRailRaptorDataTest { - @Test - public void testTransfersFromSchedule() { + @Test + void testTransfersFromSchedule() { Fixture f = new Fixture(); f.init(); diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorInVehicleCostTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorInVehicleCostTest.java index 76b098fa73f..05aa44fe5d2 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorInVehicleCostTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorInVehicleCostTest.java @@ -20,7 +20,7 @@ package ch.sbb.matsim.routing.pt.raptor; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -72,7 +72,7 @@ */ public class SwissRailRaptorInVehicleCostTest { - /* fastRoute takes 14min30sec. (==> 870 sec) + /*fastRoute takes 14min30sec. (==> 870 sec) * slowRoute takes 20min30sec (==> 1230 sec) and departs 1 min later. * slowRoute arrives 7 minutes later ==> 420 sec * @@ -82,19 +82,19 @@ public class SwissRailRaptorInVehicleCostTest { */ @Test - public void testBaseline_defaultInVehicleCostCalculator_uses_fastRoute() { + void testBaseline_defaultInVehicleCostCalculator_uses_fastRoute() { Fixture f = new Fixture(); runTest(f, new DefaultRaptorInVehicleCostCalculator(), f.fastLineId); } @Test - public void testBaseline_capacityDependentInVehicleCost_indifferent_uses_fastRoute() { + void testBaseline_capacityDependentInVehicleCost_indifferent_uses_fastRoute() { Fixture f = new Fixture(); runTest(f, new CapacityDependentInVehicleCostCalculator(1.0, 0.3, 0.6, 1.8), f.fastLineId); } @Test - public void test_capacityDependentInVehicleCost_prefersLowOccupancy_uses_slowRoute() { + void test_capacityDependentInVehicleCost_prefersLowOccupancy_uses_slowRoute() { Fixture f = new Fixture(); // from the note above: @@ -114,13 +114,13 @@ public void test_capacityDependentInVehicleCost_prefersLowOccupancy_uses_slowRou } @Test - public void test_capacityDependentInVehicleCost_minorHighOccupancyAvoidance_uses_fastRoute() { + void test_capacityDependentInVehicleCost_minorHighOccupancyAvoidance_uses_fastRoute() { Fixture f = new Fixture(); runTest(f, new CapacityDependentInVehicleCostCalculator(1.0, 0.3, 0.6, 1.2), f.fastLineId); } @Test - public void test_capacityDependentInVehicleCost_majorHighOccupancyAvoidance_uses_slowRoute() { + void test_capacityDependentInVehicleCost_majorHighOccupancyAvoidance_uses_slowRoute() { Fixture f = new Fixture(); runTest(f, new CapacityDependentInVehicleCostCalculator(1.0, 0.3, 0.6, 2.0), f.slowLineId); } diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorIntermodalTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorIntermodalTest.java index 973d16bb1f2..61ddb4ba6de 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorIntermodalTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorIntermodalTest.java @@ -22,7 +22,7 @@ import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; import ch.sbb.matsim.config.SwissRailRaptorConfigGroup.IntermodalAccessEgressParameterSet; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -69,8 +69,8 @@ */ public class SwissRailRaptorIntermodalTest { - @Test - public void testIntermodalTrip() { + @Test + void testIntermodalTrip() { IntermodalFixture f = new IntermodalFixture(); ScoringConfigGroup.ModeParams walk = new ScoringConfigGroup.ModeParams(TransportMode.walk); @@ -133,8 +133,8 @@ public void testIntermodalTrip() { Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } - @Test - public void testIntermodalTrip_TripRouterIntegration() { + @Test + void testIntermodalTrip_TripRouterIntegration() { IntermodalFixture f = new IntermodalFixture(); RoutingModule walkRoutingModule = new TeleportationRoutingModule(TransportMode.walk, f.scenario, 1.1, 1.3); @@ -214,8 +214,8 @@ public void testIntermodalTrip_TripRouterIntegration() { Assert.assertEquals(0.0, ((Activity)planElements.get(7)).getMaximumDuration().seconds(), 0.0); } - @Test - public void testIntermodalTrip_walkOnlyNoSubpop() { + @Test + void testIntermodalTrip_walkOnlyNoSubpop() { IntermodalFixture f = new IntermodalFixture(); ScoringConfigGroup.ModeParams walk = new ScoringConfigGroup.ModeParams(TransportMode.walk); @@ -262,12 +262,12 @@ public void testIntermodalTrip_walkOnlyNoSubpop() { Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } - /** - * Test that if start and end are close to each other, such that the intermodal - * access and egress go to/from the same stop, still a direct transit_walk is returned. - */ - @Test - public void testIntermodalTrip_withoutPt() { + /** + * Test that if start and end are close to each other, such that the intermodal + * access and egress go to/from the same stop, still a direct transit_walk is returned. + */ + @Test + void testIntermodalTrip_withoutPt() { IntermodalFixture f = new IntermodalFixture(); ScoringConfigGroup.ModeParams walk = new ScoringConfigGroup.ModeParams(TransportMode.walk); @@ -302,8 +302,8 @@ public void testIntermodalTrip_withoutPt() { Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); } - @Test - public void testDirectWalkFactor() { + @Test + void testDirectWalkFactor() { IntermodalFixture f = new IntermodalFixture(); f.config.scoring().setPerforming_utils_hr(6.0); @@ -392,8 +392,8 @@ public void testDirectWalkFactor() { Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } - @Test - public void testAccessEgressModeFasterThanPt() { + @Test + void testAccessEgressModeFasterThanPt() { IntermodalFixture f = new IntermodalFixture(); /* * setDirectWalkFactor(Double.POSITIVE_INFINITY) leads to the case where in SwissRailRaptor.calcRoute() both the found @@ -486,9 +486,8 @@ public void testAccessEgressModeFasterThanPt() { } - - @Test - public void testIntermodalTrip_competingAccess() { + @Test + void testIntermodalTrip_competingAccess() { IntermodalFixture f = new IntermodalFixture(); Map routingModules = new HashMap<>(); @@ -580,10 +579,10 @@ public void testIntermodalTrip_competingAccess() { } } - // Checks RandomAccessEgressModeRaptorStopFinder. The desired result is that the StopFinder will try out the different - // access/egress modes, regardless of the modes' freespeeds. - @Test - public void testIntermodalTrip_RandomAccessEgressModeRaptorStopFinder() { + // Checks RandomAccessEgressModeRaptorStopFinder. The desired result is that the StopFinder will try out the different + // access/egress modes, regardless of the modes' freespeeds. + @Test + void testIntermodalTrip_RandomAccessEgressModeRaptorStopFinder() { IntermodalFixture f = new IntermodalFixture(); Map routingModules = new HashMap<>(); @@ -682,13 +681,13 @@ else if ((((Leg)(legs.get(0))).getMode().equals(TransportMode.bike)) && (((Leg)l } } - /** - * Tests the following situation: two stops A and B close to each other, A has intermodal access, B not. - * The route is fastest from B to C, with intermodal access to A and then transferring from A to B. - * Make sure that in such cases the correct transit_walks are generated around stops A and B for access to pt. - */ - @Test - public void testIntermodalTrip_accessTransfer() { + /** + * Tests the following situation: two stops A and B close to each other, A has intermodal access, B not. + * The route is fastest from B to C, with intermodal access to A and then transferring from A to B. + * Make sure that in such cases the correct transit_walks are generated around stops A and B for access to pt. + */ + @Test + void testIntermodalTrip_accessTransfer() { IntermodalTransferFixture f = new IntermodalTransferFixture(); Facility fromFac = new FakeFacility(new Coord(10000, 500), Id.create("from", Link.class)); // stop B or C @@ -731,17 +730,17 @@ public void testIntermodalTrip_accessTransfer() { Assert.assertEquals("to", legAccess.getRoute().getEndLinkId().toString()); } - /** - * When using intermodal access/egress, transfers at the beginning are allowed to - * be able to transfer from a stop with intermodal access/egress to another stop - * with better connections to the destination. Earlier versions of SwissRailRaptor - * had a bug that resulted in only stops where such transfers were possible to be - * used for route finding, but not stops directly reachable and usable. - * This test tries to cover this case to make sure, route finding works as expected - * in all cases. - */ - @Test - public void testIntermodalTrip_singleReachableStop() { + /** + * When using intermodal access/egress, transfers at the beginning are allowed to + * be able to transfer from a stop with intermodal access/egress to another stop + * with better connections to the destination. Earlier versions of SwissRailRaptor + * had a bug that resulted in only stops where such transfers were possible to be + * used for route finding, but not stops directly reachable and usable. + * This test tries to cover this case to make sure, route finding works as expected + * in all cases. + */ + @Test + void testIntermodalTrip_singleReachableStop() { IntermodalTransferFixture f = new IntermodalTransferFixture(); f.srrConfig.getIntermodalAccessEgressParameterSets().removeIf(paramset -> paramset.getMode().equals("bike")); // we only want "walk" as mode @@ -777,8 +776,8 @@ public void testIntermodalTrip_singleReachableStop() { } - @Test - public void testIntermodalTrip_egressTransfer() { + @Test + void testIntermodalTrip_egressTransfer() { IntermodalTransferFixture f = new IntermodalTransferFixture(); Facility fromFac = new FakeFacility(new Coord(20000, 100), Id.create("from", Link.class)); // stop D @@ -821,12 +820,12 @@ public void testIntermodalTrip_egressTransfer() { Assert.assertEquals("to", legBike.getRoute().getEndLinkId().toString()); } - /** - * If there is no pt stop within the search radius, the Raptor will assign a transit_walk route from the fromFacility - * to the toFacility. In this case, the search radius is 500, but the fromFacility is 600 away from stop A. - */ - @Test - public void testIntermodalTrip_noPtStopsInRadius() { + /** + * If there is no pt stop within the search radius, the Raptor will assign a transit_walk route from the fromFacility + * to the toFacility. In this case, the search radius is 500, but the fromFacility is 600 away from stop A. + */ + @Test + void testIntermodalTrip_noPtStopsInRadius() { IntermodalTransferFixture f = new IntermodalTransferFixture(); f.srrConfig.getIntermodalAccessEgressParameterSets().removeIf(paramset -> paramset.getMode().equals("bike")); // we only want "walk" as mode @@ -843,7 +842,7 @@ public void testIntermodalTrip_noPtStopsInRadius() { Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); } - /** + /** * The agent is placed close to stop B, which is bike accessible. The agent is 600 meters away from stop B, which * puts it inside the Bike Radius for Access/Egress Mode but not in the Walk radius. This test is meant to verify * that the Swiss Rail Raptor will give the agent a transit_walk route if all the applicable intermodal @@ -858,8 +857,8 @@ public void testIntermodalTrip_noPtStopsInRadius() { * Swiss Rail Raptor will return a transit_walk between the fromFacility and the toFacility. */ - @Test - public void testIntermodalTrip_accessModeRouterReturnsNull() { + @Test + void testIntermodalTrip_accessModeRouterReturnsNull() { // Part 1: Bike is very fast. Bike Router will return intermodal route including bike, pt, and walk. IntermodalTransferFixture f = new IntermodalTransferFixture(); @@ -919,17 +918,18 @@ public List calcRoute(RoutingRequest request) { Assert.assertNull("The router should not find a route and return null, but did return something else.", legs2); } - /** - * - * The agent has a super-fast bike. So in theory it is faster to travel - * from stop_3 to the destination. However, with the introduced trip share - * constraint it will still take the closest stop accessible by the bike. - * If this constraint is not used the agent will take pt_3 stop as an - * access stop to his final destination. - * - */ - @Test - public void testIntermodalTrip_tripLengthShare() { + + /** + * + * The agent has a super-fast bike. So in theory it is faster to travel + * from stop_3 to the destination. However, with the introduced trip share + * constraint it will still take the closest stop accessible by the bike. + * If this constraint is not used the agent will take pt_3 stop as an + * access stop to his final destination. + * + */ + @Test + void testIntermodalTrip_tripLengthShare() { IntermodalFixture f = new IntermodalFixture(); ScoringConfigGroup.ModeParams walk = new ScoringConfigGroup.ModeParams(TransportMode.walk); @@ -995,8 +995,8 @@ public void testIntermodalTrip_tripLengthShare() { Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } - @Test - public void testIntermodalTrip_activityInteraction() { + @Test + void testIntermodalTrip_activityInteraction() { double bikeInteractionDuration = 1.0; double walkSpeed = 1.1; IntermodalFixture f = new IntermodalFixture(); @@ -1110,14 +1110,14 @@ public List calcRoute(RoutingRequest request) { Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } - /** - * - * This test tests the intermodal router when access modes - * have interaction activities and it tests the inclusion of the - * pt interaction activities by the SwissRailRaptorRoutingModule - */ - @Test - public void testIntermodalTrip_activityInteractionAdd() { + /** + * + * This test tests the intermodal router when access modes + * have interaction activities and it tests the inclusion of the + * pt interaction activities by the SwissRailRaptorRoutingModule + */ + @Test + void testIntermodalTrip_activityInteractionAdd() { double bikeInteractionDuration = 1.0; double walkSpeed = 1.1; IntermodalFixture f = new IntermodalFixture(); @@ -1238,7 +1238,7 @@ public List calcRoute(RoutingRequest request) { } @Test - public void testIntermodalTripWithAccessAndEgressTimesAtStops() { + void testIntermodalTripWithAccessAndEgressTimesAtStops() { IntermodalFixture f = new IntermodalFixture(); f.scenario.getTransitSchedule().getFacilities().values() .forEach(stopFacility -> TransitScheduleUtils.setSymmetricStopAccessEgressTime(stopFacility,120.0)); diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java index 13ab81099e8..f043d8bbc77 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java @@ -25,8 +25,8 @@ import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -90,8 +90,8 @@ public void setUp() { System.setProperty("matsim.preferLocalDtds", "true"); } - @Test - public void testInitialization() { + @Test + void testInitialization() { Config config = ConfigUtils.createConfig(); config.controller().setLastIteration(0); config.controller().setOutputDirectory(this.utils.getOutputDirectory()); @@ -117,8 +117,8 @@ public void install() { Assert.assertTrue(module instanceof SwissRailRaptorRoutingModule); } - @Test - public void testIntermodalIntegration() { + @Test + void testIntermodalIntegration() { IntermodalFixture f = new IntermodalFixture(); // add a single agent traveling with (intermodal) pt from A to B @@ -247,11 +247,11 @@ public void install() { } - /** - * Test update of SwissRailRaptorData after TransitScheduleChangedEvent - */ - @Test - public void testTransitScheduleUpdate() { + /** + * Test update of SwissRailRaptorData after TransitScheduleChangedEvent + */ + @Test + void testTransitScheduleUpdate() { Fixture f = new Fixture(); f.init(); f.addVehicles(); @@ -339,11 +339,11 @@ public void install() { Assert.assertEquals(Id.create("AddedLine" + 1, TransitLine.class), ptRoute.getLineId()); } - /** - * Test individual scoring parameters for agents - */ - @Test - public void testRaptorParametersForPerson() { + /** + * Test individual scoring parameters for agents + */ + @Test + void testRaptorParametersForPerson() { SwissRailRaptorConfigGroup srrConfig = new SwissRailRaptorConfigGroup(); srrConfig.setScoringParameters(ch.sbb.matsim.config.SwissRailRaptorConfigGroup.ScoringParameters.Individual); diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTest.java index e24bf036cc6..e37985287b6 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTest.java @@ -22,7 +22,7 @@ import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; import ch.sbb.matsim.routing.pt.raptor.SwissRailRaptor.Builder; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -85,8 +85,8 @@ private SwissRailRaptor createTransitRouter(TransitSchedule schedule, Config con return raptor; } - @Test - public void testSingleLine() { + @Test + void testSingleLine() { Fixture f = new Fixture(); f.init(); RaptorParameters raptorParams = RaptorUtils.createParameters(f.config); @@ -117,8 +117,8 @@ public void testSingleLine() { assertEquals(15434, Math.ceil(distance), MatsimTestUtils.EPSILON); } - @Test - public void testSingleLine_linkIds() { + @Test + void testSingleLine_linkIds() { Fixture f = new Fixture(); f.init(); RaptorParameters raptorParams = RaptorUtils.createParameters(f.config); @@ -149,8 +149,8 @@ public void testSingleLine_linkIds() { assertEquals(Math.ceil(expectedTravelTime), actualTravelTime, MatsimTestUtils.EPSILON); } - @Test - public void testWalkDurations() { + @Test + void testWalkDurations() { Fixture f = new Fixture(); f.init(); RaptorParameters raptorParams = RaptorUtils.createParameters(f.config); @@ -171,7 +171,7 @@ public void testWalkDurations() { @Test - public void testStationAccessEgressTimes() { + void testStationAccessEgressTimes() { Fixture f = new Fixture(); f.init(); RaptorParameters raptorParams = RaptorUtils.createParameters(f.config); @@ -191,8 +191,8 @@ public void testStationAccessEgressTimes() { assertEquals(Math.ceil(expectedEgressWalkTime), ((Leg)legs.get(2)).getTravelTime().seconds(), MatsimTestUtils.EPSILON); } - @Test - public void testWalkDurations_range() { + @Test + void testWalkDurations_range() { Fixture f = new Fixture(); f.init(); RaptorParameters raptorParams = RaptorUtils.createParameters(f.config); @@ -213,15 +213,15 @@ public void testWalkDurations_range() { } - /** - * The fromFacility and toFacility are both closest to TransitStopFacility I. The expectation is that the Swiss Rail - * Raptor will return null (TripRouter / FallbackRouter will create a transit_walk between the fromFacility and - * toFacility) instead of routing the agent to make a major detour by walking the triangle from the fromFacility to - * the transitStopFacility and then to the toFacility, without once using pt. - */ + /** + * The fromFacility and toFacility are both closest to TransitStopFacility I. The expectation is that the Swiss Rail + * Raptor will return null (TripRouter / FallbackRouter will create a transit_walk between the fromFacility and + * toFacility) instead of routing the agent to make a major detour by walking the triangle from the fromFacility to + * the transitStopFacility and then to the toFacility, without once using pt. + */ - @Test - public void testFromToSameStop() { + @Test + void testFromToSameStop() { Fixture f = new Fixture(); f.init(); TransitRouter router = createTransitRouter(f.schedule, f.config, f.network); @@ -233,11 +233,10 @@ public void testFromToSameStop() { } - - // now the pt router should always try to return a pt route no matter whether a direct walk would be faster - // adjusted the test - gl aug'19 - @Test - public void testDirectWalkCheaper() { + // now the pt router should always try to return a pt route no matter whether a direct walk would be faster + // adjusted the test - gl aug'19 + @Test + void testDirectWalkCheaper() { Fixture f = new Fixture(); f.init(); SwissRailRaptorConfigGroup srrConfig = ConfigUtils.addOrGetModule(f.config,SwissRailRaptorConfigGroup.class); @@ -257,8 +256,8 @@ public void testDirectWalkCheaper() { assertEquals(expectedTravelTime, actualTravelTime, MatsimTestUtils.EPSILON); } - @Test - public void testDirectWalkFactor() { + @Test + void testDirectWalkFactor() { Fixture f = new Fixture(); f.init(); f.config.transitRouter().setDirectWalkFactor(100.0); @@ -287,8 +286,8 @@ public void testDirectWalkFactor() { assertEquals((5002-3000)*1.3, ((Leg)legs.get(2)).getRoute().getDistance(), 0.0); } - @Test - public void testSingleLine_DifferentWaitingTime() { + @Test + void testSingleLine_DifferentWaitingTime() { Fixture f = new Fixture(); f.init(); TransitRouter router = createTransitRouter(f.schedule, f.config, f.network); @@ -308,8 +307,8 @@ public void testSingleLine_DifferentWaitingTime() { } } - @Test - public void testLineChange() { + @Test + void testLineChange() { Fixture f = new Fixture(); f.init(); ConfigUtils.addOrGetModule(f.config, SwissRailRaptorConfigGroup.class).setTransferWalkMargin(0); @@ -345,8 +344,8 @@ public void testLineChange() { assertEquals(Math.ceil(expectedTravelTime), actualTravelTime, MatsimTestUtils.EPSILON); } - @Test - public void testFasterAlternative() { + @Test + void testFasterAlternative() { /* idea: travel from A to G * One could just take the blue line and travel from A to G (dep *:46, arrival *:28), * or one could first travel from A to C (dep *:46, arr *:58), and then take the red line @@ -387,8 +386,8 @@ public void testFasterAlternative() { } - @Test - public void testTransferWeights() { + @Test + void testTransferWeights() { /* idea: travel from C to F * If starting at the right time, one could take the red line to G and travel back with blue to F. * If one doesn't want to switch lines, one could take the blue line from C to F directly. @@ -425,8 +424,8 @@ public void testTransferWeights() { assertEquals(TransportMode.walk, ((Leg)legs.get(2)).getMode()); } - @Test - public void testTransferTime() { + @Test + void testTransferTime() { /* idea: travel from C to F * If starting at the right time, one could take the red line to G and travel back with blue to F. * If one doesn't want to switch lines, one could take the blue line from C to F directly. @@ -462,8 +461,8 @@ public void testTransferTime() { } - @Test - public void testAfterMidnight() { + @Test + void testAfterMidnight() { // in contrast to the default PT router, SwissRailRaptor will not automatically // repeat the schedule after 24 hours, so any agent departing late will have to walk if there // is no late service in the schedule. @@ -477,8 +476,8 @@ public void testAfterMidnight() { Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); } - @Test - public void testCoordFarAway() { + @Test + void testCoordFarAway() { Fixture f = new Fixture(); f.init(); TransitRouter router = createTransitRouter(f.schedule, f.config, f.network); @@ -497,12 +496,12 @@ public void testCoordFarAway() { assertEquals(Id.create("blue A > I", TransitRoute.class), ptRoute.getRouteId()); } - /** - * Tests that if only a single transfer-/walk-link is found, the router correctly only returns - * null (TripRouter/FallbackRouter will create a walk leg from start to end). - */ - @Test - public void testSingleWalkOnly() { + /** + * Tests that if only a single transfer-/walk-link is found, the router correctly only returns + * null (TripRouter/FallbackRouter will create a walk leg from start to end). + */ + @Test + void testSingleWalkOnly() { WalkFixture f = new WalkFixture(); f.scenario.getConfig().transitRouter().setSearchRadius(0.8 * CoordUtils.calcEuclideanDistance(f.coord2, f.coord4)); f.scenario.getConfig().transitRouter().setExtensionRadius(0.0); @@ -513,14 +512,14 @@ public void testSingleWalkOnly() { } - /** - * Tests that if only exactly two transfer-/walk-link are found, the router correctly only returns - * null (which will be replaced by the TripRouter and FallbackRouter with one walk leg from start - * to end). Differs from {@link #testSingleWalkOnly()} in that it tests for the correct internal - * working when more than one walk links are returned. - */ - @Test - public void testDoubleWalkOnly() { + /** + * Tests that if only exactly two transfer-/walk-link are found, the router correctly only returns + * null (which will be replaced by the TripRouter and FallbackRouter with one walk leg from start + * to end). Differs from {@link #testSingleWalkOnly()} in that it tests for the correct internal + * working when more than one walk links are returned. + */ + @Test + void testDoubleWalkOnly() { WalkFixture f = new WalkFixture(); f.scenario.getConfig().transitRouter().setSearchRadius(0.8 * CoordUtils.calcEuclideanDistance(f.coord2, f.coord4)); f.scenario.getConfig().transitRouter().setExtensionRadius(0.0); @@ -531,9 +530,9 @@ public void testDoubleWalkOnly() { Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); } - @SuppressWarnings("unchecked") - @Test - public void testLongTransferTime_withTransitRouterWrapper() { + @SuppressWarnings("unchecked") + @Test + void testLongTransferTime_withTransitRouterWrapper() { // 5 minutes additional transfer time { TransferFixture f = new TransferFixture(5 * 60.0); @@ -649,8 +648,8 @@ private static double calcTripDuration(List planElements) { return duration; } - @Test - public void testNightBus() { + @Test + void testNightBus() { // test a special case where a direct connection only runs at a late time, when typically // no other services run anymore. NightBusFixture f = new NightBusFixture(); @@ -684,8 +683,8 @@ public void testNightBus() { assertEquals(f.lineId3, ptRoute.getLineId()); } - @Test - public void testCircularLine() { + @Test + void testCircularLine() { Fixture f = new Fixture(); f.init(); @@ -713,8 +712,8 @@ public void testCircularLine() { Assert.assertEquals(Id.create(20, TransitStopFacility.class), ((TransitPassengerRoute) ((Leg)legs.get(3)).getRoute()).getEgressStopId()); } - @Test - public void testRangeQuery() { + @Test + void testRangeQuery() { Fixture f = new Fixture(); f.init(); SwissRailRaptor raptor = createTransitRouter(f.schedule, f.config, f.network); @@ -746,12 +745,12 @@ private void assertRaptorRoute(RaptorRoute route, String depTime, String arrTime Assert.assertEquals("wrong cost", expectedCost, route.getTotalCosts(), 1e-5); } - /** test for https://github.com/SchweizerischeBundesbahnen/matsim-sbb-extensions/issues/1 - * - * If there are StopFacilities in the transit schedule, that are not part of any route, the Router crashes with a NPE in SwissRailRaptorData at line 213, because toRouteStopIndices == null. - */ - @Test - public void testUnusedTransitStop() { + /** test for https://github.com/SchweizerischeBundesbahnen/matsim-sbb-extensions/issues/1 + * + * If there are StopFacilities in the transit schedule, that are not part of any route, the Router crashes with a NPE in SwissRailRaptorData at line 213, because toRouteStopIndices == null. + */ + @Test + void testUnusedTransitStop() { Fixture f = new Fixture(); f.init(); @@ -777,8 +776,8 @@ public void testUnusedTransitStop() { Assert.assertEquals(3, legs.size()); } - @Test - public void testTravelTimeDependentTransferCosts() { + @Test + void testTravelTimeDependentTransferCosts() { TravelTimeDependentTransferFixture f = new TravelTimeDependentTransferFixture(); { // test default 0 + 0 * tt @@ -862,8 +861,8 @@ public void testTravelTimeDependentTransferCosts() { } } - @Test - public void testCustomTransferCostCalculator() { + @Test + void testCustomTransferCostCalculator() { TransferFixture f = new TransferFixture(60.0); int[] transferCount = new int[] { 0 }; @@ -912,8 +911,8 @@ private Config prepareConfig(double transferFixedCost, double transferRelativeCo return config; } - @Test - public void testModeMapping() { + @Test + void testModeMapping() { Fixture f = new Fixture(); f.init(); for (TransitRoute route : f.blueLine.getRoutes().values()) { @@ -951,8 +950,8 @@ public void testModeMapping() { assertEquals(TransportMode.walk, ((Leg)legs.get(4)).getMode()); } - @Test - public void testModeMappingCosts() { + @Test + void testModeMappingCosts() { Fixture f = new Fixture(); f.init(); @@ -1045,13 +1044,13 @@ public void testModeMappingCosts() { } } - /** - * Tests what happens if there is a transit service available, but the agent's departure time (11 AM) is after the last transit - * departure time (9:46 AM). The expectation is that the router returns null and TripRouter/FallbackRouter will create a direct - * walk leg to get from the fromFacility to the toFacility. - */ - @Test - public void testDepartureAfterLastBus(){ + /** + * Tests what happens if there is a transit service available, but the agent's departure time (11 AM) is after the last transit + * departure time (9:46 AM). The expectation is that the router returns null and TripRouter/FallbackRouter will create a direct + * walk leg to get from the fromFacility to the toFacility. + */ + @Test + void testDepartureAfterLastBus(){ Fixture f = new Fixture(); f.init(); TransitRouter router = createTransitRouter(f.schedule, f.config, f.network); diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTreeTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTreeTest.java index 05ad518af21..a380bd4ebca 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTreeTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTreeTest.java @@ -21,7 +21,7 @@ import ch.sbb.matsim.routing.pt.raptor.SwissRailRaptorCore.TravelInfo; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.utils.misc.Time; @@ -38,8 +38,8 @@ */ public class SwissRailRaptorTreeTest { - @Test - public void testSingleStop_dep0740atN_optimized() { + @Test + void testSingleStop_dep0740atN_optimized() { Fixture f = new Fixture(); f.init(); @@ -83,8 +83,8 @@ public void testSingleStop_dep0740atN_optimized() { assertTravelInfo(map, 23, "23", 0, "07:40:00", "07:40:00"); // our start location } - @Test - public void testSingleStop_dep0740atN_unoptimized() { + @Test + void testSingleStop_dep0740atN_unoptimized() { Fixture f = new Fixture(); f.init(); @@ -126,8 +126,8 @@ public void testSingleStop_dep0740atN_unoptimized() { assertTravelInfo(map, 23, "23", 0, "07:40:00", "07:40:00"); // our start location } - @Test - public void testSingleStop_dep0750atN_optimized() { + @Test + void testSingleStop_dep0750atN_optimized() { Fixture f = new Fixture(); f.init(); @@ -172,8 +172,8 @@ public void testSingleStop_dep0750atN_optimized() { assertTravelInfo(map, 23, "23", 0, "07:50:00", "07:50:00"); // our start location } - @Test - public void testSingleStop_dep0750atN_unoptimized() { + @Test + void testSingleStop_dep0750atN_unoptimized() { Fixture f = new Fixture(); f.init(); @@ -216,8 +216,8 @@ public void testSingleStop_dep0750atN_unoptimized() { assertTravelInfo(map, 23, "23", 0, "07:50:00", "07:50:00"); // our start location } - @Test - public void testMultipleStops_optimized() { + @Test + void testMultipleStops_optimized() { Fixture f = new Fixture(); f.init(); @@ -265,8 +265,8 @@ public void testMultipleStops_optimized() { assertTravelInfo(map, 23, "15", 1, "07:43:00", "08:11:00"); // from H, transfer at G, 7:48/7:51 green } - @Test - public void testMultipleStops_unoptimized() { + @Test + void testMultipleStops_unoptimized() { Fixture f = new Fixture(); f.init(); @@ -312,8 +312,8 @@ public void testMultipleStops_unoptimized() { assertTravelInfo(map, 23, "15", 1, "07:43:00", "08:11:00"); // from H, transfer at G, 7:48/7:51 green } - @Test - public void testSingleStop_costs_dep0740atN_optimized() { + @Test + void testSingleStop_costs_dep0740atN_optimized() { Fixture f = new Fixture(); f.init(); @@ -345,8 +345,8 @@ public void testSingleStop_costs_dep0740atN_optimized() { Assert.assertTrue("waiting cost should differ", info0740.waitingCost < info0739.waitingCost); } - @Test - public void testSingleStop_raptorroute_dep0740atN_optimized() { + @Test + void testSingleStop_raptorroute_dep0740atN_optimized() { Fixture f = new Fixture(); f.init(); diff --git a/matsim/src/test/java/org/matsim/analysis/CalcAverageTripLengthTest.java b/matsim/src/test/java/org/matsim/analysis/CalcAverageTripLengthTest.java index 17a8d0dea7d..05d463b8b0c 100644 --- a/matsim/src/test/java/org/matsim/analysis/CalcAverageTripLengthTest.java +++ b/matsim/src/test/java/org/matsim/analysis/CalcAverageTripLengthTest.java @@ -22,8 +22,7 @@ package org.matsim.analysis; import java.util.ArrayList; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -45,10 +44,10 @@ import org.junit.Assert; -public class CalcAverageTripLengthTest { + public class CalcAverageTripLengthTest { - @Test - public void testWithRoute() { + @Test + void testWithRoute() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); Population population = scenario.getPopulation(); @@ -112,8 +111,8 @@ public void testWithRoute() { Assert.assertEquals(500.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); } - @Test - public void testWithRoute_OneLinkRoute() { + @Test + void testWithRoute_OneLinkRoute() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); Population population = scenario.getPopulation(); @@ -149,8 +148,8 @@ public void testWithRoute_OneLinkRoute() { Assert.assertEquals(100.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); } - @Test - public void testWithRoute_StartEndOnSameLink() { + @Test + void testWithRoute_StartEndOnSameLink() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); Population population = scenario.getPopulation(); diff --git a/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java b/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java index f04fdbd7ffc..88e253fa21b 100644 --- a/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java +++ b/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java @@ -26,8 +26,8 @@ import org.junit.After; import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -102,7 +102,8 @@ public class CalcLegTimesTest { this.network = null; } - @Test public void testNoEvents() throws IOException { + @Test + void testNoEvents() throws IOException { CalcLegTimes testee = new CalcLegTimes(); @@ -114,7 +115,8 @@ public class CalcLegTimesTest { this.runTest(testee); } - @Test public void testAveraging() throws IOException { + @Test + void testAveraging() throws IOException { CalcLegTimes testee = new CalcLegTimes(); diff --git a/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java b/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java index 72eaa88a2bb..06e85721459 100644 --- a/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java +++ b/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java @@ -22,8 +22,8 @@ import java.io.File; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -50,7 +50,7 @@ public class CalcLinkStatsTest { @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test - public void testAddData() { + void testAddData() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = s.getNetwork(); NetworkFactory nf = network.getFactory(); @@ -131,7 +131,7 @@ public void testAddData() { * @author ikaddoura */ @Test - public void testAddDataObservedTravelTime() { + void testAddDataObservedTravelTime() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = s.getNetwork(); NetworkFactory nf = network.getFactory(); @@ -215,7 +215,7 @@ public void testAddDataObservedTravelTime() { } @Test - public void testWriteRead() { + void testWriteRead() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = s.getNetwork(); NetworkFactory nf = network.getFactory(); diff --git a/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java index 10c333db369..4d16738191e 100644 --- a/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java @@ -11,8 +11,8 @@ import java.util.zip.GZIPInputStream; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; import org.matsim.api.core.v01.Scenario; @@ -54,7 +54,7 @@ public class IterationTravelStatsControlerListenerTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testIterationTravelStatsControlerListener() { + void testIterationTravelStatsControlerListener() { Plans plans = new Plans(); diff --git a/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java b/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java index 9146970dde1..e29dfc0af55 100644 --- a/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java +++ b/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java @@ -24,8 +24,8 @@ import java.util.Set; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -54,7 +54,8 @@ public class LegHistogramTest { * accordingly. Also tests that modes not defined as constants are * handled correctly. */ - @Test public void testDeparturesMiscModes() { + @Test + void testDeparturesMiscModes() { Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create(1, Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createAndAddNode(network, Id.create(2, Node.class), new Coord((double) 1000, (double) 0)); @@ -107,7 +108,8 @@ public class LegHistogramTest { * taken into account and that times larger than what is covered by the bins * do not lead to an exception. */ - @Test public void testNofBins() { + @Test + void testNofBins() { Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create(1, Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createAndAddNode(network, Id.create(2, Node.class), new Coord((double) 1000, (double) 0)); @@ -147,7 +149,8 @@ public class LegHistogramTest { assertEquals(2, histo.getArrivals()[10]); } - @Test public void testReset() { + @Test + void testReset() { Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create(1, Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createAndAddNode(network, Id.create(2, Node.class), new Coord((double) 1000, (double) 0)); diff --git a/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java index 17538d237d8..214b7fffb9b 100644 --- a/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java @@ -21,8 +21,8 @@ import com.google.inject.*; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -61,7 +61,7 @@ public class LinkStatsControlerListenerTest { private MatsimTestUtils util = new MatsimTestUtils(); @Test - public void testlinksOutputCSV() throws IOException { + void testlinksOutputCSV() throws IOException { String outputDirectory = util.getOutputDirectory(); Config config = this.util.loadConfig("test/scenarios/equil/config_plans1.xml"); @@ -82,7 +82,7 @@ public void testlinksOutputCSV() throws IOException { } @Test - public void testUseVolumesOfIteration() { + void testUseVolumesOfIteration() { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory(util.getOutputDirectory()); final Scenario scenario = ScenarioUtils.createScenario(config); @@ -309,7 +309,7 @@ public void install() { } @Test - public void test_writeLinkStatsInterval() { + void test_writeLinkStatsInterval() { Config config = this.util.loadConfig((String) null); LinkStatsConfigGroup lsConfig = config.linkStats(); @@ -346,7 +346,7 @@ public void install() { } @Test - public void testReset_CorrectlyExecuted() throws IOException { + void testReset_CorrectlyExecuted() throws IOException { Config config = this.util.loadConfig((String) null); config.controller().setMobsim("dummy"); config.controller().setFirstIteration(0); diff --git a/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java index 76927ec7a57..51f97e29a64 100644 --- a/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java @@ -1,8 +1,8 @@ package org.matsim.analysis; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -34,8 +34,8 @@ public class ModeChoiceCoverageControlerListenerTest { public MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testChangePlanModes() { + @Test + void testChangePlanModes() { Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig()); ScoringConfigGroup scoreConfig = new ScoringConfigGroup(); @@ -92,8 +92,8 @@ public void testChangePlanModes() { (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(2)); } - @Test - public void testTwoAgents() { + @Test + void testTwoAgents() { Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig()); ScoringConfigGroup scoreConfig = new ScoringConfigGroup(); TransportPlanningMainModeIdentifier transportId = new TransportPlanningMainModeIdentifier(); @@ -162,8 +162,8 @@ public void testTwoAgents() { (Double) 0.75, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(2)); } - @Test - public void testDifferentLevels() { + @Test + void testDifferentLevels() { Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig()); ScoringConfigGroup scoreConfig = new ScoringConfigGroup(); diff --git a/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java index ab15ea48c94..400c0b270f8 100644 --- a/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java @@ -11,8 +11,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -56,7 +56,7 @@ public class ModeStatsControlerListenerTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testModeStatsControlerListener() { + void testModeStatsControlerListener() { Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig()); final List planElem = new ArrayList(); diff --git a/matsim/src/test/java/org/matsim/analysis/OutputTravelStatsTest.java b/matsim/src/test/java/org/matsim/analysis/OutputTravelStatsTest.java index da31465d1c5..33f09c31ff1 100644 --- a/matsim/src/test/java/org/matsim/analysis/OutputTravelStatsTest.java +++ b/matsim/src/test/java/org/matsim/analysis/OutputTravelStatsTest.java @@ -19,8 +19,8 @@ package org.matsim.analysis; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.controler.Controler; import org.matsim.testcases.MatsimTestUtils; @@ -40,7 +40,7 @@ public class OutputTravelStatsTest { private MatsimTestUtils util = new MatsimTestUtils(); @Test - public void testActivitiesOutputCSV() throws IOException { + void testActivitiesOutputCSV() throws IOException { String outputDirectory = util.getOutputDirectory(); Config config = this.util.loadConfig("test/scenarios/equil/config_plans1.xml"); diff --git a/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java b/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java index 4622a31b6b9..38e5bec0a4e 100644 --- a/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java @@ -9,9 +9,9 @@ import java.util.HashMap; import java.util.Iterator; import java.util.List; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; import org.matsim.api.core.v01.population.Activity; @@ -26,8 +26,8 @@ import org.matsim.core.controler.OutputDirectoryHierarchy.OverwriteFileSetting; import org.matsim.core.router.StageActivityTypeIdentifier; import org.matsim.core.scoring.EventsToLegs; -import org.matsim.testcases.MatsimTestUtils; - +import org.matsim.testcases.MatsimTestUtils; + /** * @author Aravind * @@ -49,10 +49,10 @@ public class PHbyModeCalculatorTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - final IdMap map = new IdMap<>(Person.class); - - @Test - public void testPKMbyModeCalculator() { + final IdMap map = new IdMap<>(Person.class); + + @Test + void testPKMbyModeCalculator() { Plans plans = new Plans(); diff --git a/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java b/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java index 8af9981fb13..b2153471206 100644 --- a/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java @@ -9,8 +9,8 @@ import java.util.HashMap; import java.util.stream.Collectors; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; import org.matsim.api.core.v01.TransportMode; @@ -44,7 +44,7 @@ public class PKMbyModeCalculatorTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testPKMbyModeCalculator() { + void testPKMbyModeCalculator() { final IdMap map = new IdMap<>(Person.class); Plans plans = new Plans(); diff --git a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java index 9c6d251a048..1fb5b7900f9 100644 --- a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java @@ -7,8 +7,8 @@ import org.assertj.core.api.Assertions; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -52,7 +52,7 @@ public class ScoreStatsControlerListenerTest { private Population population = scenario.getPopulation(); @Test - public void testScoreStatsControlerListner() throws IOException { + void testScoreStatsControlerListner() throws IOException { /************************************ * Person - creating person 1 diff --git a/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java b/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java index d2141c89b78..0ed11f63558 100644 --- a/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java @@ -6,15 +6,15 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Leg; import org.matsim.api.core.v01.population.Plan; import org.matsim.api.core.v01.population.PlanElement; -import org.matsim.testcases.MatsimTestUtils; - +import org.matsim.testcases.MatsimTestUtils; + /** * @author Aravind * @@ -24,10 +24,10 @@ public class TransportPlanningMainModeIdentifierTest { private final List modeHierarchy = new ArrayList<>(); @RegisterExtension - private MatsimTestUtils utils = new MatsimTestUtils(); - - @Test - public void testIterationTravelStatsControlerListener() { + private MatsimTestUtils utils = new MatsimTestUtils(); + + @Test + void testIterationTravelStatsControlerListener() { modeHierarchy.add(TransportMode.non_network_walk); modeHierarchy.add("undefined"); diff --git a/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java b/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java index 4836dbb1e1c..a98fef56fbf 100644 --- a/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java @@ -10,8 +10,8 @@ import java.util.stream.Collectors; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdMap; import org.matsim.api.core.v01.TransportMode; @@ -55,7 +55,7 @@ public class TravelDistanceStatsTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testTravelDistanceStats() { + void testTravelDistanceStats() { final IdMap map = new IdMap<>(Person.class); diff --git a/matsim/src/test/java/org/matsim/analysis/TripsAnalysisIT.java b/matsim/src/test/java/org/matsim/analysis/TripsAnalysisIT.java index e0a372d519b..528fefa6d41 100644 --- a/matsim/src/test/java/org/matsim/analysis/TripsAnalysisIT.java +++ b/matsim/src/test/java/org/matsim/analysis/TripsAnalysisIT.java @@ -23,8 +23,8 @@ import org.apache.commons.csv.CSVParser; import org.apache.commons.csv.CSVRecord; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -46,7 +46,7 @@ public class TripsAnalysisIT { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testMainMode() { + void testMainMode() { final Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); Scenario scenario = ScenarioUtils.loadScenario(config); diff --git a/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java b/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java index cfb58800664..e5eccd66e12 100644 --- a/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java @@ -21,8 +21,8 @@ package org.matsim.analysis; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.analysis.TripsAndLegsCSVWriter.NoLegsWriterExtension; import org.matsim.analysis.TripsAndLegsCSVWriter.NoTripWriterExtension; import org.matsim.api.core.v01.*; @@ -116,7 +116,7 @@ public class TripsAndLegsCSVWriterTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testTripsAndLegsCSVWriter() { + void testTripsAndLegsCSVWriter() { Plans plans = new Plans(); diff --git a/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java b/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java index 01ade096cca..511778fce7c 100644 --- a/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java @@ -3,9 +3,9 @@ */ package org.matsim.analysis; -import org.junit.Assert; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -20,8 +20,8 @@ import org.matsim.core.config.ConfigUtils; import org.matsim.core.scenario.ScenarioUtils; import org.matsim.testcases.MatsimTestUtils; -import org.matsim.vehicles.Vehicle; - +import org.matsim.vehicles.Vehicle; + /** * @author Aravind * @@ -29,10 +29,10 @@ public class VolumesAnalyzerTest { @RegisterExtension - private MatsimTestUtils util = new MatsimTestUtils(); - - @Test - public void performTest() { + private MatsimTestUtils util = new MatsimTestUtils(); + + @Test + void performTest() { final Id link1 = Id.create(10723, Link.class); final Id link2 = Id.create(123160, Link.class); diff --git a/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java b/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java index 126b90c8dcf..e8686cd7cf4 100644 --- a/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java +++ b/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java @@ -23,8 +23,8 @@ import org.apache.commons.csv.CSVParser; import org.apache.commons.csv.CSVRecord; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.analysis.linkpaxvolumes.LinkPaxVolumesAnalysis; import org.matsim.analysis.linkpaxvolumes.LinkPaxVolumesWriter; import org.matsim.analysis.linkpaxvolumes.VehicleStatsPerVehicleType; @@ -55,12 +55,12 @@ public class LinkPaxVolumesAnalysisTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - /** - * Test method for {@link LinkPaxVolumesAnalysis}. - */ + /** + * Test method for {@link LinkPaxVolumesAnalysis}. + */ - @Test - public void testLinkPaxVolumes() { + @Test + void testLinkPaxVolumes() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java b/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java index 542b72deb15..4e1e6b20caf 100644 --- a/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java @@ -23,8 +23,8 @@ import org.apache.commons.csv.CSVRecord; import org.apache.commons.lang3.mutable.MutableDouble; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonMoneyEvent; import org.matsim.api.core.v01.events.handler.PersonMoneyEventHandler; @@ -46,7 +46,7 @@ public class PersonMoneyEventAggregatorTest { * Test method for {@link org.matsim.analysis.personMoney.PersonMoneyEventsCollector}. */ @Test - public void testPersonMoneyEventCollector() { + void testPersonMoneyEventCollector() { Id passenger1 = Id.createPersonId("passenger1"); diff --git a/matsim/src/test/java/org/matsim/analysis/pt/stop2stop/PtStop2StopAnalysisTest.java b/matsim/src/test/java/org/matsim/analysis/pt/stop2stop/PtStop2StopAnalysisTest.java index 9007107f017..dc39adf4358 100644 --- a/matsim/src/test/java/org/matsim/analysis/pt/stop2stop/PtStop2StopAnalysisTest.java +++ b/matsim/src/test/java/org/matsim/analysis/pt/stop2stop/PtStop2StopAnalysisTest.java @@ -20,7 +20,7 @@ package org.matsim.analysis.pt.stop2stop; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -50,11 +50,11 @@ public class PtStop2StopAnalysisTest { - /** - * Test method for {@link PtStop2StopAnalysis}. - */ - @Test - public void testPtStop2StopAnalysisSingle() { + /** + * Test method for {@link PtStop2StopAnalysis}. + */ + @Test + void testPtStop2StopAnalysisSingle() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); @@ -173,8 +173,8 @@ public void testPtStop2StopAnalysisSingle() { // ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ - @Test - public void testPtStop2StopAnalysisMulti() { + @Test + void testPtStop2StopAnalysisMulti() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/api/core/v01/CoordTest.java b/matsim/src/test/java/org/matsim/api/core/v01/CoordTest.java index 0697ffe8289..8a9e0264d4b 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/CoordTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/CoordTest.java @@ -22,13 +22,13 @@ import static org.junit.Assert.*; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.testcases.MatsimTestUtils; public class CoordTest { @Test - public void testCoord2D() { + void testCoord2D() { @SuppressWarnings("unused") Coord c; try{ @@ -39,7 +39,7 @@ public void testCoord2D() { } @Test - public void testCoord3D() { + void testCoord3D() { @SuppressWarnings("unused") Coord c; try{ @@ -60,7 +60,7 @@ public void testCoord3D() { } @Test - public void testGetX() { + void testGetX() { // 2D Coord c2 = new Coord(0.0, 1.0); assertEquals("Wrong x-value.", 0.0, c2.getX(), MatsimTestUtils.EPSILON); @@ -71,7 +71,7 @@ public void testGetX() { } @Test - public void testGetY() { + void testGetY() { // 2D Coord c2 = new Coord(0.0, 1.0); assertEquals("Wrong y-value.", 1.0, c2.getY(), MatsimTestUtils.EPSILON); @@ -82,7 +82,7 @@ public void testGetY() { } @Test - public void testGetZ() { + void testGetZ() { // 2D Coord c2 = new Coord(0.0, 1.0); try{ @@ -99,7 +99,7 @@ public void testGetZ() { } @Test - public void testEqualsObject() { + void testEqualsObject() { Double dummy = 0.0; Coord c2a = new Coord(0.0, 1.0); @@ -122,7 +122,7 @@ public void testEqualsObject() { } @Test - public void testToString() { + void testToString() { Coord c2 = new Coord(0.0, 1.0); assertTrue(c2.toString().equalsIgnoreCase("[x=0.0 | y=1.0]")); diff --git a/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java b/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java index 254e8a05703..b92c50d4c4d 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java @@ -25,8 +25,8 @@ import org.junit.After; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; import org.matsim.api.core.v01.network.Node; @@ -68,7 +68,8 @@ public class DemandGenerationTest { this.sc = null; } - @Test public void testDemandGeneration(){ + @Test + void testDemandGeneration(){ Config conf = sc.getConfig(); assertNotNull(conf); diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdAnnotationsTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdAnnotationsTest.java index dcfa4db3a27..f2e82c6ecdb 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdAnnotationsTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdAnnotationsTest.java @@ -3,7 +3,7 @@ import java.util.Objects; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.IdAnnotations.JsonId; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Node; @@ -19,7 +19,7 @@ public class IdAnnotationsTest { private static final ObjectMapper objectMapper = new ObjectMapper(); @Test - public void testRecordJsonIds() throws JsonProcessingException { + void testRecordJsonIds() throws JsonProcessingException { Id personId = Id.createPersonId("person"); RecordWithIds recordWithIds1 = new RecordWithIds( personId, @@ -35,7 +35,7 @@ public void testRecordJsonIds() throws JsonProcessingException { } @Test - public void testRecordJsonIdsWithNull() throws JsonProcessingException { + void testRecordJsonIdsWithNull() throws JsonProcessingException { Id personId = null; RecordWithIds recordWithIds1 = new RecordWithIds(personId, null, null); @@ -48,7 +48,7 @@ public void testRecordJsonIdsWithNull() throws JsonProcessingException { } @Test - public void testClassJsonIds() throws JsonProcessingException { + void testClassJsonIds() throws JsonProcessingException { Id personId = Id.createPersonId("person"); ClassWithIds classWithIds1 = new ClassWithIds( personId, @@ -64,7 +64,7 @@ public void testClassJsonIds() throws JsonProcessingException { } @Test - public void testClassJsonIdsWithNull() throws JsonProcessingException { + void testClassJsonIdsWithNull() throws JsonProcessingException { Id personId = null; ClassWithIds classWithIds1 = new ClassWithIds(personId, null, null); diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdCollectorsTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdCollectorsTest.java index 12dac47e927..4ef8664b489 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdCollectorsTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdCollectorsTest.java @@ -26,7 +26,7 @@ import java.util.List; import java.util.Map; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.vehicles.Vehicle; /** @@ -35,7 +35,7 @@ public class IdCollectorsTest { @Test - public void testToIdMap() { + void testToIdMap() { record Entry(Id id, String value) { } @@ -53,7 +53,7 @@ record Entry(Id id, String value) { } @Test - public void testToIdMap_streamWithDuplicateKeys() { + void testToIdMap_streamWithDuplicateKeys() { record Entry(Id id, String value) { } @@ -65,7 +65,7 @@ record Entry(Id id, String value) { } @Test - public void testToIdMap_withMerge() { + void testToIdMap_withMerge() { record Entry(Id id, int value) { } @@ -82,7 +82,7 @@ record Entry(Id id, int value) { } @Test - public void testToIdSet() { + void testToIdSet() { var id1 = Id.createVehicleId("v1"); var id2 = Id.createVehicleId("v2"); var id3 = Id.createVehicleId("v3"); diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java index 6550f16c2d4..2562a5798c8 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java @@ -5,7 +5,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.network.Link; import com.fasterxml.jackson.core.JsonProcessingException; @@ -26,7 +26,7 @@ public void init() { } @Test - public void testMapKey() { + void testMapKey() { // create map with Id as keys Map, String> map0 = new LinkedHashMap<>(); @@ -65,7 +65,7 @@ public void testMapKey() { } @Test - public void testMapValue() { + void testMapValue() { // create map with Id as values Map> map0 = new LinkedHashMap<>(); diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdMapTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdMapTest.java index 716609ed586..f57550f3272 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdMapTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdMapTest.java @@ -1,7 +1,7 @@ package org.matsim.api.core.v01; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Person; import org.matsim.core.utils.collections.Tuple; @@ -14,7 +14,7 @@ public class IdMapTest { @Test - public void testPutGetRemoveSize() { + void testPutGetRemoveSize() { IdMap map = new IdMap<>(Person.class, 10); Assert.assertEquals(0, map.size()); @@ -50,7 +50,7 @@ public void testPutGetRemoveSize() { } @Test - public void testIterable() { + void testIterable() { IdMap map = new IdMap<>(Person.class, 10); map.put(Id.create(1, Person.class), "one"); @@ -78,7 +78,7 @@ public void testIterable() { } @Test - public void testForEach() { + void testForEach() { IdMap map = new IdMap<>(Person.class, 10); map.put(Id.create(1, Person.class), "one"); @@ -105,7 +105,7 @@ public void testForEach() { } @Test - public void testContainsKey() { + void testContainsKey() { IdMap map = new IdMap<>(Person.class, 10); map.put(Id.create(1, Person.class), "one"); @@ -137,7 +137,7 @@ public void testContainsKey() { } @Test - public void testContainsValue() { + void testContainsValue() { IdMap map = new IdMap<>(Person.class, 10); map.put(Id.create(1, Person.class), "one"); @@ -155,7 +155,7 @@ public void testContainsValue() { } @Test - public void testPutAll_IdMap() { + void testPutAll_IdMap() { IdMap map = new IdMap<>(Person.class, 10); IdMap map2 = new IdMap<>(Person.class, 10); @@ -177,7 +177,7 @@ public void testPutAll_IdMap() { } @Test - public void testPutAll_GenericMap() { + void testPutAll_GenericMap() { IdMap map = new IdMap<>(Person.class, 10); Map, String> map2 = new HashMap<>(); @@ -199,7 +199,7 @@ public void testPutAll_GenericMap() { } @Test - public void testClear() { + void testClear() { IdMap map = new IdMap<>(Person.class, 10); map.put(Id.create(1, Person.class), "one"); @@ -222,7 +222,7 @@ public void testClear() { } @Test - public void testValues() { + void testValues() { IdMap map = new IdMap<>(Person.class, 10); map.put(Id.create(1, Person.class), "one"); @@ -257,7 +257,7 @@ public void testValues() { } @Test - public void testKeySet() { + void testKeySet() { Id id1 = Id.create(1, Person.class); Id id2 = Id.create(2, Person.class); Id id3 = Id.create(3, Person.class); @@ -298,7 +298,7 @@ public void testKeySet() { } @Test - public void testEntrySet() { + void testEntrySet() { Id id1 = Id.create(1, Person.class); Id id2 = Id.create(2, Person.class); Id id3 = Id.create(3, Person.class); @@ -352,7 +352,7 @@ public void testEntrySet() { } @Test - public void testIterator_iterate() { + void testIterator_iterate() { Id id1 = Id.create(1, Person.class); Id id2 = Id.create(2, Person.class); Id id3 = Id.create(3, Person.class); @@ -393,7 +393,7 @@ public void testIterator_iterate() { } @Test - public void testIterator_remove() { + void testIterator_remove() { Id id1 = Id.create(1, Person.class); Id id2 = Id.create(2, Person.class); Id id3 = Id.create(3, Person.class); @@ -430,7 +430,7 @@ public void testIterator_remove() { } @Test - public void testKeySetToArray() { + void testKeySetToArray() { Id id1 = Id.create(1, Person.class); Id id2 = Id.create(2, Person.class); Id id3 = Id.create(3, Person.class); @@ -454,7 +454,7 @@ public void testKeySetToArray() { } @Test - public void testEqualsAndHashCode() { + void testEqualsAndHashCode() { Id id1 = Id.create(1, Person.class); Id id2 = Id.create(2, Person.class); Id id3 = Id.create(3, Person.class); diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdSetTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdSetTest.java index 7d79338bfa2..63bee1c218d 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdSetTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdSetTest.java @@ -1,7 +1,7 @@ package org.matsim.api.core.v01; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.Person; @@ -15,7 +15,7 @@ public class IdSetTest { @Test - public void testAddContainsRemoveSize() { + void testAddContainsRemoveSize() { IdSet set = new IdSet<>(Person.class); Id id1 = Id.create("1", Person.class); @@ -56,7 +56,7 @@ public void testAddContainsRemoveSize() { } @Test - public void testIterator() { + void testIterator() { IdSet set = new IdSet<>(Person.class); Id id1 = Id.create("1", Person.class); @@ -85,7 +85,7 @@ public void testIterator() { } @Test - public void testClear() { + void testClear() { IdSet set = new IdSet<>(Person.class); Id id1 = Id.create("1", Person.class); @@ -110,7 +110,7 @@ public void testClear() { } @Test - public void testAddAll() { + void testAddAll() { IdSet set1 = new IdSet<>(Person.class); IdSet set2 = new IdSet<>(Person.class); @@ -142,7 +142,7 @@ public void testAddAll() { } @Test - public void testRemoveAll() { + void testRemoveAll() { IdSet set1 = new IdSet<>(Person.class); IdSet set2 = new IdSet<>(Person.class); @@ -173,7 +173,7 @@ public void testRemoveAll() { } @Test - public void testRetainAll() { + void testRetainAll() { IdSet set1 = new IdSet<>(Person.class); IdSet set2 = new IdSet<>(Person.class); @@ -205,7 +205,7 @@ public void testRetainAll() { } @Test - public void testContainsAll() { + void testContainsAll() { IdSet set1 = new IdSet<>(Person.class); IdSet set2 = new IdSet<>(Person.class); @@ -233,7 +233,7 @@ public void testContainsAll() { } @Test - public void testToArray() { + void testToArray() { IdSet set = new IdSet<>(Person.class); Id id1 = Id.create("1", Person.class); @@ -302,7 +302,7 @@ public void testToArray() { } @Test - public void testEqualsAndHashCode() { + void testEqualsAndHashCode() { Id id1 = Id.create("1", Person.class); Id id2 = Id.create("2", Person.class); Id id3 = Id.create("3", Person.class); diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdTest.java index bee42066ee6..77bc2676621 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdTest.java @@ -23,18 +23,18 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.collections.Tuple; import java.util.ArrayList; import java.util.List; -public class IdTest { + public class IdTest { private final static Logger LOG = LogManager.getLogger(IdTest.class); - @Test - public void testConstructor() { + @Test + void testConstructor() { Id linkId1 = Id.create("1", TLink.class); Id linkId2 = Id.create("2", TLink.class); @@ -42,22 +42,22 @@ public void testConstructor() { Assert.assertEquals("2", linkId2.toString()); } - @Test - public void testIdConstructor() { + @Test + void testIdConstructor() { Id nodeId1 = Id.create("1", TNode.class); Id linkId1 = Id.create(nodeId1, TLink.class); Assert.assertEquals("1", linkId1.toString()); } - - @Test - public void testIdConstructor_Null() { + + @Test + void testIdConstructor_Null() { Id linkId1 = Id.create((Id) null, TLink.class); Assert.assertNull(linkId1); } - - @Test - public void testObjectIdentity_cache() { + + @Test + void testObjectIdentity_cache() { Id linkId1 = Id.create("1", TLink.class); Id linkId2 = Id.create("2", TLink.class); Id linkId1again = Id.create("1", TLink.class); @@ -65,17 +65,17 @@ public void testObjectIdentity_cache() { Assert.assertTrue(linkId1 == linkId1again); Assert.assertFalse(linkId1 == linkId2); } - - @Test - public void testObjectIdentity_types() { + + @Test + void testObjectIdentity_types() { Id linkId1 = Id.create("1", TLink.class); Id nodeId1 = Id.create("1", TNode.class); Assert.assertFalse((Id) linkId1 == (Id) nodeId1); } - - @Test - public void testCompareTo() { + + @Test + void testCompareTo() { Id linkId1 = Id.create("1", TLink.class); Id linkId2 = Id.create("2", TLink.class); Id linkId1again = Id.create("1", TLink.class); @@ -94,8 +94,8 @@ public void testCompareTo() { // } // FIXME temporarily deactivated } - @Test - public void testResetCaches() { + @Test + void testResetCaches() { Id.create("1", TLink.class); Id.create("2", TLink.class); int count = Id.getNumberOfIds(TLink.class); @@ -108,8 +108,8 @@ public void testResetCaches() { Assert.assertEquals(3, Id.getNumberOfIds(TLink.class)); } - @Test - public void testResetCaches_onlyFromJUnit() throws InterruptedException { + @Test + void testResetCaches_onlyFromJUnit() throws InterruptedException { Id.create("1", TLink.class); int countBefore = Id.getNumberOfIds(TLink.class); Assert.assertTrue(countBefore > 0); diff --git a/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java b/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java index ce259d996c2..c6e62203b22 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; import org.matsim.api.core.v01.network.NetworkFactory; @@ -43,7 +43,8 @@ public class NetworkCreationTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testCreateNetwork() { + @Test + void testCreateNetwork() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Id nodeId1 = Id.create("1", Node.class); diff --git a/matsim/src/test/java/org/matsim/api/core/v01/network/AbstractNetworkTest.java b/matsim/src/test/java/org/matsim/api/core/v01/network/AbstractNetworkTest.java index 0b4a790d2ce..0e52b8b0594 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/network/AbstractNetworkTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/network/AbstractNetworkTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -38,7 +38,7 @@ public abstract class AbstractNetworkTest { public abstract Network getEmptyTestNetwork(); @Test - public void removeLink() { + void removeLink() { Fixture f = new Fixture(getEmptyTestNetwork()); Assert.assertTrue(f.network.getLinks().containsKey(f.linkIds[1])); @@ -63,7 +63,7 @@ public void removeLink() { } @Test - public void removeNode() { + void removeNode() { Fixture f = new Fixture(getEmptyTestNetwork()); Assert.assertEquals(8, f.network.getNodes().size()); diff --git a/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java b/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java index 4d623e74764..8a5ea4b5d90 100644 --- a/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java +++ b/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java @@ -1,8 +1,10 @@ package org.matsim.core.config; +import static org.junit.jupiter.api.Assertions.assertThrows; + import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import java.util.NoSuchElementException; @@ -12,7 +14,7 @@ public class CommandLineTest{ @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test - public void testStandardUsage() { + void testStandardUsage() { String outDir = utils.getOutputDirectory() ; final String configFilename = outDir + "/config.xml"; @@ -29,25 +31,28 @@ public void testStandardUsage() { } - @Test( expected = NoSuchElementException.class ) - public void testTypo() { + @Test + void testTypo() { + assertThrows(NoSuchElementException.class, () -> { - final String configFilename = utils.getOutputDirectory() + "/config.xml"; + final String configFilename = utils.getOutputDirectory() + "/config.xml"; - // write some config: - ConfigUtils.writeConfig( ConfigUtils.createConfig(), configFilename ); + // write some config: + ConfigUtils.writeConfig(ConfigUtils.createConfig(), configFilename); - String [] args = {configFilename, "--something=abc"} ; + String [] args = {configFilename, "--something=abc"} ; - Config config = ConfigUtils.loadConfig( args ) ; - CommandLine cmd = ConfigUtils.getCommandLine( args ); + Config config = ConfigUtils.loadConfig(args) ; + CommandLine cmd = ConfigUtils.getCommandLine(args); - Assert.assertEquals( "abc", cmd.getOption( "someting" ).get() ); + Assert.assertEquals("abc", cmd.getOption("someting").get()); + + }); } @Test - public void testAdditionalConfigGroup() { + void testAdditionalConfigGroup() { final String configFilename = utils.getOutputDirectory() + "/config.xml"; @@ -67,7 +72,7 @@ public void testAdditionalConfigGroup() { } @Test - public void testSetParameterInAllParameterSets() { + void testSetParameterInAllParameterSets() { final String configFilename = utils.getOutputDirectory() + "/config.xml"; @@ -94,24 +99,26 @@ public void testSetParameterInAllParameterSets() { } } - @Test( expected = RuntimeException.class ) - public void testNotYetExistingAdditionalConfigGroup() { - final String configFilename = utils.getOutputDirectory() + "/config.xml"; - { - // write some config: - final Config config = ConfigUtils.createConfig() ; - ConfigUtils.writeConfig( config, configFilename ); - } - { - String[] args = {configFilename, "--config:mockConfigGroup.abc=28"}; - Config config = ConfigUtils.loadConfig( args ); - // (fails in the above line because CommandLine can not deal with the additional config group when it does not know about it + @Test + void testNotYetExistingAdditionalConfigGroup() { + assertThrows(RuntimeException.class, () -> { + final String configFilename = utils.getOutputDirectory() + "/config.xml"; + { + // write some config: + final Config config = ConfigUtils.createConfig() ; + ConfigUtils.writeConfig(config, configFilename); + } + { + String[] args = {configFilename, "--config:mockConfigGroup.abc=28"}; + Config config = ConfigUtils.loadConfig(args); + // (fails in the above line because CommandLine can not deal with the additional config group when it does not know about it - } + } + }); } @Test - public void testFixNotYetExistingAdditionalConfigGroup() { + void testFixNotYetExistingAdditionalConfigGroup() { final String configFilename = utils.getOutputDirectory() + "/config.xml"; { // write some config: diff --git a/matsim/src/test/java/org/matsim/core/config/ConfigReaderMatsimV2Test.java b/matsim/src/test/java/org/matsim/core/config/ConfigReaderMatsimV2Test.java index af1a7d1a58b..89bf12288d9 100644 --- a/matsim/src/test/java/org/matsim/core/config/ConfigReaderMatsimV2Test.java +++ b/matsim/src/test/java/org/matsim/core/config/ConfigReaderMatsimV2Test.java @@ -1,7 +1,7 @@ package org.matsim.core.config; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.config.groups.ControllerConfigGroup; import java.io.ByteArrayInputStream; @@ -15,7 +15,7 @@ public class ConfigReaderMatsimV2Test { @Test - public void testModuleNameAlias() { + void testModuleNameAlias() { Config config = ConfigUtils.createConfig(); ConfigReaderMatsimV2 r2 = new ConfigReaderMatsimV2(config); @@ -37,7 +37,7 @@ public void testModuleNameAlias() { } @Test - public void testModuleNameAlias_noOldModules() { + void testModuleNameAlias_noOldModules() { Config config = ConfigUtils.createConfig(); ConfigReaderMatsimV2 r2 = new ConfigReaderMatsimV2(config); @@ -59,7 +59,7 @@ public void testModuleNameAlias_noOldModules() { } @Test - public void testParamNameAlias() { + void testParamNameAlias() { Config config = ConfigUtils.createConfig(); ConfigReaderMatsimV2 r2 = new ConfigReaderMatsimV2(config); @@ -81,7 +81,7 @@ public void testParamNameAlias() { } @Test - public void testModuleAndParamNameAlias() { + void testModuleAndParamNameAlias() { Config config = ConfigUtils.createConfig(); ConfigReaderMatsimV2 r2 = new ConfigReaderMatsimV2(config); @@ -107,7 +107,7 @@ public void testModuleAndParamNameAlias() { * Test that a parameter can be renamed inside a renamed module. */ @Test - public void testConditionalParamNameAliasWithModuleRenaming() { + void testConditionalParamNameAliasWithModuleRenaming() { Config config = ConfigUtils.createConfig(); ConfigReaderMatsimV2 r2 = new ConfigReaderMatsimV2(config); @@ -141,7 +141,7 @@ public void testConditionalParamNameAliasWithModuleRenaming() { * different parameter names depending on in which module they are in. */ @Test - public void testConditionalParamNameAlias() { + void testConditionalParamNameAlias() { Config config = ConfigUtils.createConfig(); ConfigReaderMatsimV2 r2 = new ConfigReaderMatsimV2(config); @@ -171,7 +171,7 @@ public void testConditionalParamNameAlias() { * Test that an alias only matches if its path also matches. */ @Test - public void testConditionalParamNameAlias2() { + void testConditionalParamNameAlias2() { Config config = ConfigUtils.createConfig(); ConfigReaderMatsimV2 r2 = new ConfigReaderMatsimV2(config); @@ -200,7 +200,7 @@ public void testConditionalParamNameAlias2() { * Test that an alias only matches if its path also matches. */ @Test - public void testConditionalParamNameAlias3() { + void testConditionalParamNameAlias3() { Config config = ConfigUtils.createConfig(); ConfigReaderMatsimV2 r2 = new ConfigReaderMatsimV2(config); @@ -225,7 +225,7 @@ public void testConditionalParamNameAlias3() { * Test that an alias only matches if its path also matches. */ @Test - public void testConditionalParamNameAlias4() { + void testConditionalParamNameAlias4() { Config config = ConfigUtils.createConfig(); ConfigReaderMatsimV2 r2 = new ConfigReaderMatsimV2(config); @@ -251,7 +251,7 @@ public void testConditionalParamNameAlias4() { * Test that an alias also matches in nested parameter sets. */ @Test - public void testAliasWithParamSets() { + void testAliasWithParamSets() { Config config = ConfigUtils.createConfig(); ConfigReaderMatsimV2 r2 = new ConfigReaderMatsimV2(config); diff --git a/matsim/src/test/java/org/matsim/core/config/ConfigTest.java b/matsim/src/test/java/org/matsim/core/config/ConfigTest.java index 1f37611804a..07c481b7935 100644 --- a/matsim/src/test/java/org/matsim/core/config/ConfigTest.java +++ b/matsim/src/test/java/org/matsim/core/config/ConfigTest.java @@ -22,7 +22,7 @@ import java.io.ByteArrayInputStream; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author mrieser / senozon @@ -30,7 +30,7 @@ public class ConfigTest { @Test - public void testAddModule_beforeLoading() { + void testAddModule_beforeLoading() { Config config = new Config(); ConfigTestGroup group = new ConfigTestGroup(); @@ -54,7 +54,7 @@ public void testAddModule_beforeLoading() { } @Test - public void testAddModule_afterLoading() { + void testAddModule_afterLoading() { Config config = new Config(); ConfigTestGroup group = new ConfigTestGroup(); diff --git a/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java b/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java index 57f77ab8bca..0bdd7443ea7 100644 --- a/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java +++ b/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java @@ -3,8 +3,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class MaterializeConfigTest { @@ -14,7 +14,7 @@ public class MaterializeConfigTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public final void testMaterializeAfterReadParameterSets() { + final void testMaterializeAfterReadParameterSets() { { // generate a test config that sets two values away from their defaults, and // write it to file: diff --git a/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java index a0302aea465..45243363ca7 100644 --- a/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java @@ -33,8 +33,8 @@ import java.util.Set; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -52,7 +52,7 @@ public class ReflectiveConfigGroupTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testDumpAndRead() { + void testDumpAndRead() { MyModule dumpedModule = new MyModule(); dumpedModule.setDoubleField(1000); dumpedModule.setIdField(Id.create(123, Link.class)); @@ -76,13 +76,13 @@ public void testDumpAndRead() { } @Test - public void testDumpAndReadNulls() { + void testDumpAndReadNulls() { MyModule dumpedModule = new MyModule(); assertEqualAfterDumpAndRead(dumpedModule); } @Test - public void testDumpAndReadEmptyCollections() { + void testDumpAndReadEmptyCollections() { MyModule dumpedModule = new MyModule(); dumpedModule.listField = List.of(); dumpedModule.setField = ImmutableSet.of(); @@ -92,7 +92,7 @@ public void testDumpAndReadEmptyCollections() { } @Test - public void testDumpAndReadCollectionsWithExactlyOneEmptyString() { + void testDumpAndReadCollectionsWithExactlyOneEmptyString() { MyModule dumpedModule = new MyModule(); //fail on list @@ -109,7 +109,7 @@ public void testDumpAndReadCollectionsWithExactlyOneEmptyString() { } @Test - public void testDumpAndReadCollectionsIncludingEmptyString() { + void testDumpAndReadCollectionsIncludingEmptyString() { MyModule dumpedModule = new MyModule(); //fail on list @@ -141,7 +141,7 @@ private void assertEqualAfterDumpAndRead(MyModule dumpedModule) { } @Test - public void testReadCollectionsIncludingEmptyString() { + void testReadCollectionsIncludingEmptyString() { String fileName = utils.getInputDirectory() + "/config_with_blank_comma_separated_elements.xml"; final Config readConfig = ConfigUtils.loadConfig(fileName); final MyModule readModule = new MyModule(); @@ -152,7 +152,7 @@ public void testReadCollectionsIncludingEmptyString() { } @Test - public void testComments() { + void testComments() { var expectedComments = new HashMap<>(); expectedComments.put("floatField", "float"); expectedComments.put("longField", "long"); @@ -173,7 +173,7 @@ public void testComments() { } @Test - public void testFailOnConstructingOrphanSetter() { + void testFailOnConstructingOrphanSetter() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { @StringSetter("setterWithoutGetter") public void setStuff(String s) { @@ -182,7 +182,7 @@ public void setStuff(String s) { } @Test - public void testFailOnConstructingOrphanGetter() { + void testFailOnConstructingOrphanGetter() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { @StringGetter("setterWithoutGetter") public Coord getStuff() { @@ -192,7 +192,7 @@ public Coord getStuff() { } @Test - public void testFailOnConstructingInvalidSetter() { + void testFailOnConstructingInvalidSetter() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { // no arg: no good @StringSetter("field") @@ -221,7 +221,7 @@ public Object getStuff() { } @Test - public void testFailOnConstructingInvalidGetter() { + void testFailOnConstructingInvalidGetter() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { @StringSetter("field") public Object setStuff(String s) { @@ -249,7 +249,7 @@ public Object getStuff(Object someArg) { } @Test - public void testFailOnConstructingSeveralGetters() { + void testFailOnConstructingSeveralGetters() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { @StringSetter("field") public void setStuff(String s) { @@ -268,7 +268,7 @@ public Object getStuff2() { } @Test - public void testFailOnConstructingSeveralSetters() { + void testFailOnConstructingSeveralSetters() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { @StringSetter("field") public void setStuff(String s) { @@ -286,7 +286,7 @@ public Object getStuff() { } @Test - public void testFailOnConstructingSeveralParameters() { + void testFailOnConstructingSeveralParameters() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { @Parameter double field; @@ -297,7 +297,7 @@ public void testFailOnConstructingSeveralParameters() { } @Test - public void testFailOnMixingGettersSettersWithParameters() { + void testFailOnMixingGettersSettersWithParameters() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { @StringSetter("field") public void setStuff(double s) { @@ -314,7 +314,7 @@ public Object getStuff() { } @Test - public void testFailUnsupportedType_StringCollections() { + void testFailUnsupportedType_StringCollections() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { @Parameter("field") private Collection stuff; @@ -322,7 +322,7 @@ public void testFailUnsupportedType_StringCollections() { } @Test - public void testFailUnsupportedType_NonStringList() { + void testFailUnsupportedType_NonStringList() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { @Parameter("field") private List stuff; @@ -330,7 +330,7 @@ public void testFailUnsupportedType_NonStringList() { } @Test - public void testFailUnsupportedType_StringHashSet() { + void testFailUnsupportedType_StringHashSet() { assertThatThrownBy(() -> new ReflectiveConfigGroup("name") { @Parameter("field") private HashSet stuff; @@ -338,7 +338,7 @@ public void testFailUnsupportedType_StringHashSet() { } @Test - public void testPreferCustomCommentToAutoGeneratedEnumComment() { + void testPreferCustomCommentToAutoGeneratedEnumComment() { var config = new ReflectiveConfigGroup("name") { @Comment("my comment") @Parameter("field") @@ -348,7 +348,7 @@ public void testPreferCustomCommentToAutoGeneratedEnumComment() { } @Test - public void testBehaviorWhenAcceptingUnknownParameters() { + void testBehaviorWhenAcceptingUnknownParameters() { final ConfigGroup testee = new ReflectiveConfigGroup("name", true) { @StringSetter("field") public void setStuff(String s) { @@ -367,7 +367,7 @@ public Object getStuff() { } @Test - public void testBehaviorWhenRejectingUnknownParameters() { + void testBehaviorWhenRejectingUnknownParameters() { final ConfigGroup testee = new ReflectiveConfigGroup("name", false) { @StringSetter("field") public void setStuff(String s) { @@ -388,7 +388,7 @@ public Object getStuff() { } @Test - public void testExceptionRedirection() { + void testExceptionRedirection() { final RuntimeException expectedException = new RuntimeException(); final ConfigGroup m = new ReflectiveConfigGroup("name") { @StringSetter("field") diff --git a/matsim/src/test/java/org/matsim/core/config/URLTest.java b/matsim/src/test/java/org/matsim/core/config/URLTest.java index 2b75f03cff3..c5472f0c73a 100644 --- a/matsim/src/test/java/org/matsim/core/config/URLTest.java +++ b/matsim/src/test/java/org/matsim/core/config/URLTest.java @@ -21,17 +21,17 @@ package org.matsim.core.config; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.scenario.ScenarioUtils; import java.net.MalformedURLException; import java.net.URL; -public class URLTest { + public class URLTest { - @Test - public void testLoadWithURL() throws MalformedURLException { + @Test + void testLoadWithURL() throws MalformedURLException { Config config = ConfigUtils.loadConfig(new URL("file:../examples/scenarios/equil/config.xml")); Scenario scenario = ScenarioUtils.loadScenario(config); } diff --git a/matsim/src/test/java/org/matsim/core/config/consistency/BeanValidationConfigConsistencyCheckerTest.java b/matsim/src/test/java/org/matsim/core/config/consistency/BeanValidationConfigConsistencyCheckerTest.java index 083c74cf9e6..b6e9eba0719 100644 --- a/matsim/src/test/java/org/matsim/core/config/consistency/BeanValidationConfigConsistencyCheckerTest.java +++ b/matsim/src/test/java/org/matsim/core/config/consistency/BeanValidationConfigConsistencyCheckerTest.java @@ -32,7 +32,7 @@ import jakarta.validation.constraints.PositiveOrZero; import org.assertj.core.api.Assertions; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigGroup; import org.matsim.core.config.ConfigUtils; @@ -44,17 +44,17 @@ public class BeanValidationConfigConsistencyCheckerTest { @Test - public void emptyConfig_valid() { + void emptyConfig_valid() { assertThat(getViolationTuples(new Config())).isEmpty(); } @Test - public void defaultConfig_valid() { + void defaultConfig_valid() { assertThat(getViolationTuples(ConfigUtils.createConfig())).isEmpty(); } @Test - public void invalidConfigGroup_violationsReturned() { + void invalidConfigGroup_violationsReturned() { { Config config = ConfigUtils.createConfig(); config.qsim().setFlowCapFactor(0); @@ -75,7 +75,7 @@ public void invalidConfigGroup_violationsReturned() { } @Test - public void invalidParameterSet_violationsReturned() { + void invalidParameterSet_violationsReturned() { ConfigGroup configGroup = new ConfigGroup("config_group"); configGroup.addParameterSet(new ConfigGroup("invalid_param_set") { @PositiveOrZero @@ -88,7 +88,7 @@ public void invalidParameterSet_violationsReturned() { } @Test - public void manyConfigGroupsInvalid_violationsReturned() { + void manyConfigGroupsInvalid_violationsReturned() { { Config config = ConfigUtils.createConfig(); config.qsim().setFlowCapFactor(0); diff --git a/matsim/src/test/java/org/matsim/core/config/consistency/ConfigConsistencyCheckerImplTest.java b/matsim/src/test/java/org/matsim/core/config/consistency/ConfigConsistencyCheckerImplTest.java index 737607dae7d..1e996282944 100644 --- a/matsim/src/test/java/org/matsim/core/config/consistency/ConfigConsistencyCheckerImplTest.java +++ b/matsim/src/test/java/org/matsim/core/config/consistency/ConfigConsistencyCheckerImplTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.Level; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -38,7 +38,7 @@ public class ConfigConsistencyCheckerImplTest { @Test - public void testCheckPlanCalcScore_DefaultsOk() { + void testCheckPlanCalcScore_DefaultsOk() { Config config = new Config(); config.addCoreModules(); @@ -54,7 +54,7 @@ public void testCheckPlanCalcScore_DefaultsOk() { } @Test - public void testCheckPlanCalcScore_Traveling() { + void testCheckPlanCalcScore_Traveling() { Config config = new Config(); config.addCoreModules(); @@ -72,7 +72,7 @@ public void testCheckPlanCalcScore_Traveling() { } @Test - public void testCheckPlanCalcScore_TravelingPt() { + void testCheckPlanCalcScore_TravelingPt() { Config config = new Config(); config.addCoreModules(); @@ -90,7 +90,7 @@ public void testCheckPlanCalcScore_TravelingPt() { } @Test - public void testCheckPlanCalcScore_TravelingBike() { + void testCheckPlanCalcScore_TravelingBike() { Config config = new Config(); config.addCoreModules(); @@ -108,7 +108,7 @@ public void testCheckPlanCalcScore_TravelingBike() { } @Test - public void testCheckPlanCalcScore_TravelingWalk() { + void testCheckPlanCalcScore_TravelingWalk() { Config config = new Config(); config.addCoreModules(); @@ -126,7 +126,7 @@ public void testCheckPlanCalcScore_TravelingWalk() { } @Test - public void testCheckPlanCalcScore_PtInteractionActivity() { + void testCheckPlanCalcScore_PtInteractionActivity() { Config config = new Config(); config.addCoreModules(); @@ -154,7 +154,7 @@ public void testCheckPlanCalcScore_PtInteractionActivity() { @Test - public void checkConsistencyBetweenRouterAndTravelTimeCalculatorTest(){ + void checkConsistencyBetweenRouterAndTravelTimeCalculatorTest(){ { Config config = ConfigUtils.createConfig(); diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java index a1c50b1d46f..26499157749 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java @@ -24,7 +24,7 @@ import java.util.Set; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.config.groups.ControllerConfigGroup.EventsFileFormat; public class ControllerConfigGroupTest { @@ -36,7 +36,7 @@ public class ControllerConfigGroupTest { * @author mrieser */ @Test - public void testEventsFileFormat() { + void testEventsFileFormat() { ControllerConfigGroup cg = new ControllerConfigGroup(); Set formats; // test initial value @@ -86,7 +86,7 @@ public void testEventsFileFormat() { * @author mrieser */ @Test - public void testMobsim() { + void testMobsim() { ControllerConfigGroup cg = new ControllerConfigGroup(); // test initial value Assert.assertEquals("qsim", cg.getMobsim()); @@ -108,7 +108,7 @@ public void testMobsim() { * @author mrieser */ @Test - public void testWritePlansInterval() { + void testWritePlansInterval() { ControllerConfigGroup cg = new ControllerConfigGroup(); // test initial value Assert.assertEquals(50, cg.getWritePlansInterval()); @@ -125,7 +125,7 @@ public void testWritePlansInterval() { * returned with the getters and setters. */ @Test - public void testLink2LinkRouting(){ + void testLink2LinkRouting(){ ControllerConfigGroup cg = new ControllerConfigGroup(); //initial value Assert.assertFalse(cg.isLinkToLinkRoutingEnabled()); @@ -148,7 +148,7 @@ public void testLink2LinkRouting(){ * returned with the getters and setters. */ @Test - public void testWriteSnapshotInterval(){ + void testWriteSnapshotInterval(){ ControllerConfigGroup cg = new ControllerConfigGroup(); //initial value Assert.assertEquals(1, cg.getWriteSnapshotsInterval()); diff --git a/matsim/src/test/java/org/matsim/core/config/groups/CountsConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/CountsConfigGroupTest.java index 64016c97940..f1c2fdf7276 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/CountsConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/CountsConfigGroupTest.java @@ -20,7 +20,7 @@ package org.matsim.core.config.groups; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author mrieser @@ -28,7 +28,7 @@ public class CountsConfigGroupTest { @Test - public void testWriteCountsInterval() { + void testWriteCountsInterval() { CountsConfigGroup cg = new CountsConfigGroup(); // test initial value Assert.assertEquals(10, cg.getWriteCountsInterval()); @@ -44,13 +44,13 @@ public void testWriteCountsInterval() { } @Test - public void testGetParams_writeCountsInterval() { + void testGetParams_writeCountsInterval() { CountsConfigGroup cg = new CountsConfigGroup(); Assert.assertNotNull(cg.getParams().get("writeCountsInterval")); } - + @Test - public void testWriteAverageOverIterations() { + void testWriteAverageOverIterations() { CountsConfigGroup cg = new CountsConfigGroup(); // test initial value Assert.assertEquals(5, cg.getAverageCountsOverIterations()); @@ -64,9 +64,9 @@ public void testWriteAverageOverIterations() { Assert.assertEquals(2, cg.getAverageCountsOverIterations()); Assert.assertEquals("2", cg.getValue("averageCountsOverIterations")); } - + @Test - public void testGetParams_averageCountsOverIterations() { + void testGetParams_averageCountsOverIterations() { CountsConfigGroup cg = new CountsConfigGroup(); Assert.assertNotNull(cg.getParams().get("averageCountsOverIterations")); } diff --git a/matsim/src/test/java/org/matsim/core/config/groups/LinkStatsConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/LinkStatsConfigGroupTest.java index 95397daf264..363c5eca282 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/LinkStatsConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/LinkStatsConfigGroupTest.java @@ -20,7 +20,7 @@ package org.matsim.core.config.groups; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author mrieser @@ -28,7 +28,7 @@ public class LinkStatsConfigGroupTest { @Test - public void testWriteLinkStatsInterval() { + void testWriteLinkStatsInterval() { LinkStatsConfigGroup cg = new LinkStatsConfigGroup(); // test initial value Assert.assertEquals(50, cg.getWriteLinkStatsInterval()); @@ -44,13 +44,13 @@ public void testWriteLinkStatsInterval() { } @Test - public void testGetParams_writeLinkStatsInterval() { + void testGetParams_writeLinkStatsInterval() { LinkStatsConfigGroup cg = new LinkStatsConfigGroup(); Assert.assertNotNull(cg.getParams().get("writeLinkStatsInterval")); } - + @Test - public void testWriteAverageOverIterations() { + void testWriteAverageOverIterations() { LinkStatsConfigGroup cg = new LinkStatsConfigGroup(); // test initial value Assert.assertEquals(5, cg.getAverageLinkStatsOverIterations()); @@ -64,9 +64,9 @@ public void testWriteAverageOverIterations() { Assert.assertEquals(2, cg.getAverageLinkStatsOverIterations()); Assert.assertEquals("2", cg.getValue("averageLinkStatsOverIterations")); } - + @Test - public void testGetParams_averageLinkStatsOverIterations() { + void testGetParams_averageLinkStatsOverIterations() { LinkStatsConfigGroup cg = new LinkStatsConfigGroup(); Assert.assertNotNull(cg.getParams().get("averageLinkStatsOverIterations")); } diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java index ba0fae597fa..ba0ff07c5f3 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigGroup; @@ -55,7 +55,7 @@ public class ReplanningConfigGroupTest { * @author mrieser */ @Test - public void testParamNames() { + void testParamNames() { ReplanningConfigGroup configGroup = new ReplanningConfigGroup(); configGroup.addParam("maxAgentPlanMemorySize", "3"); configGroup.addParam("Module_1", "ReRoute"); @@ -79,7 +79,7 @@ public void testParamNames() { * @author mrieser */ @Test - public void testCheckConsistency() { + void testCheckConsistency() { // start with a simple configuration with exactly one module defined ReplanningConfigGroup configGroup = new ReplanningConfigGroup(); configGroup.addParam("maxAgentPlanMemorySize", "3"); @@ -148,7 +148,7 @@ public void testCheckConsistency() { } @Test - public void testIOWithFormatChange() { + void testIOWithFormatChange() { final ReplanningConfigGroup initialGroup = createTestConfigGroup(); final String v1path = utils.getOutputDirectory() + "/configv1_out.xml"; diff --git a/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java index 5b04311c78f..45f9c4e335c 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java @@ -23,10 +23,12 @@ import java.util.Map; import org.apache.logging.log4j.LogManager; + +import static org.junit.jupiter.api.Assertions.assertThrows; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigGroup; @@ -44,7 +46,7 @@ public class RoutingConfigGroupTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testAddModeParamsTwice() { + void testAddModeParamsTwice() { String outdir = utils.getOutputDirectory(); final String filename = outdir + "config.xml"; { @@ -67,8 +69,9 @@ public void testAddModeParamsTwice() { Assert.assertEquals( 0, group.getModeRoutingParams().size() ); } } + @Test - public void testClearParamsWriteRead() { + void testClearParamsWriteRead() { String outdir = utils.getOutputDirectory(); final String filename = outdir + "config.xml"; { @@ -91,8 +94,9 @@ public void testClearParamsWriteRead() { Assert.assertEquals( 0, group.getModeRoutingParams().size() ); } } + @Test - public void testRemoveParamsWriteRead() { + void testRemoveParamsWriteRead() { String outdir = utils.getOutputDirectory(); final String filename = outdir + "config.xml"; { @@ -116,8 +120,9 @@ public void testRemoveParamsWriteRead() { Assert.assertEquals( 0, group.getModeRoutingParams().size() ); } } + @Test - public void testClearDefaults() { + void testClearDefaults() { Config config = ConfigUtils.createConfig( ) ; RoutingConfigGroup group = config.routing() ; Assert.assertEquals( N_MODE_ROUTING_PARAMS_DEFAULT, group.getModeRoutingParams().size() ); @@ -128,22 +133,26 @@ public void testClearDefaults() { group.clearModeRoutingParams( ); Assert.assertEquals( 0, group.getModeRoutingParams().size() ); } + @Test - public void test3() { + void test3() { Config config = ConfigUtils.createConfig( ) ; RoutingConfigGroup group = config.routing() ; group.clearModeRoutingParams(); group.setClearingDefaultModeRoutingParams( true ); // should be ok } - @Test( expected = RuntimeException.class ) - public void testInconsistencyBetweenActionAndState() { - RoutingConfigGroup group = new RoutingConfigGroup() ; - group.clearModeRoutingParams(); - group.setClearingDefaultModeRoutingParams( false ); // should fail + + @Test + void testInconsistencyBetweenActionAndState() { + assertThrows(RuntimeException.class, () -> { + RoutingConfigGroup group = new RoutingConfigGroup() ; + group.clearModeRoutingParams(); + group.setClearingDefaultModeRoutingParams(false); // should fail + }); // should fail } @Test - public void testBackwardsCompatibility() { + void testBackwardsCompatibility() { RoutingConfigGroup group = new RoutingConfigGroup(); // test default @@ -161,7 +170,7 @@ public void testBackwardsCompatibility() { } @Test - public void testDefaultsAreCleared() { + void testDefaultsAreCleared() { RoutingConfigGroup group = new RoutingConfigGroup(); // group.clearModeRoutingParams(); group.setTeleportedModeSpeed( "skateboard" , 20 / 3.6 ); @@ -173,7 +182,7 @@ public void testDefaultsAreCleared() { } @Test - public void testIODifferentVersions() + void testIODifferentVersions() { final RoutingConfigGroup initialGroup = createTestConfigGroup(); @@ -210,29 +219,35 @@ public void testIODifferentVersions() assertIdentical("re-read v2", initialGroup, configV2.routing()); } - @Test( expected=RuntimeException.class ) - public void testConsistencyCheckIfNoTeleportedSpeed() { - final Config config = ConfigUtils.createConfig(); + @Test + void testConsistencyCheckIfNoTeleportedSpeed() { + assertThrows(RuntimeException.class, () -> { + final Config config = ConfigUtils.createConfig(); - final TeleportedModeParams params = new TeleportedModeParams( "skateboard" ); - config.routing().addModeRoutingParams( params ); - // (one needs to set one of the teleported speed settings) + final TeleportedModeParams params = new TeleportedModeParams( "skateboard" ); + config.routing().addModeRoutingParams(params); + // (one needs to set one of the teleported speed settings) - config.checkConsistency(); + config.checkConsistency(); + }); } - @Test( expected=IllegalStateException.class ) - public void testCannotAddSpeedAfterFactor() { - final TeleportedModeParams params = new TeleportedModeParams( "overboard" ); - params.setTeleportedModeFreespeedFactor( 2.0 ); - params.setTeleportedModeSpeed( 12.0 ); + @Test + void testCannotAddSpeedAfterFactor() { + assertThrows(IllegalStateException.class, () -> { + final TeleportedModeParams params = new TeleportedModeParams( "overboard" ); + params.setTeleportedModeFreespeedFactor(2.0); + params.setTeleportedModeSpeed(12.0); + }); } - @Test( expected=IllegalStateException.class ) - public void testCannotAddFactorAfterSpeed() { - final TeleportedModeParams params = new TeleportedModeParams( "overboard" ); - params.setTeleportedModeSpeed( 12.0 ); - params.setTeleportedModeFreespeedFactor( 2.0 ); + @Test + void testCannotAddFactorAfterSpeed() { + assertThrows(IllegalStateException.class, () -> { + final TeleportedModeParams params = new TeleportedModeParams( "overboard" ); + params.setTeleportedModeSpeed(12.0); + params.setTeleportedModeFreespeedFactor(2.0); + }); } private static void assertIdentical( diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java index d75ee413732..80512022e3f 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java @@ -29,8 +29,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigGroup; @@ -41,7 +41,7 @@ import org.matsim.core.config.groups.ScoringConfigGroup.ModeParams; import org.matsim.testcases.MatsimTestUtils; -public class ScoringConfigGroupTest { + public class ScoringConfigGroupTest { private static final Logger log = LogManager.getLogger(ScoringConfigGroupTest.class); @@ -78,8 +78,8 @@ private void testResultsAfterCheckConsistency( Config config ) { } } - @Test - public void testFullyHierarchicalVersion() { + @Test + void testFullyHierarchicalVersion() { Config config = ConfigUtils.loadConfig( utils.getClassInputDirectory() + "config_v2_w_scoringparams.xml" ) ; ScoringConfigGroup scoringConfig = config.scoring() ; testResultsBeforeCheckConsistency( config, true ) ; @@ -106,8 +106,9 @@ public void testFullyHierarchicalVersion() { } log.warn( "" ); } - @Test - public void testVersionWoScoringparams() { + + @Test + void testVersionWoScoringparams() { Config config = ConfigUtils.loadConfig( utils.getClassInputDirectory() + "config_v2_wo_scoringparams.xml" ) ; ScoringConfigGroup scoringConfig = config.scoring() ; testResultsBeforeCheckConsistency( config, false ) ; @@ -135,8 +136,8 @@ public void testVersionWoScoringparams() { log.warn( "" ); } - @Test - public void testAddActivityParams() { + @Test + void testAddActivityParams() { ScoringConfigGroup c = new ScoringConfigGroup(); int originalSize = c.getActivityParams().size(); Assert.assertNull(c.getActivityParams("type1")); @@ -148,8 +149,8 @@ public void testAddActivityParams() { Assert.assertEquals(originalSize + 1, c.getActivityParams().size()); } - @Test - public void testIODifferentVersions() { + @Test + void testIODifferentVersions() { final ScoringConfigGroup initialGroup = createTestConfigGroup(); final String v1path = utils.getOutputDirectory() + "/configv1_out.xml"; diff --git a/matsim/src/test/java/org/matsim/core/config/groups/SubtourModeChoiceConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/SubtourModeChoiceConfigGroupTest.java index 23a51557f6d..77bcf5c5869 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/SubtourModeChoiceConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/SubtourModeChoiceConfigGroupTest.java @@ -24,7 +24,7 @@ import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author thibautd @@ -32,7 +32,7 @@ public class SubtourModeChoiceConfigGroupTest { @Test - public void testModes() throws Exception { + void testModes() throws Exception { SubtourModeChoiceConfigGroup group = new SubtourModeChoiceConfigGroup(); final String msg = "Wrong values for modes"; final String msgString = "Wrong string representation"; @@ -78,7 +78,7 @@ public void testModes() throws Exception { } @Test - public void testChainBasedModes() throws Exception { + void testChainBasedModes() throws Exception { SubtourModeChoiceConfigGroup group = new SubtourModeChoiceConfigGroup(); final String msg = "Wrong values for chain based modes"; final String msgString = "Wrong string representation"; @@ -124,7 +124,7 @@ public void testChainBasedModes() throws Exception { } @Test - public void testCarAvail() throws Exception { + void testCarAvail() throws Exception { SubtourModeChoiceConfigGroup group = new SubtourModeChoiceConfigGroup(); assertFalse( diff --git a/matsim/src/test/java/org/matsim/core/config/groups/VspExperimentalConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/VspExperimentalConfigGroupTest.java index 088d486fea7..9ddaaa3fde0 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/VspExperimentalConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/VspExperimentalConfigGroupTest.java @@ -22,8 +22,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class VspExperimentalConfigGroupTest { @@ -34,7 +34,8 @@ public class VspExperimentalConfigGroupTest { private static final Logger log = LogManager.getLogger(VspExperimentalConfigGroupTest.class); - @Test public void testVspConfigGroup() { + @Test + void testVspConfigGroup() { // VspExperimentalConfigGroup vspConfig = ConfigUtils.createConfig().vspExperimental() ; // diff --git a/matsim/src/test/java/org/matsim/core/controler/AbstractModuleTest.java b/matsim/src/test/java/org/matsim/core/controler/AbstractModuleTest.java index 5651097897f..14ce2ce7150 100644 --- a/matsim/src/test/java/org/matsim/core/controler/AbstractModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/AbstractModuleTest.java @@ -5,8 +5,8 @@ import com.google.inject.name.Named; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.Config; @@ -25,7 +25,7 @@ public class AbstractModuleTest{ @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test - public void test1() { + void test1() { Config config = ConfigUtils.createConfig() ; config.controller().setOutputDirectory( utils.getOutputDirectory() ); diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java b/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java index a1739b52361..d4b1efc64b6 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java @@ -28,8 +28,8 @@ import org.junit.After; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.controler.events.IterationEndsEvent; import org.matsim.core.controler.events.IterationStartsEvent; @@ -60,7 +60,8 @@ void addCalledStartupListenerNumber(int i) { this.calledStartupListener = null; } - @Test public void testCoreListenerExecutionOrder() { + @Test + void testCoreListenerExecutionOrder() { Config config = utils.loadConfig(utils.getClassInputDirectory() + "config.xml"); TestController controler = new TestController(config); @@ -77,7 +78,8 @@ void addCalledStartupListenerNumber(int i) { assertEquals(1, this.calledStartupListener.get(2).intValue()); } - @Test public void testEvents() { + @Test + void testEvents() { Config config = utils.loadConfig(utils.getClassInputDirectory() + "config.xml"); TestController controler = new TestController(config); diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java index 3f49cbf2b46..b304f34dbd1 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java @@ -21,6 +21,7 @@ package org.matsim.core.controler; import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.assertThrows; import static org.matsim.core.config.groups.ControllerConfigGroup.CompressionType; import static org.matsim.core.config.groups.ControllerConfigGroup.SnapshotFormat; @@ -34,8 +35,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -95,7 +96,7 @@ public static Collection parameterObjects () { } @Test - public void testScenarioLoading() { + void testScenarioLoading() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); Controler controler = new Controler( config ); @@ -113,7 +114,7 @@ public void testScenarioLoading() { } @Test - public void testTerminationCriterion() { + void testTerminationCriterion() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); config.controller().setOutputDirectory(utils.getOutputDirectory()); Controler controler = new Controler(config); @@ -132,7 +133,7 @@ public boolean doTerminate(int iteration) { } @Test - public void testConstructor_EventsManagerTypeImmutable() { + void testConstructor_EventsManagerTypeImmutable() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); MatsimServices controler = new Controler(config); try { @@ -156,7 +157,7 @@ public void testConstructor_EventsManagerTypeImmutable() { * @author mrieser */ @Test - public void testTravelTimeCalculation() { + void testTravelTimeCalculation() { Fixture f = new Fixture(ConfigUtils.createConfig()); Config config = f.scenario.getConfig(); @@ -249,7 +250,7 @@ public void testTravelTimeCalculation() { * @author mrieser */ @Test - public void testSetScoringFunctionFactory() { + void testSetScoringFunctionFactory() { final Config config = this.utils.loadConfig((String) null); config.controller().setLastIteration(0); @@ -297,7 +298,7 @@ public Mobsim get() { * @author mrieser */ @Test - public void testCalcMissingRoutes() { + void testCalcMissingRoutes() { Config config = this.utils.loadConfig((String) null); Fixture f = new Fixture(config); @@ -386,7 +387,7 @@ public Mobsim get() { * @author mrieser */ @Test - public void testCalcMissingActLinks() { + void testCalcMissingActLinks() { Config config = this.utils.loadConfig((String) null); Fixture f = new Fixture(config); @@ -499,7 +500,7 @@ public Mobsim get() { * @author mrieser */ @Test - public void testCompressionType() { + void testCompressionType() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(0); config.controller().setCompressionType( CompressionType.zst ); @@ -538,7 +539,7 @@ public Mobsim get() { * @author mrieser */ @Test - public void testSetWriteEventsInterval() { + void testSetWriteEventsInterval() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(10); config.controller().setWritePlansInterval(0); @@ -582,7 +583,7 @@ public Mobsim get() { * @author wrashid */ @Test - public void testSetWriteEventsIntervalConfig() { + void testSetWriteEventsIntervalConfig() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(10); config.controller().setWritePlansInterval(0); @@ -623,7 +624,7 @@ public Mobsim get() { * @author mrieser */ @Test - public void testSetWriteEventsNever() { + void testSetWriteEventsNever() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(1); config.controller().setWritePlansInterval(0); @@ -656,7 +657,7 @@ public Mobsim get() { * @author mrieser */ @Test - public void testSetWriteEventsAlways() { + void testSetWriteEventsAlways() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(1); config.controller().setWritePlansInterval(0); @@ -687,7 +688,7 @@ public Mobsim get() { * @author mrieser */ @Test - public void testSetWriteEventsXml() { + void testSetWriteEventsXml() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(0); config.controller().setWritePlansInterval(0); @@ -718,7 +719,7 @@ public Mobsim get() { * @author mrieser */ @Test - public void testSetDumpDataAtEnd_true() { + void testSetDumpDataAtEnd_true() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(0); config.controller().setWritePlansInterval(0); @@ -748,7 +749,7 @@ public Mobsim get() { * @author mrieser */ @Test - public void testSetDumpDataAtEnd_false() { + void testSetDumpDataAtEnd_false() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(0); config.controller().setWritePlansInterval(0); @@ -775,25 +776,27 @@ public Mobsim get() { assertFalse(new File(controler.getControlerIO().getOutputFilename(Controler.DefaultFiles.population)).exists()); } - @Test(expected = RuntimeException.class) - public void testShutdown_UncaughtException() { - final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); - config.controller().setLastIteration(1); + @Test + void testShutdown_UncaughtException() { + assertThrows(RuntimeException.class, () -> { + final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); + config.controller().setLastIteration(1); - Controler controler = new Controler(config); - controler.addOverridingModule(new AbstractModule() { - @Override - public void install() { - bindMobsim().to(CrashingMobsim.class); - } + Controler controler = new Controler(config); + controler.addOverridingModule(new AbstractModule() { + @Override + public void install() { + bindMobsim().to(CrashingMobsim.class); + } + }); + controler.getConfig().controller().setCreateGraphs(false); + controler.getConfig().controller().setDumpDataAtEnd(false); + controler.run(); }); - controler.getConfig().controller().setCreateGraphs(false); - controler.getConfig().controller().setDumpDataAtEnd(false); - controler.run(); } @Test - public void test_ExceptionOnMissingPopulationFile() { + void test_ExceptionOnMissingPopulationFile() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(0); config.controller().setWriteEventsInterval(0); @@ -828,7 +831,7 @@ public Mobsim get() { } @Test - public void test_ExceptionOnMissingNetworkFile() { + void test_ExceptionOnMissingNetworkFile() { try { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(0); @@ -863,7 +866,7 @@ public Mobsim get() { } @Test - public void test_ExceptionOnMissingFacilitiesFile() { + void test_ExceptionOnMissingFacilitiesFile() { try { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(0); @@ -898,7 +901,7 @@ public Mobsim get() { } @Test - public void testOneSnapshotWriterInConfig() { + void testOneSnapshotWriterInConfig() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(0); config.controller().setWriteEventsInterval(0); @@ -915,7 +918,7 @@ public void testOneSnapshotWriterInConfig() { } @Test - public void testTransimsSnapshotWriterOnQSim() { + void testTransimsSnapshotWriterOnQSim() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); config.controller().setLastIteration(2); config.controller().setWriteEventsInterval(0); @@ -944,36 +947,38 @@ public void testTransimsSnapshotWriterOnQSim() { * @thibautd * */ - @Test( expected = RuntimeException.class ) - public void testGuiceModulesCannotAddModules() { - final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); - config.controller().setLastIteration( 0 ); - final Controler controler = new Controler( config ); + @Test + void testGuiceModulesCannotAddModules() { + assertThrows(RuntimeException.class, () -> { + final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); + config.controller().setLastIteration(0); + final Controler controler = new Controler( config ); - final Scenario replacementScenario = ScenarioUtils.createScenario( config ); + final Scenario replacementScenario = ScenarioUtils.createScenario(config); - controler.addOverridingModule( - new AbstractModule() { - @Override - public void install() { - controler.addOverridingModule( - new AbstractModule() { - @Override - public void install() { - bind( Scenario.class ).toInstance( replacementScenario ); + controler.addOverridingModule( + new AbstractModule() { + @Override + public void install() { + controler.addOverridingModule( + new AbstractModule() { + @Override + public void install() { + bind(Scenario.class).toInstance(replacementScenario); + } } - } - ); + ); + } } - } - ); + ); - controler.run(); + controler.run(); - Assert.assertSame( - "adding a Guice module to the controler from a Guice module is allowed but has no effect", - replacementScenario, - controler.getScenario() ); + Assert.assertSame( + "adding a Guice module to the controler from a Guice module is allowed but has no effect", + replacementScenario, + controler.getScenario()); + }); } static class FakeMobsim implements Mobsim { diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerListenerManagerImplTest.java b/matsim/src/test/java/org/matsim/core/controler/ControlerListenerManagerImplTest.java index f22e7b4c87b..762a73afc2e 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerListenerManagerImplTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerListenerManagerImplTest.java @@ -22,7 +22,7 @@ package org.matsim.core.controler; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.controler.events.IterationStartsEvent; import org.matsim.core.controler.events.ShutdownEvent; import org.matsim.core.controler.events.StartupEvent; @@ -30,13 +30,13 @@ import org.matsim.core.controler.listener.ShutdownListener; import org.matsim.core.controler.listener.StartupListener; -/** + /** * @author mrieser / senozon */ public class ControlerListenerManagerImplTest { - @Test - public void testAddControlerListener_ClassHierarchy() { + @Test + void testAddControlerListener_ClassHierarchy() { ControlerListenerManagerImpl m = new ControlerListenerManagerImpl(); CountingControlerListener ccl = new CountingControlerListener(); ExtendedControlerListener ecl = new ExtendedControlerListener(); @@ -72,8 +72,8 @@ public void testAddControlerListener_ClassHierarchy() { Assert.assertEquals(1, ecl.nOfShutdowns); } - @Test - public void testAddCoreControlerListener_ClassHierarchy() { + @Test + void testAddCoreControlerListener_ClassHierarchy() { ControlerListenerManagerImpl m = new ControlerListenerManagerImpl(); CountingControlerListener ccl = new CountingControlerListener(); ExtendedControlerListener ecl = new ExtendedControlerListener(); diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java b/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java index d20bc0a6222..af2cf20fe23 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java @@ -19,12 +19,14 @@ package org.matsim.core.controler; +import static org.junit.jupiter.api.Assertions.assertThrows; + import com.google.inject.Provider; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.api.experimental.events.EventsManager; import org.matsim.core.config.Config; @@ -43,7 +45,7 @@ public class ControlerMobsimIntegrationTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testRunMobsim_customMobsim() { + void testRunMobsim_customMobsim() { Config cfg = this.utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config_plans1.xml")); cfg.controller().setLastIteration(0); cfg.controller().setMobsim("counting"); @@ -70,17 +72,19 @@ public Mobsim get() { Assert.assertEquals(1, mf.callCount); } - @Test(expected = RuntimeException.class) - public void testRunMobsim_missingMobsimFactory() { - Config cfg = this.utils.loadConfig("test/scenarios/equil/config_plans1.xml"); - cfg.controller().setLastIteration(0); - cfg.controller().setMobsim("counting"); - cfg.controller().setWritePlansInterval(0); - Controler c = new Controler(cfg); - c.getConfig().controller().setCreateGraphs(false); - c.getConfig().controller().setDumpDataAtEnd(false); - c.getConfig().controller().setWriteEventsInterval(0); - c.run(); + @Test + void testRunMobsim_missingMobsimFactory() { + assertThrows(RuntimeException.class, () -> { + Config cfg = this.utils.loadConfig("test/scenarios/equil/config_plans1.xml"); + cfg.controller().setLastIteration(0); + cfg.controller().setMobsim("counting"); + cfg.controller().setWritePlansInterval(0); + Controler c = new Controler(cfg); + c.getConfig().controller().setCreateGraphs(false); + c.getConfig().controller().setDumpDataAtEnd(false); + c.getConfig().controller().setWriteEventsInterval(0); + c.run(); + }); } private static class CountingMobsimFactory implements MobsimFactory { diff --git a/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java b/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java index 9c7e303230d..1bb0b102e20 100644 --- a/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java @@ -23,22 +23,22 @@ import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.controler.events.IterationStartsEvent; import org.matsim.core.controler.listener.IterationStartsListener; import org.matsim.testcases.MatsimTestUtils; -public class MatsimServicesImplTest { + public class MatsimServicesImplTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Ignore - @Test - public void testIterationInServicesEqualsIterationInEvent() { + @Ignore + @Test + void testIterationInServicesEqualsIterationInEvent() { Config config = ConfigUtils.createConfig(); config.controller().setLastIteration(1); diff --git a/matsim/src/test/java/org/matsim/core/controler/MobsimListenerTest.java b/matsim/src/test/java/org/matsim/core/controler/MobsimListenerTest.java index 8818f2b63b6..4efe0580ad6 100644 --- a/matsim/src/test/java/org/matsim/core/controler/MobsimListenerTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/MobsimListenerTest.java @@ -21,9 +21,8 @@ */ package org.matsim.core.controler; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.mobsim.framework.events.MobsimInitializedEvent; import org.matsim.core.mobsim.framework.listeners.MobsimInitializedListener; @@ -31,13 +30,15 @@ import jakarta.inject.Singleton; +import static org.junit.jupiter.api.Assertions.assertThrows; + public class MobsimListenerTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testRunMobsim_listenerTransient() { + @Test + void testRunMobsim_listenerTransient() { Config cfg = this.utils.loadConfig("test/scenarios/equil/config_plans1.xml"); cfg.controller().setLastIteration(1); cfg.controller().setWritePlansInterval(0); @@ -54,23 +55,25 @@ public void install() { c.run(); } - @Test(expected = RuntimeException.class) - public void testRunMobsim_listenerSingleton() { - Config cfg = this.utils.loadConfig("test/scenarios/equil/config_plans1.xml"); - cfg.controller().setLastIteration(1); - cfg.controller().setWritePlansInterval(0); - final Controler c = new Controler(cfg); - c.addOverridingModule(new AbstractModule() { - @Override - public void install() { - addMobsimListenerBinding().to(SingletonCountingMobsimListener.class); - } - }); - c.getConfig().controller().setCreateGraphs(false); - c.getConfig().controller().setDumpDataAtEnd(false); - c.getConfig().controller().setWriteEventsInterval(0); - c.run(); - } + @Test + void testRunMobsim_listenerSingleton() { + assertThrows(RuntimeException.class, () -> { + Config cfg = this.utils.loadConfig("test/scenarios/equil/config_plans1.xml"); + cfg.controller().setLastIteration(1); + cfg.controller().setWritePlansInterval(0); + final Controler c = new Controler(cfg); + c.addOverridingModule(new AbstractModule() { + @Override + public void install() { + addMobsimListenerBinding().to(SingletonCountingMobsimListener.class); + } + }); + c.getConfig().controller().setCreateGraphs(false); + c.getConfig().controller().setDumpDataAtEnd(false); + c.getConfig().controller().setWriteEventsInterval(0); + c.run(); + }); + } private static class CountingMobsimListener implements MobsimInitializedListener { diff --git a/matsim/src/test/java/org/matsim/core/controler/NewControlerTest.java b/matsim/src/test/java/org/matsim/core/controler/NewControlerTest.java index b10a0509487..b5195d537e7 100644 --- a/matsim/src/test/java/org/matsim/core/controler/NewControlerTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/NewControlerTest.java @@ -21,8 +21,8 @@ package org.matsim.core.controler; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.groups.FacilitiesConfigGroup; @@ -33,13 +33,13 @@ import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; -public class NewControlerTest { + public class NewControlerTest { @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); - @Test - public void testInjectionBeforeControler() { + @Test + void testInjectionBeforeControler() { Config config = testUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); // a scenario is created and none of the files are loaded; diff --git a/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java b/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java index 9f9e788218e..76d790ebe04 100644 --- a/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java @@ -19,8 +19,8 @@ package org.matsim.core.controler; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.groups.ControllerConfigGroup; import org.matsim.core.utils.io.IOUtils; import org.matsim.testcases.MatsimTestUtils; @@ -38,7 +38,7 @@ public class OutputDirectoryHierarchyTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testFailureIfDirectoryExists() { + void testFailureIfDirectoryExists() { final String outputDirectory = utils.getOutputDirectory(); IOUtils.deleteDirectoryRecursively(new File( outputDirectory ).toPath()); @@ -74,7 +74,7 @@ public void testFailureIfDirectoryExists() { } @Test - public void testOverrideIfDirectoryExists() { + void testOverrideIfDirectoryExists() { final String outputDirectory = utils.getOutputDirectory(); IOUtils.deleteDirectoryRecursively(new File( outputDirectory ).toPath()); @@ -109,7 +109,7 @@ public void testOverrideIfDirectoryExists() { } @Test - public void testDeleteIfDirectoryExists() { + void testDeleteIfDirectoryExists() { final String outputDirectory = utils.getOutputDirectory(); IOUtils.deleteDirectoryRecursively(new File( outputDirectory ).toPath()); diff --git a/matsim/src/test/java/org/matsim/core/controler/PrepareForSimImplTest.java b/matsim/src/test/java/org/matsim/core/controler/PrepareForSimImplTest.java index d711ebceaaa..582276839b3 100644 --- a/matsim/src/test/java/org/matsim/core/controler/PrepareForSimImplTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/PrepareForSimImplTest.java @@ -22,7 +22,7 @@ import java.util.*; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -72,7 +72,7 @@ public class PrepareForSimImplTest { @Test - public void testSingleLegTripRoutingMode() { + void testSingleLegTripRoutingMode() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); Scenario scenario = ScenarioUtils.createScenario(config); @@ -135,7 +135,7 @@ public void testSingleLegTripRoutingMode() { } @Test - public void testSingleFallbackModeLegTrip() { + void testSingleFallbackModeLegTrip() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); Scenario scenario = ScenarioUtils.createScenario(config); @@ -200,7 +200,7 @@ public void testSingleFallbackModeLegTrip() { } @Test - public void testCorrectTripsRemainUnchanged() { + void testCorrectTripsRemainUnchanged() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); Scenario scenario = ScenarioUtils.createScenario(config); @@ -366,7 +366,7 @@ public void testCorrectTripsRemainUnchanged() { } @Test - public void testRoutingModeConsistency() { + void testRoutingModeConsistency() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); Scenario scenario = ScenarioUtils.createScenario(config); @@ -449,7 +449,7 @@ public void testRoutingModeConsistency() { } @Test - public void testOutdatedHelperModesReplacement() { + void testOutdatedHelperModesReplacement() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); config.plans().setHandlingOfPlansWithoutRoutingMode(HandlingOfPlansWithoutRoutingMode.reject); @@ -672,7 +672,7 @@ public void testOutdatedHelperModesReplacement() { } @Test - public void testOutdatedFallbackAndHelperModesReplacement() { + void testOutdatedFallbackAndHelperModesReplacement() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); config.plans().setHandlingOfPlansWithoutRoutingMode(HandlingOfPlansWithoutRoutingMode.reject); @@ -763,7 +763,7 @@ public void testOutdatedFallbackAndHelperModesReplacement() { } @Test - public void vehicleTypes() { + void vehicleTypes() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); diff --git a/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java b/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java index 6bfbc27f763..cd9a12401fe 100644 --- a/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java @@ -3,8 +3,8 @@ import java.io.File; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.PersonDepartureEvent; import org.matsim.api.core.v01.events.handler.PersonDepartureEventHandler; @@ -34,7 +34,7 @@ public class TerminationTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testSimulationEndsOnInterval() { + void testSimulationEndsOnInterval() { prepareExperiment(2, 4, ControllerConfigGroup.CleanIterations.keep).run(); Assert.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.4/4.events.xml.gz").exists()); @@ -46,7 +46,7 @@ public void testSimulationEndsOnInterval() { } @Test - public void testOnlyRunIterationZero() { + void testOnlyRunIterationZero() { prepareExperiment(2, 0, ControllerConfigGroup.CleanIterations.keep).run(); Assert.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.0/0.events.xml.gz").exists()); @@ -58,7 +58,7 @@ public void testOnlyRunIterationZero() { } @Test - public void testSimulationEndsOffInterval() { + void testSimulationEndsOffInterval() { // This is the case when the TerminationCriterion decides that the simulation is // done, but it does not fall at the same time as the output interval. @@ -74,7 +74,7 @@ public void testSimulationEndsOffInterval() { } @Test - public void testSimulationEndDeleteIters() { + void testSimulationEndDeleteIters() { prepareExperiment(2, 3, ControllerConfigGroup.CleanIterations.delete).run(); Assert.assertFalse(new File(utils.getOutputDirectory(), "/ITERS").exists()); } @@ -91,7 +91,7 @@ private Controler prepareExperiment(int interval, int criterion, ControllerConfi } @Test - public void testMultipleLastIterations() { + void testMultipleLastIterations() { /** * This test covers the case where the termination criterion decides that the * coming iteration may be the last, but then, after analysis and after the data @@ -125,7 +125,7 @@ public boolean doTerminate(int iteration) { } @Test - public void testCustomConverenceCriterion() { + void testCustomConverenceCriterion() { /** * In this test, we set all legs to walk and let agents change them to car. We * stop the simulation once there are more car legs than walk legs. diff --git a/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java b/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java index b02ba76fbe4..c2be0f5b584 100644 --- a/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java @@ -25,8 +25,8 @@ import java.util.ArrayList; import java.util.Collections; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -65,7 +65,8 @@ public class TransitControlerIntegrationTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testTransitRouteCopy() { + @Test + void testTransitRouteCopy() { Config config = utils.loadConfig((String)null); config.transit().setUseTransit(true); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java b/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java index 300296fbc27..bf569a37ec6 100644 --- a/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java @@ -20,8 +20,8 @@ package org.matsim.core.controler.corelisteners; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.analysis.IterationStopWatch; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -46,27 +46,27 @@ public class ListenersInjectionTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testDumpDataAtEndIsSingleton() { + void testDumpDataAtEndIsSingleton() { testIsSingleton( DumpDataAtEnd.class ); } @Test - public void testEvensHandlingIsSingleton() { + void testEvensHandlingIsSingleton() { testIsSingleton( EventsHandling.class ); } @Test - public void testPlansDumpingIsSingleton() { + void testPlansDumpingIsSingleton() { testIsSingleton( PlansDumping.class ); } @Test - public void testPlansReplanningIsSingleton() { + void testPlansReplanningIsSingleton() { testIsSingleton( PlansReplanning.class ); } @Test - public void testPlansScoringIsSingleton() { + void testPlansScoringIsSingleton() { testIsSingleton( PlansScoring.class ); } diff --git a/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java b/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java index 68e67547cb2..a686c394e77 100644 --- a/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java +++ b/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java @@ -19,8 +19,8 @@ package org.matsim.core.controler.corelisteners; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.controler.Controler; import org.matsim.testcases.MatsimTestUtils; @@ -38,7 +38,7 @@ public class PlansDumpingIT { @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test - public void testPlansDump_Interval() { + void testPlansDump_Interval() { Config config = this.util.loadConfig("test/scenarios/equil/config_plans1.xml"); config.controller().setLastIteration(10); config.controller().setWritePlansInterval(3); @@ -62,7 +62,7 @@ public void testPlansDump_Interval() { } @Test - public void testPlansDump_Never() { + void testPlansDump_Never() { Config config = this.util.loadConfig("test/scenarios/equil/config_plans1.xml"); config.controller().setLastIteration(10); config.controller().setWritePlansInterval(0); @@ -86,7 +86,7 @@ public void testPlansDump_Never() { } @Test - public void testPlansDump_Always() { + void testPlansDump_Always() { Config config = this.util.loadConfig("test/scenarios/equil/config_plans1.xml"); config.controller().setLastIteration(10); config.controller().setWritePlansInterval(1); diff --git a/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java b/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java index aee383139ab..fe6e6f93cef 100644 --- a/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -41,7 +41,8 @@ public class ActEndEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final ActivityEndEvent event = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", new ActivityEndEvent(7893.14, Id.create("143", Person.class), Id.create("293", Link.class), Id.create("f811", ActivityFacility.class), "home", new Coord( 234., 5.67 ))); diff --git a/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java b/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java index 7a57d2334e3..c0a64d343d4 100644 --- a/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -41,7 +41,8 @@ public class ActStartEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final ActivityStartEvent event = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", new ActivityStartEvent(5668.27, Id.create("a92", Person.class), Id.create("l081", Link.class), Id.create("f792", ActivityFacility.class), "work", new Coord( 234., 5.67 ) ) ); diff --git a/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java b/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java index 0a40dc47137..b0645c6f797 100644 --- a/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonMoneyEvent; import org.matsim.api.core.v01.population.Person; @@ -38,7 +38,8 @@ public class AgentMoneyEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final PersonMoneyEvent event1 = new PersonMoneyEvent(25560.23, Id.create("1", Person.class), 2.71828, "tollRefund", "motorwayOperator"); final PersonMoneyEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event1); assertEquals(event1.getTime(), event2.getTime(), MatsimTestUtils.EPSILON); diff --git a/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java b/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java index 08e5667ce31..0bc24ebe510 100644 --- a/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java @@ -20,8 +20,8 @@ package org.matsim.core.events; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.core.api.experimental.events.AgentWaitingForPtEvent; @@ -37,7 +37,7 @@ public class AgentWaitingForPtEventTest { @RegisterExtension private MatsimTestUtils helper = new MatsimTestUtils(); @Test - public void testReadWriteXml() { + void testReadWriteXml() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Id waitStopId = Id.create("1980", TransitStopFacility.class); Id destinationStopId = Id.create("0511", TransitStopFacility.class); diff --git a/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java b/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java index d8c25c4eaa5..86fd56add98 100644 --- a/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java +++ b/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkEnterEvent; @@ -43,7 +43,8 @@ public class BasicEventsHandlerTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testLinkEnterEventHandler() { + @Test + void testLinkEnterEventHandler() { EventsManager events = EventsUtils.createEventsManager(); MyLinkEnterEventHandler handler = new MyLinkEnterEventHandler(); events.addHandler(handler); diff --git a/matsim/src/test/java/org/matsim/core/events/CustomEventTest.java b/matsim/src/test/java/org/matsim/core/events/CustomEventTest.java index 5741890da92..bee022f3d97 100644 --- a/matsim/src/test/java/org/matsim/core/events/CustomEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/CustomEventTest.java @@ -29,7 +29,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; import org.matsim.api.core.v01.population.Person; @@ -70,7 +70,7 @@ public Map getAttributes() { } @Test - public void testCustomEventCanBeWrittenAndRead_XML() { + void testCustomEventCanBeWrittenAndRead_XML() { ByteArrayOutputStream baos = new ByteArrayOutputStream(); PrintStream ps = new PrintStream(baos); EventsManager eventsManager1 = EventsUtils.createEventsManager(); @@ -109,7 +109,7 @@ public void reset(int iteration) { } @Test - public void testCustomEventCanBeWrittenAndRead_Json() { + void testCustomEventCanBeWrittenAndRead_Json() { ByteArrayOutputStream baos = new ByteArrayOutputStream(); PrintStream ps = new PrintStream(baos); EventsManager eventsManager1 = EventsUtils.createEventsManager(); diff --git a/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java b/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java index 6c09b3bd184..7bbdfa343bc 100644 --- a/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java +++ b/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; import org.matsim.api.core.v01.events.LinkLeaveEvent; @@ -67,7 +67,8 @@ class B extends A {} @SuppressWarnings("unused") class C extends A implements BasicEventHandler, LinkLeaveEventHandler {} - @Test public final void testHandlerHierarchy() { + @Test + final void testHandlerHierarchy() { EventsManager events = EventsUtils.createEventsManager(); Id linkId = Id.create("1", Link.class); Id vehId = Id.create("1", Vehicle.class); @@ -83,7 +84,8 @@ class C extends A implements BasicEventHandler, LinkLeaveEventHandler {} assertEquals(this.eventHandled, 1); } - @Test public final void testHierarchicalReset() { + @Test + final void testHierarchicalReset() { EventsManager events = EventsUtils.createEventsManager(); Id linkId = Id.create("1", Link.class); Id vehId = Id.create("1", Vehicle.class); diff --git a/matsim/src/test/java/org/matsim/core/events/EventsManagerImplTest.java b/matsim/src/test/java/org/matsim/core/events/EventsManagerImplTest.java index 6746d32d64c..0ea80ab3d12 100644 --- a/matsim/src/test/java/org/matsim/core/events/EventsManagerImplTest.java +++ b/matsim/src/test/java/org/matsim/core/events/EventsManagerImplTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.events.Event; import org.matsim.core.api.experimental.events.EventsManager; import org.matsim.core.events.handler.EventHandler; @@ -38,7 +38,7 @@ public class EventsManagerImplTest { * @author mrieser */ @Test - public void testProcessEvent_CustomEventHandler() { + void testProcessEvent_CustomEventHandler() { EventsManager manager = EventsUtils.createEventsManager(); CountingMyEventHandler handler = new CountingMyEventHandler(); manager.addHandler(handler); @@ -52,7 +52,7 @@ public void testProcessEvent_CustomEventHandler() { * @author mrieser */ @Test - public void testProcessEvent_ExceptionInEventHandler() { + void testProcessEvent_ExceptionInEventHandler() { EventsManager manager = EventsUtils.createEventsManager(); CrashingMyEventHandler handler = new CrashingMyEventHandler(); manager.addHandler(handler); diff --git a/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java b/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java index 24f43377b2d..ca1a804be6d 100644 --- a/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java +++ b/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java @@ -26,8 +26,8 @@ import javax.xml.parsers.ParserConfigurationException; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -143,7 +143,8 @@ public void handleEvent(final PersonStuckEvent event) { } - @Test public final void testXmlReader() throws SAXException, ParserConfigurationException, IOException { + @Test + final void testXmlReader() throws SAXException, ParserConfigurationException, IOException { EventsManager events = EventsUtils.createEventsManager(); TestHandler handler = new TestHandler(); events.addHandler(handler); @@ -154,7 +155,8 @@ public void handleEvent(final PersonStuckEvent event) { assertEquals("number of read events", 8, handler.eventCounter); } - @Test public final void testAutoFormatReaderXml() { + @Test + final void testAutoFormatReaderXml() { EventsManager events = EventsUtils.createEventsManager(); TestHandler handler = new TestHandler(); events.addHandler(handler); diff --git a/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java b/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java index b24edda5020..705c6e08aff 100644 --- a/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java @@ -21,8 +21,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.events.GenericEvent; import org.matsim.testcases.MatsimTestUtils; @@ -36,7 +36,8 @@ public class GenericEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final String TYPE = "GenericEvent"; final String KEY1 = "k1"; final String VALUE1 = "v1"; diff --git a/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java b/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java index c098d01d14a..7a400077bce 100644 --- a/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkEnterEvent; import org.matsim.api.core.v01.network.Link; @@ -39,7 +39,8 @@ public class LinkEnterEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final LinkEnterEvent event1 = new LinkEnterEvent(6823.8, Id.create("veh", Vehicle.class), Id.create("abcd", Link.class)); final LinkEnterEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event1); diff --git a/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java b/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java index 10c7c168aee..7a9f373ed82 100644 --- a/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkLeaveEvent; import org.matsim.api.core.v01.network.Link; @@ -39,7 +39,8 @@ public class LinkLeaveEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final LinkLeaveEvent event1 = new LinkLeaveEvent(68423.98, Id.create("veh", Vehicle.class), Id.create(".235", Link.class)); final LinkLeaveEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event1); diff --git a/matsim/src/test/java/org/matsim/core/events/MobsimScopeEventHandlingTest.java b/matsim/src/test/java/org/matsim/core/events/MobsimScopeEventHandlingTest.java index b20e06fcec8..6767ab3394d 100644 --- a/matsim/src/test/java/org/matsim/core/events/MobsimScopeEventHandlingTest.java +++ b/matsim/src/test/java/org/matsim/core/events/MobsimScopeEventHandlingTest.java @@ -22,7 +22,7 @@ import static org.mockito.Mockito.*; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.api.experimental.events.EventsManager; import org.matsim.core.controler.events.AfterMobsimEvent; @@ -35,14 +35,14 @@ public class MobsimScopeEventHandlingTest { private final MobsimScopeEventHandler handler = mock(MobsimScopeEventHandler.class); @Test - public void test_addMobsimScopeHandler() { + void test_addMobsimScopeHandler() { eventHandling.addMobsimScopeHandler(handler); verify(eventsManager, times(1)).addHandler(argThat(arg -> arg == handler)); } @Test - public void test_notifyAfterMobsim_oneHandler() { + void test_notifyAfterMobsim_oneHandler() { eventHandling.addMobsimScopeHandler(handler); eventHandling.notifyAfterMobsim(new AfterMobsimEvent(null, 99, false)); @@ -51,7 +51,7 @@ public void test_notifyAfterMobsim_oneHandler() { } @Test - public void test_notifyAfterMobsim_noHandlersAfterRemoval() { + void test_notifyAfterMobsim_noHandlersAfterRemoval() { eventHandling.addMobsimScopeHandler(handler); eventHandling.notifyAfterMobsim(new AfterMobsimEvent(null, 99, false)); diff --git a/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java b/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java index db33e1b7b58..373075691ec 100644 --- a/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java +++ b/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java @@ -1,7 +1,7 @@ package org.matsim.core.events; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.events.Event; import org.matsim.core.api.experimental.events.EventsManager; @@ -19,8 +19,8 @@ public void setUp() throws Exception { handler = new EventsManagerImplTest.CountingMyEventHandler(); } - @Test - public void forgetInit() { + @Test + void forgetInit() { EventsManager m = EventsUtils.createParallelEventsManager(); @@ -36,8 +36,8 @@ public void forgetInit() { assertEquals(1, handler.counter); } - @Test - public void lateHandler() { + @Test + void lateHandler() { EventsManager m = EventsUtils.createParallelEventsManager(); m.initProcessing(); diff --git a/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java index b5a2e03edca..60110acc6ce 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.PersonArrivalEvent; @@ -40,7 +40,8 @@ public class PersonArrivalEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final PersonArrivalEvent event = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", new PersonArrivalEvent(68423.98, Id.create("443", Person.class), Id.create("78-3", Link.class), TransportMode.bike)); assertEquals(68423.98, event.getTime(), MatsimTestUtils.EPSILON); diff --git a/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java index 7f42ea5a472..f1372da2f07 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.PersonDepartureEvent; @@ -40,7 +40,8 @@ public class PersonDepartureEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final PersonDepartureEvent event = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", new PersonDepartureEvent(25669.05, Id.create("921", Person.class), Id.create("390", Link.class), TransportMode.bike, "bikeRoutingMode")); assertEquals(25669.05, event.getTime(), MatsimTestUtils.EPSILON); diff --git a/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java index bb554d35908..849a0f7878e 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonEntersVehicleEvent; import org.matsim.api.core.v01.population.Person; @@ -42,7 +42,8 @@ public class PersonEntersVehicleEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testReadWriteXml() { + @Test + void testReadWriteXml() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); VehicleType vehicleType = VehicleUtils.createVehicleType(Id.create("testVehType", VehicleType.class ) ); Vehicle vehicle = VehicleUtils.createVehicle(Id.create(80, Vehicle.class ), vehicleType ); diff --git a/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java index bd0c7ac42c6..867624642ad 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonLeavesVehicleEvent; import org.matsim.api.core.v01.population.Person; @@ -42,7 +42,8 @@ public class PersonLeavesVehicleEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); VehicleType vehicleType = VehicleUtils.createVehicleType(Id.create("testVehType", VehicleType.class ) ); Vehicle vehicle = VehicleUtils.createVehicle(Id.create(80, Vehicle.class ), vehicleType ); diff --git a/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java index 090c2512aa5..b17e124d471 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.PersonStuckEvent; @@ -40,7 +40,8 @@ public class PersonStuckEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final PersonStuckEvent event1 = new PersonStuckEvent(81153.3, Id.create("a007", Person.class), Id.create("link1", Link.class), TransportMode.walk); final PersonStuckEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event1); assertEquals(event1.getTime(), event2.getTime(), MatsimTestUtils.EPSILON); @@ -49,7 +50,8 @@ public class PersonStuckEventTest { assertEquals(event1.getLegMode(), event2.getLegMode()); } - @Test public void testWriteReadXmlWithLinkIdNull() { + @Test + void testWriteReadXmlWithLinkIdNull() { final PersonStuckEvent event1 = new PersonStuckEvent(81153.3, Id.create("a007", Person.class), null, TransportMode.walk); final PersonStuckEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event1); assertEquals(event1.getTime(), event2.getTime(), MatsimTestUtils.EPSILON); diff --git a/matsim/src/test/java/org/matsim/core/events/SimStepParallelEventsManagerImplTest.java b/matsim/src/test/java/org/matsim/core/events/SimStepParallelEventsManagerImplTest.java index 39c8280f4cf..894bc9661b1 100644 --- a/matsim/src/test/java/org/matsim/core/events/SimStepParallelEventsManagerImplTest.java +++ b/matsim/src/test/java/org/matsim/core/events/SimStepParallelEventsManagerImplTest.java @@ -22,7 +22,7 @@ package org.matsim.core.events; import org.assertj.core.api.Assertions; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkEnterEvent; import org.matsim.api.core.v01.events.LinkLeaveEvent; @@ -30,10 +30,10 @@ import org.matsim.api.core.v01.events.handler.LinkEnterEventHandler; import org.matsim.testcases.utils.EventsCollector; -public class SimStepParallelEventsManagerImplTest { + public class SimStepParallelEventsManagerImplTest { - @Test - public void testEventHandlerCanProduceAdditionalEventLateInSimStep() { + @Test + void testEventHandlerCanProduceAdditionalEventLateInSimStep() { final SimStepParallelEventsManagerImpl events = new SimStepParallelEventsManagerImpl(8); events.addHandler(new LinkEnterEventHandler() { @Override diff --git a/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java b/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java index 4f9076d4f51..37d6156086e 100644 --- a/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java @@ -20,8 +20,8 @@ package org.matsim.core.events; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; import org.matsim.api.core.v01.population.Person; @@ -39,7 +39,7 @@ public class TransitDriverStartsEventTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testWriteReadXml() { + void testWriteReadXml() { final TransitDriverStartsEvent event1 = new TransitDriverStartsEvent(36095.2, Id.create("ptDrvr-1", Person.class), Id.create("vehicle-bus5", Vehicle.class), diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java index 274cb9b762a..15d82589b79 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.VehicleAbortsEvent; import org.matsim.api.core.v01.network.Link; @@ -39,7 +39,8 @@ public class VehicleAbortsEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final VehicleAbortsEvent event1 = new VehicleAbortsEvent(81153.3, Id.create("a007", Vehicle.class), Id.create("link1", Link.class)); final VehicleAbortsEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event1); assertEquals(event1.getTime(), event2.getTime(), MatsimTestUtils.EPSILON); diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java index 05929edf7e8..26d0fa561f8 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.api.experimental.events.VehicleArrivesAtFacilityEvent; import org.matsim.core.utils.misc.Time; @@ -37,7 +37,8 @@ public class VehicleArrivesAtFacilityEventImplTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { VehicleArrivesAtFacilityEvent event = new VehicleArrivesAtFacilityEvent(Time.parseTime("10:55:00"), Id.create(5, Vehicle.class), Id.create(11, TransitStopFacility.class), diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java index 99b3396177a..11e414b40f2 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.api.experimental.events.VehicleDepartsAtFacilityEvent; import org.matsim.core.utils.misc.Time; @@ -37,7 +37,8 @@ public class VehicleDepartsAtFacilityEventImplTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { VehicleDepartsAtFacilityEvent event = new VehicleDepartsAtFacilityEvent(Time.parseTime("10:55:00"), Id.create(5, Vehicle.class), Id.create(11, TransitStopFacility.class), -1.2); VehicleDepartsAtFacilityEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event); assertEquals(Time.parseTime("10:55:00"), event2.getTime(), MatsimTestUtils.EPSILON); diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java index 45f4676e80b..af9686b35bc 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.VehicleEntersTrafficEvent; @@ -41,7 +41,8 @@ public class VehicleEntersTrafficEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final VehicleEntersTrafficEvent event1 = new VehicleEntersTrafficEvent(8463.7301, Id.create("483", Person.class), Id.create("783", Link.class), Id.create("veh7", Vehicle.class), TransportMode.car, 1.0); final VehicleEntersTrafficEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event1); diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java index 241e0b9f382..7428df475b5 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.VehicleLeavesTrafficEvent; @@ -41,7 +41,8 @@ public class VehicleLeavesTrafficEventTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final VehicleLeavesTrafficEvent event1 = new VehicleLeavesTrafficEvent(8463.7301, Id.create("483", Person.class), Id.create("783", Link.class), Id.create("veh7", Vehicle.class), TransportMode.car,1.0); final VehicleLeavesTrafficEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event1); diff --git a/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterJsonTest.java b/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterJsonTest.java index 9756af4c134..60a4cc3c49a 100644 --- a/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterJsonTest.java +++ b/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterJsonTest.java @@ -1,7 +1,7 @@ package org.matsim.core.events.algorithms; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.GenericEvent; import org.matsim.api.core.v01.events.LinkLeaveEvent; @@ -26,7 +26,7 @@ public class EventWriterJsonTest { * values are correctly encoded when written to a file. */ @Test - public void testSpecialCharacters() { + void testSpecialCharacters() { ByteArrayOutputStream baos = new ByteArrayOutputStream(); EventWriterJson writer = new EventWriterJson(baos); @@ -55,7 +55,7 @@ public void testSpecialCharacters() { } @Test - public void testNullAttribute() { + void testNullAttribute() { ByteArrayOutputStream baos = new ByteArrayOutputStream(); EventWriterJson writer = new EventWriterJson(baos); diff --git a/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java b/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java index a84b21baf2d..114d27637b1 100644 --- a/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java +++ b/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java @@ -22,8 +22,8 @@ import java.io.File; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.GenericEvent; import org.matsim.api.core.v01.events.LinkLeaveEvent; @@ -47,7 +47,7 @@ public class EventWriterXMLTest { * values are correctly encoded when written to a file. */ @Test - public void testSpecialCharacters() { + void testSpecialCharacters() { String filename = this.utils.getOutputDirectory() + "testEvents.xml"; EventWriterXML writer = new EventWriterXML(filename); @@ -76,7 +76,7 @@ public void testSpecialCharacters() { } @Test - public void testNullAttribute() { + void testNullAttribute() { String filename = this.utils.getOutputDirectory() + "testEvents.xml"; EventWriterXML writer = new EventWriterXML(filename); diff --git a/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java b/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java index c9e1aa8c73c..741469401ff 100644 --- a/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java +++ b/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java @@ -25,8 +25,8 @@ import java.util.Random; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -41,7 +41,8 @@ public class MatsimRandomTest { /** * Test that MatsimRandom returns different values. */ - @Test public void testRandomness() { + @Test + void testRandomness() { final double value1 = MatsimRandom.getRandom().nextDouble(); final double value2 = MatsimRandom.getRandom().nextDouble(); final double value3 = MatsimRandom.getRandom().nextDouble(); @@ -53,7 +54,8 @@ public class MatsimRandomTest { /** * Tests that resetting the RandomObject creates the same random numbers again. */ - @Test public void testReset() { + @Test + void testReset() { MatsimRandom.reset(); int value1 = MatsimRandom.getRandom().nextInt(); MatsimRandom.reset(); @@ -65,7 +67,8 @@ public class MatsimRandomTest { * Tests that the same number of random numbers is generated if a custom seed * is used, and that these numbers are different with different seeds. */ - @Test public void testSeedReset() { + @Test + void testSeedReset() { final long seed1 = 123L; final long seed2 = 234L; @@ -84,7 +87,8 @@ public class MatsimRandomTest { * Tests that local instances can be recreated (=are deterministic) if the * same random seed is used to generate them. */ - @Test public void testLocalInstances_deterministic() { + @Test + void testLocalInstances_deterministic() { MatsimRandom.reset(); Random local1a = MatsimRandom.getLocalInstance(); Random local1b = MatsimRandom.getLocalInstance(); @@ -101,7 +105,8 @@ public class MatsimRandomTest { * Tests that multiple local instance return different random numbers, * and that they are more or less evenly distributed. */ - @Test public void testLocalInstances_distribution() { + @Test + void testLocalInstances_distribution() { MatsimRandom.reset(123L); Random local1a = MatsimRandom.getLocalInstance(); double value1 = local1a.nextDouble(); diff --git a/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java b/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java index 40394904b1f..a47adfa7e6c 100644 --- a/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java +++ b/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java @@ -24,8 +24,8 @@ import java.awt.Image; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -37,7 +37,8 @@ public class MatsimResourceTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public final void testGetAsImage() { + @Test + final void testGetAsImage() { final Image logo = MatsimResource.getAsImage("matsim_logo_transparent.png"); // verify that the correct image was correctly loaded by testing its dimension diff --git a/matsim/src/test/java/org/matsim/core/mobsim/AbstractMobsimModuleTest.java b/matsim/src/test/java/org/matsim/core/mobsim/AbstractMobsimModuleTest.java index af4f89cf383..9675beba522 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/AbstractMobsimModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/AbstractMobsimModuleTest.java @@ -24,7 +24,7 @@ import java.util.Collections; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.mobsim.framework.AbstractMobsimModule; @@ -32,9 +32,9 @@ import com.google.inject.Guice; import com.google.inject.Injector; -public class AbstractMobsimModuleTest { - @Test - public void testOverrides() { + public class AbstractMobsimModuleTest { + @Test + void testOverrides() { AbstractMobsimModule moduleA = new AbstractMobsimModule() { @Override protected void configureMobsim() { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/AgentTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/AgentTest.java index e360f31ec6e..2a571c61146 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/AgentTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/AgentTest.java @@ -19,14 +19,14 @@ package org.matsim.core.mobsim.hermes; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.locationtech.jts.util.Assert; import static org.junit.Assert.assertEquals; public class AgentTest { @Test - public void prepareLinkEntry() { + void prepareLinkEntry() { for (int eventid = 1; eventid < HermesConfigGroup.MAX_EVENTS_AGENT; eventid *= 8) { for (int lid = 1; lid < HermesConfigGroup.MAX_LINK_ID; lid *= 8) { for (int j = 0; j < 255; j++) { @@ -49,55 +49,55 @@ public void prepareLinkEntry() { } @Test - public void fastSpeedIsEncodedByAdding90() { + void fastSpeedIsEncodedByAdding90() { int encoded = Agent.prepareVelocityForLinkEntry(15); assertEquals(15 + 90, encoded); } @Test - public void fastSpeedIsDecodedBySubtracting90() { + void fastSpeedIsDecodedBySubtracting90() { double decoded = Agent.decodeVelocityFromLinkEntry(15 + 90); assertEquals(15.0, decoded, 0.0); } @Test - public void encodingFastDecimalPointSpeedRoundsDownToNearestInteger() { + void encodingFastDecimalPointSpeedRoundsDownToNearestInteger() { int encoded = Agent.prepareVelocityForLinkEntry(15.3); assertEquals(15 + 90, encoded); } @Test - public void encodingFastDecimalPointSpeedRoundsUpToNearestInteger() { + void encodingFastDecimalPointSpeedRoundsUpToNearestInteger() { int encoded = Agent.prepareVelocityForLinkEntry(15.6); assertEquals(16 + 90, encoded); } @Test - public void slowSpeedIsEncodedByMultiplyingBy10() { + void slowSpeedIsEncodedByMultiplyingBy10() { int encoded = Agent.prepareVelocityForLinkEntry(4.6); assertEquals(46, encoded); } @Test - public void slowSpeedIsDecodedByDividingBy10() { + void slowSpeedIsDecodedByDividingBy10() { double decoded = Agent.decodeVelocityFromLinkEntry(46); assertEquals(4.6, decoded, 0.0); } @Test - public void encodingSlowDecimalPointSpeedRoundsDown() { + void encodingSlowDecimalPointSpeedRoundsDown() { int encoded = Agent.prepareVelocityForLinkEntry(5.33); assertEquals(53, encoded); } @Test - public void encodingSlowDecimalPointSpeedRoundsUp() { + void encodingSlowDecimalPointSpeedRoundsUp() { int encoded = Agent.prepareVelocityForLinkEntry(5.66); assertEquals(57, encoded); } @Test - public void fastSpeedIsIntegerWithFlatPlan() { + void fastSpeedIsIntegerWithFlatPlan() { int eventId = 0; int linkId = 0; double velocity = 15.2; @@ -108,7 +108,7 @@ public void fastSpeedIsIntegerWithFlatPlan() { } @Test - public void smallSpeedHasOneDecimalPointAccuracyWithFlatPlan() { + void smallSpeedHasOneDecimalPointAccuracyWithFlatPlan() { int eventId = 0; int linkId = 0; double velocity = 3.43; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java index 1cdf91d61d0..83a4f62d0d4 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.analysis.VolumesAnalyzer; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -63,7 +63,7 @@ public void setup() { * @author mrieser */ @Test - public void testFlowCapacityDriving() { + void testFlowCapacityDriving() { Fixture f = new Fixture(); // add a lot of persons with legs from link1 to link3, starting at 6:30 @@ -133,7 +133,7 @@ public void testFlowCapacityDriving() { */ @Test - public void testFlowCapacityDrivingFlowCapacityFactors() { + void testFlowCapacityDrivingFlowCapacityFactors() { Fixture f = new Fixture(); // add a lot of persons with legs from link1 to link3, starting at 6:30 for (int i = 1; i <= 1200; i++) { @@ -190,7 +190,7 @@ public void testFlowCapacityDrivingFlowCapacityFactors() { */ @Test - public void testFlowCapacityDrivingFlowEfficiencyFactors() { + void testFlowCapacityDrivingFlowEfficiencyFactors() { Fixture f = new Fixture(); ScenarioImporter.flush(); @@ -255,7 +255,7 @@ public void testFlowCapacityDrivingFlowEfficiencyFactors() { */ @Test - public void testFlowCapacityDrivingFlowEfficiencyFactorsWithDownscaling() { + void testFlowCapacityDrivingFlowEfficiencyFactorsWithDownscaling() { Fixture f = new Fixture(); ScenarioImporter.flush(); @@ -319,7 +319,7 @@ public void testFlowCapacityDrivingFlowEfficiencyFactorsWithDownscaling() { */ @Test - public void testFlowCapacityEfficiencyFactorWithLowValueAndDownscaling() { + void testFlowCapacityEfficiencyFactorWithLowValueAndDownscaling() { Fixture f = new Fixture(); ScenarioImporter.flush(); @@ -384,7 +384,7 @@ public void testFlowCapacityEfficiencyFactorWithLowValueAndDownscaling() { * @author michaz */ @Test - public void testFlowCapacityDrivingFraction() { + void testFlowCapacityDrivingFraction() { Fixture f = new Fixture(); ScenarioImporter.flush(); f.link2.setCapacity(900.0); // One vehicle every 4 seconds diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesRoundaboutTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesRoundaboutTest.java index e8dcd098d1b..14af770067d 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesRoundaboutTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesRoundaboutTest.java @@ -20,8 +20,9 @@ import java.util.List; import java.util.Map; + +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.util.Assert; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -65,7 +66,7 @@ public class HermesRoundaboutTest { @Test - public void testRoundaboutBehavior(){ + void testRoundaboutBehavior(){ ScenarioImporter.flush(); final Config config = createConfig(); config.controller().setMobsim("hermes"); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java index bc9ebc23292..69fc3bfbd3e 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.Logger; import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -116,7 +116,7 @@ public void prepareTest() { * @author mrieser */ @Test - public void testSingleAgent() { + void testSingleAgent() { Fixture f = new Fixture(); // add a single person with leg from link1 to link3 @@ -156,7 +156,7 @@ public void testSingleAgent() { * @author Kai Nagel */ @Test - public void testSingleAgentWithEndOnLeg() { + void testSingleAgentWithEndOnLeg() { Fixture f = new Fixture(); // add a single person with leg from link1 to link3 @@ -202,7 +202,7 @@ public void testSingleAgentWithEndOnLeg() { * @author mrieser */ @Test - public void testTwoAgent() { + void testTwoAgent() { Fixture f = new Fixture(); // add two persons with leg from link1 to link3, the first starting at 6am, the second at 7am @@ -243,7 +243,7 @@ public void testTwoAgent() { * @author mrieser */ @Test - public void testTeleportationSingleAgent() { + void testTeleportationSingleAgent() { Fixture f = new Fixture(); // add a single person with leg from link1 to link3 @@ -290,7 +290,7 @@ public void testTeleportationSingleAgent() { * @author cdobler */ @Test - public void testSingleAgentImmediateDeparture() { + void testSingleAgentImmediateDeparture() { Fixture f = new Fixture(); // add a single person with leg from link1 to link3 @@ -335,7 +335,7 @@ public void testSingleAgentImmediateDeparture() { * @author mrieser */ @Test - public void testSingleAgent_EmptyRoute() { + void testSingleAgent_EmptyRoute() { Fixture f = new Fixture(); // add a single person with leg from link1 to link1 @@ -408,7 +408,7 @@ public void testSingleAgent_EmptyRoute() { * @author mrieser */ @Test - public void testSingleAgent_LastLinkIsLoop() { + void testSingleAgent_LastLinkIsLoop() { Fixture f = new Fixture(); Link loopLink = NetworkUtils.createAndAddLink(f.network,Id.create("loop", Link.class), f.node4, f.node4, 100.0, 10.0, 500, 1 ); @@ -478,7 +478,7 @@ public void reset(final int iteration) { * @author mrieser */ @Test - public void testAgentWithoutLeg() { + void testAgentWithoutLeg() { Fixture f = new Fixture(); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -505,7 +505,7 @@ public void testAgentWithoutLeg() { * @author mrieser */ @Test - public void testAgentWithoutLegWithEndtime() { + void testAgentWithoutLegWithEndtime() { Fixture f = new Fixture(); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -533,7 +533,7 @@ public void testAgentWithoutLegWithEndtime() { * @author mrieser */ @Test - public void testAgentWithLastActWithEndtime() { + void testAgentWithLastActWithEndtime() { Fixture f = new Fixture(); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -567,7 +567,7 @@ public void testAgentWithLastActWithEndtime() { * @author mrieser */ @Test - public void testVehicleTeleportationTrue() { + void testVehicleTeleportationTrue() { Fixture f = new Fixture(); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan plan = PersonUtils.createAndAddPlan(person, true); @@ -621,7 +621,7 @@ public void testVehicleTeleportationTrue() { * @author mrieser */ @Test - public void testCircleAsRoute() { + void testCircleAsRoute() { Fixture f = new Fixture(); Link link4 = NetworkUtils.createAndAddLink(f.network,Id.create(4, Link.class), f.node4, f.node1, 1000.0, 100.0, 6000, 1.0 ); // close the network @@ -683,7 +683,7 @@ public void testCircleAsRoute() { * @author mrieser */ @Test - public void testRouteWithEndLinkTwice() { + void testRouteWithEndLinkTwice() { Fixture f = new Fixture(); Link link4 = NetworkUtils.createAndAddLink(f.network,Id.create(4, Link.class), f.node4, f.node1, 1000.0, 100.0, 6000, 1.0 ); // close the network @@ -801,7 +801,7 @@ private LogCounter runConsistentRoutesTestSim(final String startLinkId, final St } @Test - public void testStartAndEndTime() { + void testStartAndEndTime() { final Config config = ConfigUtils.createConfig(); @@ -857,7 +857,7 @@ public void testStartAndEndTime() { * @author mrieser */ @Test - public void testCleanupSim_EarlyEnd() { + void testCleanupSim_EarlyEnd() { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); Config config = scenario.getConfig(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java index c85f63ffcd0..332dbb4660a 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java @@ -2,7 +2,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -114,7 +114,7 @@ public void prepareTest() { * Makes sure Hermes works also when not all stop facilities are used by transit lines. */ @Test - public void testSuperflousStopFacilities() { + void testSuperflousStopFacilities() { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); f.config.hermes().setDeterministicPt(this.isDeterministic); @@ -199,7 +199,7 @@ public void testSuperflousStopFacilities() { * Makes sure Hermes works also when transit routes in different lines have the same Id */ @Test - public void testRepeatedRouteIds() { + void testRepeatedRouteIds() { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); f.config.hermes().setDeterministicPt(this.isDeterministic); @@ -301,7 +301,7 @@ public void testRepeatedRouteIds() { * Originally, this resulted in wrong events because there was an exception that there is at most one stop per link. */ @Test - public void testConsecutiveStopsWithSameLink_1() { + void testConsecutiveStopsWithSameLink_1() { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); f.config.hermes().setDeterministicPt(this.isDeterministic); @@ -394,7 +394,7 @@ public void testConsecutiveStopsWithSameLink_1() { * and this 0 meters than resulted in infinite values somewhere later on. */ @Test - public void testConsecutiveStopsWithSameLink_2() { + void testConsecutiveStopsWithSameLink_2() { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); f.config.hermes().setDeterministicPt(this.isDeterministic); @@ -487,7 +487,7 @@ public void testConsecutiveStopsWithSameLink_2() { * Makes sure Hermes does not produce exceptions when the configured end time is before the latest transit event */ @Test - public void testEarlyEnd() { + void testEarlyEnd() { double baseTime = 30 * 3600 - 10; // HERMES has a default of 30:00:00 as end time, so let's start later Fixture f = new Fixture(); f.config.transit().setUseTransit(true); @@ -558,7 +558,7 @@ public void testEarlyEnd() { * Makes sure Hermes correctly handles strange transit routes with some links before the first stop is served. */ @Test - public void testLinksAtRouteStart() { + void testLinksAtRouteStart() { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); f.config.hermes().setDeterministicPt(this.isDeterministic); @@ -628,7 +628,7 @@ public void testLinksAtRouteStart() { * In some cases, the time information of linkEnter/linkLeave events was wrong. */ @Test - public void testDeterministicCorrectTiming() { + void testDeterministicCorrectTiming() { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); f.config.hermes().setDeterministicPt(this.isDeterministic); @@ -753,7 +753,7 @@ public void testDeterministicCorrectTiming() { * Tests that event times are correct when a transit route starts with some links before arriving at the first stop. */ @Test - public void testDeterministicCorrectTiming_initialLinks() { + void testDeterministicCorrectTiming_initialLinks() { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); f.config.hermes().setDeterministicPt(this.isDeterministic); @@ -872,7 +872,7 @@ public void testDeterministicCorrectTiming_initialLinks() { * Tests that everything is correct when a transit route ends with some links after arriving at the last stop. */ @Test - public void testTrailingLinksInRoute() { + void testTrailingLinksInRoute() { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); f.config.hermes().setDeterministicPt(this.isDeterministic); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/StorageCapacityTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/StorageCapacityTest.java index bd3289bc276..2f331bc9f8e 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/StorageCapacityTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/StorageCapacityTest.java @@ -23,7 +23,7 @@ import java.util.Map; import java.util.Set; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -64,7 +64,7 @@ public class StorageCapacityTest { * @author jfbischoff */ @Test - public void testStorageCapacity() { + void testStorageCapacity() { ScenarioImporter.flush(); Config config = ConfigUtils.createConfig(); config.hermes().setStuckTime(Integer.MAX_VALUE); @@ -113,7 +113,7 @@ public void testStorageCapacity() { * @author jfbischoff */ @Test - public void testStorageCapacityDownscaling() { + void testStorageCapacityDownscaling() { ScenarioImporter.flush(); Config config = ConfigUtils.createConfig(); config.hermes().setStuckTime(Integer.MAX_VALUE); @@ -165,8 +165,7 @@ public void testStorageCapacityDownscaling() { * @author jfbischoff */ @Test - - public void testStorageCapacityWithDifferentPCUs() { + void testStorageCapacityWithDifferentPCUs() { ScenarioImporter.flush(); Config config = ConfigUtils.createConfig(); config.hermes().setStuckTime(Integer.MAX_VALUE); @@ -230,8 +229,7 @@ public void testStorageCapacityWithDifferentPCUs() { * @author jfbischoff */ @Test - - public void testStorageCapacityWithVaryingPCUs() { + void testStorageCapacityWithVaryingPCUs() { ScenarioImporter.flush(); Config config = ConfigUtils.createConfig(); config.routing().setNetworkModes(Set.of(TransportMode.car, TransportMode.truck)); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/TravelTimeTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/TravelTimeTest.java index b8429e4dd45..e75676a0ae5 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/TravelTimeTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/TravelTimeTest.java @@ -23,7 +23,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.LinkEnterEvent; @@ -47,7 +47,7 @@ public class TravelTimeTest { @Test - public void testEquilOneAgent() { + void testEquilOneAgent() { Map, Map, Double>> agentTravelTimes = new HashMap<>(); Config config = ConfigUtils.loadConfig("test/scenarios/equil/config.xml"); @@ -77,13 +77,13 @@ public void testEquilOneAgent() { Assert.assertEquals(358.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); } - @Test /** * This test shows that the Netsim always rounds up link travel times. * Please note that a computed link travel time of 400.0s is treated the same, * i.e. it is rounded up to 401s. */ - public void testEquilOneAgentTravelTimeRounding() { + @Test + void testEquilOneAgentTravelTimeRounding() { Map, Map, Double>> agentTravelTimes = new HashMap<>(); Config config = ConfigUtils.loadConfig("test/scenarios/equil/config.xml"); @@ -173,7 +173,7 @@ public void testEquilOneAgentTravelTimeRounding() { } @Test - public void testEquilTwoAgents() { + void testEquilTwoAgents() { Map, Map, Double>> agentTravelTimes = new HashMap<>(); Config config = ConfigUtils.loadConfig("test/scenarios/equil/config.xml"); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/ConfigParameterTest.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/ConfigParameterTest.java index f95aa9149da..06be879f616 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/ConfigParameterTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/ConfigParameterTest.java @@ -21,8 +21,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.testcases.MatsimTestUtils; @@ -33,7 +33,8 @@ public class ConfigParameterTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testParametersSetCorrectly() { + @Test + void testParametersSetCorrectly() { Config config = utils.loadConfig(utils.getPackageInputDirectory() + "config.xml"); JDEQSimConfigGroup jdeqSimConfigGroup = ConfigUtils.addOrGetModule(config, JDEQSimConfigGroup.NAME, JDEQSimConfigGroup.class); assertEquals(360.0, jdeqSimConfigGroup.getSimulationEndTime().seconds(), MatsimTestUtils.EPSILON); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/EmptyCarLegTest.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/EmptyCarLegTest.java index 706eaa0a34a..0fe0da3b23a 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/EmptyCarLegTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/EmptyCarLegTest.java @@ -21,9 +21,9 @@ package org.matsim.core.mobsim.jdeqsim; -import java.util.List; - -import org.junit.Test; +import java.util.List; + +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -36,12 +36,12 @@ import org.matsim.core.utils.io.IOUtils; import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; - -public class EmptyCarLegTest extends AbstractJDEQSimTest { - - @Test - public void test_EmptyCarRoute() { +import static org.junit.Assert.assertTrue; + + public class EmptyCarLegTest extends AbstractJDEQSimTest { + + @Test + void test_EmptyCarRoute() { Config config = utils.loadConfig(IOUtils.extendUrl(utils.packageInputResourcePath(), "config1.xml")); MatsimRandom.reset(config.global().getRandomSeed()); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/EquilPlans1Test.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/EquilPlans1Test.java index 505cec87b6e..43157abe660 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/EquilPlans1Test.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/EquilPlans1Test.java @@ -21,9 +21,9 @@ package org.matsim.core.mobsim.jdeqsim; -import java.util.List; - -import org.junit.Test; +import java.util.List; + +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -39,12 +39,12 @@ import org.matsim.core.scenario.ScenarioUtils; import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; - -public class EquilPlans1Test extends AbstractJDEQSimTest { - - @Test - public void test_EmptyCarRoute() { +import static org.junit.Assert.assertTrue; + + public class EquilPlans1Test extends AbstractJDEQSimTest { + + @Test + void test_EmptyCarRoute() { Config config = ConfigUtils.loadConfig("test/scenarios/equil/config_plans1.xml"); MatsimRandom.reset(config.global().getRandomSeed()); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/NonCarLegTest.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/NonCarLegTest.java index c5d931819a1..a9760a740ef 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/NonCarLegTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/NonCarLegTest.java @@ -21,9 +21,9 @@ package org.matsim.core.mobsim.jdeqsim; -import java.util.List; - -import org.junit.Test; +import java.util.List; + +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -35,12 +35,12 @@ import org.matsim.core.scenario.ScenarioUtils; import org.matsim.core.utils.io.IOUtils; -import static org.junit.Assert.assertTrue; - -public class NonCarLegTest extends AbstractJDEQSimTest { - - @Test - public void test_EmptyCarRoute() { +import static org.junit.Assert.assertTrue; + + public class NonCarLegTest extends AbstractJDEQSimTest { + + @Test + void test_EmptyCarRoute() { Config config = utils.loadConfig(IOUtils.extendUrl(utils.packageInputResourcePath(), "config2.xml")); MatsimRandom.reset(config.global().getRandomSeed()); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_Berlin.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_Berlin.java index afc9477d20f..cec376de710 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_Berlin.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_Berlin.java @@ -19,22 +19,22 @@ * * * *********************************************************************** */ - package org.matsim.core.mobsim.jdeqsim; - -import org.junit.Test; + package org.matsim.core.mobsim.jdeqsim; + +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.gbl.MatsimRandom; import org.matsim.core.scenario.ScenarioUtils; -import static org.junit.Assert.assertEquals; - - -public class TestDESStarter_Berlin extends AbstractJDEQSimTest { - - @Test - public void test_Berlin_TestHandlerDetailedEventChecker() { +import static org.junit.Assert.assertEquals; + + + public class TestDESStarter_Berlin extends AbstractJDEQSimTest { + + @Test + void test_Berlin_TestHandlerDetailedEventChecker() { Config config = ConfigUtils.loadConfig("test/scenarios/berlin/config.xml"); MatsimRandom.reset(config.global().getRandomSeed()); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_EquilPopulationPlans1Modified1.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_EquilPopulationPlans1Modified1.java index 510aa5add88..a1d95ea3a89 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_EquilPopulationPlans1Modified1.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_EquilPopulationPlans1Modified1.java @@ -19,9 +19,9 @@ * * * *********************************************************************** */ - package org.matsim.core.mobsim.jdeqsim; - -import org.junit.Test; + package org.matsim.core.mobsim.jdeqsim; + +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -29,12 +29,12 @@ import org.matsim.core.mobsim.jdeqsim.scenarios.EquilPopulationPlans1Modified1; import org.matsim.core.scenario.ScenarioUtils; -import static org.junit.Assert.assertEquals; - -public class TestDESStarter_EquilPopulationPlans1Modified1 extends AbstractJDEQSimTest { - - @Test - public void test_EquilPopulationPlans1Modified1_TestHandlerDetailedEventChecker() { +import static org.junit.Assert.assertEquals; + + public class TestDESStarter_EquilPopulationPlans1Modified1 extends AbstractJDEQSimTest { + + @Test + void test_EquilPopulationPlans1Modified1_TestHandlerDetailedEventChecker() { Config config = ConfigUtils.loadConfig("test/scenarios/equil/config.xml"); config.plans().setInputFile("plans1.xml"); MatsimRandom.reset(config.global().getRandomSeed()); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_equilPlans100.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_equilPlans100.java index 88e0e59a7f0..2fcb20b2bdc 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_equilPlans100.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestDESStarter_equilPlans100.java @@ -19,21 +19,21 @@ * * * *********************************************************************** */ - package org.matsim.core.mobsim.jdeqsim; - -import org.junit.Test; + package org.matsim.core.mobsim.jdeqsim; + +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.gbl.MatsimRandom; import org.matsim.core.scenario.ScenarioUtils; -import static org.junit.Assert.assertEquals; - -public class TestDESStarter_equilPlans100 extends AbstractJDEQSimTest { - - @Test - public void test_equilPlans100_TestHandlerDetailedEventChecker() { +import static org.junit.Assert.assertEquals; + + public class TestDESStarter_equilPlans100 extends AbstractJDEQSimTest { + + @Test + void test_equilPlans100_TestHandlerDetailedEventChecker() { Config config = ConfigUtils.loadConfig("test/scenarios/equil/config.xml"); MatsimRandom.reset(config.global().getRandomSeed()); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestEventLog.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestEventLog.java index fb8231a0859..cb90b9b6390 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestEventLog.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestEventLog.java @@ -23,8 +23,8 @@ import java.util.ArrayList; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.mobsim.jdeqsim.util.CppEventFileParser; import org.matsim.testcases.MatsimTestUtils; @@ -34,12 +34,14 @@ public class TestEventLog { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testGetTravelTime(){ + @Test + void testGetTravelTime(){ ArrayList deqSimLog=CppEventFileParser.parseFile(utils.getPackageInputDirectory() + "deq_events.txt"); assertEquals(3599.0, Math.floor(EventLog.getTravelTime(deqSimLog,1)), MatsimTestUtils.EPSILON); } - @Test public void testGetAverageTravelTime(){ + @Test + void testGetAverageTravelTime(){ ArrayList deqSimLog=CppEventFileParser.parseFile(utils.getPackageInputDirectory() + "deq_events.txt"); assertEquals(EventLog.getTravelTime(deqSimLog,1), EventLog.getSumTravelTime(deqSimLog), MatsimTestUtils.EPSILON); } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageFactory.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageFactory.java index 0906d2c8814..23a43d3328f 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageFactory.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageFactory.java @@ -23,8 +23,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.core.config.ConfigUtils; @@ -33,13 +33,14 @@ import org.matsim.core.utils.timing.TimeInterpretation; import org.matsim.testcases.MatsimTestUtils; -public class TestMessageFactory { + public class TestMessageFactory { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - // check if gc turned on - @Test public void testMessageFactory1(){ + // check if gc turned on + @Test + void testMessageFactory1(){ MessageFactory.GC_ALL_MESSAGES(); JDEQSimConfigGroup.setGC_MESSAGES(true); MessageFactory.disposeEndLegMessage(new EndLegMessage(null,null, TimeInterpretation.create(ConfigUtils.createConfig()))); @@ -57,8 +58,9 @@ public class TestMessageFactory { assertEquals(0, MessageFactory.getEndLegMessageQueue().size()); } - // check when gc turned off - @Test public void testMessageFactory2(){ + // check when gc turned off + @Test + void testMessageFactory2(){ MessageFactory.GC_ALL_MESSAGES(); JDEQSimConfigGroup.setGC_MESSAGES(false); MessageFactory.disposeEndLegMessage(new EndLegMessage(null,null, TimeInterpretation.create(ConfigUtils.createConfig()))); @@ -76,8 +78,9 @@ public class TestMessageFactory { assertEquals(1, MessageFactory.getEndLegMessageQueue().size()); } - // check check use of Message factory - @Test public void testMessageFactory3(){ + // check check use of Message factory + @Test + void testMessageFactory3(){ MessageFactory.GC_ALL_MESSAGES(); JDEQSimConfigGroup.setGC_MESSAGES(false); MessageFactory.disposeEndLegMessage(new EndLegMessage(null,null, TimeInterpretation.create(ConfigUtils.createConfig()))); @@ -102,8 +105,9 @@ public class TestMessageFactory { assertEquals(0, MessageFactory.getEndLegMessageQueue().size()); } - // check initialization using constructer - @Test public void testMessageFactory5(){ + // check initialization using constructer + @Test + void testMessageFactory5(){ MessageFactory.GC_ALL_MESSAGES(); JDEQSimConfigGroup.setGC_MESSAGES(true); Scheduler scheduler=new Scheduler(new MessageQueue()); @@ -127,8 +131,9 @@ public class TestMessageFactory { assertEquals(true,MessageFactory.getDeadlockPreventionMessage(scheduler, vehicle).vehicle==vehicle); } - // check initialization using rest - @Test public void testMessageFactory6(){ + // check initialization using rest + @Test + void testMessageFactory6(){ MessageFactory.GC_ALL_MESSAGES(); JDEQSimConfigGroup.setGC_MESSAGES(false); Scheduler scheduler=new Scheduler(new MessageQueue()); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageQueue.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageQueue.java index 23bc2712123..def946b6c71 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageQueue.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestMessageQueue.java @@ -23,18 +23,19 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.mobsim.jdeqsim.util.DummyMessage; import org.matsim.testcases.MatsimTestUtils; -public class TestMessageQueue { + public class TestMessageQueue { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testPutMessage1(){ + @Test + void testPutMessage1(){ MessageQueue mq=new MessageQueue(); Message m1=new DummyMessage(); m1.setMessageArrivalTime(1); @@ -48,7 +49,8 @@ public class TestMessageQueue { assertEquals(true, mq.getNextMessage()==m1); } - @Test public void testPutMessage2(){ + @Test + void testPutMessage2(){ MessageQueue mq=new MessageQueue(); Message m1=new DummyMessage(); m1.setMessageArrivalTime(2); @@ -62,7 +64,8 @@ public class TestMessageQueue { assertEquals(true, mq.getNextMessage()==m2); } - @Test public void testPutMessage3(){ + @Test + void testPutMessage3(){ MessageQueue mq=new MessageQueue(); Message m1=new DummyMessage(); m1.setMessageArrivalTime(2); @@ -80,7 +83,8 @@ public class TestMessageQueue { assertEquals(true, mq.getNextMessage().getMessageArrivalTime()==1); } - @Test public void testRemoveMessage1(){ + @Test + void testRemoveMessage1(){ MessageQueue mq=new MessageQueue(); Message m1=new DummyMessage(); m1.setMessageArrivalTime(1); @@ -96,7 +100,8 @@ public class TestMessageQueue { assertEquals(0, mq.getQueueSize()); } - @Test public void testRemoveMessage2(){ + @Test + void testRemoveMessage2(){ MessageQueue mq=new MessageQueue(); Message m1=new DummyMessage(); m1.setMessageArrivalTime(1); @@ -112,7 +117,8 @@ public class TestMessageQueue { assertEquals(0, mq.getQueueSize()); } - @Test public void testRemoveMessage3(){ + @Test + void testRemoveMessage3(){ MessageQueue mq=new MessageQueue(); Message m1=new DummyMessage(); m1.setMessageArrivalTime(1); @@ -130,9 +136,10 @@ public class TestMessageQueue { assertEquals(true, mq.isEmpty()); } - // a higher priority message will be at front of queue, if there are - // several messages with same time - @Test public void testMessagePriority(){ + // a higher priority message will be at front of queue, if there are + // several messages with same time + @Test + void testMessagePriority(){ MessageQueue mq=new MessageQueue(); Message m1=new DummyMessage(); m1.setMessageArrivalTime(1); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestScheduler.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestScheduler.java index a5074d8ad20..6e2f13ebe7f 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestScheduler.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/TestScheduler.java @@ -21,29 +21,29 @@ package org.matsim.core.mobsim.jdeqsim; -import org.junit.Assert; -import org.junit.Test; +import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.matsim.core.mobsim.jdeqsim.util.DummyMessage; import org.matsim.core.mobsim.jdeqsim.util.DummyMessage1; -import org.matsim.core.mobsim.jdeqsim.util.DummySimUnit; - -public class TestScheduler { - - // the time at the end of the simulation is equal to the time of the last message processed - @Test - public void testSchedule1(){ +import org.matsim.core.mobsim.jdeqsim.util.DummySimUnit; + + public class TestScheduler { + + // the time at the end of the simulation is equal to the time of the last message processed + @Test + void testSchedule1(){ Scheduler scheduler=new Scheduler(new MessageQueue()); SimUnit sm1=new DummySimUnit(scheduler); Message m1=new DummyMessage(); sm1.sendMessage(m1, sm1, 9000); scheduler.startSimulation(); Assert.assertEquals(9000.0, scheduler.getSimTime(), 0.0); - } - - // a message is scheduled and unscheduled before starting the simulation - // this causes the simulation to stop immediatly (because no messages in queue) - @Test - public void testUnschedule(){ + } + + // a message is scheduled and unscheduled before starting the simulation + // this causes the simulation to stop immediatly (because no messages in queue) + @Test + void testUnschedule(){ Scheduler scheduler=new Scheduler(new MessageQueue()); SimUnit sm1=new DummySimUnit(scheduler); Message m1=new DummyMessage(); @@ -51,12 +51,12 @@ public void testUnschedule(){ scheduler.unschedule(m1); scheduler.startSimulation(); Assert.assertEquals(0.0, scheduler.getSimTime(), 0.0); - } - - // We shedule two messages, but the first message deletes upon handling the message the second message. - // This results in that the simulation stops not at time 10, but immediatly at time 1. - @Test - public void testUnschedule2(){ + } + + // We shedule two messages, but the first message deletes upon handling the message the second message. + // This results in that the simulation stops not at time 10, but immediatly at time 1. + @Test + void testUnschedule2(){ Scheduler scheduler=new Scheduler(new MessageQueue()); SimUnit sm1=new DummySimUnit(scheduler); Message m1=new DummyMessage(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/util/TestEventLibrary.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/util/TestEventLibrary.java index 314faf79eb5..acbcd8498fb 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/util/TestEventLibrary.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/util/TestEventLibrary.java @@ -25,8 +25,8 @@ import java.util.LinkedList; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.Event; @@ -36,13 +36,14 @@ import org.matsim.api.core.v01.population.Person; import org.matsim.testcases.MatsimTestUtils; -public class TestEventLibrary { + public class TestEventLibrary { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testGetTravelTime(){ + @Test + void testGetTravelTime(){ LinkedList events=new LinkedList(); events.add(new PersonDepartureEvent(20, Id.create("2", Person.class), Id.create("0", Link.class), TransportMode.car, TransportMode.car)); events.add(new PersonArrivalEvent(30, Id.create("2", Person.class), Id.create("0", Link.class), TransportMode.car)); @@ -52,7 +53,8 @@ public class TestEventLibrary { assertEquals(20.0, EventLibrary.getTravelTime(events,1), MatsimTestUtils.EPSILON); } - @Test public void testGetAverageTravelTime(){ + @Test + void testGetAverageTravelTime(){ LinkedList events=new LinkedList(); events.add(new PersonDepartureEvent(20, Id.create("2", Person.class), Id.create("0", Link.class), TransportMode.car, TransportMode.car)); events.add(new PersonArrivalEvent(30, Id.create("2", Person.class), Id.create("0", Link.class), TransportMode.car)); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/AbstractQSimModuleTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/AbstractQSimModuleTest.java index 02166c720bb..b2cdc109615 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/AbstractQSimModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/AbstractQSimModuleTest.java @@ -25,7 +25,7 @@ import java.util.concurrent.atomic.AtomicLong; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -47,9 +47,9 @@ import com.google.inject.Inject; import com.google.inject.Injector; -public class AbstractQSimModuleTest { - @Test - public void testOverrides() { + public class AbstractQSimModuleTest { + @Test + void testOverrides() { AbstractQSimModule moduleA = new AbstractQSimModule() { @Override protected void configureQSim() { @@ -80,8 +80,8 @@ protected void configureQSim() { Assert.assertEquals("testBString", injector.getInstance(String.class)); } - @Test - public void testOverrideAgentFactory() { + @Test + void testOverrideAgentFactory() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); config.controller().setLastIteration(0); @@ -104,8 +104,8 @@ public void testOverrideAgentFactory() { Assert.assertTrue(value.get() > 0); } - @Test - public void testOverrideAgentFactoryTwice() { + @Test + void testOverrideAgentFactoryTwice() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); config.controller().setLastIteration(0); @@ -162,8 +162,8 @@ public MobsimAgent createMobsimAgentFromPerson(Person p) { } } - @Test - public void testAddEngine() { + @Test + void testAddEngine() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); config.controller().setLastIteration(0); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/AgentNotificationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/AgentNotificationTest.java index 55a02dfcfd6..49a35771959 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/AgentNotificationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/AgentNotificationTest.java @@ -31,7 +31,7 @@ import org.hamcrest.FeatureMatcher; import org.hamcrest.Matcher; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -76,7 +76,7 @@ import org.matsim.vehicles.Vehicle; -public class AgentNotificationTest { + public class AgentNotificationTest { private static class MyAgentFactory implements AgentFactory { @@ -261,9 +261,9 @@ public PlanElement getPreviousPlanElement() { } - @SuppressWarnings("static-method") - @Test - public void testAgentNotification() { + @SuppressWarnings("static-method") + @Test + void testAgentNotification() { Scenario scenario = createSimpleScenario(); EventsManager eventsManager = EventsUtils.createEventsManager(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java index 0b5d2e4d65c..5dd21d977ed 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java @@ -24,8 +24,8 @@ import java.util.*; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -89,7 +89,7 @@ public static Collection parameterObjects () { private Id linkId4 = Id.create("link4", Link.class); @Test - public final void testFlowCongestion(){ + final void testFlowCongestion(){ Scenario sc = loadScenario(); setPopulation(sc); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/MobsimListenerManagerTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/MobsimListenerManagerTest.java index ec84c16752d..1c4930b1271 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/MobsimListenerManagerTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/MobsimListenerManagerTest.java @@ -20,7 +20,7 @@ package org.matsim.core.mobsim.qsim; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.mobsim.framework.events.MobsimInitializedEvent; import org.matsim.core.mobsim.framework.listeners.MobsimInitializedListener; @@ -30,7 +30,7 @@ public class MobsimListenerManagerTest { @Test - public void testAddQueueSimulationListener() { + void testAddQueueSimulationListener() { MobsimListenerManager manager = new MobsimListenerManager(null); TestSimListener simpleListener = new TestSimListener(); TestSubSimListener subListener = new TestSubSimListener(); @@ -48,7 +48,7 @@ public void testAddQueueSimulationListener() { } @Test - public void testRemoveQueueSimulationListener() { + void testRemoveQueueSimulationListener() { MobsimListenerManager manager = new MobsimListenerManager(null); TestSimListener simpleListener = new TestSimListener(); TestSubSimListener subListener = new TestSubSimListener(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/NetsimRoutingConsistencyTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/NetsimRoutingConsistencyTest.java index c93509f82c9..94d1ed9b117 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/NetsimRoutingConsistencyTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/NetsimRoutingConsistencyTest.java @@ -26,7 +26,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -64,65 +64,65 @@ import org.matsim.vehicles.Vehicle; import org.matsim.vehicles.VehicleUtils; -public class NetsimRoutingConsistencyTest { - @Test + public class NetsimRoutingConsistencyTest { /* - * This test shows that the travel time that is predicted with the - * NetworkRoutingModule is NOT equivalent to the travel time that is produced by - * the Netsim. - * - * The scenario is as follows: - * - * N1 ----- N2 ----- N3 ----- N4 ----- N5 - * L12 L23 L34 L45 - * - * There are nodes Ni and connecting links Lij. There is one agent P who wants - * to depart at L12 and arrive at L45. He has a plan with an activity at L12 and - * another one at L45 and a connecting leg by car. - * - * This car leg is produced (as would be in the full stack simulation) using the - * NetworkRoutingModule. For the disutility OnlyTimeDependentDisutility is used, - * for the TravelTime, freespeed is used. The freespeed of all links is 10, - * while the length is 1000, hence the traversal time for each link is 100. - * - * Accordingly, the NetworkRoutingModule produces a Leg for the agent with a - * travel time of - * - * routingTravelTime = 200.0 - * - * because link L23 and L45 are taken into account. As expected the routing goes - * from the end node of the departure link to the start node of the arrival - * link. We already know that this will not be the true Netsim simulated time, - * because traversal times are rounded up. So we would expect a - * - * adjustedRoutingTravelTime = 202.0 - * - * because we need to add 1s per traversed link. - * - * Now, the scenario is simulated using the QSim/Netsim. An event handler is set - * up that captures the only "departure" event and the only "arrival" event in - * the simulation (which is produced by the leg of the agent). The travel time - * can be computed an we get: - * - * netsimTravelTime = 303.0 - * - * Apparently, looking at QueueWithBuffer::moveQueueToBuffer , the agent needs - * to traverse the arrival link before he can arrive there. This leads to a - * travel time that is higher than expected by the router and so predictions - * done by the NetworkRoutingModule are inconsistent. - * - * Not sure, what to do about that. Possible options: - * - Adjust Netsim such that agents arrive before they traverse the arrival link - * - Adjust the car routing such that the travel time of the final link is added - * - Adjust the car routing such that the routing goes to the end node of the arrival link - * - Explicitly document this behaviour somewhere - * - * I guess usually this should not make such a big difference for MATSim, - * because the shortest path is found anyway. However, if one wants to predict - * travel times one should state that the NetworkRoutingModule has a bias by the - * arrival link. - */ - public void testRoutingVsSimulation() { +* This test shows that the travel time that is predicted with the +* NetworkRoutingModule is NOT equivalent to the travel time that is produced by +* the Netsim. + * +* The scenario is as follows: + * +* N1 ----- N2 ----- N3 ----- N4 ----- N5 +* L12 L23 L34 L45 + * +* There are nodes Ni and connecting links Lij. There is one agent P who wants +* to depart at L12 and arrive at L45. He has a plan with an activity at L12 and +* another one at L45 and a connecting leg by car. + * +* This car leg is produced (as would be in the full stack simulation) using the +* NetworkRoutingModule. For the disutility OnlyTimeDependentDisutility is used, +* for the TravelTime, freespeed is used. The freespeed of all links is 10, +* while the length is 1000, hence the traversal time for each link is 100. + * +* Accordingly, the NetworkRoutingModule produces a Leg for the agent with a +* travel time of + * +* routingTravelTime = 200.0 + * +* because link L23 and L45 are taken into account. As expected the routing goes +* from the end node of the departure link to the start node of the arrival +* link. We already know that this will not be the true Netsim simulated time, +* because traversal times are rounded up. So we would expect a + * +* adjustedRoutingTravelTime = 202.0 + * +* because we need to add 1s per traversed link. + * +* Now, the scenario is simulated using the QSim/Netsim. An event handler is set +* up that captures the only "departure" event and the only "arrival" event in +* the simulation (which is produced by the leg of the agent). The travel time +* can be computed an we get: + * +* netsimTravelTime = 303.0 + * +* Apparently, looking at QueueWithBuffer::moveQueueToBuffer , the agent needs +* to traverse the arrival link before he can arrive there. This leads to a +* travel time that is higher than expected by the router and so predictions +* done by the NetworkRoutingModule are inconsistent. + * +* Not sure, what to do about that. Possible options: +* - Adjust Netsim such that agents arrive before they traverse the arrival link +* - Adjust the car routing such that the travel time of the final link is added +* - Adjust the car routing such that the routing goes to the end node of the arrival link +* - Explicitly document this behaviour somewhere + * +* I guess usually this should not make such a big difference for MATSim, +* because the shortest path is found anyway. However, if one wants to predict +* travel times one should state that the NetworkRoutingModule has a bias by the +* arrival link. + */ + @Test + void testRoutingVsSimulation() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); @@ -206,12 +206,12 @@ public void testRoutingVsSimulation() { Assert.assertEquals(adjustedRoutingTravelTime, 202.0, 1e-3); } - @Test /* - * The same test as above, but here the full stack MATSim setup is used (i.e. the - * NetworkRoutingModule, etc. are created implicitly by the Controler). - */ - public void testRoutingVsSimulationFullStack() { +* The same test as above, but here the full stack MATSim setup is used (i.e. the +* NetworkRoutingModule, etc. are created implicitly by the Controler). + */ + @Test + void testRoutingVsSimulationFullStack() { Config config = ConfigUtils.createConfig(); config.controller().setOverwriteFileSetting(OverwriteFileSetting.deleteDirectoryIfExists); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java index 954f61a3eda..23711c823b1 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java @@ -27,7 +27,7 @@ import java.util.TreeMap; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Coord; @@ -90,7 +90,7 @@ public NodeTransitionTest(boolean useFastCapUpdate) { } @Test - public void testMergeSituationWithEmptyBufferAfterBufferRandomDistribution() { + void testMergeSituationWithEmptyBufferAfterBufferRandomDistribution() { Scenario scenario = Fixture.createMergeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.emptyBufferAfterBufferRandomDistribution_dontBlockNode); scenario.getConfig().qsim().setUsingFastCapacityUpdate(useFastCapUpdate); @@ -158,7 +158,7 @@ public void testMergeSituationWithEmptyBufferAfterBufferRandomDistribution() { } @Test - public void testMergeSituationWithMoveVehByVehRandomDistribution() { + void testMergeSituationWithMoveVehByVehRandomDistribution() { Scenario scenario = Fixture.createMergeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.moveVehByVehRandomDistribution_dontBlockNode); scenario.getConfig().qsim().setUsingFastCapacityUpdate(useFastCapUpdate); @@ -233,7 +233,7 @@ public void testMergeSituationWithMoveVehByVehRandomDistribution() { } @Test - public void testMergeSituationWithMoveVehByVehDeterministicPriorities() { + void testMergeSituationWithMoveVehByVehDeterministicPriorities() { Scenario scenario = Fixture.createMergeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.moveVehByVehDeterministicPriorities_nodeBlockedWhenSingleOutlinkFull); // note: the deterministic node transition is only implemented for the case when the node is blocked as soon as one outgoing link is full @@ -302,7 +302,7 @@ public void testMergeSituationWithMoveVehByVehDeterministicPriorities() { } @Test - public void testBlockedNodeSituationWithEmptyBufferAfterBufferRandomDistribution() { + void testBlockedNodeSituationWithEmptyBufferAfterBufferRandomDistribution() { Scenario scenario = Fixture.createBlockedNodeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.emptyBufferAfterBufferRandomDistribution_nodeBlockedWhenSingleOutlinkFull); scenario.getConfig().qsim().setUsingFastCapacityUpdate(useFastCapUpdate); @@ -383,7 +383,7 @@ public void testBlockedNodeSituationWithEmptyBufferAfterBufferRandomDistribution } @Test - public void testBlockedNodeSituationWithMoveVehByVehRandomDistribution() { + void testBlockedNodeSituationWithMoveVehByVehRandomDistribution() { Scenario scenario = Fixture.createBlockedNodeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.moveVehByVehRandomDistribution_nodeBlockedWhenSingleOutlinkFull); scenario.getConfig().qsim().setUsingFastCapacityUpdate(useFastCapUpdate); @@ -465,7 +465,7 @@ public void testBlockedNodeSituationWithMoveVehByVehRandomDistribution() { } @Test - public void testBlockedNodeSituationWithMoveVehByVehDeterministicPriorities() { + void testBlockedNodeSituationWithMoveVehByVehDeterministicPriorities() { Scenario scenario = Fixture.createBlockedNodeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.moveVehByVehDeterministicPriorities_nodeBlockedWhenSingleOutlinkFull); scenario.getConfig().qsim().setUsingFastCapacityUpdate(useFastCapUpdate); @@ -554,7 +554,7 @@ public void testBlockedNodeSituationWithMoveVehByVehDeterministicPriorities() { * 3. both streams are independently (because blockNode=false). */ @Test - public void testNodeTransitionWithTimeStepSizeSmallerOne() { + void testNodeTransitionWithTimeStepSizeSmallerOne() { Scenario scenario = Fixture.createBlockedNodeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.emptyBufferAfterBufferRandomDistribution_dontBlockNode); scenario.getConfig().qsim().setTimeStepSize(0.5); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimEventsIntegrationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimEventsIntegrationTest.java index e7ec111bd4b..e9cbe1d2d6e 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimEventsIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimEventsIntegrationTest.java @@ -22,9 +22,9 @@ package org.matsim.core.mobsim.qsim; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Timeout; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.handler.LinkLeaveEventHandler; import org.matsim.core.api.experimental.events.EventsManager; @@ -41,7 +41,7 @@ public class QSimEventsIntegrationTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void netsimEngineHandlesExceptionCorrectly() { + void netsimEngineHandlesExceptionCorrectly() { Config config = utils.loadConfig("test/scenarios/equil/config_plans1.xml"); Scenario scenario = ScenarioUtils.loadScenario(config); @@ -58,7 +58,7 @@ public void netsimEngineHandlesExceptionCorrectly() { } @Test - public void controlerHandlesExceptionCorrectly_syncOnSimSteps() { + void controlerHandlesExceptionCorrectly_syncOnSimSteps() { Config config = utils.loadConfig("test/scenarios/equil/config_plans1.xml"); config.eventsManager().setNumberOfThreads(1); config.eventsManager().setSynchronizeOnSimSteps(true); @@ -73,7 +73,7 @@ public void controlerHandlesExceptionCorrectly_syncOnSimSteps() { } @Test - public void controlerHandlesExceptionCorrectly_noSyncOnSimSteps() { + void controlerHandlesExceptionCorrectly_noSyncOnSimSteps() { Config config = utils.loadConfig("test/scenarios/equil/config_plans1.xml"); config.eventsManager().setNumberOfThreads(1); config.eventsManager().setSynchronizeOnSimSteps(false); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java index a322a208f70..b27f758dfb3 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java @@ -30,7 +30,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -144,7 +144,7 @@ private static QSim createQSim(Fixture f, EventsManager events) { * @author mrieser */ @Test - public void testSingleAgent() { + void testSingleAgent() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a single person with leg from link1 to link3 @@ -184,7 +184,7 @@ public void testSingleAgent() { * @author Kai Nagel */ @Test - public void testSingleAgentWithEndOnLeg() { + void testSingleAgentWithEndOnLeg() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a single person with leg from link1 to link3 @@ -250,7 +250,7 @@ public void testSingleAgentWithEndOnLeg() { * @author mrieser */ @Test - public void testTwoAgent() { + void testTwoAgent() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add two persons with leg from link1 to link3, the first starting at 6am, the second at 7am @@ -291,7 +291,7 @@ public void testTwoAgent() { * @author mrieser */ @Test - public void testTeleportationSingleAgent() { + void testTeleportationSingleAgent() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a single person with leg from link1 to link3 @@ -338,7 +338,7 @@ public void testTeleportationSingleAgent() { * @author cdobler */ @Test - public void testSingleAgentImmediateDeparture() { + void testSingleAgentImmediateDeparture() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a single person with leg from link1 to link3 @@ -383,7 +383,7 @@ public void testSingleAgentImmediateDeparture() { * @author mrieser */ @Test - public void testSingleAgent_EmptyRoute() { + void testSingleAgent_EmptyRoute() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a single person with leg from link1 to link1 @@ -456,7 +456,7 @@ public void testSingleAgent_EmptyRoute() { * @author mrieser */ @Test - public void testSingleAgent_LastLinkIsLoop() { + void testSingleAgent_LastLinkIsLoop() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Link loopLink = NetworkUtils.createAndAddLink(f.network,Id.create("loop", Link.class), f.node4, f.node4, 100.0, 10.0, 500, 1 ); @@ -526,7 +526,7 @@ public void reset(final int iteration) { * @author mrieser */ @Test - public void testAgentWithoutLeg() { + void testAgentWithoutLeg() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -553,7 +553,7 @@ public void testAgentWithoutLeg() { * @author mrieser */ @Test - public void testAgentWithoutLegWithEndtime() { + void testAgentWithoutLegWithEndtime() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -581,7 +581,7 @@ public void testAgentWithoutLegWithEndtime() { * @author mrieser */ @Test - public void testAgentWithLastActWithEndtime() { + void testAgentWithLastActWithEndtime() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -616,7 +616,7 @@ public void testAgentWithLastActWithEndtime() { * @author mrieser */ @Test - public void testFlowCapacityDriving() { + void testFlowCapacityDriving() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a lot of persons with legs from link1 to link3, starting at 6:30 @@ -681,7 +681,7 @@ public void testFlowCapacityDriving() { * @author michaz */ @Test - public void testFlowCapacityDrivingFraction() { + void testFlowCapacityDrivingFraction() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.link2.setCapacity(900.0); // One vehicle every 4 seconds @@ -736,7 +736,7 @@ public void testFlowCapacityDrivingFraction() { * @author mrieser */ @Test - public void testFlowCapacityStarting() { + void testFlowCapacityStarting() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a lot of persons with legs from link2 to link3 @@ -791,7 +791,7 @@ public void testFlowCapacityStarting() { * @author mrieser */ @Test - public void testFlowCapacityMixed() { + void testFlowCapacityMixed() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a lot of persons with legs from link2 to link3 @@ -859,7 +859,7 @@ public void testFlowCapacityMixed() { * @author mrieser */ @Test - public void testVehicleTeleportationTrue() { + void testVehicleTeleportationTrue() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan plan = PersonUtils.createAndAddPlan(person, true); @@ -914,7 +914,7 @@ public void testVehicleTeleportationTrue() { * @author michaz */ @Test - public void testWaitingForCar() { + void testWaitingForCar() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.scenario.getConfig().qsim().setVehicleBehavior(QSimConfigGroup.VehicleBehavior.wait); f.scenario.getConfig().qsim().setEndTime(24.0 * 60.0 * 60.0); @@ -1009,7 +1009,7 @@ public void testWaitingForCar() { * @author mrieser */ @Test - public void testVehicleTeleportationFalse() { + void testVehicleTeleportationFalse() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.scenario.getConfig().qsim().setVehicleBehavior(QSimConfigGroup.VehicleBehavior.exception); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -1062,7 +1062,7 @@ public void testVehicleTeleportationFalse() { * @author mrieser */ @Test - public void testAssignedVehicles() { + void testAssignedVehicles() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); // do not add person to population, we'll do it ourselves for the test Plan plan = PersonUtils.createAndAddPlan(person, true); @@ -1118,7 +1118,7 @@ public void testAssignedVehicles() { * @author mrieser */ @Test - public void testCircleAsRoute() { + void testCircleAsRoute() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Link link4 = NetworkUtils.createAndAddLink(f.network,Id.create(4, Link.class), f.node4, f.node1, 1000.0, 100.0, 6000, 1.0 ); // close the network @@ -1176,7 +1176,7 @@ public void testCircleAsRoute() { * @author mrieser */ @Test - public void testRouteWithEndLinkTwice() { + void testRouteWithEndLinkTwice() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Link link4 = NetworkUtils.createAndAddLink(f.network,Id.create(4, Link.class), f.node4, f.node1, 1000.0, 100.0, 6000, 1.0 ); // close the network @@ -1237,7 +1237,7 @@ public void testRouteWithEndLinkTwice() { * @author mrieser */ @Test - public void testConsistentRoutes_WrongRoute() { + void testConsistentRoutes_WrongRoute() { EventsManager events = EventsUtils.createEventsManager(); EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); @@ -1253,7 +1253,7 @@ public void testConsistentRoutes_WrongRoute() { * @author mrieser */ @Test - public void testConsistentRoutes_WrongStartLink() { + void testConsistentRoutes_WrongStartLink() { EventsManager events = EventsUtils.createEventsManager(); EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); @@ -1269,7 +1269,7 @@ public void testConsistentRoutes_WrongStartLink() { * @author mrieser */ @Test - public void testConsistentRoutes_WrongEndLink() { + void testConsistentRoutes_WrongEndLink() { EventsManager events = EventsUtils.createEventsManager(); EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); @@ -1286,7 +1286,7 @@ public void testConsistentRoutes_WrongEndLink() { * @author mrieser */ @Test - public void testConsistentRoutes_ImpossibleRoute() { + void testConsistentRoutes_ImpossibleRoute() { EventsManager events = EventsUtils.createEventsManager(); EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); @@ -1302,7 +1302,7 @@ public void testConsistentRoutes_ImpossibleRoute() { * @author mrieser */ @Test - public void testConsistentRoutes_MissingRoute() { + void testConsistentRoutes_MissingRoute() { EventsManager events = EventsUtils.createEventsManager(); EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); @@ -1371,7 +1371,7 @@ private LogCounter runConsistentRoutesTestSim(final String startLinkId, final St } @Test - public void testStartAndEndTime() { + void testStartAndEndTime() { final Config config = ConfigUtils.createConfig(); config.qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); @@ -1437,7 +1437,7 @@ public void testStartAndEndTime() { * @author mrieser */ @Test - public void testCleanupSim_EarlyEnd() { + void testCleanupSim_EarlyEnd() { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); Config config = scenario.getConfig(); @@ -1535,7 +1535,7 @@ public void testCleanupSim_EarlyEnd() { * @author ikaddoura based on mrieser */ @Test - public void testFlowCapacityDrivingKinematicWavesWithFlowReductionCorrectionBehavior() { + void testFlowCapacityDrivingKinematicWavesWithFlowReductionCorrectionBehavior() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.config.qsim().setTrafficDynamics(TrafficDynamics.kinematicWaves); f.config.qsim().setInflowCapacitySetting(QSimConfigGroup.InflowCapacitySetting.INFLOW_FROM_FDIAG); @@ -1595,7 +1595,7 @@ public void testFlowCapacityDrivingKinematicWavesWithFlowReductionCorrectionBeha * @author ikaddoura based on mrieser */ @Test - public void testFlowCapacityDrivingKinematicWavesWithLaneIncreaseCorrectionBehavior() { + void testFlowCapacityDrivingKinematicWavesWithLaneIncreaseCorrectionBehavior() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.config.qsim().setTrafficDynamics(TrafficDynamics.kinematicWaves); f.config.qsim().setInflowCapacitySetting(QSimConfigGroup.InflowCapacitySetting.NR_OF_LANES_FROM_FDIAG); @@ -1655,7 +1655,7 @@ public void testFlowCapacityDrivingKinematicWavesWithLaneIncreaseCorrectionBehav * @author tschlenther based on ikaddoura based on mrieser */ @Test - public void testFlowCapacityDrivingKinematicWavesWithInflowEqualToMaxCapForOneLane() { + void testFlowCapacityDrivingKinematicWavesWithInflowEqualToMaxCapForOneLane() { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.config.qsim().setTrafficDynamics(TrafficDynamics.kinematicWaves); f.config.qsim().setInflowCapacitySetting(QSimConfigGroup.InflowCapacitySetting.MAX_CAP_FOR_ONE_LANE); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TeleportationEngineWDistanceCheckTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TeleportationEngineWDistanceCheckTest.java index 0af1d61514c..8f0286cf9cd 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TeleportationEngineWDistanceCheckTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TeleportationEngineWDistanceCheckTest.java @@ -20,8 +20,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -59,7 +59,7 @@ public class TeleportationEngineWDistanceCheckTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test - public final void test() { + final void test() { Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory( utils.getOutputDirectory() ); config.controller().setOverwriteFileSetting( OverwriteFileSetting.deleteDirectoryIfExists ); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TransitQueueNetworkTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TransitQueueNetworkTest.java index 0d9a67d768e..deb611bbab7 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TransitQueueNetworkTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TransitQueueNetworkTest.java @@ -28,7 +28,7 @@ import java.util.Collections; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -78,16 +78,17 @@ public class TransitQueueNetworkTest { - /** - * Tests that a non-blocking stops on the first link of a transit vehicle's network - * route is correctly handled. - * @throws NoSuchMethodException - * @throws SecurityException - * @throws InvocationTargetException - * @throws IllegalAccessException - * @throws IllegalArgumentException - */ - @Test public void testNonBlockingStop_FirstLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { + /** + * Tests that a non-blocking stops on the first link of a transit vehicle's network + * route is correctly handled. + * @throws NoSuchMethodException + * @throws SecurityException + * @throws InvocationTargetException + * @throws IllegalAccessException + * @throws IllegalArgumentException + */ + @Test + void testNonBlockingStop_FirstLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { Fixture f = new Fixture(1, false, 0, false); f.simEngine.doSimStep(100); @@ -122,20 +123,21 @@ public class TransitQueueNetworkTest { assertEquals(2, f.qlink2.getAllVehicles().size()); } - /** - * Tests that blocking stops are correctly handled on the - * first link of a transit vehicle's network route. - * Note that on the first link, a stop is by definition non-blocking, - * as the wait2buffer-queue is seen as similary independent than the transit stop queue! - * So, it essentially tests the same thing as {@link #testNonBlockingStop_FirstLink()}. - * - * @throws NoSuchMethodException - * @throws SecurityException - * @throws InvocationTargetException - * @throws IllegalAccessException - * @throws IllegalArgumentException - */ - @Test public void testBlockingStop_FirstLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { + /** + * Tests that blocking stops are correctly handled on the + * first link of a transit vehicle's network route. + * Note that on the first link, a stop is by definition non-blocking, + * as the wait2buffer-queue is seen as similary independent than the transit stop queue! + * So, it essentially tests the same thing as {@link #testNonBlockingStop_FirstLink()}. + * + * @throws NoSuchMethodException + * @throws SecurityException + * @throws InvocationTargetException + * @throws IllegalAccessException + * @throws IllegalArgumentException + */ + @Test + void testBlockingStop_FirstLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { Fixture f = new Fixture(1, true, 0, false); f.qsim.getSimTimer().setTime(100); @@ -167,16 +169,17 @@ public class TransitQueueNetworkTest { assertEquals(2, f.qlink2.getAllVehicles().size()); } - /** - * Tests that a non-blocking stop is correctly handled when it is somewhere in the middle - * of the transit vehicle's network route. - * @throws NoSuchMethodException - * @throws SecurityException - * @throws InvocationTargetException - * @throws IllegalAccessException - * @throws IllegalArgumentException - */ - @Test public void testNonBlockingStop_MiddleLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { + /** + * Tests that a non-blocking stop is correctly handled when it is somewhere in the middle + * of the transit vehicle's network route. + * @throws NoSuchMethodException + * @throws SecurityException + * @throws InvocationTargetException + * @throws IllegalAccessException + * @throws IllegalArgumentException + */ + @Test + void testNonBlockingStop_MiddleLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { Fixture f = new Fixture(2, false, 0, false); // time 100: agents start, transitVeh is moved to qlink1.buffer @@ -250,16 +253,17 @@ public class TransitQueueNetworkTest { assertEquals(f.transitVehicle, vehicles[1]); } - /** - * Tests that a blocking stop is correctly handled when it is somewhere in the middle - * of the transit vehicle's network route. - * @throws NoSuchMethodException - * @throws SecurityException - * @throws InvocationTargetException - * @throws IllegalAccessException - * @throws IllegalArgumentException - */ - @Test public void testBlockingStop_MiddleLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { + /** + * Tests that a blocking stop is correctly handled when it is somewhere in the middle + * of the transit vehicle's network route. + * @throws NoSuchMethodException + * @throws SecurityException + * @throws InvocationTargetException + * @throws IllegalAccessException + * @throws IllegalArgumentException + */ + @Test + void testBlockingStop_MiddleLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { Fixture f = new Fixture(2, true, 0, false); // time 100: agents start, transitVeh is moved to qlink1.buffer @@ -330,16 +334,17 @@ public class TransitQueueNetworkTest { assertEquals(f.normalVehicle, vehicles[1]); } - /** - * Tests that a non-blocking stop is correctly handled when it is the last link - * of the transit vehicle's network route. - * @throws NoSuchMethodException - * @throws SecurityException - * @throws InvocationTargetException - * @throws IllegalAccessException - * @throws IllegalArgumentException - */ - @Test public void testNonBlockingStop_LastLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { + /** + * Tests that a non-blocking stop is correctly handled when it is the last link + * of the transit vehicle's network route. + * @throws NoSuchMethodException + * @throws SecurityException + * @throws InvocationTargetException + * @throws IllegalAccessException + * @throws IllegalArgumentException + */ + @Test + void testNonBlockingStop_LastLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { Fixture f = new Fixture(3, false, 0, false); // time 100: agents start, transitVeh is moved to qlink1.buffer @@ -412,16 +417,17 @@ public class TransitQueueNetworkTest { assertEquals(0, f.qlink3.getAllNonParkedVehicles().size()); } - /** - * Tests that a blocking stop is correctly handled when it is the last link - * of the transit vehicle's network route. - * @throws NoSuchMethodException - * @throws SecurityException - * @throws InvocationTargetException - * @throws IllegalAccessException - * @throws IllegalArgumentException - */ - @Test public void testBlockingStop_LastLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { + /** + * Tests that a blocking stop is correctly handled when it is the last link + * of the transit vehicle's network route. + * @throws NoSuchMethodException + * @throws SecurityException + * @throws InvocationTargetException + * @throws IllegalAccessException + * @throws IllegalArgumentException + */ + @Test + void testBlockingStop_LastLink() throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException { Fixture f = new Fixture(3, true, 0, false); // time 100: agents start, transitVeh is moved to qlink1.buffer @@ -487,7 +493,8 @@ public class TransitQueueNetworkTest { assertEquals(0, f.qlink3.getAllNonParkedVehicles().size()); } - @Test public void testTwoStopsOnOneLink_FirstLink() throws IllegalArgumentException, SecurityException, IllegalAccessException, InvocationTargetException, NoSuchMethodException { + @Test + void testTwoStopsOnOneLink_FirstLink() throws IllegalArgumentException, SecurityException, IllegalAccessException, InvocationTargetException, NoSuchMethodException { Fixture f = new Fixture(1, true, 1, true); // first stop at the first link is non-blocking by definition! // time 100: agents start, transitVeh is moved to qlink1.transitStopQueue (delay 19, exit-time 119), normalVeh is moved to qlink1.buffer @@ -536,7 +543,8 @@ public class TransitQueueNetworkTest { assertEquals(f.transitVehicle, vehicles[2]); } - @Test public void testTwoStopsOnOneLink_MiddleLink_FirstBlockThenNonBlock() throws IllegalArgumentException, SecurityException, IllegalAccessException, InvocationTargetException, NoSuchMethodException { + @Test + void testTwoStopsOnOneLink_MiddleLink_FirstBlockThenNonBlock() throws IllegalArgumentException, SecurityException, IllegalAccessException, InvocationTargetException, NoSuchMethodException { Fixture f = new Fixture(2, true, 2, false); // time 100: agents start, transitVeh is moved to qlink1.buffer @@ -638,7 +646,8 @@ public class TransitQueueNetworkTest { assertEquals(f.normalVehicle2, vehicles[2]); } - @Test public void testTwoStopsOnOneLink_MiddleLink_FirstNonBlockThenBlock() throws IllegalArgumentException, SecurityException, IllegalAccessException, InvocationTargetException, NoSuchMethodException { + @Test + void testTwoStopsOnOneLink_MiddleLink_FirstNonBlockThenBlock() throws IllegalArgumentException, SecurityException, IllegalAccessException, InvocationTargetException, NoSuchMethodException { Fixture f = new Fixture(2, false, 2, true); // time 100: agents start, transitVeh is moved to qlink1.buffer @@ -752,7 +761,8 @@ public class TransitQueueNetworkTest { assertEquals(f.normalVehicle2, vehicles[2]); } - @Test public void testTwoStopsOnOneLink_LastLink_FirstBlockThenNonBlock() throws IllegalArgumentException, SecurityException, IllegalAccessException, InvocationTargetException, NoSuchMethodException { + @Test + void testTwoStopsOnOneLink_LastLink_FirstBlockThenNonBlock() throws IllegalArgumentException, SecurityException, IllegalAccessException, InvocationTargetException, NoSuchMethodException { Fixture f = new Fixture(3, true, 3, false); // time 100: agents start, transitVeh is moved to qlink1.buffer @@ -865,7 +875,8 @@ public class TransitQueueNetworkTest { assertEquals(0, f.qlink3.getAllNonParkedVehicles().size()); } - @Test public void testTwoStopsOnOneLink_LastLink_FirstNonBlockThenBlock() throws IllegalArgumentException, SecurityException, IllegalAccessException, InvocationTargetException, NoSuchMethodException { + @Test + void testTwoStopsOnOneLink_LastLink_FirstNonBlockThenBlock() throws IllegalArgumentException, SecurityException, IllegalAccessException, InvocationTargetException, NoSuchMethodException { Fixture f = new Fixture(3, false, 3, true); // time 100: agents start, transitVeh is moved to qlink1.buffer diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TravelTimeTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TravelTimeTest.java index d5ed75191cd..6670ac30280 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TravelTimeTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TravelTimeTest.java @@ -23,7 +23,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.LinkEnterEvent; @@ -47,7 +47,7 @@ public class TravelTimeTest { @Test - public void testEquilOneAgent() { + void testEquilOneAgent() { Map, Map, Double>> agentTravelTimes = new HashMap<>(); Config config = ConfigUtils.loadConfig("test/scenarios/equil/config.xml"); @@ -77,14 +77,14 @@ public void testEquilOneAgent() { Assert.assertEquals(1260.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); Assert.assertEquals(360.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); } - - @Test + /** * This test shows that the Netsim always rounds up link travel times. * Please note that a computed link travel time of 400.0s is treated the same, * i.e. it is rounded up to 401s. */ - public void testEquilOneAgentTravelTimeRounding() { + @Test + void testEquilOneAgentTravelTimeRounding() { Map, Map, Double>> agentTravelTimes = new HashMap<>(); Config config = ConfigUtils.loadConfig("test/scenarios/equil/config.xml"); @@ -174,7 +174,7 @@ public void testEquilOneAgentTravelTimeRounding() { } @Test - public void testEquilTwoAgents() { + void testEquilTwoAgents() { Map, Map, Double>> agentTravelTimes = new HashMap<>(); Config config = ConfigUtils.loadConfig("test/scenarios/equil/config.xml"); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java index 5ffc5e3b6af..6b84f956f3f 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java @@ -19,8 +19,8 @@ package org.matsim.core.mobsim.qsim; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -108,7 +108,7 @@ public static Collection parameterObjects () { private Link link3; @Test - public void main() { + void main() { scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createNetwork(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/changeeventsengine/NetworkChangeEventsEngineTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/changeeventsengine/NetworkChangeEventsEngineTest.java index d62f119e79c..6eb210f684d 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/changeeventsengine/NetworkChangeEventsEngineTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/changeeventsengine/NetworkChangeEventsEngineTest.java @@ -22,7 +22,7 @@ package org.matsim.core.mobsim.qsim.changeeventsengine; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -46,13 +46,13 @@ import java.util.List; -/** + /** * @author mrieser / Simunto GmbH */ public class NetworkChangeEventsEngineTest { - @Test - public void testActivation_inactive() { + @Test + void testActivation_inactive() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); @@ -86,8 +86,8 @@ public void testActivation_inactive() { } } - @Test - public void testActivation_timedepOnly_freespeed() { + @Test + void testActivation_timedepOnly_freespeed() { Config config = ConfigUtils.createConfig(); config.network().setTimeVariantNetwork(true); Scenario scenario = ScenarioUtils.createScenario(config); @@ -122,8 +122,8 @@ public void testActivation_timedepOnly_freespeed() { Assert.assertEquals("it should be 50 now.", 50, link1.getFreespeed(40), 0); } - @Test - public void testActivation_timedepOnly_capacity() { + @Test + void testActivation_timedepOnly_capacity() { Config config = ConfigUtils.createConfig(); config.network().setTimeVariantNetwork(true); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/QSimComponentsTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/QSimComponentsTest.java index a11cadd58c0..3e97d857a17 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/QSimComponentsTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/QSimComponentsTest.java @@ -32,7 +32,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.Event; import org.matsim.core.api.experimental.events.EventsManager; @@ -52,12 +52,13 @@ import static java.lang.annotation.ElementType.*; import static java.lang.annotation.RetentionPolicy.RUNTIME; +import static org.junit.jupiter.api.Assertions.assertThrows; -public class QSimComponentsTest { + public class QSimComponentsTest { private static final Logger log = LogManager.getLogger( QSimComponentsTest.class ) ; - @Test - public void testAddComponentViaString() { + @Test + void testAddComponentViaString() { // request "abc" component by config: Config config = ConfigUtils.createConfig(); @@ -97,12 +98,13 @@ public void testAddComponentViaString() { Assert.assertTrue( "MockMobsimListener was not added to QSim", handler.hasBeenCalled() ) ; } - /** - * this tests what happens when we run the same as in {@link #testAddComponentViaString()}, but without requesting the "abc" - * component by config. "abc" will not be activated (although it is "registered" = added as a qsim module). - */ - @Test - public void testAddModuleOnly() { + + /** + * this tests what happens when we run the same as in {@link #testAddComponentViaString()}, but without requesting the "abc" + * component by config. "abc" will not be activated (although it is "registered" = added as a qsim module). + */ + @Test + void testAddModuleOnly() { Config config = ConfigUtils.createConfig(); @@ -140,52 +142,57 @@ public void testAddModuleOnly() { Assert.assertFalse( "MockMobsimListener was added to QSim although it should not have been added", handler.hasBeenCalled() ) ; } - /** - * this tests what happens when we run the same as in {@link #testAddComponentViaString()}, but without registering the "abc" - * module. Evidently, it throws an exception. - */ - @Test( expected = ProvisionException.class ) - public void testAddComponentOnly() { - Config config = ConfigUtils.createConfig(); - - QSimComponentsConfigGroup qsimComponentsConfig = ConfigUtils.addOrGetModule( config, QSimComponentsConfigGroup.class ); - List list = new ArrayList<>( qsimComponentsConfig.getActiveComponents() ) ; // contains the "standard components" (*) - list.add( "abc" ) ; - qsimComponentsConfig.setActiveComponents( list ); - - log.warn( "" ); - log.warn( "qsimComponentsConfig=" + qsimComponentsConfig + "; active components:"); - for( String component : qsimComponentsConfig.getActiveComponents() ){ - log.warn( component ); - } - log.warn( "" ); - - Scenario scenario = ScenarioUtils.createScenario(config); - EventsManager eventsManager = EventsUtils.createEventsManager(); + /** + * this tests what happens when we run the same as in {@link #testAddComponentViaString()}, but without registering the "abc" + * module. Evidently, it throws an exception. + */ + @Test + void testAddComponentOnly() { + assertThrows(ProvisionException.class, () -> { + Config config = ConfigUtils.createConfig(); + + QSimComponentsConfigGroup qsimComponentsConfig = ConfigUtils.addOrGetModule(config, QSimComponentsConfigGroup.class); + List list = new ArrayList<>( qsimComponentsConfig.getActiveComponents() ) ; // contains the "standard components" (*) + list.add("abc") ; + qsimComponentsConfig.setActiveComponents(list); + + log.warn(""); + log.warn("qsimComponentsConfig=" + qsimComponentsConfig + "; active components:"); + for (String component : qsimComponentsConfig.getActiveComponents()) { + log.warn(component); + } + log.warn(""); + + Scenario scenario = ScenarioUtils.createScenario(config); + EventsManager eventsManager = EventsUtils.createEventsManager(); + + AnalysisEventsHandler handler = new AnalysisEventsHandler() ; + eventsManager.addHandler(handler); + + AbstractQSimModule module = new AbstractQSimModule() { + @Override + protected void configureQSim() { + addQSimComponentBinding("abc").to(MockMobsimListener.class) ; + } + }; - AnalysisEventsHandler handler = new AnalysisEventsHandler() ; - eventsManager.addHandler( handler ); + new QSimBuilder(config) // + .useDefaultComponents() // uses components from config + .useDefaultQSimModules() // registers the default modules (needed here because of (*)) +// .addQSimModule(module) // registers the additional modules + .build(scenario, eventsManager) // + .run(); - AbstractQSimModule module = new AbstractQSimModule() { - @Override protected void configureQSim() { - addQSimComponentBinding( "abc" ).to( MockMobsimListener.class ) ; - } - }; + }); - new QSimBuilder(config) // - .useDefaultComponents() // uses components from config - .useDefaultQSimModules() // registers the default modules (needed here because of (*)) -// .addQSimModule(module) // registers the additional modules - .build(scenario, eventsManager) // - .run(); + } - } - /** - * this tests what happens when we run the same as in {@link #testAddComponentViaString()}, but request the "abc" component twice. - */ - @Test -// ( expected = IllegalStateException.class ) - public void testAddComponentViaStringTwice() { + /** + * this tests what happens when we run the same as in {@link #testAddComponentViaString()}, but request the "abc" component twice. + */ + // ( expected = IllegalStateException.class ) + @Test + void testAddComponentViaStringTwice() { // request "abc" component by config: Config config = ConfigUtils.createConfig(); @@ -228,8 +235,8 @@ public void testAddComponentViaStringTwice() { } - @Test - public void testGenericAddComponentMethod() { + @Test + void testGenericAddComponentMethod() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); EventsManager eventsManager = EventsUtils.createEventsManager(); @@ -258,8 +265,8 @@ public void testGenericAddComponentMethod() { Assert.assertTrue( handler.hasBeenCalled() ) ; } - @Test - public void testGenericAddComponentMethodWithoutConfiguringIt() { + @Test + void testGenericAddComponentMethodWithoutConfiguringIt() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); EventsManager eventsManager = EventsUtils.createEventsManager(); @@ -281,8 +288,8 @@ public void testGenericAddComponentMethodWithoutConfiguringIt() { Assert.assertFalse( handler.hasBeenCalled() ) ; } - @Test - public void testMultipleBindings() { + @Test + void testMultipleBindings() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); EventsManager eventsManager = EventsUtils.createEventsManager(); @@ -308,8 +315,8 @@ protected void configureQSim() { Assert.assertTrue(mockEngineB.isCalled); } - @Test - public void testExplicitAnnotationConfiguration() { + @Test + void testExplicitAnnotationConfiguration() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); EventsManager eventsManager = EventsUtils.createEventsManager(); @@ -332,8 +339,8 @@ protected void configureQSim() { Assert.assertTrue(mockEngine.isCalled); } - @Test - public void testManualConfiguration() { + @Test + void testManualConfiguration() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); EventsManager eventsManager = EventsUtils.createEventsManager(); @@ -356,8 +363,8 @@ protected void configureQSim() { Assert.assertTrue(mockEngine.isCalled); } - @Test - public void testUseConfigGroup() { + @Test + void testUseConfigGroup() { Config config = ConfigUtils.createConfig(); QSimComponentsConfigGroup componentsConfig = new QSimComponentsConfigGroup(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/ExplicitBindingsRequiredTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/ExplicitBindingsRequiredTest.java index b7f017bbc8d..d750d1e2efc 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/ExplicitBindingsRequiredTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/ExplicitBindingsRequiredTest.java @@ -22,15 +22,14 @@ package org.matsim.core.mobsim.qsim.components.guice; import org.junit.Assert; -import org.junit.Test; - +import org.junit.jupiter.api.Test; import com.google.inject.AbstractModule; import com.google.inject.CreationException; import com.google.inject.Guice; import com.google.inject.Inject; import com.google.inject.Injector; -/** + /** * This test shows how Guice works with child injectors and explicit bindings. * In the test there is a ParentScopeObject in a parent injector. Then a child * injector is created which contains a ChildScopeObject, which has the @@ -60,8 +59,8 @@ static class OtherChildScopeObject { } - @Test - public void testExplicitBindings() { + @Test + void testExplicitBindings() { Injector injector = Guice.createInjector(new AbstractModule() { @Override protected void configure() { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/MultipleBindingsTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/MultipleBindingsTest.java index e17420704ed..b558b40965a 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/MultipleBindingsTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/MultipleBindingsTest.java @@ -22,15 +22,14 @@ package org.matsim.core.mobsim.qsim.components.guice; import org.junit.Assert; -import org.junit.Test; - +import org.junit.jupiter.api.Test; import com.google.inject.AbstractModule; import com.google.inject.Guice; import com.google.inject.Injector; import com.google.inject.Key; import com.google.inject.name.Names; -/** + /** * This test shows that Guice creates Singletons solely based on the *class * name*. So as shown in the example one can bind the same class to different * interfaces, even with different names. If the class is declared in the @@ -47,8 +46,8 @@ static class Implementation implements InterfaceA, InterfaceB { } - @Test - public void testGuiceComponentNaming() { + @Test + void testGuiceComponentNaming() { Injector injector = Guice.createInjector(new AbstractModule() { @Override protected void configure() { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/jdeqsimengine/JDEQSimPluginTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/jdeqsimengine/JDEQSimPluginTest.java index af6cfbc3aa3..ab45f904bf2 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/jdeqsimengine/JDEQSimPluginTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/jdeqsimengine/JDEQSimPluginTest.java @@ -21,8 +21,8 @@ package org.matsim.core.mobsim.qsim.jdeqsimengine; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.api.experimental.events.EventsManager; import org.matsim.core.config.ConfigUtils; @@ -33,7 +33,7 @@ import org.matsim.core.scenario.ScenarioUtils; import org.matsim.testcases.MatsimTestUtils; -/** + /** * Created by michaelzilske on 19/03/14. */ public class JDEQSimPluginTest { @@ -50,7 +50,8 @@ private QSim prepareQSim(Scenario scenario, EventsManager eventsManager) { .build(scenario, eventsManager); } - @Test public void testRunsAtAll() { + @Test + void testRunsAtAll() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); EventsManager eventsManager = EventsUtils.createEventsManager(scenario.getConfig()); eventsManager.initProcessing(); @@ -60,7 +61,8 @@ private QSim prepareQSim(Scenario scenario, EventsManager eventsManager) { qsim.run(); } - @Test public void testRunsEquil() { + @Test + void testRunsEquil() { Scenario scenario = ScenarioUtils.loadScenario(utils.loadConfig("test/scenarios/equil/config.xml")); EventsManager eventsManager = EventsUtils.createEventsManager(scenario.getConfig()); eventsManager.initProcessing(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/QSimIntegrationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/QSimIntegrationTest.java index 125ca9ac88f..b85534b5e04 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/QSimIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/QSimIntegrationTest.java @@ -26,7 +26,7 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; @@ -61,7 +61,7 @@ public class QSimIntegrationTest { @Test - public void test_twoStopsOnFirstLink() throws SAXException, ParserConfigurationException, IOException { + void test_twoStopsOnFirstLink() throws SAXException, ParserConfigurationException, IOException { Fixture f = new Fixture(); String scheduleXml = "" + "" + @@ -121,7 +121,7 @@ public void test_twoStopsOnFirstLink() throws SAXException, ParserConfigurationE } @Test - public void test_multipleStopsOnFirstLink_singleLinkRoute_noPassengers() throws SAXException, ParserConfigurationException, IOException { + void test_multipleStopsOnFirstLink_singleLinkRoute_noPassengers() throws SAXException, ParserConfigurationException, IOException { Fixture f = new Fixture(); String scheduleXml = "" + "" + @@ -184,7 +184,7 @@ public void test_multipleStopsOnFirstLink_singleLinkRoute_noPassengers() throws } @Test - public void test_multipleStopsOnFirstLink_singleLinkRoute_withPassengersAtFirstStop() throws SAXException, ParserConfigurationException, IOException { + void test_multipleStopsOnFirstLink_singleLinkRoute_withPassengersAtFirstStop() throws SAXException, ParserConfigurationException, IOException { Fixture f = new Fixture(); String scheduleXml = "" + "" + @@ -269,7 +269,7 @@ public void test_multipleStopsOnFirstLink_singleLinkRoute_withPassengersAtFirstS } @Test - public void test_multipleStopsOnFirstLink_singleLinkRoute_withPassengersAtSecondStop() throws SAXException, ParserConfigurationException, IOException { + void test_multipleStopsOnFirstLink_singleLinkRoute_withPassengersAtSecondStop() throws SAXException, ParserConfigurationException, IOException { Fixture f = new Fixture(); String scheduleXml = "" + "" + @@ -366,7 +366,7 @@ public void test_multipleStopsOnFirstLink_singleLinkRoute_withPassengersAtSecond * @throws IOException */ @Test - public void test_circularEmptyRoute_singleLinkRoute_noPassengers() throws SAXException, ParserConfigurationException, IOException { + void test_circularEmptyRoute_singleLinkRoute_noPassengers() throws SAXException, ParserConfigurationException, IOException { Fixture f = new Fixture(); String scheduleXml = "" + "" + diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitAgentTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitAgentTest.java index 3b9a0802515..6ec86bdcb5b 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitAgentTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitAgentTest.java @@ -26,7 +26,7 @@ import java.util.Arrays; import java.util.Collections; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -63,7 +63,8 @@ */ public class TransitAgentTest { - @Test public void testAcceptLineRoute() { + @Test + void testAcceptLineRoute() { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = (Network) scenario.getNetwork(); @@ -114,7 +115,8 @@ public class TransitAgentTest { assertTrue(agent.getEnterTransitRoute(line1, route1a, route1a.getStops(), null)); // offering the same line again should yield "true" } - @Test public void testArriveAtStop() { + @Test + void testArriveAtStop() { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = (Network) scenario.getNetwork(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitDriverTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitDriverTest.java index e8239c343e0..13b7f743fb8 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitDriverTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitDriverTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -78,7 +78,7 @@ public class TransitDriverTest { public MatsimTestUtils util = new MatsimTestUtils(); @Test - public void testInitializationNetworkRoute() { + void testInitializationNetworkRoute() { Config config = ConfigUtils.createConfig(); config.transit().setUseTransit(true); Scenario scenario = ScenarioUtils.createScenario(config); @@ -165,7 +165,7 @@ public void testInitializationNetworkRoute() { } @Test - public void testInitializationDeparture() { + void testInitializationDeparture() { Config config = ConfigUtils.createConfig(); config.transit().setUseTransit(true); Scenario scenario = ScenarioUtils.createScenario(config); @@ -194,7 +194,7 @@ public void testInitializationDeparture() { } @Test - public void testInitializationStops() { + void testInitializationStops() { EventsManager eventsManager = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -246,7 +246,7 @@ public void testInitializationStops() { } @Test - public void testHandleStop_EnterPassengers() { + void testHandleStop_EnterPassengers() { EventsManager eventsManager = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -351,7 +351,7 @@ public void handleEvent(Event ev) { } @Test - public void testHandleStop_ExitPassengers() { + void testHandleStop_ExitPassengers() { EventsManager eventsManager = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -418,7 +418,7 @@ public void testHandleStop_ExitPassengers() { } @Test - public void testHandleStop_CorrectIdentification() { + void testHandleStop_CorrectIdentification() { EventsManager eventsManager = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -461,7 +461,7 @@ public void testHandleStop_CorrectIdentification() { } @Test - public void testHandleStop_AwaitDepartureTime() { + void testHandleStop_AwaitDepartureTime() { EventsManager eventsManager = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -520,7 +520,7 @@ public void testHandleStop_AwaitDepartureTime() { } @Test - public void testExceptionWhenNotEmptyAfterLastStop() { + void testExceptionWhenNotEmptyAfterLastStop() { EventsManager eventsManager = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -581,7 +581,7 @@ public void testExceptionWhenNotEmptyAfterLastStop() { } @Test - public void testExceptionWhenNotAllStopsServed() { + void testExceptionWhenNotAllStopsServed() { EventsManager eventsManager = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitQueueSimulationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitQueueSimulationTest.java index d113070bae9..9424a078021 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitQueueSimulationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitQueueSimulationTest.java @@ -22,6 +22,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertThrows; import java.util.ArrayList; import java.util.Collections; @@ -30,7 +31,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -102,11 +103,11 @@ */ public class TransitQueueSimulationTest { - /** - * Ensure that for each departure an agent is created and departs - */ - @Test - public void testCreateAgents() { + /** + * Ensure that for each departure an agent is created and departs + */ + @Test + void testCreateAgents() { // setup: config final Config config = ConfigUtils.createConfig(); config.transit().setUseTransit(true); @@ -236,11 +237,11 @@ public int compare(MobsimAgent mobsimAgent, MobsimAgent mobsimAgent1) { assertEquals(9.0*3600, agents.get(4).getActivityEndTime(), MatsimTestUtils.EPSILON); } - /** - * Tests that the simulation is adding an agent correctly to the transit stop - */ - @Test - public void testAddAgentToStop() { + /** + * Tests that the simulation is adding an agent correctly to the transit stop + */ + @Test + void testAddAgentToStop() { // setup: config final Config config = ConfigUtils.createConfig(); config.transit().setUseTransit(true); @@ -301,83 +302,85 @@ public void testAddAgentToStop() { assertEquals(1, transitEngine.getAgentTracker().getAgentsAtFacility(stop1.getId()).size()); } - /** - * Tests that the simulation refuses to let an agent teleport herself by starting a transit - * leg on a link where she isn't. - * - */ - @Test(expected = TransitAgentTriesToTeleportException.class) - public void testAddAgentToStopWrongLink() { - // setup: config - final Config config = ConfigUtils.createConfig(); - config.transit().setUseTransit(true); - - MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); - - // setup: network - Network network = scenario.getNetwork(); - Node node1 = network.getFactory().createNode(Id.create("1", Node.class), new Coord((double) 0, (double) 0)); - Node node2 = network.getFactory().createNode(Id.create("2", Node.class), new Coord((double) 1000, (double) 0)); - Node node3 = network.getFactory().createNode(Id.create("3", Node.class), new Coord((double) 2000, (double) 0)); - network.addNode(node1); - network.addNode(node2); - network.addNode(node3); - Link link1 = network.getFactory().createLink(Id.create("1", Link.class), node1, node2); - Link link2 = network.getFactory().createLink(Id.create("2", Link.class), node2, node3); - setDefaultLinkAttributes(link1); - network.addLink(link1); - setDefaultLinkAttributes(link2); - network.addLink(link2); - - // setup: transit schedule - TransitSchedule schedule = scenario.getTransitSchedule(); - TransitScheduleFactory builder = schedule.getFactory(); - TransitLine line = builder.createTransitLine(Id.create("1", TransitLine.class)); - - TransitStopFacility stop1 = builder.createTransitStopFacility(Id.create("stop1", TransitStopFacility.class), new Coord((double) 0, (double) 0), false); - stop1.setLinkId(link1.getId()); - TransitStopFacility stop2 = builder.createTransitStopFacility(Id.create("stop2", TransitStopFacility.class), new Coord((double) 0, (double) 0), false); - stop2.setLinkId(link2.getId()); - schedule.addStopFacility(stop1); - schedule.addStopFacility(stop2); - - // setup: population - Population population = scenario.getPopulation(); - PopulationFactory pb = population.getFactory(); - Person person = pb.createPerson(Id.create("1", Person.class)); - Plan plan = pb.createPlan(); - person.addPlan(plan); - Activity homeAct = pb.createActivityFromLinkId("home", Id.create("2", Link.class)); - - homeAct.setEndTime(7.0*3600 - 10.0); - // as no transit line runs, make sure to stop the simulation manually. - scenario.getConfig().qsim().setEndTime(7.0*3600); - - Leg leg = pb.createLeg(TransportMode.pt); - leg.setRoute(new DefaultTransitPassengerRoute(stop1, line, null, stop2)); - Activity workAct = pb.createActivityFromLinkId("work", Id.create("1", Link.class)); - plan.addActivity(homeAct); - plan.addLeg(leg); - plan.addActivity(workAct); - population.addPerson(person); - - // run simulation - EventsManager events = EventsUtils.createEventsManager(); - PrepareForSimUtils.createDefaultPrepareForSim(scenario).run(); - new QSimBuilder(scenario.getConfig()) // - .useDefaults() // - .build(scenario, events) // - .run(); - } - - /** - * Tests that a vehicle's handleStop() method is correctly called, e.g. - * it is re-called again when returning a delay > 0, and that is is correctly - * called when the stop is located on the first link of the network route, on the last - * link of the network route, or any intermediary link. - */ - @Test - public void testHandleStop() { + /** + * Tests that the simulation refuses to let an agent teleport herself by starting a transit + * leg on a link where she isn't. + * + */ + @Test + void testAddAgentToStopWrongLink() { + assertThrows(TransitAgentTriesToTeleportException.class, () -> { + // setup: config + final Config config = ConfigUtils.createConfig(); + config.transit().setUseTransit(true); + + MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); + + // setup: network + Network network = scenario.getNetwork(); + Node node1 = network.getFactory().createNode(Id.create("1", Node.class), new Coord((double) 0, (double) 0)); + Node node2 = network.getFactory().createNode(Id.create("2", Node.class), new Coord((double) 1000, (double) 0)); + Node node3 = network.getFactory().createNode(Id.create("3", Node.class), new Coord((double) 2000, (double) 0)); + network.addNode(node1); + network.addNode(node2); + network.addNode(node3); + Link link1 = network.getFactory().createLink(Id.create("1", Link.class), node1, node2); + Link link2 = network.getFactory().createLink(Id.create("2", Link.class), node2, node3); + setDefaultLinkAttributes(link1); + network.addLink(link1); + setDefaultLinkAttributes(link2); + network.addLink(link2); + + // setup: transit schedule + TransitSchedule schedule = scenario.getTransitSchedule(); + TransitScheduleFactory builder = schedule.getFactory(); + TransitLine line = builder.createTransitLine(Id.create("1", TransitLine.class)); + + TransitStopFacility stop1 = builder.createTransitStopFacility(Id.create("stop1", TransitStopFacility.class), new Coord((double) 0, (double) 0), false); + stop1.setLinkId(link1.getId()); + TransitStopFacility stop2 = builder.createTransitStopFacility(Id.create("stop2", TransitStopFacility.class), new Coord((double) 0, (double) 0), false); + stop2.setLinkId(link2.getId()); + schedule.addStopFacility(stop1); + schedule.addStopFacility(stop2); + + // setup: population + Population population = scenario.getPopulation(); + PopulationFactory pb = population.getFactory(); + Person person = pb.createPerson(Id.create("1", Person.class)); + Plan plan = pb.createPlan(); + person.addPlan(plan); + Activity homeAct = pb.createActivityFromLinkId("home", Id.create("2", Link.class)); + + homeAct.setEndTime(7.0 * 3600 - 10.0); + // as no transit line runs, make sure to stop the simulation manually. + scenario.getConfig().qsim().setEndTime(7.0 * 3600); + + Leg leg = pb.createLeg(TransportMode.pt); + leg.setRoute(new DefaultTransitPassengerRoute(stop1, line, null, stop2)); + Activity workAct = pb.createActivityFromLinkId("work", Id.create("1", Link.class)); + plan.addActivity(homeAct); + plan.addLeg(leg); + plan.addActivity(workAct); + population.addPerson(person); + + // run simulation + EventsManager events = EventsUtils.createEventsManager(); + PrepareForSimUtils.createDefaultPrepareForSim(scenario).run(); + new QSimBuilder(scenario.getConfig()) // + .useDefaults() // + .build(scenario, events) // + .run(); + }); + } + + /** + * Tests that a vehicle's handleStop() method is correctly called, e.g. + * it is re-called again when returning a delay > 0, and that is is correctly + * called when the stop is located on the first link of the network route, on the last + * link of the network route, or any intermediary link. + */ + @Test + void testHandleStop() { // setup: config final Config config = ConfigUtils.createConfig(); config.transit().setUseTransit(true); @@ -627,8 +630,8 @@ protected SpyHandleStopData(final TransitStopFacility stopFacility, final double } } - @Test - public void testStartAndEndTime() { + @Test + void testStartAndEndTime() { final Config config = ConfigUtils.createConfig(); config.transit().setUseTransit(true); @@ -724,8 +727,8 @@ public void reset(final int iteration) { } } - @Test - public void testEvents() { + @Test + void testEvents() { final Config config = ConfigUtils.createConfig(); config.transit().setUseTransit(true); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitStopAgentTrackerTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitStopAgentTrackerTest.java index 661db42f779..fe957af3ece 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitStopAgentTrackerTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitStopAgentTrackerTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.core.api.experimental.events.EventsManager; @@ -42,7 +42,8 @@ public class TransitStopAgentTrackerTest { private static final Logger log = LogManager.getLogger(TransitStopAgentTrackerTest.class); - @Test public void testAddAgent() { + @Test + void testAddAgent() { EventsManager events = EventsUtils.createEventsManager(); TransitStopAgentTracker tracker = new TransitStopAgentTracker(events); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); @@ -67,7 +68,8 @@ public class TransitStopAgentTrackerTest { assertTrue(tracker.getAgentsAtFacility(stop2.getId()).contains(agent3)); } - @Test public void testRemoveAgent() { + @Test + void testRemoveAgent() { EventsManager events = EventsUtils.createEventsManager(); TransitStopAgentTracker tracker = new TransitStopAgentTracker(events); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); @@ -92,7 +94,8 @@ public class TransitStopAgentTrackerTest { assertEquals(1, tracker.getAgentsAtFacility(stop1.getId()).size()); // should stay the same } - @Test public void testGetAgentsAtStopImmutable() { + @Test + void testGetAgentsAtStopImmutable() { EventsManager events = EventsUtils.createEventsManager(); TransitStopAgentTracker tracker = new TransitStopAgentTracker(events); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitVehicleTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitVehicleTest.java index 33a84d1219f..dcc4082886c 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitVehicleTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitVehicleTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.pt.fakes.FakePassengerAgent; import org.matsim.testcases.MatsimTestUtils; @@ -46,7 +46,8 @@ private TransitVehicle createTransitVehicle(final Vehicle vehicle) { return new TransitQVehicle(vehicle); } - @Test public void testSizeInEquivalents() { + @Test + void testSizeInEquivalents() { VehicleType carType = VehicleUtils.createVehicleType(Id.create("carType", VehicleType.class ) ); VehicleType busType = VehicleUtils.createVehicleType(Id.create("busType", VehicleType.class ) ); busType.setPcuEquivalents(2.5); @@ -60,7 +61,8 @@ private TransitVehicle createTransitVehicle(final Vehicle vehicle) { assertEquals(2.5, veh.getSizeInEquivalents(), MatsimTestUtils.EPSILON); } - @Test public void testInitialization_SeatAndStandCapacity() { + @Test + void testInitialization_SeatAndStandCapacity() { VehicleType vehType = VehicleUtils.createVehicleType(Id.create("busType", VehicleType.class ) ); vehType.getCapacity().setSeats(Integer.valueOf(5)); vehType.getCapacity().setStandingRoom(Integer.valueOf(2)); @@ -70,7 +72,8 @@ private TransitVehicle createTransitVehicle(final Vehicle vehicle) { assertEquals(7, veh.getPassengerCapacity()); } - @Test public void testInitialization_SeatOnlyCapacity() { + @Test + void testInitialization_SeatOnlyCapacity() { VehicleType vehType = VehicleUtils.createVehicleType(Id.create("busType", VehicleType.class ) ); vehType.getCapacity().setSeats(Integer.valueOf(4)); Vehicle vehicle = VehicleUtils.createVehicle(Id.create(1976, Vehicle.class ), vehType ); @@ -79,7 +82,8 @@ private TransitVehicle createTransitVehicle(final Vehicle vehicle) { assertEquals(4, veh.getPassengerCapacity()); } - @Test public void testInitialization_NoCapacity() { + @Test + void testInitialization_NoCapacity() { VehicleType vehType = VehicleUtils.createVehicleType(Id.create("busType", VehicleType.class ) ); Vehicle vehicle = VehicleUtils.createVehicle(Id.create(1976, Vehicle.class ), vehType ); try { @@ -91,7 +95,8 @@ private TransitVehicle createTransitVehicle(final Vehicle vehicle) { } } - @Test public void testAddPassenger() { + @Test + void testAddPassenger() { VehicleType vehType = VehicleUtils.createVehicleType(Id.create("busType", VehicleType.class ) ); vehType.getCapacity().setSeats(Integer.valueOf(5)); Vehicle vehicle = VehicleUtils.createVehicle(Id.create(1976, Vehicle.class ), vehType ); @@ -111,7 +116,8 @@ private TransitVehicle createTransitVehicle(final Vehicle vehicle) { assertFalse(veh.addPassenger(new FakePassengerAgent(null))); } - @Test public void testRemovePassenger() { + @Test + void testRemovePassenger() { VehicleType vehType = VehicleUtils.createVehicleType(Id.create("busType", VehicleType.class ) ); vehType.getCapacity().setSeats(Integer.valueOf(5)); Vehicle vehicle = VehicleUtils.createVehicle(Id.create(1976, Vehicle.class ), vehType ); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java index a30dfcc609f..bf5bd5adb2c 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java @@ -29,8 +29,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -84,7 +84,8 @@ public class UmlaufDriverTest { utils.loadConfig((String)null); } - @Test public void testInitializationNetworkRoute() { + @Test + void testInitializationNetworkRoute() { TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); ArrayList> linkIds = new ArrayList>(); @@ -172,7 +173,8 @@ private Umlauf buildUmlauf(TransitLine tLine) { return new SingletonUmlaufBuilderImpl(Collections.singletonList(tLine)).build().get(0); } - @Test public void testInitializationDeparture() { + @Test + void testInitializationDeparture() { TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); NetworkRoute route = RouteUtils.createLinkNetworkRouteImpl(null, null); @@ -197,7 +199,8 @@ private Umlauf buildUmlauf(TransitLine tLine) { assertEquals(depTime, driver.getActivityEndTime(), MatsimTestUtils.EPSILON); } - @Test public void testInitializationStops() { + @Test + void testInitializationStops() { EventsManager events = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -248,7 +251,8 @@ private Umlauf buildUmlauf(TransitLine tLine) { assertEquals(null, driver.getNextTransitStop()); } - @Test public void testHandleStop_EnterPassengers() { + @Test + void testHandleStop_EnterPassengers() { EventsManager events = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -324,7 +328,8 @@ private Umlauf buildUmlauf(TransitLine tLine) { 0.0, driver.handleTransitStop(stop2, 170), MatsimTestUtils.EPSILON); } - @Test public void testHandleStop_ExitPassengers() { + @Test + void testHandleStop_ExitPassengers() { EventsManager events = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -391,7 +396,8 @@ private Umlauf buildUmlauf(TransitLine tLine) { assertEquals(0.0, driver.handleTransitStop(stop2, 160), MatsimTestUtils.EPSILON); } - @Test public void testReturnSensiblePlanElements() { + @Test + void testReturnSensiblePlanElements() { EventsManager events = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -434,7 +440,8 @@ private Umlauf buildUmlauf(TransitLine tLine) { assertTrue(driver.getCurrentPlanElement() instanceof Activity); } - @Test public void testHandleStop_CorrectIdentification() { + @Test + void testHandleStop_CorrectIdentification() { EventsManager events = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -476,7 +483,8 @@ private Umlauf buildUmlauf(TransitLine tLine) { assertEquals(tLine, agent.offeredLine); } - @Test public void testHandleStop_AwaitDepartureTime() { + @Test + void testHandleStop_AwaitDepartureTime() { EventsManager events = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); @@ -535,7 +543,8 @@ private Umlauf buildUmlauf(TransitLine tLine) { assertEquals(0.0, driver.handleTransitStop(stop3, departureTime + 210), MatsimTestUtils.EPSILON); } - @Test public void testExceptionWhenNotEmptyAfterLastStop() { + @Test + void testExceptionWhenNotEmptyAfterLastStop() { EventsManager events = EventsUtils.createEventsManager(); TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitLine tLine = builder.createTransitLine(Id.create("L", TransitLine.class)); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/DeparturesOnSameLinkSameTimeTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/DeparturesOnSameLinkSameTimeTest.java index f6af0e77d91..69911b6e800 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/DeparturesOnSameLinkSameTimeTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/DeparturesOnSameLinkSameTimeTest.java @@ -19,7 +19,7 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -60,7 +60,7 @@ public class DeparturesOnSameLinkSameTimeTest { * whereas cars should leave at a gap of one second. */ @Test - public void test4LinkEnterTimeOfCarAndBike () { + void test4LinkEnterTimeOfCarAndBike() { Id firstAgent = Id.createVehicleId(1); Id secondAgent = Id.createVehicleId(2); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/EquiDistAgentSnapshotInfoBuilderTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/EquiDistAgentSnapshotInfoBuilderTest.java index 0e9d83d72ea..21566dda480 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/EquiDistAgentSnapshotInfoBuilderTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/EquiDistAgentSnapshotInfoBuilderTest.java @@ -1,6 +1,6 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -32,8 +32,8 @@ public class EquiDistAgentSnapshotInfoBuilderTest { - @Test - public void positionVehiclesAlongLine_singleVehicleFreeFlow(){ + @Test + void positionVehiclesAlongLine_singleVehicleFreeFlow(){ var setUp = new SimpleTestSetUp(); List outCollection = new ArrayList<>(); @@ -64,8 +64,8 @@ public void positionVehiclesAlongLine_singleVehicleFreeFlow(){ assertEquals(setUp.linkLength / 2, firstEntry.getEasting(), 0.00001); } - @Test - public void positionVehiclesAlongLine_congestedAboveCapacityLimit() { + @Test + void positionVehiclesAlongLine_congestedAboveCapacityLimit() { var setUp = new SimpleTestSetUp(); List outCollection = new ArrayList<>(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowCapacityVariationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowCapacityVariationTest.java index aac8fccef3f..644fab1765f 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowCapacityVariationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowCapacityVariationTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -59,23 +59,23 @@ * @author amit */ public class FlowCapacityVariationTest { - + @Test - public void twoCarsLeavingTimes () { + void twoCarsLeavingTimes() { vehiclesLeavingSameTime(TransportMode.car,3601); } - @Test - public void twoMotorbikesTravelTime(){ + @Test + void twoMotorbikesTravelTime(){ /* linkCapacity higher than 1PCU/sec*/ vehiclesLeavingSameTime("motorbike",3601); /*link capacuty higher than 1motorbike/sec = 0.25PCU/sec */ vehiclesLeavingSameTime("motorbike",1800); } - - @Test - public void twoBikesTravelTime(){ + + @Test + void twoBikesTravelTime(){ /* linkCapacity higher than 1PCU/sec */ vehiclesLeavingSameTime(TransportMode.bike,3601); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowEfficiencyCalculatorTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowEfficiencyCalculatorTest.java index c343ec924ae..aaf251d8c0d 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowEfficiencyCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowEfficiencyCalculatorTest.java @@ -23,7 +23,7 @@ import com.google.inject.Provides; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -50,7 +50,7 @@ public class FlowEfficiencyCalculatorTest { @Test - public void testFlowEfficiencyCalculator() { + void testFlowEfficiencyCalculator() { // In this test we send 1000 vehicles over a link with capacity 500. We then // define a custom FlowEfficiencyCalculator that varies the flow efficiency // globally. We see that with infinite flow efficiency, vehicles move in diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/JavaRoundingErrorInQsimTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/JavaRoundingErrorInQsimTest.java index cf722576d5b..bf1b8ee6733 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/JavaRoundingErrorInQsimTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/JavaRoundingErrorInQsimTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -66,7 +66,7 @@ public class JavaRoundingErrorInQsimTest { @Test - public void printDecimalSum(){ + void printDecimalSum(){ double a = 0.1; double sum =0; double counter = 0; @@ -77,9 +77,9 @@ public void printDecimalSum(){ System.out.println("Sum at counter "+counter+" is "+sum); } } - + @Test - public void testToCheckTravelTime () { + void testToCheckTravelTime() { // 2 cars depart on same time, central (bottleneck) link allow only 1 agent / 10 sec. PseudoInputs net = new PseudoInputs(); net.createNetwork(360); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java index 7f1d04bc347..f72301f3fd0 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java @@ -23,8 +23,8 @@ import jakarta.inject.Inject; import jakarta.inject.Provider; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -61,7 +61,7 @@ public class LinkSpeedCalculatorIntegrationTest { @RegisterExtension private MatsimTestUtils helper = new MatsimTestUtils(); @Test - public void testIntegration_Default() { + void testIntegration_Default() { Fixture f = new Fixture(); EventsCollector collector = new EventsCollector(); f.events.addHandler(collector); @@ -90,7 +90,7 @@ public void testIntegration_Default() { @SuppressWarnings("static-method") @Test - public void testIntegration_Slow() { + void testIntegration_Slow() { Fixture f = new Fixture(); final Scenario scenario = f.scenario ; @@ -142,7 +142,7 @@ public void testIntegration_Slow() { @SuppressWarnings("static-method") @Test - public void testIntegration_Fast() { + void testIntegration_Fast() { Fixture f = new Fixture(); final Scenario scenario = f.scenario ; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java index 554b88b3059..ceac270a514 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java @@ -21,8 +21,8 @@ import java.util.*; import jakarta.inject.Inject; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -71,7 +71,7 @@ public class PassingTest { * tt_car = 50 sec; tt_bike = 200 sec */ @Test - public void test4PassingInFreeFlowState(){ + void test4PassingInFreeFlowState(){ SimpleNetwork net = new SimpleNetwork(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java index 064025f4fe1..76e0c77788b 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -134,7 +134,8 @@ private static void createThreeLanes(Scenario scenario) { lanes.addLanesToLinkAssignment(lanesForLink1); } - @Test public void testCapacityWoLanes() { + @Test + void testCapacityWoLanes() { Config config = ConfigUtils.createConfig(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); initNetwork(scenario.getNetwork()); @@ -151,7 +152,8 @@ private static void createThreeLanes(Scenario scenario) { assertEquals(268.0, ql.getSpaceCap(), 0); } - @Test public void testCapacityWithOneLaneOneLane() { + @Test + void testCapacityWithOneLaneOneLane() { Config config = ConfigUtils.createConfig(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); initNetwork(scenario.getNetwork()); @@ -186,7 +188,8 @@ private static void createThreeLanes(Scenario scenario) { assertEquals(14.0, qlane.getStorageCapacity(), 0); } - @Test public void testCapacityWithOneLaneTwoLanes() { + @Test + void testCapacityWithOneLaneTwoLanes() { Config config = ConfigUtils.createConfig(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); initNetwork(scenario.getNetwork()); @@ -222,8 +225,8 @@ private static void createThreeLanes(Scenario scenario) { } - - @Test public void testCapacityWithLanes() { + @Test + void testCapacityWithLanes() { Config config = ConfigUtils.createConfig(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); initNetwork(scenario.getNetwork()); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java index bb83c11c1d8..9ccdd910c12 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java @@ -28,8 +28,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -106,7 +106,8 @@ public static Collection parameterObjects () { } - @Test public void testInit() { + @Test + void testInit() { Fixture f = new Fixture(isUsingFastCapacityUpdate); assertNotNull(f.qlink1); assertEquals(1.0, f.qlink1.getSimulatedFlowCapacityPerTimeStep(), MatsimTestUtils.EPSILON); @@ -120,7 +121,8 @@ public static Collection parameterObjects () { } - @Test public void testAdd() { + @Test + void testAdd() { Fixture f = new Fixture(isUsingFastCapacityUpdate); assertEquals(0, ((QueueWithBuffer) f.qlink1.getAcceptingQLane()).getAllVehicles().size()); QVehicle v = new QVehicleImpl(f.basicVehicle); @@ -151,7 +153,8 @@ private static PersonDriverAgentImpl createAndInsertPersonDriverAgentImpl(Person * @author mrieser */ - @Test public void testGetVehicle_Driving() { + @Test + void testGetVehicle_Driving() { Fixture f = new Fixture(isUsingFastCapacityUpdate); Id id1 = Id.create("1", Vehicle.class); @@ -216,7 +219,8 @@ private static PersonDriverAgentImpl createAndInsertPersonDriverAgentImpl(Person * @author mrieser */ - @Test public void testGetVehicle_Parking() { + @Test + void testGetVehicle_Parking() { Fixture f = new Fixture(isUsingFastCapacityUpdate); Id id1 = Id.create("1", Vehicle.class); @@ -253,7 +257,8 @@ private static PersonDriverAgentImpl createAndInsertPersonDriverAgentImpl(Person * @author mrieser */ - @Test public void testGetVehicle_Departing() { + @Test + void testGetVehicle_Departing() { Fixture f = new Fixture(isUsingFastCapacityUpdate); Id id1 = Id.create("1", Vehicle.class); @@ -317,7 +322,8 @@ private static PersonDriverAgentImpl createAndInsertPersonDriverAgentImpl(Person * @author mrieser */ - @Test public void testBuffer() { + @Test + void testBuffer() { Config conf = utils.loadConfig((String)null); conf.qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); @@ -440,7 +446,8 @@ private static Person createPerson(Id personId, MutableScenario scenario } - @Test public void testStorageSpaceDifferentVehicleSizes() { + @Test + void testStorageSpaceDifferentVehicleSizes() { Fixture f = new Fixture(isUsingFastCapacityUpdate); @@ -541,7 +548,8 @@ private Person createPerson2(Id personId, Fixture f) { } - @Test public void testStuckEvents() { + @Test + void testStuckEvents() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); scenario.getConfig().qsim().setStuckTime(100); scenario.getConfig().qsim().setRemoveStuckVehicles(true); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QSimComponentsTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QSimComponentsTest.java index 28f2c1bd0dd..2a3cf2d781e 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QSimComponentsTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QSimComponentsTest.java @@ -1,11 +1,13 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; +import static org.junit.jupiter.api.Assertions.assertThrows; + import com.google.inject.Inject; import com.google.inject.ProvisionException; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Node; @@ -32,59 +34,65 @@ public class QSimComponentsTest{ private static final Logger log = LogManager.getLogger( QSimComponentsTest.class ); @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test(expected = RuntimeException.class) - public void testRemoveNetsimEngine() { - // test removing a default qsim module by name + @Test + void testRemoveNetsimEngine() { + assertThrows(RuntimeException.class, () -> { + // test removing a default qsim module by name - // running MATSim should fail after removing the netsim engine, since some of the routes do not have a travel time, and in consequence cannot - // be teleported if netsim engine is missing. Thus, the RuntimeException confirms that removing the module worked. + // running MATSim should fail after removing the netsim engine, since some of the routes do not have a travel time, and in consequence cannot + // be teleported if netsim engine is missing. Thus, the RuntimeException confirms that removing the module worked. - Config config = ConfigUtils.loadConfig( IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "equil" ), "config.xml" ) ); - config.controller().setOverwriteFileSetting( OutputDirectoryHierarchy.OverwriteFileSetting.deleteDirectoryIfExists ); - config.controller().setLastIteration( 0 ); - config.controller().setOutputDirectory(utils.getOutputDirectory()); + Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); + config.controller().setOverwriteFileSetting(OutputDirectoryHierarchy.OverwriteFileSetting.deleteDirectoryIfExists); + config.controller().setLastIteration(0); + config.controller().setOutputDirectory(utils.getOutputDirectory()); - // remove the module: (There is also syntax at some intermediate level for this, but I prefer the syntax at config level. kai, oct'22) - QSimComponentsConfigGroup componentsConfig = ConfigUtils.addOrGetModule( config, QSimComponentsConfigGroup.class ); - List components = componentsConfig.getActiveComponents(); - components.remove( QNetsimEngineModule.COMPONENT_NAME ); - componentsConfig.setActiveComponents( components ); + // remove the module: (There is also syntax at some intermediate level for this, but I prefer the syntax at config level. kai, oct'22) + QSimComponentsConfigGroup componentsConfig = ConfigUtils.addOrGetModule(config, QSimComponentsConfigGroup.class); + List components = componentsConfig.getActiveComponents(); + components.remove(QNetsimEngineModule.COMPONENT_NAME); + componentsConfig.setActiveComponents(components); - Scenario scenario = ScenarioUtils.loadScenario( config ); + Scenario scenario = ScenarioUtils.loadScenario(config); - Controler controler = new Controler( scenario ); + Controler controler = new Controler( scenario ); - controler.run(); + controler.run(); + }); } - @Test(expected= ProvisionException.class) - public void testReplaceQNetworkFactory() { - // here we try to replace the QNetworkFactory. Complains that QNetworkFactory is bound multiple times. - - Config config = ConfigUtils.loadConfig( IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "equil" ), "config.xml" ) ); - config.controller().setOverwriteFileSetting( OutputDirectoryHierarchy.OverwriteFileSetting.deleteDirectoryIfExists ); - config.controller().setLastIteration( 0 ); - config.controller().setOutputDirectory(utils.getOutputDirectory()); - - Scenario scenario = ScenarioUtils.loadScenario( config ); - - Controler controler = new Controler( scenario ); - - controler.addOverridingModule( new AbstractModule(){ - @Override public void install(){ - this.installQSimModule( new AbstractQSimModule(){ - @Override protected void configureQSim(){ - bind( QNetworkFactory.class ).to( MyNetworkFactory.class ); - } - } ); - } - } ); - - controler.run(); + @Test + void testReplaceQNetworkFactory() { + assertThrows(ProvisionException.class, () -> { + // here we try to replace the QNetworkFactory. Complains that QNetworkFactory is bound multiple times. + + Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); + config.controller().setOverwriteFileSetting(OutputDirectoryHierarchy.OverwriteFileSetting.deleteDirectoryIfExists); + config.controller().setLastIteration(0); + config.controller().setOutputDirectory(utils.getOutputDirectory()); + + Scenario scenario = ScenarioUtils.loadScenario(config); + + Controler controler = new Controler( scenario ); + + controler.addOverridingModule(new AbstractModule(){ + @Override + public void install() { + this.installQSimModule(new AbstractQSimModule(){ + @Override + protected void configureQSim() { + bind(QNetworkFactory.class).to(MyNetworkFactory.class); + } + }); + } + }); + + controler.run(); + }); } @Test - public void testReplaceQNetworkFactory2() { + void testReplaceQNetworkFactory2() { // here we try to replace the QNetworkFactory at AbstractQSimModule. This works. Config config = ConfigUtils.loadConfig( IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "equil" ), "config.xml" ) ); @@ -106,7 +114,7 @@ public void testReplaceQNetworkFactory2() { } @Test - public void testOverridingQSimModule() { + void testOverridingQSimModule() { // use the newly implemented install _overriding_ qsim module. With this, replacing the QNetworkFactory now works as part of AbstractModule. Config config = ConfigUtils.loadConfig( IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "equil" ), "config.xml" ) ); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QueueAgentSnapshotInfoBuilderTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QueueAgentSnapshotInfoBuilderTest.java index ae07ea71565..325ef2996c1 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QueueAgentSnapshotInfoBuilderTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QueueAgentSnapshotInfoBuilderTest.java @@ -1,6 +1,6 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -32,8 +32,8 @@ public class QueueAgentSnapshotInfoBuilderTest { - @Test - public void positionVehiclesAlongLine_singleVehicleFreeFlow() { + @Test + void positionVehiclesAlongLine_singleVehicleFreeFlow() { var setUp = new SimpleTestSetUp(); List outCollection = new ArrayList<>(); @@ -73,8 +73,8 @@ public void positionVehiclesAlongLine_singleVehicleFreeFlow() { assertEquals(AgentSnapshotInfo.AgentState.PERSON_DRIVING_CAR, firstEntry.getAgentState()); } - @Test - public void positionVehiclesAlongLine_congestedAboveCapacityLimit() { + @Test + void positionVehiclesAlongLine_congestedAboveCapacityLimit() { var setUp = new SimpleTestSetUp(); List outCollection = new ArrayList<>(); @@ -111,8 +111,8 @@ public void positionVehiclesAlongLine_congestedAboveCapacityLimit() { } } - @Test - public void positionVehiclesAlongLine_queueAtEnd() { + @Test + void positionVehiclesAlongLine_queueAtEnd() { var setUp = new SimpleTestSetUp(); // use other vehicle list than in simple set up @@ -180,8 +180,8 @@ private static void assertStackedPositions(Collection positio } } - @Test - public void positionAgentsInActivities() { + @Test + void positionAgentsInActivities() { var setUp = new SimpleTestSetUp(); List outCollection = new ArrayList<>(); @@ -197,8 +197,8 @@ public void positionAgentsInActivities() { } - @Test - public void positionVehiclesFromWaitingList() { + @Test + void positionVehiclesFromWaitingList() { var setUp = new SimpleTestSetUp(); List outCollection = new ArrayList<>(); @@ -218,8 +218,8 @@ public void positionVehiclesFromWaitingList() { outCollection.forEach(position -> assertEquals(Id.createVehicleId(1), position.getVehicleId())); } - @Test - public void positionVehiclesFromTransitStop() { + @Test + void positionVehiclesFromTransitStop() { var setUp = new SimpleTestSetUp(); List outCollection = new ArrayList<>(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/RunConfigurableQNetworkFactoryExampleTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/RunConfigurableQNetworkFactoryExampleTest.java index 958ba50b9ea..57751c8381a 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/RunConfigurableQNetworkFactoryExampleTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/RunConfigurableQNetworkFactoryExampleTest.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.core.mobsim.qsim.qnetsimengine; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.controler.OutputDirectoryHierarchy.OverwriteFileSetting; @@ -34,7 +34,7 @@ public class RunConfigurableQNetworkFactoryExampleTest { */ @SuppressWarnings("static-method") @Test - public final void testMain() { + final void testMain() { try { Config config = ConfigUtils.createConfig() ; config.controller().setOverwriteFileSetting( OverwriteFileSetting.deleteDirectoryIfExists ); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java index 4002e1b4cbb..6a18868b17d 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -75,7 +75,7 @@ public static Collection parameterObjects () { Object [] capacityUpdates = new Object [] { false, true }; return Arrays.asList(capacityUpdates); } - + /** * Two carAgents end act at time 948 and 949 sec and walkAgent ends act at 49 sec. * Link length is 1 km and flow capacity 1 PCU/min. Speed of car and walk is 20 mps and 1 mps. @@ -83,8 +83,8 @@ public static Collection parameterObjects () { * WalkAgent joins queue at 1050 sec but leave link before second car at 1060 sec and thus blocking link for another 6 sec(flowCap*PCU) * Thus, second car leaves link after walkAgent. */ - @Test - public void seepageOfWalkInCongestedRegime(){ + @Test + void seepageOfWalkInCongestedRegime(){ SimpleNetwork net = new SimpleNetwork(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java index 01ee89e122e..92e225da500 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java @@ -27,8 +27,8 @@ import java.util.HashMap; import java.util.Map; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -207,7 +207,8 @@ private static void initPopulation(Population population) { * test simulated capacity of link 1 in case without lanes. * the capacity should correspond to the given flow capacity of the link */ - @Test public void testCapacityWoLanes() { + @Test + void testCapacityWoLanes() { Config config = ConfigUtils.createConfig(); ActivityParams dummyAct = new ActivityParams("dummy"); dummyAct.setTypicalDuration(12 * 3600); @@ -234,7 +235,8 @@ private static void initPopulation(Population population) { * test simulated capacities of link 1 in case of one lane representing one lane. * the capacity of the link should correspond to the capacity of the lane, also when it is less than the link capacity given in the network. */ - @Test public void testCapacityWithOneLaneOneLane() { + @Test + void testCapacityWithOneLaneOneLane() { Config config = ConfigUtils.createConfig(); ActivityParams dummyAct = new ActivityParams("dummy"); dummyAct.setTypicalDuration(12 * 3600); @@ -265,7 +267,8 @@ private static void initPopulation(Population population) { * test simulated capacities of link 1 in case of one lane representing two lanes. * the capacity of the link should correspond to the capacity of the lane, also when it is less than the link capacity given in the network. */ - @Test public void testCapacityWithOneLaneTwoLanes() { + @Test + void testCapacityWithOneLaneTwoLanes() { Config config = ConfigUtils.createConfig(); ActivityParams dummyAct = new ActivityParams("dummy"); dummyAct.setTypicalDuration(12 * 3600); @@ -297,7 +300,8 @@ private static void initPopulation(Population population) { * Interestingly, it also corresponds to this sum, if it is more than the link capacity given in the network. * And, finally, it still only uses the lane capacity given in the network, when it is higher than the link capacity (see lane 2 here). */ - @Test public void testCapacityWithThreeLanes() { + @Test + void testCapacityWithThreeLanes() { Config config = ConfigUtils.createConfig(); ActivityParams dummyAct = new ActivityParams("dummy"); dummyAct.setTypicalDuration(12 * 3600); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java index dcef567b287..cc4b76d055c 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java @@ -1,8 +1,8 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; import com.google.inject.Singleton; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -37,7 +37,8 @@ public class SpeedCalculatorTest{ private final Config config = ConfigUtils.createConfig(); private final Network unusedNetwork = NetworkUtils.createNetwork(); - @Test public void limitedByVehicleSpeed() { + @Test + void limitedByVehicleSpeed() { Link link = createLinkWithNoGradientAndNoSpecialSurface(); VehicleType type = VehicleUtils.createVehicleType(Id.create("no-bike", VehicleType.class ) ); type.setMaximumVelocity(link.getFreespeed() / 2); // less than the link's freespeed @@ -48,7 +49,9 @@ public class SpeedCalculatorTest{ assertEquals( type.getMaximumVelocity(), getSpeedOnLink( link, vehicle ), 0.0 ); } - @Test public void limitedByLinkSpeed() { + + @Test + void limitedByLinkSpeed() { Link link = createLinkWithNoGradientAndNoSpecialSurface(); @@ -61,7 +64,9 @@ public class SpeedCalculatorTest{ assertEquals( link.getFreespeed(), getSpeedOnLink( link, vehicle ), 0.0 ); } - @Test public void bikeWithSpecificLinkSpeedCalculator() { + + @Test + void bikeWithSpecificLinkSpeedCalculator() { Link link = createLinkWithNoGradientAndNoSpecialSurface(); @@ -76,7 +81,9 @@ public class SpeedCalculatorTest{ assertEquals( type.getMaximumVelocity()*1.5, getSpeedOnLink( link, vehicle ), 0.0 ); // (specific link speed calculator uses speed that is larger than maximum vehicle speed) } - @Test public void bikeLimitedByLinkFreespeed() { + + @Test + void bikeLimitedByLinkFreespeed() { Link link = createLinkWithNoGradientAndNoSpecialSurface(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java index bb7c940987c..765d3875106 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java @@ -20,7 +20,7 @@ import java.util.*; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -77,9 +77,9 @@ public static Collection createFds() { }; return Arrays.asList(vehSpeeds); } - - @Test - public void testVehicleSpeed(){ + + @Test + void testVehicleSpeed(){ SimpleNetwork net = new SimpleNetwork(); Id id = Id.createPersonId(0); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java index 6919f8f020c..b258f338ef5 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java @@ -24,8 +24,8 @@ import java.util.Arrays; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -61,7 +61,7 @@ public class VehicleHandlerTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testVehicleHandler() { + void testVehicleHandler() { // This is a test where there is a link with a certain parking capacity. As soon // as // it is reached the link is blocking, until a vehicle is leaving the link diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleWaitingTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleWaitingTest.java index c8b0231e2c5..133dd1d9ed9 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleWaitingTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleWaitingTest.java @@ -26,7 +26,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -66,22 +66,22 @@ public class VehicleWaitingTest { @Test - public void testVehicleWaitingOneLapDoesntFailNoDummies() { + void testVehicleWaitingOneLapDoesntFailNoDummies() { testVehicleWaitingDoesntFail( 1 , false ); } @Test - public void testVehicleWaitingOneLapDoesntFailDummies() { + void testVehicleWaitingOneLapDoesntFailDummies() { testVehicleWaitingDoesntFail( 1 , true ); } @Test - public void testVehicleWaitingSeveralLapDoesntFailNoDummies() { + void testVehicleWaitingSeveralLapDoesntFailNoDummies() { testVehicleWaitingDoesntFail( 4 , false ); } @Test - public void testVehicleWaitingSeveralLapDoesntFailDummies() { + void testVehicleWaitingSeveralLapDoesntFailDummies() { testVehicleWaitingDoesntFail( 4 , true ); } diff --git a/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java b/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java index 7391d0b4d2f..33464907505 100644 --- a/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java @@ -34,8 +34,8 @@ import java.util.Set; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -93,19 +93,23 @@ public abstract class AbstractNetworkWriterReaderTest { */ protected abstract void readNetwork(final Scenario scenario, final InputStream stream); - @Test public void testAllowedModes_multipleModes() { + @Test + void testAllowedModes_multipleModes() { doTestAllowedModes(createHashSet("bus", "train"), utils.getOutputDirectory() + "network.xml"); } - @Test public void testAllowedModes_singleMode() { + @Test + void testAllowedModes_singleMode() { doTestAllowedModes(createHashSet("miv"), utils.getOutputDirectory() + "network.xml"); } - @Test public void testAllowedModes_noMode() { + @Test + void testAllowedModes_noMode() { doTestAllowedModes(new HashSet(), utils.getOutputDirectory() + "network.xml"); } - @Test public void testNodes_withoutElevation(){ + @Test + void testNodes_withoutElevation(){ List nodes = new ArrayList<>(2); Node n1 = NetworkUtils.createNode( Id.create("1", Node.class), @@ -118,7 +122,8 @@ public abstract class AbstractNetworkWriterReaderTest { doTestNodes(nodes, utils.getOutputDirectory() + "network.xml"); } - @Test public void testNodes_withElevation(){ + @Test + void testNodes_withElevation(){ List nodes = new ArrayList<>(2); Node n1 = NetworkUtils.createNode( Id.create("1", Node.class), @@ -131,7 +136,8 @@ public abstract class AbstractNetworkWriterReaderTest { doTestNodes(nodes, utils.getOutputDirectory() + "network.xml"); } - @Test public void testNodes_withAndWithoutElevation(){ + @Test + void testNodes_withAndWithoutElevation(){ List nodes = new ArrayList<>(2); Node n1 = NetworkUtils.createNode( Id.create("1", Node.class), @@ -144,7 +150,8 @@ public abstract class AbstractNetworkWriterReaderTest { doTestNodes(nodes, utils.getOutputDirectory() + "network.xml"); } - @Test public void testNodes_IdSpecialCharacters() { + @Test + void testNodes_IdSpecialCharacters() { Network network1 = NetworkUtils.createNetwork(); NetworkFactory nf = network1.getFactory(); Node nodeA1 = nf.createNode(Id.create("A & 1 \"'aa", Node.class), new Coord(100, 200)); @@ -162,7 +169,8 @@ public abstract class AbstractNetworkWriterReaderTest { Assert.assertNotSame(nodeB1, nodeB2); } - @Test public void testLinks_IdSpecialCharacters() { + @Test + void testLinks_IdSpecialCharacters() { Network network1 = NetworkUtils.createNetwork(); NetworkFactory nf = network1.getFactory(); Node nodeA1 = nf.createNode(Id.create("A & 1 \"'aa", Node.class), new Coord(100, 200)); @@ -190,7 +198,8 @@ public abstract class AbstractNetworkWriterReaderTest { // Assert.assertEquals(NetworkUtils.getOrigId(linkB1), NetworkUtils.getOrigId(linkB2)); // origId is not supported anymore in v2 } - @Test public void testNetwork_NameSpecialCharacters() { + @Test + void testNetwork_NameSpecialCharacters() { Network network1 = NetworkUtils.createNetwork(); network1.setName("Special & characters < are > in \" this ' name."); NetworkFactory nf = network1.getFactory(); diff --git a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java index f48d85ecc6b..c4e230ce20f 100644 --- a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java +++ b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java @@ -8,8 +8,8 @@ import java.util.Map; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Coord; @@ -27,7 +27,7 @@ public class DisallowedNextLinksTest { public File tempFolder; @Test - public void testEquals() { + void testEquals() { DisallowedNextLinks dnl0 = new DisallowedNextLinks(); DisallowedNextLinks dnl1 = new DisallowedNextLinks(); dnl0.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1"))); @@ -43,13 +43,13 @@ public void testEquals() { } @Test - public void testIsEmpty() { + void testIsEmpty() { DisallowedNextLinks dnl= new DisallowedNextLinks(); Assert.assertTrue(dnl.isEmpty()); } @Test - public void testAdding() { + void testAdding() { DisallowedNextLinks dnl = new DisallowedNextLinks(); dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1"))); dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"))); @@ -62,7 +62,7 @@ public void testAdding() { } @Test - public void testRemoving() { + void testRemoving() { DisallowedNextLinks dnl = new DisallowedNextLinks(); dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1"))); dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"))); @@ -76,7 +76,7 @@ public void testRemoving() { } @Test - public void testNotAddingDuplicates() { + void testNotAddingDuplicates() { DisallowedNextLinks dnl = new DisallowedNextLinks(); Assert.assertTrue(dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1")))); @@ -85,21 +85,21 @@ public void testNotAddingDuplicates() { } @Test - public void testNotAddingEmpty() { + void testNotAddingEmpty() { DisallowedNextLinks dnl = new DisallowedNextLinks(); Assert.assertFalse(dnl.addDisallowedLinkSequence("car", Collections.emptyList())); } @Test - public void testNotAddingSequenceWithDuplicates() { + void testNotAddingSequenceWithDuplicates() { DisallowedNextLinks dnl = new DisallowedNextLinks(); Assert.assertFalse(dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("0")))); } @Test - public void testEqualAndHashCode() { + void testEqualAndHashCode() { DisallowedNextLinks dnl0 = new DisallowedNextLinks(); dnl0.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1"))); dnl0.addDisallowedLinkSequence("car", List.of(Id.createLinkId("4"), Id.createLinkId("5"))); @@ -112,7 +112,7 @@ public void testEqualAndHashCode() { } @Test - public void testSerialization() { + void testSerialization() { DisallowedNextLinks dnl0 = new DisallowedNextLinks(); dnl0.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("3"))); dnl0.addDisallowedLinkSequence("car", @@ -130,7 +130,7 @@ public void testSerialization() { } @Test - public void testNetworkWritingAndReading() throws IOException { + void testNetworkWritingAndReading() throws IOException { Network n = createNetwork(); Link l1 = n.getLinks().get(Id.createLinkId("1")); diff --git a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksUtilsTest.java b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksUtilsTest.java index 494314c5f6a..42ea61a6022 100644 --- a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksUtilsTest.java @@ -4,7 +4,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -14,12 +14,12 @@ public class DisallowedNextLinksUtilsTest { Network n = DisallowedNextLinksTest.createNetwork(); @Test - public void testNoDisallowedNextLinks() { + void testNoDisallowedNextLinks() { Assert.assertTrue(DisallowedNextLinksUtils.isValid(n)); } @Test - public void testIsNotValid1() { + void testIsNotValid1() { Map, ? extends Link> links = n.getLinks(); Link l1 = links.get(Id.createLinkId("1")); Link l3 = links.get(Id.createLinkId("3")); @@ -32,7 +32,7 @@ public void testIsNotValid1() { } @Test - public void testIsNotValid2() { + void testIsNotValid2() { Map, ? extends Link> links = n.getLinks(); Link l1 = links.get(Id.createLinkId("1")); Link l3 = links.get(Id.createLinkId("3")); @@ -45,7 +45,7 @@ public void testIsNotValid2() { } @Test - public void testIsValid() { + void testIsValid() { Map, ? extends Link> links = n.getLinks(); Link l1 = links.get(Id.createLinkId("1")); Link l3 = links.get(Id.createLinkId("3")); diff --git a/matsim/src/test/java/org/matsim/core/network/LinkImplTest.java b/matsim/src/test/java/org/matsim/core/network/LinkImplTest.java index 13c944bd144..26257dffe0a 100644 --- a/matsim/src/test/java/org/matsim/core/network/LinkImplTest.java +++ b/matsim/src/test/java/org/matsim/core/network/LinkImplTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -47,7 +47,7 @@ public class LinkImplTest { @Test - public void testCalcDistance() { + void testCalcDistance() { /* create a sample network: * * (3)---3---(4) @@ -180,7 +180,7 @@ public void testCalcDistance() { } @Test - public void testSetAttributes() { + void testSetAttributes() { Network network = new NetworkImpl(new LinkFactoryImpl()); network.setCapacityPeriod(3600.0); Node node1 = NetworkUtils.createAndAddNode(network, Id.create(1, Node.class), new Coord((double) 0, (double) 0)); @@ -200,7 +200,7 @@ public void testSetAttributes() { * */ @Test - public void testAllowedModes() { + void testAllowedModes() { Network network = new NetworkImpl(new LinkFactoryImpl()); Node n1 = NetworkUtils.createAndAddNode(network, Id.create(1, Node.class), new Coord((double) 0, (double) 0)); Node n2 = NetworkUtils.createAndAddNode(network, Id.create(2, Node.class), new Coord((double) 1000, (double) 0)); @@ -233,7 +233,7 @@ public void testAllowedModes() { @Test - public void testHashSetCache_get_unmodifiable() { + void testHashSetCache_get_unmodifiable() { Set s1 = new TreeSet(); s1.add("A"); s1.add("B"); @@ -258,14 +258,14 @@ public void testHashSetCache_get_unmodifiable() { @Test - public void testHashSetCache_get_null() { + void testHashSetCache_get_null() { Set s = HashSetCache.get((Set) null); Assert.assertNull(s); } @Test - public void testHashSetCache_get_emptySet() { + void testHashSetCache_get_emptySet() { Set s = HashSetCache.get(new TreeSet()); Assert.assertNotNull(s); Assert.assertEquals(0, s.size()); @@ -273,7 +273,7 @@ public void testHashSetCache_get_emptySet() { @Test - public void testHashSetCache_get() { + void testHashSetCache_get() { Set s1 = new TreeSet(); s1.add("A"); s1.add("B"); @@ -312,7 +312,7 @@ public void testHashSetCache_get() { @Test - public void testHashSetCache_get_identicalObjects() { + void testHashSetCache_get_identicalObjects() { Set s1 = new TreeSet(); s1.add("A"); s1.add("B"); diff --git a/matsim/src/test/java/org/matsim/core/network/LinkQuadTreeTest.java b/matsim/src/test/java/org/matsim/core/network/LinkQuadTreeTest.java index 6c2a92fa703..897e0d47506 100644 --- a/matsim/src/test/java/org/matsim/core/network/LinkQuadTreeTest.java +++ b/matsim/src/test/java/org/matsim/core/network/LinkQuadTreeTest.java @@ -22,7 +22,7 @@ package org.matsim.core.network; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -32,13 +32,13 @@ import org.matsim.core.config.ConfigUtils; import org.matsim.core.scenario.ScenarioUtils; -/** + /** * @author mrieser / senozon */ public class LinkQuadTreeTest { - @Test - public void testGetNearest() { + @Test + void testGetNearest() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -68,8 +68,8 @@ public void testGetNearest() { Assert.assertEquals(c, qt.getNearest(1205, 1101)); } - @Test - public void testGetNearest_longNear_smallFarAway() { + @Test + void testGetNearest_longNear_smallFarAway() { /* * Test the following constellation: @@ -98,9 +98,9 @@ public void testGetNearest_longNear_smallFarAway() { Assert.assertEquals(b, qt.getNearest(300, 210)); // outside of segment (1)-(2), thus (3)-(4) is closer Assert.assertEquals(a, qt.getNearest(400, 210)); // distance to (1) is smaller than to (3)-(4) } - - @Test - public void testPut_zeroLengthLink() { + + @Test + void testPut_zeroLengthLink() { /* * Test the following constellation: * @@ -144,8 +144,8 @@ public void testPut_zeroLengthLink() { Assert.assertEquals(l13, qt.getNearest(100, 800)); } - @Test - public void testPut_zeroLengthLink_negativeCoords() { + @Test + void testPut_zeroLengthLink_negativeCoords() { /* Same as test above, but with negative coords */ @@ -169,8 +169,8 @@ public void testPut_zeroLengthLink_negativeCoords() { Assert.assertEquals(l13, qt.getNearest(-100, -800)); } - @Test - public void testRemove() { + @Test + void testRemove() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); LinkQuadTree qt = new LinkQuadTree(0, 0, 1000, 1000); @@ -189,11 +189,11 @@ public void testRemove() { Assert.assertEquals(l23, qt.getNearest(100, 800)); } - /** - * Test for MATSIM-687: links not stored in top-node are not removed - */ - @Test - public void testRemove_inSubNode() { + /** + * Test for MATSIM-687: links not stored in top-node are not removed + */ + @Test + void testRemove_inSubNode() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); LinkQuadTree qt = new LinkQuadTree(0, 0, 1000, 1000); diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java index 44479f38383..f3d135ce74e 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java @@ -21,8 +21,8 @@ package org.matsim.core.network; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -40,6 +40,7 @@ import static org.hamcrest.core.IsCollectionContaining.hasItem; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertThat; +import static org.junit.jupiter.api.Assertions.assertThrows; public class NetworkChangeEventsParserWriterTest { @@ -47,7 +48,7 @@ public class NetworkChangeEventsParserWriterTest { private MatsimTestUtils utils = new MatsimTestUtils() ; @Test - public void testChangeEventsParserWriter() { + void testChangeEventsParserWriter() { String input = utils.getInputDirectory() + "testNetworkChangeEvents.xml"; String output = utils.getOutputDirectory() + "outputTestNetworkChangeEvents.xml"; final Network network = new NetworkImpl(new VariableIntervalTimeVariantLinkFactory()); @@ -67,19 +68,21 @@ public void testChangeEventsParserWriter() { assertEquals(checksum_ref, checksum_run); } - @Test(expected = Exception.class) - public void testWriteChangeEventWithoutLinkDoesntWork() { - final String fileName = utils.getOutputDirectory() + "wurst.xml"; - - List events = new ArrayList<>(); - final NetworkChangeEvent e = new NetworkChangeEvent(0.0); - e.setFlowCapacityChange(new NetworkChangeEvent.ChangeValue(NetworkChangeEvent.ChangeType.ABSOLUTE_IN_SI_UNITS, 10)); - events.add(e); - new NetworkChangeEventsWriter().write(fileName, events); + @Test + void testWriteChangeEventWithoutLinkDoesntWork() { + assertThrows(Exception.class, () -> { + final String fileName = utils.getOutputDirectory() + "wurst.xml"; + + List events = new ArrayList<>(); + final NetworkChangeEvent e = new NetworkChangeEvent(0.0); + e.setFlowCapacityChange(new NetworkChangeEvent.ChangeValue(NetworkChangeEvent.ChangeType.ABSOLUTE_IN_SI_UNITS, 10)); + events.add(e); + new NetworkChangeEventsWriter().write(fileName, events); + }); } @Test - public void testWriteChangeEventWithSmallValueAndReadBack() { + void testWriteChangeEventWithSmallValueAndReadBack() { final String fileName = utils.getOutputDirectory() + "wurst.xml"; final Network network = NetworkUtils.createNetwork(); @@ -101,8 +104,9 @@ public void testWriteChangeEventWithSmallValueAndReadBack() { assertThat(inputEvents, hasItem(event)); } - @Test // see MATSIM-770 - public void testWriteReadZeroChangeEvents() { + // see MATSIM-770 + @Test + void testWriteReadZeroChangeEvents() { final String fileName = this.utils.getOutputDirectory() + "zeroChanges.xml"; List changeEvents = new ArrayList<>(); new NetworkChangeEventsWriter().write(fileName, changeEvents); @@ -116,7 +120,7 @@ public void testWriteReadZeroChangeEvents() { } @Test - public void testAbsoluteChangeEvents() { + void testAbsoluteChangeEvents() { final Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createAndAddNode(network, Id.create("2", Node.class), new Coord((double) 0, (double) 1000)); @@ -144,7 +148,7 @@ public void testAbsoluteChangeEvents() { } @Test - public void testScaleFactorChangeEvents() { + void testScaleFactorChangeEvents() { final Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createAndAddNode(network, Id.create("2", Node.class), new Coord((double) 0, (double) 1000)); @@ -172,7 +176,7 @@ public void testScaleFactorChangeEvents() { } @Test - public void testPositiveOffsetChangeEvents() { + void testPositiveOffsetChangeEvents() { final Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createAndAddNode(network, Id.create("2", Node.class), new Coord((double) 0, (double) 1000)); @@ -200,7 +204,7 @@ public void testPositiveOffsetChangeEvents() { } @Test - public void testNegativeOffsetChangeEvents() { + void testNegativeOffsetChangeEvents() { final Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createAndAddNode(network, Id.create("2", Node.class), new Coord((double) 0, (double) 1000)); diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkCollectorTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkCollectorTest.java index e9516aaad85..36184ddc30d 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkCollectorTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkCollectorTest.java @@ -1,6 +1,6 @@ package org.matsim.core.network; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Network; import org.matsim.api.core.v01.network.Node; @@ -21,8 +21,8 @@ private static Network getNetworkFromExample() { return network; } - @Test - public void testWithSequentialStream() { + @Test + void testWithSequentialStream() { var network = getNetworkFromExample(); @@ -32,8 +32,8 @@ public void testWithSequentialStream() { assertTrue(NetworkUtils.compare(network, collectedNetwork)); } - @Test - public void testWithParallelStream() { + @Test + void testWithParallelStream() { var network = getNetworkFromExample(); @@ -43,8 +43,8 @@ public void testWithParallelStream() { assertTrue(NetworkUtils.compare(network, collectedNetwork)); } - @Test - public void testWithFilter() { + @Test + void testWithFilter() { var network = getNetworkFromExample(); // choose link 73 because both of its nodes have multiple in and out links diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkImplTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkImplTest.java index f5da909f975..1a4de57b8aa 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkImplTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkImplTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.AbstractNetworkTest; @@ -44,12 +44,12 @@ public class NetworkImplTest extends AbstractNetworkTest { public Network getEmptyTestNetwork() { return new NetworkImpl(new LinkFactoryImpl()); } - + /** * Tests if the default values of a network instance are the same as the defaults specified in the network_v1.dtd */ @Test - public void testDefaultValues(){ + void testDefaultValues(){ Network net = new NetworkImpl(new LinkFactoryImpl()); Assert.assertEquals(7.5, net.getEffectiveCellSize(), 0.0); Assert.assertEquals(3.75, net.getEffectiveLaneWidth(), 0.0); @@ -72,7 +72,7 @@ public void testDefaultValues(){ * second time. */ @Test - public void testAddLink_existingId() { + void testAddLink_existingId() { Network network = new NetworkImpl(new LinkFactoryImpl()); Node node1 = NetworkUtils.createNode(Id.create(1, Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createNode(Id.create(2, Node.class), new Coord((double) 1000, (double) 0)); @@ -102,14 +102,14 @@ public void testAddLink_existingId() { network.addLink(link2); // adding the same link again should just be ignored Assert.assertEquals(2, network.getLinks().size()); } - + /** * Tests that if a link is added when its associated nodes are not in the network, * an exception is thrown. If the node is already in the network, no exception * should be thrown. */ @Test - public void testAddLink_noNodes(){ + void testAddLink_noNodes(){ Network n = NetworkUtils.createNetwork(); Node a = n.getFactory().createNode(Id.create("a", Node.class), new Coord(0.0, 0.0)); Node b = n.getFactory().createNode(Id.create("b", Node.class), new Coord(1000.0, 0.0)); @@ -156,9 +156,9 @@ public void testAddLink_noNodes(){ } } - + @Test - public void testAddNode_existingId() { + void testAddNode_existingId() { Network network = new NetworkImpl(new LinkFactoryImpl()); Node node1 = NetworkUtils.createNode(Id.create(1, Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createNode(Id.create(2, Node.class), new Coord((double) 1000, (double) 0)); @@ -180,14 +180,14 @@ public void testAddNode_existingId() { network.addNode(node3); Assert.assertEquals(3, network.getNodes().size()); } - + /** * MATSIM-278, 10jun2015: adding a node if quadtree only contained one node * * @author mrieser / Senozon AG */ @Test - public void testAddNode_singleNodeFirstOnly() { + void testAddNode_singleNodeFirstOnly() { Network network = new NetworkImpl(new LinkFactoryImpl()); Node node1 = NetworkUtils.createNode(Id.create(1, Node.class), new Coord((double) 500, (double) 400)); Node node2 = NetworkUtils.createNode(Id.create(2, Node.class), new Coord((double) 600, (double) 500)); @@ -210,7 +210,7 @@ public void testAddNode_singleNodeFirstOnly() { * @author droeder / Senozon Deutschland GmbH */ @Test - public void testAddTwoNodes_initializedEmptyQuadtree() { + void testAddTwoNodes_initializedEmptyQuadtree() { Network network = new NetworkImpl(new LinkFactoryImpl()); Node node1 = NetworkUtils.createNode(Id.create(1, Node.class), new Coord((double) 500, (double) 400)); Node node2 = NetworkUtils.createNode(Id.create(2, Node.class), new Coord((double) 600, (double) 500)); @@ -231,7 +231,7 @@ public void testAddTwoNodes_initializedEmptyQuadtree() { } @Test - public void testRemoveLink_alsoInQuadTrees() { + void testRemoveLink_alsoInQuadTrees() { Network network = new NetworkImpl(new LinkFactoryImpl()); Node node1 = NetworkUtils.createNode(Id.create(1, Node.class), new Coord(100, 100)); Node node2 = NetworkUtils.createNode(Id.create(2, Node.class), new Coord(1000, 200)); @@ -269,7 +269,7 @@ public void testRemoveLink_alsoInQuadTrees() { } @Test - public void testAddLink_alsoInQuadTrees() { + void testAddLink_alsoInQuadTrees() { Network network = new NetworkImpl(new LinkFactoryImpl()); Node node1 = NetworkUtils.createNode(Id.create(1, Node.class), new Coord(100, 100)); Node node2 = NetworkUtils.createNode(Id.create(2, Node.class), new Coord(1000, 200)); @@ -296,7 +296,7 @@ public void testAddLink_alsoInQuadTrees() { } @Test - public void testAddLink_intoEmptyQuadTree() { + void testAddLink_intoEmptyQuadTree() { Network network = new NetworkImpl(new LinkFactoryImpl()); Assert.assertEquals(0, network.getLinks().size()); diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java index 28008eaa50c..9144ea61f59 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java @@ -21,8 +21,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -54,7 +54,7 @@ public class NetworkUtilsTest { * Test method for {@link org.matsim.core.network.NetworkUtils#isMultimodal(org.matsim.api.core.v01.network.Network)}. */ @Test - public final void testIsMultimodal() { + final void testIsMultimodal() { Config config = utils.createConfigWithInputResourcePathAsContext(); config.network().setInputFile("network.xml" ); @@ -70,7 +70,7 @@ public final void testIsMultimodal() { @SuppressWarnings("static-method") @Test - public final void getOutLinksSortedByAngleTest() { + final void getOutLinksSortedByAngleTest() { final Network network = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); // (we need the network to properly connect the links) @@ -146,7 +146,7 @@ public final void getOutLinksSortedByAngleTest() { } @Test - public void testfindNearestPointOnLink(){ + void testfindNearestPointOnLink(){ Network network = NetworkUtils.createNetwork(); Coord n1 = new Coord(1, 1); Coord n2 = new Coord(100,100); @@ -204,7 +204,7 @@ public void testfindNearestPointOnLink(){ } @Test - public void getOriginalGeometry() { + void getOriginalGeometry() { var network = NetworkUtils.createNetwork(); var fromNode = NetworkUtils.createAndAddNode(network, Id.createNodeId("from"), new Coord(0, 0)); @@ -235,7 +235,7 @@ public void getOriginalGeometry() { } @Test - public void getOriginalGeometry_noGeometryStored() { + void getOriginalGeometry_noGeometryStored() { var network = NetworkUtils.createNetwork(); var fromNode = NetworkUtils.createAndAddNode(network, Id.createNodeId("from"), new Coord(0, 0)); @@ -263,7 +263,7 @@ public void getOriginalGeometry_noGeometryStored() { * splits an empty string ("") into string[""]... */ @Test - public void getOriginalGeometry_emptyGeometryStored() { + void getOriginalGeometry_emptyGeometryStored() { var network = NetworkUtils.createNetwork(); var fromNode = NetworkUtils.createAndAddNode(network, Id.createNodeId("from"), new Coord(0, 0)); diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java index 589ec99ba16..a3d9ddb7587 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java @@ -22,8 +22,8 @@ package org.matsim.core.network; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -33,15 +33,15 @@ import org.matsim.core.scenario.ScenarioUtils; import org.matsim.testcases.MatsimTestUtils; -/** + /** * @author thibautd */ public class NetworkV2IOTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testNetworkAttributes() { + @Test + void testNetworkAttributes() { final Scenario sc = createTestNetwork( false ); new NetworkWriter( sc.getNetwork() ).writeV2( utils.getOutputDirectory()+"network.xml" ); @@ -54,8 +54,8 @@ public void testNetworkAttributes() { read.getNetwork().getAttributes().getAttribute( "year" ) ); } - @Test - public void testNodesAttributes() { + @Test + void testNodesAttributes() { final Scenario sc = createTestNetwork( false ); new NetworkWriter( sc.getNetwork() ).writeV2( utils.getOutputDirectory()+"network.xml" ); @@ -74,8 +74,8 @@ public void testNodesAttributes() { read.getNetwork().getNodes().get( id ).getAttributes().getAttribute( "Developper Meeting" ) ); } - @Test - public void testNo3DCoord() { + @Test + void testNo3DCoord() { // should be done through once "mixed" network as soon as possible final Scenario sc = createTestNetwork( false ); @@ -92,8 +92,8 @@ public void testNo3DCoord() { zhCoord.hasZ() ); } - @Test - public void test3DCoord() { + @Test + void test3DCoord() { // should be done through once "mixed" network as soon as possible final Scenario sc = createTestNetwork( true ); @@ -115,8 +115,8 @@ public void test3DCoord() { MatsimTestUtils.EPSILON ); } - @Test - public void testLinksAttributes() { + @Test + void testLinksAttributes() { final Scenario sc = createTestNetwork( false ); new NetworkWriter( sc.getNetwork() ).writeV2( utils.getOutputDirectory()+"network.xml" ); diff --git a/matsim/src/test/java/org/matsim/core/network/ReadFromURLIT.java b/matsim/src/test/java/org/matsim/core/network/ReadFromURLIT.java index 9d1ef4ffef9..596e4d515a4 100644 --- a/matsim/src/test/java/org/matsim/core/network/ReadFromURLIT.java +++ b/matsim/src/test/java/org/matsim/core/network/ReadFromURLIT.java @@ -19,7 +19,7 @@ package org.matsim.core.network; import org.assertj.core.api.Assertions; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.network.Network; import org.matsim.core.config.ConfigUtils; import org.matsim.core.network.io.MatsimNetworkReader; @@ -36,7 +36,7 @@ public class ReadFromURLIT { @Test - public void testReadingFromURLWorks() throws MalformedURLException { + void testReadingFromURLWorks() throws MalformedURLException { Network network = ScenarioUtils.createScenario( ConfigUtils.createConfig() ).getNetwork() ; MatsimNetworkReader reader = new MatsimNetworkReader(network) ; // reader.parse(new URL("https://raw.githubusercontent.com/matsim-org/matsim/master/matsim/examples/equil/network.xml")); diff --git a/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java b/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java index 5b84ddb4263..6ee99a6bbe7 100644 --- a/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java +++ b/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -46,7 +46,8 @@ public class TimeVariantLinkImplTest { private static final double TIME_BEFORE_FIRST_CHANGE_EVENTS = -99999;//when base (default) link properties are used /** Tests the method {@link NetworkUtils#getFreespeedTravelTime(Link, double)}. */ - @Test public void testGetFreespeedTravelTime(){ + @Test + void testGetFreespeedTravelTime(){ for (LinkFactory lf : linkFactories(1, 5)) { final Network network = new NetworkImpl(lf); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); @@ -86,7 +87,8 @@ public class TimeVariantLinkImplTest { /** * Tests whether an absolute change in the freespeed really can be seen in the link's travel time */ - @Test public void testFreespeedChangeAbsolute() { + @Test + void testFreespeedChangeAbsolute() { for (LinkFactory lf : linkFactories(15 * 60, 30 * 3600)) { final Network network = new NetworkImpl(lf); @@ -128,7 +130,8 @@ public class TimeVariantLinkImplTest { /** * Tests whether a relative change in the freespeed really can be seen in the link's travel time */ - @Test public void testFreespeedChangeRelative() { + @Test + void testFreespeedChangeRelative() { for (LinkFactory lf : linkFactories(15 * 60, 30 * 3600)) { final Network network = new NetworkImpl(lf); @@ -170,7 +173,8 @@ public class TimeVariantLinkImplTest { /** * Tests how multiple freespeed changes interact with each other on the link. */ - @Test public void testMultipleFreespeedChanges() { + @Test + void testMultipleFreespeedChanges() { for (LinkFactory lf : linkFactories(15 * 60, 30 * 3600)) { final Network network = new NetworkImpl(lf); @@ -276,7 +280,8 @@ public class TimeVariantLinkImplTest { /** * Tests whether an absolute change to the flow capacity really can be observed on the link . */ - @Test public void testFlowCapChangeAbsolute() { + @Test + void testFlowCapChangeAbsolute() { for (LinkFactory lf : linkFactories(15 * 60, 30 * 3600)) { final Network network = new NetworkImpl(lf); network.setCapacityPeriod(3600.0); @@ -312,7 +317,8 @@ public class TimeVariantLinkImplTest { /** * Tests whether an absolute change to the number of lanes really can be observed on the link. */ - @Test public void testLanesChangeAbsolute() { + @Test + void testLanesChangeAbsolute() { for (LinkFactory lf : linkFactories(15 * 60, 30 * 3600)) { final Network network = new NetworkImpl(lf); network.setCapacityPeriod(3600.0); diff --git a/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java b/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java index 8a886da7975..f7cc016d101 100644 --- a/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -47,7 +47,8 @@ public class TravelTimeCalculatorIntegrationTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testTravelTimeCalculatorArray() { + @Test + void testTravelTimeCalculatorArray() { for (LinkFactory lf : TimeVariantLinkImplTest.linkFactories(15 * 60, 30 * 3600)) { Config config = utils.loadConfig((String)null); @@ -88,7 +89,8 @@ public class TravelTimeCalculatorIntegrationTest { } } - @Test public void testTravelTimeCalculatorHashMap() { + @Test + void testTravelTimeCalculatorHashMap() { for (LinkFactory lf : TimeVariantLinkImplTest.linkFactories(15 * 60, 30 * 3600)) { Config config = utils.loadConfig((String)null); diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/CalcBoundingBoxTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/CalcBoundingBoxTest.java index 37bca87b1f5..fa57c2fb070 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/CalcBoundingBoxTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/CalcBoundingBoxTest.java @@ -20,8 +20,7 @@ package org.matsim.core.network.algorithms; import org.junit.Assert; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -36,7 +35,7 @@ public class CalcBoundingBoxTest { @Test - public void testRun() { + void testRun() { Network net = NetworkUtils.createNetwork(); NetworkFactory nf = net.getFactory(); @@ -72,7 +71,7 @@ public void testRun() { } @Test - public void testRun_allNegative() { + void testRun_allNegative() { Network net = NetworkUtils.createNetwork(); NetworkFactory nf = net.getFactory(); diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/MultimodalNetworkCleanerTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/MultimodalNetworkCleanerTest.java index 227f6038b81..7021557104f 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/MultimodalNetworkCleanerTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/MultimodalNetworkCleanerTest.java @@ -24,8 +24,7 @@ import java.util.Set; import org.junit.Assert; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -43,7 +42,7 @@ public class MultimodalNetworkCleanerTest { @Test - public void testRun_singleMode() { + void testRun_singleMode() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); @@ -62,7 +61,7 @@ public void testRun_singleMode() { } @Test - public void testRun_singleMode_separateLink() { + void testRun_singleMode_separateLink() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); Node node1 = network.getNodes().get(f.nodeIds[1]); @@ -106,7 +105,7 @@ public void testRun_singleMode_separateLink() { } @Test - public void testRun_singleInexistantMode() { + void testRun_singleInexistantMode() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); @@ -126,7 +125,7 @@ public void testRun_singleInexistantMode() { } @Test - public void testRun_singleMode_singleSink() { + void testRun_singleMode_singleSink() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); Node node1 = network.getNodes().get(f.nodeIds[1]); @@ -179,7 +178,7 @@ public void testRun_singleMode_singleSink() { } @Test - public void testRun_singleMode_singleSinkIntegrated() { + void testRun_singleMode_singleSinkIntegrated() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); network.getLinks().get(f.linkIds[1]).setAllowedModes(f.modesCW); // integrate the sinks into the existing network @@ -221,7 +220,7 @@ public void testRun_singleMode_singleSinkIntegrated() { } @Test - public void testRun_singleMode_doubleSink() { + void testRun_singleMode_doubleSink() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); Node node1 = network.getNodes().get(f.nodeIds[1]); @@ -278,7 +277,7 @@ public void testRun_singleMode_doubleSink() { @Test - public void testRun_singleMode_singleSource() { + void testRun_singleMode_singleSource() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); Node node1 = network.getNodes().get(f.nodeIds[1]); @@ -331,7 +330,7 @@ public void testRun_singleMode_singleSource() { } @Test - public void testRemoveNodesWithoutLinks() { + void testRemoveNodesWithoutLinks() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); network.addNode(network.getFactory().createNode(f.nodeIds[10], new Coord((double) 300, (double) 300))); @@ -351,7 +350,7 @@ public void testRemoveNodesWithoutLinks() { } @Test - public void testRun_singleMode_doubleSource() { + void testRun_singleMode_doubleSource() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); Node node1 = network.getNodes().get(f.nodeIds[1]); @@ -407,7 +406,7 @@ public void testRun_singleMode_doubleSource() { } @Test - public void testRun_multipleModes() { + void testRun_multipleModes() { Fixture f = new MultimodeFixture(); Network network = f.scenario.getNetwork(); @@ -431,7 +430,7 @@ public void testRun_multipleModes() { } @Test - public void testRun_multipleModes_doubleSink() { + void testRun_multipleModes_doubleSink() { Fixture f = new MultimodeFixture(); Network network = f.scenario.getNetwork(); @@ -465,7 +464,7 @@ public void testRun_multipleModes_doubleSink() { } @Test - public void testRun_multipleModes_doubleSource() { + void testRun_multipleModes_doubleSource() { Fixture f = new MultimodeFixture(); Network network = f.scenario.getNetwork(); @@ -499,7 +498,7 @@ public void testRun_multipleModes_doubleSource() { } @Test - public void testRun_emptyModes() { + void testRun_emptyModes() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); @@ -520,7 +519,7 @@ public void testRun_emptyModes() { } @Test - public void testRun_unknownMode() { + void testRun_unknownMode() { Fixture f = new Fixture(); Network network = f.scenario.getNetwork(); @@ -541,7 +540,7 @@ public void testRun_unknownMode() { } @Test - public void testRun_singleLinkNetwork() { + void testRun_singleLinkNetwork() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); NetworkFactory factory = network.getFactory(); @@ -566,7 +565,7 @@ public void testRun_singleLinkNetwork() { } @Test - public void testRun_singleModeWithConnectivity() { + void testRun_singleModeWithConnectivity() { MultimodalFixture2 f = new MultimodalFixture2(); Network network = f.scenario.getNetwork(); Assert.assertEquals(6, network.getNodes().size()); @@ -577,7 +576,7 @@ public void testRun_singleModeWithConnectivity() { } @Test - public void testRun_withConnectivity_connectedSource() { + void testRun_withConnectivity_connectedSource() { MultimodalFixture2 f = new MultimodalFixture2(); Network network = f.scenario.getNetwork(); NetworkFactory nf = network.getFactory(); @@ -597,7 +596,7 @@ public void testRun_withConnectivity_connectedSource() { } @Test - public void testRun_withConnectivity_connectedSink() { + void testRun_withConnectivity_connectedSink() { MultimodalFixture2 f = new MultimodalFixture2(); Network network = f.scenario.getNetwork(); NetworkFactory nf = network.getFactory(); @@ -617,7 +616,7 @@ public void testRun_withConnectivity_connectedSink() { } @Test - public void testRun_withConnectivity_unconnectedSource() { + void testRun_withConnectivity_unconnectedSource() { MultimodalFixture2 f = new MultimodalFixture2(); Network network = f.scenario.getNetwork(); NetworkFactory nf = network.getFactory(); @@ -638,7 +637,7 @@ public void testRun_withConnectivity_unconnectedSource() { } @Test - public void testRun_withConnectivity_unconnectedSink() { + void testRun_withConnectivity_unconnectedSink() { MultimodalFixture2 f = new MultimodalFixture2(); Network network = f.scenario.getNetwork(); NetworkFactory nf = network.getFactory(); @@ -659,7 +658,7 @@ public void testRun_withConnectivity_unconnectedSink() { } @Test - public void testRun_withConnectivity_unconnectedLink() { + void testRun_withConnectivity_unconnectedLink() { MultimodalFixture2 f = new MultimodalFixture2(); Network network = f.scenario.getNetwork(); NetworkFactory nf = network.getFactory(); diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkCleanerTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkCleanerTest.java index 3bacc7f7f42..82612458c85 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkCleanerTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkCleanerTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -39,7 +39,8 @@ */ public class NetworkCleanerTest { - @Test public void testSink() { + @Test + void testSink() { // create a simple network Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); @@ -74,7 +75,8 @@ public class NetworkCleanerTest { assertEquals("# links", 4, network.getLinks().size()); } - @Test public void testDoubleSink() { + @Test + void testDoubleSink() { // create a simple network Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); @@ -112,7 +114,8 @@ public class NetworkCleanerTest { assertEquals("# links", 4, network.getLinks().size()); } - @Test public void testSource() { + @Test + void testSource() { // create a simple network Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); @@ -147,7 +150,8 @@ public class NetworkCleanerTest { assertEquals("# links", 4, network.getLinks().size()); } - @Test public void testDoubleSource() { + @Test + void testDoubleSource() { // create a simple network Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkExpandNodeTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkExpandNodeTest.java index 114120578e5..582e14d9a15 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkExpandNodeTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkExpandNodeTest.java @@ -24,8 +24,7 @@ import java.util.Set; import org.junit.Assert; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -45,7 +44,7 @@ public class NetworkExpandNodeTest { @Test - public void testExpandNode() { + void testExpandNode() { Fixture f = new Fixture(); f.createNetwork_ThreeWayIntersection(); @@ -153,7 +152,7 @@ public void testExpandNode() { } @Test - public void testExpandNode_sameCoordinateLinks() { + void testExpandNode_sameCoordinateLinks() { Fixture f = new Fixture(); f.createNetwork_ThreeWayIntersection(); Coord c = f.scenario.getNetwork().getNodes().get(Id.create("3", Node.class)).getCoord(); @@ -265,7 +264,7 @@ public void testExpandNode_sameCoordinateLinks() { } @Test - public void testExpandNode_specificModes() { + void testExpandNode_specificModes() { Fixture f = new Fixture(); f.createNetwork_ThreeWayIntersection(); @@ -388,7 +387,7 @@ public void testExpandNode_specificModes() { } @Test - public void testTurnsAreSameAsSingleNode_IncludeUTurns() { + void testTurnsAreSameAsSingleNode_IncludeUTurns() { Fixture f = new Fixture(); f.createNetwork_ThreeWayIntersection(); @@ -426,7 +425,7 @@ public void testTurnsAreSameAsSingleNode_IncludeUTurns() { } @Test - public void testTurnsAreSameAsSingleNode_IgnoreUTurns() { + void testTurnsAreSameAsSingleNode_IgnoreUTurns() { Fixture f = new Fixture(); f.createNetwork_ThreeWayIntersection(); @@ -463,9 +462,9 @@ public void testTurnsAreSameAsSingleNode_IgnoreUTurns() { Assert.assertTrue(exp.turnsAreSameAsSingleNode(nodeId, turns, true)); } - + @Test - public void testTurnInfo_equals() { + void testTurnInfo_equals() { Set modes1 = new HashSet(); Set modes2 = new HashSet(); modes2.add(TransportMode.car); diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkMergeDoubleLinksTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkMergeDoubleLinksTest.java index a2d95be4089..c5d32dbbc18 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkMergeDoubleLinksTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkMergeDoubleLinksTest.java @@ -20,8 +20,7 @@ package org.matsim.core.network.algorithms; import org.junit.Assert; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -39,7 +38,7 @@ public class NetworkMergeDoubleLinksTest { @Test - public void testRun_remove() { + void testRun_remove() { Fixture f = new Fixture(); NetworkMergeDoubleLinks merger = new NetworkMergeDoubleLinks(NetworkMergeDoubleLinks.MergeType.REMOVE); merger.run(f.network); @@ -70,7 +69,7 @@ public void testRun_remove() { } @Test - public void testRun_additive() { + void testRun_additive() { Fixture f = new Fixture(); NetworkMergeDoubleLinks merger = new NetworkMergeDoubleLinks(NetworkMergeDoubleLinks.MergeType.ADDITIVE); merger.run(f.network); @@ -101,7 +100,7 @@ public void testRun_additive() { } @Test - public void testRun_maximum() { + void testRun_maximum() { Fixture f = new Fixture(); NetworkMergeDoubleLinks merger = new NetworkMergeDoubleLinks(NetworkMergeDoubleLinks.MergeType.MAXIMUM); merger.run(f.network); diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierPass2WayTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierPass2WayTest.java index 5fc61aa82d3..94feb8bcf41 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierPass2WayTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierPass2WayTest.java @@ -25,7 +25,8 @@ import java.util.Arrays; import java.util.Collections; import java.util.List; -import org.junit.Test; + +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Network; import org.matsim.api.core.v01.network.Node; @@ -40,8 +41,8 @@ public class NetworkSimplifierPass2WayTest { - @Test - public void testSimplifying(){ + @Test + void testSimplifying(){ List networks = buildNetworks(); int counter = 0; diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java index aefb7a099fc..542823a3ad4 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java @@ -27,7 +27,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -44,14 +44,14 @@ public void setUp() { } @Test - public void testBuildNetwork() { + void testBuildNetwork() { Network network = buildNetwork(); assertEquals("Wrong number of nodes.", 6, network.getNodes().size()); assertEquals("Wrong number of links.", 5, network.getLinks().size()); } @Test - public void testRun() { + void testRun() { Network network = buildNetwork(); NetworkSimplifier nst = new NetworkSimplifier(); @@ -62,9 +62,9 @@ public void testRun() { assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("DE-EF"))); } - + @Test - public void testRunMergeLinkStats() { + void testRunMergeLinkStats() { Network network = buildNetwork(); NetworkSimplifier nst = new NetworkSimplifier(); @@ -85,7 +85,7 @@ public void testRunMergeLinkStats() { } @Test - public void testDifferentAttributesPerDirection() { + void testDifferentAttributesPerDirection() { /* Test-Network diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/TransportModeNetworkFilterTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/TransportModeNetworkFilterTest.java index ff3cd805ed9..1bfe470b9c8 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/TransportModeNetworkFilterTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/TransportModeNetworkFilterTest.java @@ -24,8 +24,7 @@ import java.util.Set; import org.junit.Assert; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -50,7 +49,7 @@ public class TransportModeNetworkFilterTest { @Test - public void testFilter_SingleMode() { + void testFilter_SingleMode() { final Fixture f = new Fixture(); TransportModeNetworkFilter filter = new TransportModeNetworkFilter(f.scenario.getNetwork()); @@ -142,7 +141,7 @@ public void testFilter_SingleMode() { } @Test - public void testFilter_MultipleModes() { + void testFilter_MultipleModes() { final Fixture f = new Fixture(); TransportModeNetworkFilter filter = new TransportModeNetworkFilter(f.scenario.getNetwork()); @@ -223,7 +222,7 @@ public void testFilter_MultipleModes() { } @Test - public void testFilter_NoModes() { + void testFilter_NoModes() { final Fixture f = new Fixture(); TransportModeNetworkFilter filter = new TransportModeNetworkFilter(f.scenario.getNetwork()); @@ -234,7 +233,7 @@ public void testFilter_NoModes() { } @Test - public void testFilter_AdditionalModes() { + void testFilter_AdditionalModes() { final Fixture f = new Fixture(); TransportModeNetworkFilter filter = new TransportModeNetworkFilter(f.scenario.getNetwork()); @@ -262,7 +261,7 @@ public void testFilter_AdditionalModes() { } @Test - public void testFilter_NoCommonModes() { + void testFilter_NoCommonModes() { final Fixture f = new Fixture(); TransportModeNetworkFilter filter = new TransportModeNetworkFilter(f.scenario.getNetwork()); @@ -271,7 +270,7 @@ public void testFilter_NoCommonModes() { Assert.assertEquals("wrong number of nodes.", 0, subNetwork.getNodes().size()); Assert.assertEquals("wrong number of links", 0, subNetwork.getLinks().size()); } - + /** * Tests the algorithm for the case the network contains direct loops, i.e. * links with the same from and to node. @@ -284,7 +283,7 @@ public void testFilter_NoCommonModes() { * scenario from scratch. */ @Test - public void testFilter_SingleMode_loop() { + void testFilter_SingleMode_loop() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Network network = scenario.getNetwork(); final NetworkFactory factory = network.getFactory(); @@ -303,12 +302,12 @@ public void testFilter_SingleMode_loop() { Assert.assertEquals("wrong number of links", 1, subNetwork.getLinks().size()); Assert.assertTrue(subNetwork.getLinks().containsKey(Id.create(1, Link.class))); } - + /** * Tests that tiem-varying information is converted */ @Test - public void testFilter_timeVariant() { + void testFilter_timeVariant() { Config config = ConfigUtils.createConfig(); config.network().setTimeVariantNetwork(true); diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/DensityClusterTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/DensityClusterTest.java index 0e7518744a0..6299e3dd572 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/DensityClusterTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/DensityClusterTest.java @@ -24,15 +24,15 @@ import java.util.List; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Node; import org.matsim.core.network.NetworkUtils; public class DensityClusterTest{ - - + + /** * Tests if the following cluster pattern is clustered into two clusters: * ___________ @@ -46,7 +46,7 @@ public class DensityClusterTest{ * |___________| */ @Test - public void testDJCluster(){ + void testDJCluster(){ List al = buildTestArrayList(); DensityCluster djc = new DensityCluster(al, false); djc.clusterInput(2, 3); diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/HullConverterTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/HullConverterTest.java index aebdcf8e8ea..b5964c3c526 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/HullConverterTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/HullConverterTest.java @@ -20,7 +20,7 @@ package org.matsim.core.network.algorithms.intersectionSimplifier; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.GeometryFactory; import org.locationtech.jts.geom.LineString; @@ -31,7 +31,7 @@ public class HullConverterTest { public void testConvert() { - } + } /** * 4 3 @@ -44,7 +44,7 @@ public void testConvert() { * 1 2 */ @Test - public void testConvertString(){ + void testConvertString(){ /* Must pass a Geometry. */ Object o = new Integer(0); HullConverter hc = new HullConverter(); @@ -81,8 +81,8 @@ public void testConvertString(){ String polygonString = "(0.0;0.0),(5.0;0.0),(5.0;5.0),(0.0;5.0),(0.0;0.0)"; Assert.assertTrue("Wrong string for polygon.", polygonString.equalsIgnoreCase(s)); } - - + + /** * (5,0)-------(5,5) * | | @@ -92,7 +92,7 @@ public void testConvertString(){ * (0,0)-------(5,0) */ @Test - public void testConstructor(){ + void testConstructor(){ HullConverter hc = new HullConverter(); GeometryFactory gf = new GeometryFactory(); Coordinate[] ca = new Coordinate[5]; diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java index 8d8e0f6639c..035a913d729 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java @@ -25,8 +25,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Network; @@ -44,7 +44,7 @@ public class IntersectionSimplifierTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testComplexIntersection() { + void testComplexIntersection() { Network network = null; try { network = buildComplexIntersection(); @@ -58,7 +58,7 @@ public void testComplexIntersection() { } @Test - public void testSimplifyCallOnlyOnce() { + void testSimplifyCallOnlyOnce() { Network network = buildComplexIntersection(); IntersectionSimplifier is = new IntersectionSimplifier(10.0, 2); try{ @@ -79,7 +79,7 @@ public void testSimplifyCallOnlyOnce() { @Test - public void testGetClusteredNode() { + void testGetClusteredNode() { Network network = buildComplexIntersection(); IntersectionSimplifier is = new IntersectionSimplifier(10.0, 2); @@ -100,7 +100,7 @@ public void testGetClusteredNode() { @Test - public void testSimplifyOne() { + void testSimplifyOne() { Network network = buildComplexIntersection(); IntersectionSimplifier is = new IntersectionSimplifier(10.0, 2); Network simpleNetwork = is.simplify(network); @@ -122,7 +122,7 @@ public void testSimplifyOne() { } @Test - public void testSimplifyTwo() { + void testSimplifyTwo() { Network network = buildComplexIntersection(); IntersectionSimplifier is = new IntersectionSimplifier(30.0, 4); Network simpleNetwork = is.simplify(network); @@ -147,7 +147,7 @@ public void testSimplifyTwo() { * The network cleaner will/should ensure that full connectivity remains. */ @Test - public void testNetworkCleaner() { + void testNetworkCleaner() { Network network = buildComplexIntersection(); IntersectionSimplifier is = new IntersectionSimplifier(10.0, 2); Network simpleNetwork = is.simplify(network); @@ -182,7 +182,7 @@ public void testNetworkCleaner() { } @Test - public void testNetworkSimplifier() { + void testNetworkSimplifier() { Network network = buildComplexIntersection(); IntersectionSimplifier is = new IntersectionSimplifier(10.0, 2); Network simpleNetwork = is.simplify(network); diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java index 8fdde25b9eb..35c3cfd024d 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java @@ -20,8 +20,8 @@ package org.matsim.core.network.algorithms.intersectionSimplifier.containers; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; import org.locationtech.jts.geom.GeometryCollection; @@ -35,7 +35,7 @@ public class ConcaveHullTest { /** Test whether duplicate input points are removed. **/ @Test - public void testConstructor(){ + void testConstructor(){ GeometryCollection gcIncorrect = setupWithDuplicates(); ConcaveHull ch1 = new ConcaveHull(gcIncorrect, 2); Assert.assertEquals("Duplicates not removed.", 8, ch1.getInputPoints()); diff --git a/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java b/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java index 935482c7a0c..8796cc67bc4 100644 --- a/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java +++ b/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java @@ -23,7 +23,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -88,7 +88,7 @@ private static void enrichLink(Link link) { } @Test - public void filterTest() { + void filterTest() { NetworkFilterManager networkFilterManager = new NetworkFilterManager(filterNetwork, new NetworkConfigGroup()); networkFilterManager.addNodeFilter(new NetworkNodeFilter() { @Override diff --git a/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java b/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java index e122adda402..313018fab00 100644 --- a/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java @@ -22,8 +22,8 @@ package org.matsim.core.network.io; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; import org.matsim.core.config.ConfigUtils; @@ -34,19 +34,19 @@ import java.util.Objects; import java.util.function.Consumer; -public class NetworkAttributeConversionTest { + public class NetworkAttributeConversionTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testDefaults() { + @Test + void testDefaults() { final String path = utils.getOutputDirectory()+"/network.xml"; testWriteAndReread(w -> w.write(path), w -> w.readFile(path)); } - @Test - public void testV2() { + @Test + void testV2() { final String path = utils.getOutputDirectory()+"/network.xml"; testWriteAndReread(w -> w.writeFileV2(path), w -> w.readFile(path)); diff --git a/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java b/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java index 33517747af2..05795477641 100644 --- a/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java +++ b/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java @@ -25,8 +25,8 @@ import java.util.Set; import java.util.Stack; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -49,7 +49,8 @@ public class NetworkReaderMatsimV1Test { /** * @author mrieser */ - @Test public void testAllowedModes_singleMode() { + @Test + void testAllowedModes_singleMode() { Link link = prepareTestAllowedModes("car"); Set modes = link.getAllowedModes(); assertEquals("wrong number of allowed modes.", 1, modes.size()); @@ -65,7 +66,8 @@ public class NetworkReaderMatsimV1Test { /** * @author mrieser */ - @Test public void testAllowedModes_emptyMode() { + @Test + void testAllowedModes_emptyMode() { Link link = prepareTestAllowedModes(""); Set modes = link.getAllowedModes(); assertEquals("wrong number of allowed modes.", 0, modes.size()); @@ -74,7 +76,8 @@ public class NetworkReaderMatsimV1Test { /** * @author mrieser */ - @Test public void testAllowedModes_multipleModes() { + @Test + void testAllowedModes_multipleModes() { Link link = prepareTestAllowedModes("car,bus"); Set modes = link.getAllowedModes(); assertEquals("wrong number of allowed modes.", 2, modes.size()); diff --git a/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java b/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java index 980cddcc1eb..b57fd8ab3f5 100644 --- a/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java @@ -22,8 +22,8 @@ package org.matsim.core.network.io; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -40,7 +40,7 @@ import org.matsim.core.utils.geometry.transformations.TransformationFactory; import org.matsim.testcases.MatsimTestUtils; -/** + /** * @author thibautd */ public class NetworkReprojectionIOTest { @@ -54,8 +54,8 @@ public class NetworkReprojectionIOTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testInput() { + @Test + void testInput() { final String networkFile = utils.getOutputDirectory()+"/network.xml"; final Network initialNetwork = createInitialNetwork(); @@ -81,8 +81,8 @@ public void testInput() { } } - @Test - public void testOutput() { + @Test + void testOutput() { final String networkFile = utils.getOutputDirectory()+"/network.xml"; final Network initialNetwork = createInitialNetwork(); @@ -109,8 +109,8 @@ public void testOutput() { } } - @Test - public void testWithControlerAndAttributes() { + @Test + void testWithControlerAndAttributes() { final String networkFile = utils.getOutputDirectory()+"/network.xml"; final Network initialNetwork = createInitialNetwork(); @@ -163,8 +163,8 @@ public void testWithControlerAndAttributes() { } } - @Test - public void testWithControlerAndConfigParameters() { + @Test + void testWithControlerAndConfigParameters() { final String networkFile = utils.getOutputDirectory()+"/network.xml"; final Network initialNetwork = createInitialNetwork(); diff --git a/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java b/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java index 732657460e2..7b63c140391 100644 --- a/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java +++ b/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -50,7 +50,8 @@ public class PersonImplTest { /** * @author mrieser */ - @Test public void testGetRandomUnscoredPlan() { + @Test + void testGetRandomUnscoredPlan() { Population population = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getPopulation(); Person person = null; Plan[] plans = new Plan[10]; @@ -97,7 +98,8 @@ public class PersonImplTest { /** * @author mrieser */ - @Test public void testRemoveUnselectedPlans() { + @Test + void testRemoveUnselectedPlans() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); PersonUtils.createAndAddPlan(person, false); PersonUtils.createAndAddPlan(person, false); @@ -112,7 +114,8 @@ public class PersonImplTest { assertEquals("remaining plan should be selPlan.", selPlan, person.getPlans().get(0)); } - @Test public void testRemovePlan() { + @Test + void testRemovePlan() { Person person = PopulationUtils.getFactory().createPerson(Id.create(5, Person.class)); Plan p1 = PersonUtils.createAndAddPlan(person, false); Plan p2 = PersonUtils.createAndAddPlan(person, true); @@ -137,7 +140,8 @@ public class PersonImplTest { assertEquals("wrong number of plans.", 0, person.getPlans().size()); } - @Test public void testSetSelectedPlan() { + @Test + void testSetSelectedPlan() { Person person = PopulationUtils.getFactory().createPerson(Id.create(11, Person.class)); Plan p1 = PersonUtils.createAndAddPlan(person, false); assertEquals(p1, person.getSelectedPlan()); @@ -159,7 +163,8 @@ public class PersonImplTest { /** * @author mrieser */ - @Test public void testGetBestPlan() { + @Test + void testGetBestPlan() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan p1 = PopulationUtils.createPlan(); p1.setScore(90.0); @@ -174,7 +179,8 @@ public class PersonImplTest { /** * @author mrieser */ - @Test public void testGetBestPlan_multipleBest() { + @Test + void testGetBestPlan_multipleBest() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan p1 = PopulationUtils.createPlan(); p1.setScore(11.0); @@ -192,7 +198,8 @@ public class PersonImplTest { /** * @author mrieser */ - @Test public void testGetBestPlan_oneWithoutScore() { + @Test + void testGetBestPlan_oneWithoutScore() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan p1 = PopulationUtils.createPlan(); Plan p2 = PopulationUtils.createPlan(); @@ -206,7 +213,8 @@ public class PersonImplTest { /** * @author mrieser */ - @Test public void testGetBestPlan_allWithoutScore() { + @Test + void testGetBestPlan_allWithoutScore() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan p1 = PopulationUtils.createPlan(); Plan p2 = PopulationUtils.createPlan(); diff --git a/matsim/src/test/java/org/matsim/core/population/PlanImplTest.java b/matsim/src/test/java/org/matsim/core/population/PlanImplTest.java index ed49d1c3bda..b818a7ec02c 100644 --- a/matsim/src/test/java/org/matsim/core/population/PlanImplTest.java +++ b/matsim/src/test/java/org/matsim/core/population/PlanImplTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -49,7 +49,7 @@ public class PlanImplTest { * @author mrieser */ @Test - public void testCreateAndAddActAndLeg() { + void testCreateAndAddActAndLeg() { Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); try { PopulationUtils.createAndAddLeg( plan, TransportMode.car ); @@ -68,7 +68,7 @@ public void testCreateAndAddActAndLeg() { * @author mrieser */ @Test - public void testInsertActLeg_Between() { + void testInsertActLeg_Between() { Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); Activity homeAct = PopulationUtils.createAndAddActivityFromCoord(plan, "h", new Coord(0, 0)); Leg leg1 = PopulationUtils.createAndAddLeg( plan, TransportMode.car ); @@ -97,7 +97,7 @@ public void testInsertActLeg_Between() { * @author mrieser */ @Test - public void testInsertActLeg_AtEnd() { + void testInsertActLeg_AtEnd() { Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); Activity homeAct = PopulationUtils.createAndAddActivityFromCoord(plan, "h", new Coord(0, 0)); Leg leg1 = PopulationUtils.createAndAddLeg( plan, TransportMode.car ); @@ -126,7 +126,7 @@ public void testInsertActLeg_AtEnd() { * @author mrieser */ @Test - public void testInsertActLeg_AtWrongPosition() { + void testInsertActLeg_AtWrongPosition() { Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "h", new Coord(0, 0)); PopulationUtils.createAndAddLeg( plan, TransportMode.car ); @@ -152,7 +152,7 @@ public void testInsertActLeg_AtWrongPosition() { * @author mrieser */ @Test - public void testInsertActLeg_AtStart() { + void testInsertActLeg_AtStart() { Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "h", new Coord(0, 0)); PopulationUtils.createAndAddLeg( plan, TransportMode.car ); @@ -179,7 +179,7 @@ public void testInsertActLeg_AtStart() { * @author mrieser */ @Test - public void testInsertActLeg_BehindEnd() { + void testInsertActLeg_BehindEnd() { Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "h", new Coord(0, 0)); PopulationUtils.createAndAddLeg( plan, TransportMode.car ); @@ -212,7 +212,7 @@ public void testInsertActLeg_BehindEnd() { } @Test - public void testCopyPlan_NetworkRoute() { + void testCopyPlan_NetworkRoute() { Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create(1, Node.class), new Coord(0, 0)); Node node2 = NetworkUtils.createAndAddNode(network, Id.create(2, Node.class), new Coord(1000, 0)); @@ -243,7 +243,7 @@ public void testCopyPlan_NetworkRoute() { } @Test - public void testCopyPlan_GenericRoute() { + void testCopyPlan_GenericRoute() { Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create(1, Node.class), new Coord(0, 0)); Node node2 = NetworkUtils.createAndAddNode(network, Id.create(2, Node.class), new Coord(1000, 0)); @@ -277,7 +277,7 @@ public void testCopyPlan_GenericRoute() { * @author meisterk */ @Test - public void testRemoveActivity() { + void testRemoveActivity() { Plan testee = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(testee, "h", new Coord(0, 0)); @@ -297,7 +297,7 @@ public void testRemoveActivity() { * @author meisterk */ @Test - public void testRemoveLeg() { + void testRemoveLeg() { Plan testee = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(testee, "h", new Coord(0, 0)); PopulationUtils.createAndAddLeg( testee, TransportMode.car ); @@ -313,7 +313,7 @@ public void testRemoveLeg() { } @Test - public void addMultipleLegs() { + void addMultipleLegs() { Plan p = PopulationUtils.createPlan(); p.addActivity(new ActivityImpl("h")); p.addLeg(PopulationUtils.createLeg(TransportMode.walk)); @@ -330,7 +330,7 @@ public void addMultipleLegs() { } @Test - public void addMultipleActs() { + void addMultipleActs() { Plan p = PopulationUtils.createPlan(); p.addActivity(new ActivityImpl("h")); p.addLeg(PopulationUtils.createLeg(TransportMode.walk)); @@ -345,7 +345,7 @@ public void addMultipleActs() { } @Test - public void createAndAddMultipleLegs() { + void createAndAddMultipleLegs() { Plan p = PopulationUtils.createPlan(); PopulationUtils.createAndAddActivity(p, "h"); PopulationUtils.createAndAddLeg( p, TransportMode.walk ); @@ -362,7 +362,7 @@ public void createAndAddMultipleLegs() { } @Test - public void createAndAddMultipleActs() { + void createAndAddMultipleActs() { Plan p = PopulationUtils.createPlan(); PopulationUtils.createAndAddActivity(p, "h"); PopulationUtils.createAndAddLeg( p, TransportMode.walk ); diff --git a/matsim/src/test/java/org/matsim/core/population/PopulationUtilsTest.java b/matsim/src/test/java/org/matsim/core/population/PopulationUtilsTest.java index d89a8100ec9..4b083a3fb9d 100644 --- a/matsim/src/test/java/org/matsim/core/population/PopulationUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/population/PopulationUtilsTest.java @@ -22,7 +22,7 @@ package org.matsim.core.population; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -31,13 +31,13 @@ import org.matsim.core.population.io.PopulationReader; import org.matsim.core.scenario.ScenarioUtils; -/** + /** * @author thibautd */ public class PopulationUtilsTest { - @Test - public void testPlanAttributesCopy() { + @Test + void testPlanAttributesCopy() { final Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig() ); final Person person = population.getFactory().createPerson(Id.createPersonId( "Donald Trump")); diff --git a/matsim/src/test/java/org/matsim/core/population/io/CompressedRoutesIntegrationTest.java b/matsim/src/test/java/org/matsim/core/population/io/CompressedRoutesIntegrationTest.java index 3f39ecacb02..58072ae7794 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/CompressedRoutesIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/CompressedRoutesIntegrationTest.java @@ -20,7 +20,7 @@ package org.matsim.core.population.io; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Leg; @@ -36,7 +36,7 @@ public class CompressedRoutesIntegrationTest { @Test - public void testReadingPlansV4parallel() { + void testReadingPlansV4parallel() { Config config = ConfigUtils.createConfig(); config.plans().setNetworkRouteType("CompressedNetworkRoute"); Scenario s = ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/population/io/MatsimPopulationReaderTest.java b/matsim/src/test/java/org/matsim/core/population/io/MatsimPopulationReaderTest.java index c9627bf4c3c..7bf327f170d 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/MatsimPopulationReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/MatsimPopulationReaderTest.java @@ -22,7 +22,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -42,7 +42,7 @@ public class MatsimPopulationReaderTest { @Test - public void testReadFile_v4() { + void testReadFile_v4() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Assert.assertEquals(0, s.getPopulation().getPersons().size()); new MatsimNetworkReader(s.getNetwork()).readFile("test/scenarios/equil/network.xml"); @@ -51,7 +51,7 @@ public void testReadFile_v4() { } @Test - public void testReadFile_v5() { + void testReadFile_v5() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Assert.assertEquals(0, s.getPopulation().getPersons().size()); new PopulationReader(s).readFile("test/input/org/matsim/core/utils/io/MatsimFileTypeGuesserTest/population_v5_example.xml"); @@ -66,9 +66,9 @@ public void testReadFile_v5() { Assert.assertTrue(planElements.get(1) instanceof Leg); Assert.assertTrue(planElements.get(2) instanceof Activity); } - + @Test - public void testReadFile_v5_multipleSuccessiveLegs() { + void testReadFile_v5_multipleSuccessiveLegs() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Assert.assertEquals(0, s.getPopulation().getPersons().size()); new PopulationReader(s).readFile("test/input/org/matsim/core/utils/io/MatsimFileTypeGuesserTest/population_v5_multipleLegs.xml"); @@ -85,9 +85,9 @@ public void testReadFile_v5_multipleSuccessiveLegs() { Assert.assertTrue(planElements.get(3) instanceof Leg); Assert.assertTrue(planElements.get(4) instanceof Activity); } - + @Test - public void testReadFile_v5_multipleSuccessiveLegsWithRoutes() { + void testReadFile_v5_multipleSuccessiveLegsWithRoutes() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Assert.assertEquals(0, s.getPopulation().getPersons().size()); new PopulationReader(s).readFile("test/input/org/matsim/core/utils/io/MatsimFileTypeGuesserTest/population_v5_multipleLegsWithRoutes.xml"); @@ -110,9 +110,9 @@ public void testReadFile_v5_multipleSuccessiveLegsWithRoutes() { Assert.assertEquals(Id.create("6", Link.class), ((Leg) planElements.get(3)).getRoute().getEndLinkId()); Assert.assertTrue(planElements.get(4) instanceof Activity); } - + @Test - public void testReadFile_v5_multipleSuccessiveLegsWithTeleportation() { + void testReadFile_v5_multipleSuccessiveLegsWithTeleportation() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Assert.assertEquals(0, s.getPopulation().getPersons().size()); new PopulationReader(s).readFile("test/input/org/matsim/core/utils/io/MatsimFileTypeGuesserTest/population_v5_multipleTeleportedLegs.xml"); diff --git a/matsim/src/test/java/org/matsim/core/population/io/ParallelPopulationReaderTest.java b/matsim/src/test/java/org/matsim/core/population/io/ParallelPopulationReaderTest.java index ba5efe96823..54e4e2fbd33 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/ParallelPopulationReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/ParallelPopulationReaderTest.java @@ -1,7 +1,7 @@ package org.matsim.core.population.io; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.ConfigUtils; import org.matsim.core.scenario.ScenarioUtils; @@ -13,7 +13,7 @@ public class ParallelPopulationReaderTest { @Test - public void testParallelPopulationReaderV4_escalateException() { + void testParallelPopulationReaderV4_escalateException() { String xml = """ @@ -42,7 +42,7 @@ public void testParallelPopulationReaderV4_escalateException() { } @Test - public void testParallelPopulationReaderV6_escalateException() { + void testParallelPopulationReaderV6_escalateException() { String xml = """ diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java index 8fe0bef6f34..86824f40ec2 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java @@ -22,8 +22,8 @@ package org.matsim.core.population.io; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -38,33 +38,33 @@ import java.util.Objects; import java.util.function.Consumer; -public class PopulationAttributeConversionTest { + public class PopulationAttributeConversionTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testDefaults() { + @Test + void testDefaults() { final String path = utils.getOutputDirectory()+"/plans.xml"; testWriteAndReread(w -> w.write(path), w -> w.readFile(path)); } - @Test - public void testDefaultsStream() { + @Test + void testDefaultsStream() { final String path = utils.getOutputDirectory()+"/plans.xml"; testWriteAndReread(w -> w.write(IOUtils.getOutputStream(IOUtils.getFileUrl(path), false)), w -> w.readFile(path)); } - @Test - public void testV6() { + @Test + void testV6() { final String path = utils.getOutputDirectory()+"/plans.xml"; testWriteAndReread(w -> w.writeV6(path), w -> w.readFile(path)); } - @Test - public void testV7() { + @Test + void testV7() { final String path = utils.getOutputDirectory()+"/plans.xml"; testWriteAndReread(w -> w.writeV6(IOUtils.getOutputStream(IOUtils.getFileUrl(path), false)), w -> w.readFile(path)); diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV4Test.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV4Test.java index 0706d6d3644..c406b80ada0 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV4Test.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV4Test.java @@ -27,7 +27,7 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -61,7 +61,7 @@ public class PopulationReaderMatsimV4Test { * @throws IOException */ @Test - public void testReadRoute() throws SAXException, ParserConfigurationException, IOException { + void testReadRoute() throws SAXException, ParserConfigurationException, IOException { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Network network = scenario.getNetwork(); final Population population = scenario.getPopulation(); @@ -154,7 +154,7 @@ public void testReadRoute() throws SAXException, ParserConfigurationException, I * @author mrieser */ @Test - public void testReadRouteWithoutActivityLinks() { + void testReadRouteWithoutActivityLinks() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Population population = scenario.getPopulation(); @@ -188,7 +188,7 @@ public void testReadRouteWithoutActivityLinks() { * @author mrieser */ @Test - public void testReadActivity() { + void testReadActivity() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Network network = (Network) scenario.getNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord(0, 0)); @@ -219,9 +219,9 @@ public void testReadActivity() { Assert.assertEquals(link3.getId(), ((Activity) plan.getPlanElements().get(0)).getLinkId()); Assert.assertEquals(Id.create("2", Link.class), ((Activity) plan.getPlanElements().get(2)).getLinkId()); } - + @Test - public void testReadingRoutesWithoutType() { + void testReadingRoutesWithoutType() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); PopulationReaderMatsimV4 reader = new PopulationReaderMatsimV4(scenario); final Population population = scenario.getPopulation(); @@ -276,7 +276,7 @@ public void testReadingRoutesWithoutType() { } @Test - public void testRepeatingLegs() { + void testRepeatingLegs() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); PopulationReaderMatsimV4 reader = new PopulationReaderMatsimV4(scenario); final Population population = scenario.getPopulation(); @@ -306,7 +306,7 @@ public void testRepeatingLegs() { } @Test - public void testRepeatingActs() { + void testRepeatingActs() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); PopulationReaderMatsimV4 reader = new PopulationReaderMatsimV4(scenario); final Population population = scenario.getPopulation(); diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV5Test.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV5Test.java index 95774b949dd..d6e6c4b31d9 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV5Test.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV5Test.java @@ -27,7 +27,7 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; import org.matsim.api.core.v01.population.Leg; @@ -52,7 +52,7 @@ public class PopulationReaderMatsimV5Test { @Test - public void testReadRoute() throws SAXException, ParserConfigurationException, IOException { + void testReadRoute() throws SAXException, ParserConfigurationException, IOException { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Population population = scenario.getPopulation(); @@ -136,7 +136,7 @@ public void testReadRoute() throws SAXException, ParserConfigurationException, I } @Test - public void testReadRoute_sameLinkRoute() throws SAXException, ParserConfigurationException, IOException { + void testReadRoute_sameLinkRoute() throws SAXException, ParserConfigurationException, IOException { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Population population = scenario.getPopulation(); @@ -172,7 +172,7 @@ public void testReadRoute_sameLinkRoute() throws SAXException, ParserConfigurati } @Test - public void testReadRoute_consequentLinks() throws SAXException, ParserConfigurationException, IOException { + void testReadRoute_consequentLinks() throws SAXException, ParserConfigurationException, IOException { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Population population = scenario.getPopulation(); @@ -215,7 +215,7 @@ public void testReadRoute_consequentLinks() throws SAXException, ParserConfigura * @author mrieser */ @Test - public void testReadRouteWithoutActivityLinks() { + void testReadRouteWithoutActivityLinks() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Population population = scenario.getPopulation(); @@ -246,7 +246,7 @@ public void testReadRouteWithoutActivityLinks() { } @Test - public void testReadingOldRoutesWithoutType() { + void testReadingOldRoutesWithoutType() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); PopulationReaderMatsimV5 reader = new PopulationReaderMatsimV5(scenario); final Population population = scenario.getPopulation(); @@ -301,12 +301,12 @@ public void testReadingOldRoutesWithoutType() { Assert.assertTrue(route3 instanceof TransitPassengerRoute); } - + /** * @author mrieser */ @Test - public void testReadActivity() { + void testReadActivity() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Population population = scenario.getPopulation(); @@ -333,7 +333,7 @@ public void testReadActivity() { } @Test - public void testRepeatingLegs() { + void testRepeatingLegs() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); PopulationReaderMatsimV5 reader = new PopulationReaderMatsimV5(scenario); final Population population = scenario.getPopulation(); @@ -363,7 +363,7 @@ public void testRepeatingLegs() { } @Test - public void testRepeatingActs() { + void testRepeatingActs() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); PopulationReaderMatsimV5 reader = new PopulationReaderMatsimV5(scenario); final Population population = scenario.getPopulation(); @@ -391,7 +391,7 @@ public void testRepeatingActs() { } @Test - public void testVehicleIdInRoute() { + void testVehicleIdInRoute() { final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); PopulationReaderMatsimV5 reader = new PopulationReaderMatsimV5(scenario); final Population population = scenario.getPopulation(); diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java index 7518db2c084..adeec746849 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java @@ -28,8 +28,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -52,7 +52,7 @@ import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; -/** + /** * @author thibautd */ public class PopulationReprojectionIOIT { @@ -69,8 +69,8 @@ public class PopulationReprojectionIOIT { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testInput_V4() { + @Test + void testInput_V4() { final String testFile = new File(utils.getOutputDirectory() + "/plans.xml.gz").getAbsolutePath(); // create test file in V4 format @@ -84,8 +84,8 @@ public void testInput_V4() { testConversionAtInput(testFile); } - @Test - public void testInput_V5() { + @Test + void testInput_V5() { final String testFile = new File(utils.getOutputDirectory() + "/plans.xml.gz").getAbsolutePath(); // create test file in V5 format @@ -99,8 +99,8 @@ public void testInput_V5() { testConversionAtInput(testFile); } - @Test - public void testOutput_V4() { + @Test + void testOutput_V4() { final String testFile = new File(utils.getOutputDirectory() + "/plans.xml.gz").getAbsolutePath(); // read test population @@ -125,8 +125,8 @@ public void testOutput_V4() { assertPopulationCorrectlyTransformed( originalScenario.getPopulation() , reprojectedScenario.getPopulation() ); } - @Test - public void testOutput_V5() { + @Test + void testOutput_V5() { final String testFile = new File(utils.getOutputDirectory() + "/plans.xml.gz").getAbsolutePath(); // read test population @@ -149,8 +149,8 @@ public void testOutput_V5() { assertPopulationCorrectlyTransformed( originalScenario.getPopulation() , reprojectedScenario.getPopulation() ); } - @Test - public void testWithControlerAndAttributes() { + @Test + void testWithControlerAndAttributes() { // accept a rounding error of 1 cm. // this is used both to compare equality and non-equality, so the more we accept difference between input // and output coordinates, the more we require the internally reprojected coordinates to be different. @@ -265,8 +265,8 @@ private URL getOutputURL() { } } - @Test - public void testWithControlerAndConfigParameters() { + @Test + void testWithControlerAndConfigParameters() { // accept a rounding error of 1 cm. // this is used both to compare equality and non-equality, so the more we accept difference between input // and output coordinates, the more we require the internally reprojected coordinates to be different. diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java index 07e7629c7cb..b30030727e9 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java @@ -22,8 +22,8 @@ package org.matsim.core.population.io; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -54,15 +54,15 @@ import java.util.Map; -/** + /** * @author thibautd */ public class PopulationV6IOTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testCoord3dIO() { + @Test + void testCoord3dIO() { final Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig() ); final Person person = population.getFactory().createPerson(Id.createPersonId( "Donald Trump")); @@ -95,8 +95,8 @@ public void testCoord3dIO() { MatsimTestUtils.EPSILON ); } - @Test - public void testEmptyPersonAttributesIO() { + @Test + void testEmptyPersonAttributesIO() { final Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig() ); final Person person = population.getFactory().createPerson(Id.createPersonId( "Donald Trump")); @@ -110,8 +110,8 @@ public void testEmptyPersonAttributesIO() { new PopulationReader( readScenario ).readFile( file ); } - @Test - public void testPersonAttributesIO() { + @Test + void testPersonAttributesIO() { final Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig() ); final Person person = population.getFactory().createPerson(Id.createPersonId( "Donald Trump")); @@ -145,8 +145,8 @@ public void testPersonAttributesIO() { VehicleUtils.getVehicleIds(readPerson) ); } - @Test - public void testActivityAttributesIO() { + @Test + void testActivityAttributesIO() { final Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig() ); final Person person = population.getFactory().createPerson(Id.createPersonId( "Donald Trump")); @@ -178,8 +178,8 @@ public void testActivityAttributesIO() { readAct.getAttributes().getAttribute( "length" ) ); } - @Test - public void testLegAttributesIO() { + @Test + void testLegAttributesIO() { final Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig() ); final Person person = population.getFactory().createPerson(Id.createPersonId( "Donald Trump")); @@ -212,8 +212,8 @@ public void testLegAttributesIO() { Assert.assertEquals("RoutingMode not set in Leg.", TransportMode.car, readLeg.getRoutingMode()); } - @Test - public void testLegAttributesLegacyIO() { + @Test + void testLegAttributesLegacyIO() { final Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig() ); final Person person = population.getFactory().createPerson(Id.createPersonId( "Donald Trump")); @@ -246,8 +246,8 @@ public void testLegAttributesLegacyIO() { Assert.assertEquals("RoutingMode not set in Leg.", TransportMode.car, readLeg.getRoutingMode()); } - @Test - public void testPlanAttributesIO() { + @Test + void testPlanAttributesIO() { final Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig() ); final Person person = population.getFactory().createPerson(Id.createPersonId( "Donald Trump")); @@ -275,8 +275,8 @@ public void testPlanAttributesIO() { readPlan.getAttributes().getAttribute( "beauty" ) ); } - @Test - public void testPopulationAttributesIO() { + @Test + void testPopulationAttributesIO() { final Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig() ); population.getAttributes().putAttribute( "type" , "candidates" ); @@ -297,9 +297,9 @@ public void testPopulationAttributesIO() { readScenario.getPopulation().getAttributes().getAttribute( "type" ) ); } - // see MATSIM-927, https://matsim.atlassian.net/browse/MATSIM-927 - @Test - public void testRouteIO() { + // see MATSIM-927, https://matsim.atlassian.net/browse/MATSIM-927 + @Test + void testRouteIO() { Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig()); PopulationFactory pf = population.getFactory(); @@ -332,9 +332,9 @@ public void testRouteIO() { Assert.assertEquals(route.getRouteDescription(), ((Leg) scenario.getPopulation().getPersons().get(person1.getId()).getSelectedPlan().getPlanElements().get(1)).getRoute().getRouteDescription()); } - // inspired from MATSIM-927, https://matsim.atlassian.net/browse/MATSIM-927 - @Test - public void testSpecialCharactersIO() { + // inspired from MATSIM-927, https://matsim.atlassian.net/browse/MATSIM-927 + @Test + void testSpecialCharactersIO() { Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig()); PopulationFactory pf = population.getFactory(); @@ -379,8 +379,8 @@ public void testSpecialCharactersIO() { Assert.assertEquals(route.getRouteDescription(), ((Leg) scenario.getPopulation().getPersons().get(person1.getId()).getSelectedPlan().getPlanElements().get(1)).getRoute().getRouteDescription()); } - @Test - public void testSingleActivityLocationInfoIO() { + @Test + void testSingleActivityLocationInfoIO() { Population population = PopulationUtils.createPopulation(ConfigUtils.createConfig()); PopulationFactory pf = population.getFactory(); @@ -432,8 +432,8 @@ public void testSingleActivityLocationInfoIO() { Assert.assertEquals(((Activity) pp1.getPlanElements().get(4)).getLinkId(), linkId); } - @Test - public void testPopulationCoordinateTransformationIO() { + @Test + void testPopulationCoordinateTransformationIO() { String outputDirectory = utils.getOutputDirectory(); // Create a population with CRS EPSG:25832 diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java index 7a242e6ab54..1de5e13e690 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -49,7 +49,8 @@ public class PopulationWriterHandlerImplV4Test { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteGenericRoute() { + @Test + void testWriteGenericRoute() { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(utils.loadConfig((String)null)); Network network = scenario.getNetwork(); new MatsimNetworkReader(scenario.getNetwork()).readFile("test/scenarios/equil/network.xml"); diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java index a0e79a87e89..a28f6de0734 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java @@ -24,8 +24,8 @@ import java.util.Stack; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -55,7 +55,7 @@ public class PopulationWriterHandlerImplV5Test { @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test - public void test_writeNetworkRoute_sameStartEndLink() { + void test_writeNetworkRoute_sameStartEndLink() { doTestWriteNetworkRoute("1", "", "1", "1"); // round trip @@ -63,12 +63,12 @@ public void test_writeNetworkRoute_sameStartEndLink() { } @Test - public void test_writeNetworkRoute_consequentLinks() { + void test_writeNetworkRoute_consequentLinks() { doTestWriteNetworkRoute("1", "", "2", "1 2"); } @Test - public void test_writeNetworkRoute_regularCase() { + void test_writeNetworkRoute_regularCase() { doTestWriteNetworkRoute("1", "2", "3", "1 2 3"); doTestWriteNetworkRoute("1", "2 3", "4", "1 2 3 4"); } @@ -117,7 +117,7 @@ private NetworkRoute doTestWriteNetworkRoute(final String startLinkId, final Str } @Test - public void testWriteGenericRouteRoute() { + void testWriteGenericRouteRoute() { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(this.util.loadConfig((String) null)); String startLinkId = "1"; String endLinkId = "4"; diff --git a/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java b/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java index de959287f47..add49f76e92 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java @@ -26,8 +26,8 @@ import java.util.function.Consumer; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -44,7 +44,7 @@ public class StreamingPopulationAttributeConversionTest { public final MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testDefaults() { + void testDefaults() { final String path = utils.getOutputDirectory() + "/plans.xml"; testWriteAndRereadStreaming((w, persons) -> { diff --git a/matsim/src/test/java/org/matsim/core/population/routes/AbstractNetworkRouteTest.java b/matsim/src/test/java/org/matsim/core/population/routes/AbstractNetworkRouteTest.java index d3158731d54..b3410153f72 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/AbstractNetworkRouteTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/AbstractNetworkRouteTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -50,7 +50,7 @@ public abstract class AbstractNetworkRouteTest { abstract protected NetworkRoute getNetworkRouteInstance(final Id fromLinkId, final Id toLinkId, final Network network); @Test - public void testSetLinkIds() { + void testSetLinkIds() { Network network = createTestNetwork(); List> links = NetworkUtils.getLinkIds("-22 2 3 24 14"); final Id link11 = Id.create(11, Link.class); @@ -68,7 +68,7 @@ public void testSetLinkIds() { } @Test - public void testSetLinks_linksNull() { + void testSetLinks_linksNull() { Network network = createTestNetwork(); Id link1 = Id.create("1", Link.class); Id link4 = Id.create("4", Link.class); @@ -88,7 +88,7 @@ public void testSetLinks_linksNull() { } @Test - public void testSetLinks_AllNull() { + void testSetLinks_AllNull() { Network network = createTestNetwork(); Id link1 = Id.create("1", Link.class); Id link4 = Id.create("4", Link.class); @@ -107,7 +107,7 @@ public void testSetLinks_AllNull() { } @Test - public void testGetDistance() { + void testGetDistance() { Network network = createTestNetwork(); Id link1 = Id.create("1", Link.class); Id link4 = Id.create("4", Link.class); @@ -119,7 +119,7 @@ public void testGetDistance() { } @Test - public void testGetLinkIds() { + void testGetLinkIds() { Network network = createTestNetwork(); Id link1 = Id.create("1", Link.class); Id link4 = Id.create("4", Link.class); @@ -135,7 +135,7 @@ public void testGetLinkIds() { } @Test - public void testGetSubRoute() { + void testGetSubRoute() { Network network = createTestNetwork(); Id id0 = Id.create("0", Link.class); Id id3 = Id.create("3", Link.class); @@ -156,7 +156,7 @@ public void testGetSubRoute() { } @Test - public void testGetSubRoute_fromStart() { + void testGetSubRoute_fromStart() { Network network = createTestNetwork(); Id id0 = Id.create("0", Link.class); Id id1 = Id.create("1", Link.class); @@ -180,7 +180,7 @@ public void testGetSubRoute_fromStart() { } @Test - public void testGetSubRoute_toEnd() { + void testGetSubRoute_toEnd() { Network network = createTestNetwork(); Id id0 = Id.create("0", Link.class); Id id3 = Id.create("3", Link.class); @@ -200,7 +200,7 @@ public void testGetSubRoute_toEnd() { } @Test - public void testGetSubRoute_startOnly() { + void testGetSubRoute_startOnly() { Network network = createTestNetwork(); Id id0 = Id.create("0", Link.class); Id id15 = Id.create("15", Link.class); @@ -215,7 +215,7 @@ public void testGetSubRoute_startOnly() { } @Test - public void testGetSubRoute_endOnly() { + void testGetSubRoute_endOnly() { Network network = createTestNetwork(); Id id0 = Id.create("0", Link.class); Id id15 = Id.create("15", Link.class); @@ -230,7 +230,7 @@ public void testGetSubRoute_endOnly() { } @Test - public void testGetSubRoute_wrongStart() { + void testGetSubRoute_wrongStart() { Network network = createTestNetwork(); Id id0 = Id.create("0", Link.class); Id id1 = Id.create("1", Link.class); @@ -247,7 +247,7 @@ public void testGetSubRoute_wrongStart() { } @Test - public void testGetSubRoute_wrongEnd() { + void testGetSubRoute_wrongEnd() { Network network = createTestNetwork(); Id id1 = Id.create("1", Link.class); Id id14 = Id.create("14", Link.class); @@ -264,7 +264,7 @@ public void testGetSubRoute_wrongEnd() { } @Test - public void testGetSubRoute_sameLinks() { + void testGetSubRoute_sameLinks() { Network network = createTestNetwork(); Id id1 = Id.create("1", Link.class); Id id12 = Id.create("12", Link.class); @@ -280,7 +280,7 @@ public void testGetSubRoute_sameLinks() { } @Test - public void testGetSubRoute_sameLinks_emptyRoute1() { + void testGetSubRoute_sameLinks_emptyRoute1() { Network network = createTestNetwork(); Id id1 = Id.create("1", Link.class); NetworkRoute route = getNetworkRouteInstance(id1, id1, network); @@ -294,7 +294,7 @@ public void testGetSubRoute_sameLinks_emptyRoute1() { } @Test - public void testGetSubRoute_sameLinks_emptyRoute2() { + void testGetSubRoute_sameLinks_emptyRoute2() { Network network = createTestNetwork(); Id id1 = Id.create("1", Link.class); Id id2 = Id.create("2", Link.class); @@ -315,7 +315,7 @@ public void testGetSubRoute_sameLinks_emptyRoute2() { } @Test - public void testGetSubRoute_fullRoute() { + void testGetSubRoute_fullRoute() { Network network = createTestNetwork(); Id id0 = Id.create("0", Link.class); Id id4 = Id.create("4", Link.class); @@ -335,7 +335,7 @@ public void testGetSubRoute_fullRoute() { } @Test - public void testGetSubRoute_circleInRoute() { + void testGetSubRoute_circleInRoute() { Network network = createTestNetwork(); NetworkUtils.createAndAddLink(network,Id.create(-3, Link.class), network.getNodes().get(Id.create(4, Node.class)), network.getNodes().get(Id.create(3, Node.class)), 1000.0, 100.0, 3600.0, (double) 1 ); Id id11 = Id.create("11", Link.class); @@ -358,7 +358,7 @@ public void testGetSubRoute_circleInRoute() { } @Test - public void testGetSubRoute_startInCircle() { + void testGetSubRoute_startInCircle() { Network network = createTestNetwork(); NetworkUtils.createAndAddLink(network,Id.create(-3, Link.class), network.getNodes().get(Id.create(4, Node.class)), network.getNodes().get(Id.create(3, Node.class)), 1000.0, 100.0, 3600.0, (double) 1 ); Id id11 = Id.create("11", Link.class); @@ -378,7 +378,7 @@ public void testGetSubRoute_startInCircle() { } @Test - public void testGetSubRoute_startInCircle_CircleInEnd() { + void testGetSubRoute_startInCircle_CircleInEnd() { Network network = createTestNetwork(); NetworkUtils.createAndAddLink(network,Id.create(-3, Link.class), network.getNodes().get(Id.create(4, Node.class)), network.getNodes().get(Id.create(3, Node.class)), 1000.0, 100.0, 3600.0, (double) 1 ); Id id11 = Id.create("11", Link.class); @@ -397,7 +397,7 @@ public void testGetSubRoute_startInCircle_CircleInEnd() { } @Test - public void testGetSubRoute_CircleAtStart() { + void testGetSubRoute_CircleAtStart() { Network network = createTestNetwork(); NetworkUtils.createAndAddLink(network,Id.create(-3, Link.class), network.getNodes().get(Id.create(4, Node.class)), network.getNodes().get(Id.create(3, Node.class)), 1000.0, 100.0, 3600.0, (double) 1 ); Id id13 = Id.create("13", Link.class); @@ -414,7 +414,7 @@ public void testGetSubRoute_CircleAtStart() { } @Test - public void testStartAndEndOnSameLinks_setLinks() { + void testStartAndEndOnSameLinks_setLinks() { Network network = createTestNetwork(); Id link = Id.create("3", Link.class); NetworkRoute route = getNetworkRouteInstance(link, link, network); @@ -423,7 +423,7 @@ public void testStartAndEndOnSameLinks_setLinks() { } @Test - public void testStartAndEndOnSubsequentLinks_setLinks() { + void testStartAndEndOnSubsequentLinks_setLinks() { Network network = createTestNetwork(); final Id link13 = Id.create("13", Link.class); final Id link14 = Id.create("14", Link.class); @@ -433,7 +433,7 @@ public void testStartAndEndOnSubsequentLinks_setLinks() { } @Test - public void testVehicleId() { + void testVehicleId() { Network network = createTestNetwork(); Id link0 = Id.create("0", Link.class); Id link15 = Id.create("15", Link.class); diff --git a/matsim/src/test/java/org/matsim/core/population/routes/LinkNetworkRouteTest.java b/matsim/src/test/java/org/matsim/core/population/routes/LinkNetworkRouteTest.java index 7c8ddcfa934..82fcb5fb6d7 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/LinkNetworkRouteTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/LinkNetworkRouteTest.java @@ -23,7 +23,7 @@ import java.util.ArrayList; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -40,7 +40,7 @@ public NetworkRoute getNetworkRouteInstance(final Id fromLinkId, final Id< } @Test - public void testClone() { + void testClone() { Id id1 = Id.create(1, Link.class); Id id2 = Id.create(2, Link.class); Id id3 = Id.create(3, Link.class); diff --git a/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java b/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java index d0025c9bb74..4288ce19e19 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java @@ -21,8 +21,8 @@ package org.matsim.core.population.routes; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.PopulationFactory; @@ -108,7 +108,8 @@ public String getCreatedRouteType() { } - @Test public void testSetRouteFactory() { + @Test + void testSetRouteFactory() { PopulationFactory factory = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getPopulation().getFactory(); // test default diff --git a/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryImplTest.java b/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryImplTest.java index 9f418fdeda1..943fb3c9adc 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryImplTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryImplTest.java @@ -18,8 +18,7 @@ * *********************************************************************** */ package org.matsim.core.population.routes; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -40,7 +39,7 @@ public class RouteFactoryImplTest { @Test - public void testConstructor_DefaultNetworkRouteType() { + void testConstructor_DefaultNetworkRouteType() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); PopulationFactory pf = scenario.getPopulation().getFactory(); @@ -52,7 +51,7 @@ public void testConstructor_DefaultNetworkRouteType() { } @Test - public void testConstructor_LinkNetworkRouteType() { + void testConstructor_LinkNetworkRouteType() { Config config = ConfigUtils.createConfig(); config.plans().setNetworkRouteType(PlansConfigGroup.NetworkRouteType.LinkNetworkRoute); Scenario scenario = ScenarioUtils.createScenario(config); @@ -65,7 +64,7 @@ public void testConstructor_LinkNetworkRouteType() { } @Test - public void testConstructor_HeavyCompressedNetworkRouteType() { + void testConstructor_HeavyCompressedNetworkRouteType() { Config config = ConfigUtils.createConfig(); config.plans().setNetworkRouteType(PlansConfigGroup.NetworkRouteType.HeavyCompressedNetworkRoute); Scenario scenario = ScenarioUtils.createScenario(config); @@ -78,7 +77,7 @@ public void testConstructor_HeavyCompressedNetworkRouteType() { } @Test - public void testConstructor_MediumCompressedNetworkRouteType() { + void testConstructor_MediumCompressedNetworkRouteType() { Config config = ConfigUtils.createConfig(); config.plans().setNetworkRouteType(PlansConfigGroup.NetworkRouteType.MediumCompressedNetworkRoute); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java b/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java index e72eb1ecde7..25b4b0ba526 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java @@ -21,8 +21,8 @@ package org.matsim.core.population.routes; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.*; import org.matsim.core.config.Config; @@ -50,7 +50,7 @@ public class RouteFactoryIntegrationTest { * Tests that the plans-reader and ReRoute-strategy module use the specified RouteFactory. */ @Test - public void testRouteFactoryIntegration() { + void testRouteFactoryIntegration() { Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); config.plans().setInputFile("plans2.xml"); Collection settings = config.replanning().getStrategySettings(); diff --git a/matsim/src/test/java/org/matsim/core/population/routes/heavycompressed/HeavyCompressedNetworkRouteTest.java b/matsim/src/test/java/org/matsim/core/population/routes/heavycompressed/HeavyCompressedNetworkRouteTest.java index 769da3bfc32..ed788d2cb1a 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/heavycompressed/HeavyCompressedNetworkRouteTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/heavycompressed/HeavyCompressedNetworkRouteTest.java @@ -21,7 +21,7 @@ package org.matsim.core.population.routes.heavycompressed; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -55,7 +55,7 @@ public NetworkRoute getNetworkRouteInstance(final Id fromLinkId, final Id< * different in this case where we do not actually store the links. */ @Test - public void testGetLinks_setLinks() { + void testGetLinks_setLinks() { Network network = createTestNetwork(); Link link1 = network.getLinks().get(Id.create("1", Link.class)); Link link22 = network.getLinks().get(Id.create("22", Link.class)); @@ -76,7 +76,7 @@ public void testGetLinks_setLinks() { } @Test - public void testGetLinks_onlySubsequentLinks() { + void testGetLinks_onlySubsequentLinks() { Network network = createTestNetwork(); Link link0 = network.getLinks().get(Id.create("0", Link.class)); Link link1 = network.getLinks().get(Id.create("1", Link.class)); @@ -107,7 +107,7 @@ public void testGetLinks_onlySubsequentLinks() { * hang when a route object is not correctly initialized. */ @Test - public void testGetLinkIds_incompleteInitialization() { + void testGetLinkIds_incompleteInitialization() { Network network = createTestNetwork(); Link link0 = network.getLinks().get(Id.create("0", Link.class)); Link link1 = network.getLinks().get(Id.create("1", Link.class)); @@ -129,7 +129,7 @@ public void testGetLinkIds_incompleteInitialization() { } @Test - public void testClone() { + void testClone() { Network network = NetworkUtils.createNetwork(); NetworkFactory builder = network.getFactory(); @@ -181,7 +181,7 @@ public void testClone() { } @Test - public void testGetLinks_setLinks_alternative() { + void testGetLinks_setLinks_alternative() { Network network = createTestNetwork(); Link link1 = network.getLinks().get(Id.create("1", Link.class)); Link link22 = network.getLinks().get(Id.create("22", Link.class)); @@ -202,7 +202,7 @@ public void testGetLinks_setLinks_alternative() { } @Test - public void testGetLinks_setLinks_endLoopLink() { + void testGetLinks_setLinks_endLoopLink() { Network network = createTestNetwork(); final Node node5 = network.getNodes().get(Id.create("5", Node.class)); @@ -228,7 +228,7 @@ public void testGetLinks_setLinks_endLoopLink() { } @Test - public void testGetLinks_setLinks_containsLargeLoop() { + void testGetLinks_setLinks_containsLargeLoop() { Network network = createTestNetwork(); final Node node13 = network.getNodes().get(Id.create("13", Node.class)); @@ -256,7 +256,7 @@ public void testGetLinks_setLinks_containsLargeLoop() { } @Test - public void testGetLinks_setLinks_containsLargeLoop_alternative() { + void testGetLinks_setLinks_containsLargeLoop_alternative() { Network network = createTestNetwork(); network.removeLink(Id.create("4", Link.class)); @@ -294,7 +294,7 @@ public void testGetLinks_setLinks_containsLargeLoop_alternative() { } @Test - public void testGetLinks_setLinks_isLargeLoop() { + void testGetLinks_setLinks_isLargeLoop() { Network network = createTestNetwork(); final Node node14 = network.getNodes().get(Id.create("14", Node.class)); diff --git a/matsim/src/test/java/org/matsim/core/population/routes/mediumcompressed/MediumCompressedNetworkRouteTest.java b/matsim/src/test/java/org/matsim/core/population/routes/mediumcompressed/MediumCompressedNetworkRouteTest.java index 4467fee0a63..483f7955606 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/mediumcompressed/MediumCompressedNetworkRouteTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/mediumcompressed/MediumCompressedNetworkRouteTest.java @@ -21,7 +21,7 @@ package org.matsim.core.population.routes.mediumcompressed; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -54,7 +54,7 @@ public NetworkRoute getNetworkRouteInstance(final Id fromLinkId, final Id< * different in this case where we do not actually store the links. */ @Test - public void testGetLinks_setLinks() { + void testGetLinks_setLinks() { Network network = createTestNetwork(); Link link1 = network.getLinks().get(Id.create("1", Link.class)); Link link22 = network.getLinks().get(Id.create("22", Link.class)); @@ -75,7 +75,7 @@ public void testGetLinks_setLinks() { } @Test - public void testGetLinks_onlySubsequentLinks() { + void testGetLinks_onlySubsequentLinks() { Network network = createTestNetwork(); Link link0 = network.getLinks().get(Id.create("0", Link.class)); Link link1 = network.getLinks().get(Id.create("1", Link.class)); @@ -100,7 +100,7 @@ public void testGetLinks_onlySubsequentLinks() { * hang when a route object is not correctly initialized. */ @Test - public void testGetLinkIds_incompleteInitialization() { + void testGetLinkIds_incompleteInitialization() { Network network = createTestNetwork(); Link link0 = network.getLinks().get(Id.create("0", Link.class)); Link link4 = network.getLinks().get(Id.create("4", Link.class)); @@ -113,7 +113,7 @@ public void testGetLinkIds_incompleteInitialization() { } @Test - public void testClone() { + void testClone() { Network network = NetworkUtils.createNetwork(); NetworkFactory builder = network.getFactory(); @@ -159,7 +159,7 @@ public void testClone() { } @Test - public void testGetLinks_setLinks_alternative() { + void testGetLinks_setLinks_alternative() { Network network = createTestNetwork(); Link link1 = network.getLinks().get(Id.create("1", Link.class)); Link link22 = network.getLinks().get(Id.create("22", Link.class)); @@ -180,7 +180,7 @@ public void testGetLinks_setLinks_alternative() { } @Test - public void testGetLinks_setLinks_endLoopLink() { + void testGetLinks_setLinks_endLoopLink() { Network network = createTestNetwork(); final Node node5 = network.getNodes().get(Id.create("5", Node.class)); @@ -206,7 +206,7 @@ public void testGetLinks_setLinks_endLoopLink() { } @Test - public void testGetLinks_setLinks_containsLargeLoop() { + void testGetLinks_setLinks_containsLargeLoop() { Network network = createTestNetwork(); final Node node13 = network.getNodes().get(Id.create("13", Node.class)); @@ -234,7 +234,7 @@ public void testGetLinks_setLinks_containsLargeLoop() { } @Test - public void testGetLinks_setLinks_containsLargeLoop_alternative() { + void testGetLinks_setLinks_containsLargeLoop_alternative() { Network network = createTestNetwork(); network.removeLink(Id.create("4", Link.class)); @@ -272,7 +272,7 @@ public void testGetLinks_setLinks_containsLargeLoop_alternative() { } @Test - public void testGetLinks_setLinks_isLargeLoop() { + void testGetLinks_setLinks_isLargeLoop() { Network network = createTestNetwork(); final Node node14 = network.getNodes().get(Id.create("14", Node.class)); diff --git a/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java b/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java index 8e4407f56e8..00f3b6ba499 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.population.Plan; import org.matsim.api.core.v01.replanning.PlanStrategyModule; import org.matsim.core.replanning.selectors.RandomPlanSelector; @@ -38,7 +38,8 @@ public class PlanStrategyTest { /** * @author mrieser */ - @Test public void testGetNumberOfStrategyModules() { + @Test + void testGetNumberOfStrategyModules() { final PlanStrategyImpl strategy = new PlanStrategyImpl(new RandomPlanSelector()); assertEquals(0, strategy.getNumberOfStrategyModules()); strategy.addStrategyModule(new DummyStrategyModule()); diff --git a/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerSubpopulationsTest.java b/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerSubpopulationsTest.java index a85d0c92315..df7709658c9 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerSubpopulationsTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerSubpopulationsTest.java @@ -23,7 +23,7 @@ import java.util.Random; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.HasPlansAndId; import org.matsim.api.core.v01.population.Person; @@ -42,7 +42,7 @@ public class StrategyManagerSubpopulationsTest { private static final String POP_NAME_2 = "buveurs_de_vin"; @Test - public void testStrategiesAreExecutedOnlyForGivenSubpopulation() { + void testStrategiesAreExecutedOnlyForGivenSubpopulation() { final StrategyManager manager = new StrategyManager(); final Random r = new Random(123); diff --git a/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerTest.java b/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerTest.java index 83457232183..90748e9f33b 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerTest.java @@ -21,7 +21,7 @@ package org.matsim.core.replanning; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.HasPlansAndId; import org.matsim.api.core.v01.population.Person; @@ -40,6 +40,7 @@ import java.util.List; import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.assertThrows; public class StrategyManagerTest { @@ -51,7 +52,7 @@ public class StrategyManagerTest { * @author mrieser */ @Test - public void testChangeRequests() { + void testChangeRequests() { MatsimRandom.reset(4711); Population population = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getPopulation(); @@ -126,12 +127,14 @@ public void testChangeRequests() { assertEquals(498, strategy4.getCounter()); } - @Test( expected=IllegalStateException.class ) - public void testAddTwiceStrategy() { - final StrategyManager manager = new StrategyManager(); - final PlanStrategy s = new PlanStrategyImpl.Builder( new RandomPlanSelector() ).build(); - manager.addStrategy( s , null , 1 ); - manager.addStrategy( s , null , 10 ); + @Test + void testAddTwiceStrategy() { + assertThrows(IllegalStateException.class, () -> { + final StrategyManager manager = new StrategyManager(); + final PlanStrategy s = new PlanStrategyImpl.Builder( new RandomPlanSelector() ).build(); + manager.addStrategy(s, null, 1); + manager.addStrategy(s, null, 10); + }); } /** @@ -141,7 +144,7 @@ public void testAddTwiceStrategy() { * @author mrieser */ @Test - public void testRemoveStrategy() { + void testRemoveStrategy() { MatsimRandom.reset(4711); Population population = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getPopulation(); @@ -200,7 +203,7 @@ public void testRemoveStrategy() { * @author mrieser */ @Test - public void testOptimisticBehavior() { + void testOptimisticBehavior() { Population population = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getPopulation(); Person person = null; @@ -250,7 +253,7 @@ public void testOptimisticBehavior() { } @Test - public void testSetPlanSelectorForRemoval() { + void testSetPlanSelectorForRemoval() { // init StrategyManager StrategyManager manager = new StrategyManager(); manager.addStrategy( new PlanStrategyImpl(new RandomPlanSelector()), null, 1.0 ); @@ -288,7 +291,7 @@ public void testSetPlanSelectorForRemoval() { } @Test - public void testGetStrategies() { + void testGetStrategies() { // init StrategyManager StrategyManager manager = new StrategyManager(); PlanStrategy str1 = new PlanStrategyImpl(new RandomPlanSelector()); @@ -306,9 +309,9 @@ public void testGetStrategies() { Assert.assertEquals(str2, strategies.get(1)); Assert.assertEquals(str3, strategies.get(2)); } - + @Test - public void testGetWeights() { + void testGetWeights() { // init StrategyManager StrategyManager manager = new StrategyManager(); PlanStrategy str1 = new PlanStrategyImpl(new RandomPlanSelector()); @@ -326,9 +329,9 @@ public void testGetWeights() { Assert.assertEquals(2.0, weights.get(1), 1e-8); Assert.assertEquals(0.5, weights.get(2), 1e-8); } - + @Test - public void testGetWeights_ChangeRequests() { + void testGetWeights_ChangeRequests() { // init StrategyManager StrategyManager manager = new StrategyManager(); PlanStrategy str1 = new PlanStrategyImpl(new RandomPlanSelector()); diff --git a/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java b/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java index e741f3d3066..4d2a55cfbb1 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java @@ -5,8 +5,8 @@ import java.util.List; import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -191,8 +191,8 @@ public void setup() { this.scenario = ScenarioUtils.createScenario(this.config); } - @Test - public void testLinearAnneal() throws IOException { + @Test + void testLinearAnneal() throws IOException { this.saConfigVar.setAnnealType("linear"); this.saConfigVar.setEndValue(0.0); this.saConfigVar.setStartValue(0.5); @@ -208,8 +208,8 @@ public void testLinearAnneal() throws IOException { Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } - @Test - public void testMsaAnneal() throws IOException { + @Test + void testMsaAnneal() throws IOException { this.saConfigVar.setAnnealType("msa"); this.saConfigVar.setShapeFactor(1.0); this.saConfigVar.setStartValue(0.5); @@ -225,8 +225,8 @@ public void testMsaAnneal() throws IOException { Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } - @Test - public void testGeometricAnneal() throws IOException { + @Test + void testGeometricAnneal() throws IOException { this.saConfigVar.setAnnealType("geometric"); this.saConfigVar.setShapeFactor(0.9); this.saConfigVar.setStartValue(0.5); @@ -242,8 +242,8 @@ public void testGeometricAnneal() throws IOException { Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } - @Test - public void testExponentialAnneal() throws IOException { + @Test + void testExponentialAnneal() throws IOException { this.saConfigVar.setAnnealType("exponential"); this.saConfigVar.setHalfLife(0.5); this.saConfigVar.setStartValue(0.5); @@ -259,8 +259,8 @@ public void testExponentialAnneal() throws IOException { Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } - @Test - public void testSigmoidAnneal() throws IOException { + @Test + void testSigmoidAnneal() throws IOException { this.saConfigVar.setAnnealType("sigmoid"); this.saConfigVar.setHalfLife(0.5); this.saConfigVar.setShapeFactor(1.0); @@ -277,8 +277,8 @@ public void testSigmoidAnneal() throws IOException { Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } - @Test - public void testParameterAnneal() throws IOException { + @Test + void testParameterAnneal() throws IOException { this.saConfigVar.setAnnealType("linear"); this.saConfigVar.setAnnealParameter("BrainExpBeta"); this.saConfigVar.setEndValue(0.0); @@ -291,8 +291,8 @@ public void testParameterAnneal() throws IOException { Assert.assertEquals(0.0, controler.getConfig().scoring().getBrainExpBeta(), 1e-4); } - @Test - public void testTwoParameterAnneal() throws IOException { + @Test + void testTwoParameterAnneal() throws IOException { this.saConfigVar.setAnnealType("msa"); this.saConfigVar.setShapeFactor(1.0); this.saConfigVar.setStartValue(0.5); @@ -316,8 +316,8 @@ public void testTwoParameterAnneal() throws IOException { Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } - @Test - public void testInnovationSwitchoffAnneal() throws IOException { + @Test + void testInnovationSwitchoffAnneal() throws IOException { this.config.replanning().setFractionOfIterationsToDisableInnovation(0.5); this.saConfigVar.setAnnealType("msa"); this.saConfigVar.setShapeFactor(1.0); @@ -334,8 +334,8 @@ public void testInnovationSwitchoffAnneal() throws IOException { Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } - @Test - public void testFreezeEarlyAnneal() throws IOException { + @Test + void testFreezeEarlyAnneal() throws IOException { this.saConfigVar.setAnnealType("msa"); this.saConfigVar.setShapeFactor(1.0); this.saConfigVar.setEndValue(0.1); @@ -352,8 +352,8 @@ public void testFreezeEarlyAnneal() throws IOException { Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } - @Test - public void testSubpopulationAnneal() throws IOException { + @Test + void testSubpopulationAnneal() throws IOException { String targetSubpop = "subpop"; this.saConfigVar.setAnnealType("linear"); this.saConfigVar.setEndValue(0.0); diff --git a/matsim/src/test/java/org/matsim/core/replanning/choosers/ForceInnovationStrategyChooserTest.java b/matsim/src/test/java/org/matsim/core/replanning/choosers/ForceInnovationStrategyChooserTest.java index 6e292e5c75f..b6683edb58c 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/choosers/ForceInnovationStrategyChooserTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/choosers/ForceInnovationStrategyChooserTest.java @@ -1,12 +1,12 @@ package org.matsim.core.replanning.choosers; -import org.junit.Test; - import java.util.ArrayList; import java.util.List; import static org.junit.Assert.*; +import org.junit.jupiter.api.Test; + public class ForceInnovationStrategyChooserTest { private static final int N = 10000; @@ -16,7 +16,7 @@ public class ForceInnovationStrategyChooserTest { * Shows how numbers are selected and permuted every iteration. */ @Test - public void permutation() { + void permutation() { List collected = new ArrayList<>(); diff --git a/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java b/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java index 66db3fd7806..1015bd7582c 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java @@ -2,8 +2,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.IdSet; @@ -42,7 +42,7 @@ public class ReplanningWithConflictsTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testModeRestriction() { + void testModeRestriction() { /* * This is the possibly simplest use of the the conflict resolution logic. We * have 100 agents and two modes, one is "unrestricted", the other one is diff --git a/matsim/src/test/java/org/matsim/core/replanning/modules/AbstractMultithreadedModuleTest.java b/matsim/src/test/java/org/matsim/core/replanning/modules/AbstractMultithreadedModuleTest.java index cc7eedfddeb..042b090e267 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/modules/AbstractMultithreadedModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/modules/AbstractMultithreadedModuleTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Plan; import org.matsim.core.config.Config; import org.matsim.core.config.groups.GlobalConfigGroup; @@ -37,7 +37,7 @@ public class AbstractMultithreadedModuleTest { private final static Logger log = LogManager.getLogger(AbstractMultithreadedModuleTest.class); @Test - public void testGetNumOfThreads() { + void testGetNumOfThreads() { Config config = new Config(); config.addCoreModules(); config.global().setNumberOfThreads(3); @@ -46,7 +46,7 @@ public void testGetNumOfThreads() { } @Test - public void testCrashingThread() { + void testCrashingThread() { try { DummyCrashingModule testee = new DummyCrashingModule(2); testee.prepareReplanning(null); diff --git a/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeLegModeTest.java b/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeLegModeTest.java index d54116712d7..b3fb4b3a27c 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeLegModeTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeLegModeTest.java @@ -21,7 +21,7 @@ package org.matsim.core.replanning.modules; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -43,7 +43,7 @@ public class ChangeLegModeTest { @Test - public void testDefaultModes() { + void testDefaultModes() { Config config = ConfigUtils.createConfig(); config.global().setNumberOfThreads(0); @@ -53,7 +53,7 @@ public void testDefaultModes() { } @Test - public void testWithConfig() { + void testWithConfig() { Config config = ConfigUtils.createConfig(); config.global().setNumberOfThreads(0); config.setParam(ChangeModeConfigGroup.CONFIG_MODULE, ChangeModeConfigGroup.CONFIG_PARAM_MODES, " car,pt ,bike,walk "); @@ -64,7 +64,7 @@ public void testWithConfig() { } @Test - public void test_behavior_allowSwitchFromListedModesOnly() { + void test_behavior_allowSwitchFromListedModesOnly() { Config config = ConfigUtils.createConfig(); config.global().setNumberOfThreads(0); config.setParam(ChangeModeConfigGroup.CONFIG_MODULE, ChangeModeConfigGroup.CONFIG_PARAM_MODES, "pt,bike,walk"); // do not include car @@ -76,7 +76,7 @@ public void test_behavior_allowSwitchFromListedModesOnly() { } @Test - public void test_behavior_fromAllModesToSpecifiedModes() { + void test_behavior_fromAllModesToSpecifiedModes() { Config config = ConfigUtils.createConfig(); config.global().setNumberOfThreads(0); config.setParam(ChangeModeConfigGroup.CONFIG_MODULE, ChangeModeConfigGroup.CONFIG_PARAM_MODES, "pt,bike,walk"); // do not include car @@ -88,14 +88,14 @@ public void test_behavior_fromAllModesToSpecifiedModes() { } @Test - public void testWithConstructor() { + void testWithConstructor() { final ChangeLegMode module = new ChangeLegMode(0, new String[] {"car", "pt", "bike", "walk"}, true, false); final String[] modes = new String[] {TransportMode.car, TransportMode.pt, TransportMode.bike, TransportMode.walk}; runTest(module, modes); } @Test - public void testWithConfig_withoutIgnoreCarAvailability() { + void testWithConfig_withoutIgnoreCarAvailability() { Config config = ConfigUtils.createConfig(); config.global().setNumberOfThreads(0); config.setParam(ChangeModeConfigGroup.CONFIG_MODULE, ChangeModeConfigGroup.CONFIG_PARAM_MODES, "car,pt,walk"); diff --git a/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeSingleLegModeTest.java b/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeSingleLegModeTest.java index 8b3b1a8bc8d..fd66a829450 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeSingleLegModeTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeSingleLegModeTest.java @@ -24,7 +24,7 @@ import java.util.Map; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -43,7 +43,7 @@ public class ChangeSingleLegModeTest { @Test - public void testDefaultModes() { + void testDefaultModes() { Config config = ConfigUtils.createConfig(); config.global().setNumberOfThreads(0); @@ -53,7 +53,7 @@ public void testDefaultModes() { } @Test - public void testWithConfig() { + void testWithConfig() { Config config = ConfigUtils.createConfig(); config.global().setNumberOfThreads(0); config.setParam(ChangeModeConfigGroup.CONFIG_MODULE, ChangeModeConfigGroup.CONFIG_PARAM_MODES, " car,pt ,bike,walk "); @@ -62,16 +62,16 @@ public void testWithConfig() { final String[] modes = new String[] {TransportMode.car, TransportMode.pt, TransportMode.bike, TransportMode.walk}; runTest(module, modes, 20); } - + @Test - public void testWithConstructor() { + void testWithConstructor() { final ChangeSingleLegMode module = new ChangeSingleLegMode(0, new String[] {"car", "pt", "bike", "walk"}, true); final String[] modes = new String[] {TransportMode.car, TransportMode.pt, TransportMode.bike, TransportMode.walk}; runTest(module, modes, 20); } @Test - public void testWithConfig_withoutIgnoreCarAvailability() { + void testWithConfig_withoutIgnoreCarAvailability() { Config config = ConfigUtils.createConfig(); config.global().setNumberOfThreads(0); config.setParam(ChangeModeConfigGroup.CONFIG_MODULE, ChangeModeConfigGroup.CONFIG_PARAM_MODES, "car,pt,walk"); diff --git a/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java b/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java index 6612877c0f1..d739f20c19c 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java @@ -24,8 +24,8 @@ import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Population; @@ -71,8 +71,8 @@ public void setUp() { // prepareForSim.run(); } - @Test - public void testNoOpExternalModule() { + @Test + void testNoOpExternalModule() { ExternalModule testee = new ExternalModule(new ExternalModule.ExeRunnerDelegate() { @Override public boolean invoke() { @@ -85,8 +85,8 @@ public boolean invoke() { Assert.assertTrue(PopulationUtils.equalPopulation(scenario.getPopulation(), originalScenario.getPopulation())); } - @Test - public void testPlanEmptyingExternalModule() { + @Test + void testPlanEmptyingExternalModule() { ExternalModule testee = new ExternalModule(new ExternalModule.ExeRunnerDelegate() { @Override public boolean invoke() { diff --git a/matsim/src/test/java/org/matsim/core/replanning/planInheritance/PlanInheritanceTest.java b/matsim/src/test/java/org/matsim/core/replanning/planInheritance/PlanInheritanceTest.java index e6ca4326678..d1063c87dd6 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/planInheritance/PlanInheritanceTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/planInheritance/PlanInheritanceTest.java @@ -7,8 +7,9 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.List; + +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -24,7 +25,6 @@ import org.matsim.testcases.MatsimTestUtils; - public class PlanInheritanceTest { /** * @author alex94263 @@ -33,8 +33,8 @@ public class PlanInheritanceTest { @RegisterExtension public MatsimTestUtils util = new MatsimTestUtils(); - @Test - public void testPlanInheritanceEnabled() throws IOException { + @Test + void testPlanInheritanceEnabled() throws IOException { String outputDirectory = util.getOutputDirectory(); Config config = this.util.loadConfig("test/scenarios/equil/config_plans1.xml"); @@ -91,8 +91,8 @@ public void run(Person person) { } - @Test - public void testPlanInheritanceDisabled() throws IOException { + @Test + void testPlanInheritanceDisabled() throws IOException { String outputDirectory = util.getOutputDirectory(); Config config = this.util.loadConfig("test/scenarios/equil/config_plans1.xml"); diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java index d6c414c47ee..8b0774ada00 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java @@ -23,8 +23,8 @@ import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.HasPlansAndId; import org.matsim.api.core.v01.population.Person; @@ -57,7 +57,8 @@ public abstract class AbstractPlanSelectorTest { * * @author mrieser */ - @Test public void testUndefinedScore() { + @Test + void testUndefinedScore() { Person person; PlanSelector selector = getPlanSelector(); Plan plan; @@ -98,7 +99,8 @@ public abstract class AbstractPlanSelectorTest { * * @author mrieser */ - @Test public void testNoPlans() { + @Test + void testNoPlans() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); assertNull(getPlanSelector().selectPlan(person)); } @@ -109,7 +111,8 @@ public abstract class AbstractPlanSelectorTest { * * @author mrieser */ - @Test public void testNegativeScore() { + @Test + void testNegativeScore() { PlanSelector selector = getPlanSelector(); Plan plan; // test with only one plan... @@ -147,7 +150,8 @@ public abstract class AbstractPlanSelectorTest { * Test how a plan selector reacts when a plan has a score of zero (0.0). * This test only ensures that a plan is returned and no Exception occurred when selecting a plan. */ - @Test public void testZeroScore() { + @Test + void testZeroScore() { PlanSelector selector = getPlanSelector(); Plan plan; Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/BestPlanSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/BestPlanSelectorTest.java index c6cfca634b7..53a61e636db 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/BestPlanSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/BestPlanSelectorTest.java @@ -23,7 +23,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNull; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -47,7 +47,8 @@ protected PlanSelector getPlanSelector() { * * @author mrieser */ - @Test public void testBestPlan() { + @Test + void testBestPlan() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan plan; PersonUtils.createAndAddPlan(person, false); diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java index 5de64cd172d..fa08c8705d5 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.Logger; import org.junit.After; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -60,7 +60,8 @@ protected ExpBetaPlanSelector getPlanSelector() { /** * Test that plans are selected depending on their weight, use beta = 2.0. */ - @Test public void testExpBeta2() { + @Test + void testExpBeta2() { this.config.scoring().setBrainExpBeta(2.0); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); // weight = Math.exp(this.beta * (plan.getScore() - maxScore)); @@ -112,7 +113,8 @@ protected ExpBetaPlanSelector getPlanSelector() { /** * Test that plans are selected depending on their weight, use beta = 2.0. */ - @Test public void testExpBeta1() { + @Test + void testExpBeta1() { this.config.scoring().setBrainExpBeta(1.0); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); // weight = Math.exp(this.beta * (plan.getScore() - maxScore)); @@ -168,7 +170,8 @@ protected ExpBetaPlanSelector getPlanSelector() { assertEquals(6460, cnt5); } - @Test public void testGetSelectionProbability() { + @Test + void testGetSelectionProbability() { /* * the expected results were computed with R. The standard output of double precision numbers in R has 7 digits. diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/KeepSelectedTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/KeepSelectedTest.java index fc257f49907..97f74593bc3 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/KeepSelectedTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/KeepSelectedTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.assertEquals; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -46,7 +46,8 @@ protected KeepSelected getPlanSelector() { * * @author mrieser */ - @Test public void testSelected() { + @Test + void testSelected() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan plan1 = PersonUtils.createAndAddPlan(person, false); Plan plan2 = PersonUtils.createAndAddPlan(person, true); diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java index f21680b1ea9..6a50781d5c5 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java @@ -29,7 +29,7 @@ import org.apache.logging.log4j.Logger; import org.junit.After; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -215,7 +215,8 @@ protected PlanSelector getPlanSelector() { assertNotNull(selector.selectPlan(person)); } - @Test public void testPathSizeLogitSelector() { + @Test + void testPathSizeLogitSelector() { this.network = createNetwork(); Link l1 = network.getLinks().get(Id.create("1", Link.class)); diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/RandomPlanSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/RandomPlanSelectorTest.java index 9d21f06c9aa..2d1bd9c14b5 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/RandomPlanSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/RandomPlanSelectorTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -48,7 +48,8 @@ protected PlanSelector getPlanSelector() { /** * Test that each of a person's plans is randomly selected. */ - @Test public void testRandom() { + @Test + void testRandom() { Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan plan1 = PersonUtils.createAndAddPlan(person, false); Plan plan2 = PersonUtils.createAndAddPlan(person, false); diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/WorstPlanForRemovalSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/WorstPlanForRemovalSelectorTest.java index 10058a49a59..631173aa68d 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/WorstPlanForRemovalSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/WorstPlanForRemovalSelectorTest.java @@ -22,7 +22,7 @@ import static org.junit.Assert.*; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -40,7 +40,8 @@ protected PlanSelector getPlanSelector() { * * @author mrieser */ - @Test public void testRemoveWorstPlans_nullType() { + @Test + void testRemoveWorstPlans_nullType() { PlanSelector selector = getPlanSelector(); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -80,7 +81,8 @@ protected PlanSelector getPlanSelector() { * * @author mrieser */ - @Test public void testRemoveWorstPlans_withTypes() { + @Test + void testRemoveWorstPlans_withTypes() { PlanSelector selector = getPlanSelector(); /* The used plans, ordered by score: * plan2: b, 22.0 diff --git a/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java b/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java index bbf1f35fa4f..1e32151930b 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java +++ b/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java @@ -23,8 +23,8 @@ import com.google.inject.Singleton; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.controler.AbstractModule; @@ -66,7 +66,7 @@ public class DeterministicMultithreadedReplanningIT { * with the same number of threads. */ @Test - public void testTimeAllocationMutator() { + void testTimeAllocationMutator() { int lastIteration = 5; Config config = testUtils.loadConfig("test/scenarios/equil/config.xml"); config.controller().setLastIteration(lastIteration); @@ -113,7 +113,7 @@ public void testTimeAllocationMutator() { * the same results with the same number of threads. */ @Test - public void testReRouteTimeAllocationMutator() { + void testReRouteTimeAllocationMutator() { int lastIteration = 5; Config config = testUtils.loadConfig("test/scenarios/equil/config.xml"); config.controller().setLastIteration(lastIteration); @@ -166,7 +166,7 @@ public void testReRouteTimeAllocationMutator() { * REGARDLESS the number of threads using only one agent. */ @Test - public void testReRouteOneAgent() { + void testReRouteOneAgent() { int lastIteration = 5; Config config = testUtils.loadConfig("test/scenarios/equil/config.xml"); @@ -221,7 +221,7 @@ public void testReRouteOneAgent() { * REGARDLESS the same number of threads. */ @Test - public void testReRoute() { + void testReRoute() { int lastIteration = 5; Config config = testUtils.loadConfig("test/scenarios/equil/config.xml"); config.controller().setLastIteration(lastIteration); diff --git a/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java b/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java index 62aa5944e92..16d45333e37 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java @@ -24,10 +24,10 @@ import com.google.inject.*; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -62,7 +62,7 @@ public class InnovationSwitchOffTest { * Integration test for testing if switching off of innovative strategies works. */ @Test - public void testInnovationSwitchOff() { + void testInnovationSwitchOff() { Config config = ConfigUtils.createConfig(ExamplesUtils.getTestScenarioURL("equil")); config.controller().setOutputDirectory(this.utils.getOutputDirectory()); diff --git a/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java b/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java index c27cf25f777..e82ed18aab7 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java @@ -23,8 +23,8 @@ import static org.junit.Assert.assertTrue; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -56,7 +56,8 @@ public class TimeAllocationMutatorModuleTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testSimplifiedMutation() { + @Test + void testSimplifiedMutation() { boolean affectingDuration = true ; runSimplifiedMutationRangeTest(new MutateActivityTimeAllocation( 750, affectingDuration, MatsimRandom.getLocalInstance(),24*3600,false,1), 750); @@ -150,7 +151,7 @@ private static void assertValueInRange(final String message, final double actual @Test - public void testRun() { + void testRun() { // setup population with one person Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan plan = PersonUtils.createAndAddPlan(person, true); @@ -188,7 +189,7 @@ public void testRun() { } @Test - public void testRunLatestEndTime() { + void testRunLatestEndTime() { // setup population with one person Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan plan = PersonUtils.createAndAddPlan(person, true); @@ -243,8 +244,9 @@ public void testRunLatestEndTime() { } } } + @Test - public void testLegTimesAreSetCorrectly() { + void testLegTimesAreSetCorrectly() { // setup population with one person Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan plan = PersonUtils.createAndAddPlan(person, true); diff --git a/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java b/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java index ecad20f4e9b..67ccf869eeb 100644 --- a/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java @@ -26,8 +26,8 @@ import javax.xml.parsers.ParserConfigurationException; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -54,7 +54,8 @@ public abstract class AbstractLeastCostPathCalculatorTest { private static final String MODE_RESTRICTION_NOT_SUPPORTED = "Router algo does not support mode restrictions. "; - @Test public void testCalcLeastCostPath_Normal() throws SAXException, ParserConfigurationException, IOException { + @Test + void testCalcLeastCostPath_Normal() throws SAXException, ParserConfigurationException, IOException { Config config = utils.loadConfig((String)null); Scenario scenario = ScenarioUtils.createScenario(config); Network network = scenario.getNetwork(); @@ -76,7 +77,8 @@ public abstract class AbstractLeastCostPathCalculatorTest { assertEquals(network.getLinks().get(Id.create("22", Link.class)), path.links.get(2)); } - @Test public void testCalcLeastCostPath_SameFromTo() throws SAXException, ParserConfigurationException, IOException { + @Test + void testCalcLeastCostPath_SameFromTo() throws SAXException, ParserConfigurationException, IOException { Scenario scenario = ScenarioUtils.createScenario(utils.loadConfig((String)null)); Network network = scenario.getNetwork(); new MatsimNetworkReader(scenario.getNetwork()).readFile("test/scenarios/equil/network.xml"); diff --git a/matsim/src/test/java/org/matsim/core/router/DefaultAnalysisMainModeIdentifierTest.java b/matsim/src/test/java/org/matsim/core/router/DefaultAnalysisMainModeIdentifierTest.java index 2f38c60ab90..cfb9a453501 100644 --- a/matsim/src/test/java/org/matsim/core/router/DefaultAnalysisMainModeIdentifierTest.java +++ b/matsim/src/test/java/org/matsim/core/router/DefaultAnalysisMainModeIdentifierTest.java @@ -1,6 +1,6 @@ package org.matsim.core.router; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.PlanElement; import org.matsim.core.population.PopulationUtils; @@ -21,7 +21,7 @@ private static List legs(String... modes) { } @Test - public void correctModes() { + void correctModes() { assertThat(mmi.identifyMainMode(legs(TransportMode.walk, TransportMode.car, TransportMode.walk))) .isEqualTo(TransportMode.car); @@ -44,7 +44,7 @@ public void correctModes() { } @Test - public void failingModes() { + void failingModes() { assertThatThrownBy(() -> mmi.identifyMainMode(legs("new_mode", TransportMode.walk, "other_new_mode"))). isInstanceOf(IllegalStateException.class); @@ -61,7 +61,7 @@ public void failingModes() { } @Test - public final void testIntermodalPtDrtTrip() { + final void testIntermodalPtDrtTrip() { assertThat(mmi.identifyMainMode(legs(TransportMode.non_network_walk, TransportMode.walk, TransportMode.non_network_walk, TransportMode.drt, TransportMode.walk, TransportMode.pt, TransportMode.walk, TransportMode.pt, TransportMode.walk))) diff --git a/matsim/src/test/java/org/matsim/core/router/FallbackRoutingModuleTest.java b/matsim/src/test/java/org/matsim/core/router/FallbackRoutingModuleTest.java index 97d039dd334..b2654bc7734 100644 --- a/matsim/src/test/java/org/matsim/core/router/FallbackRoutingModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/FallbackRoutingModuleTest.java @@ -2,8 +2,8 @@ import java.util.List; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -30,7 +30,7 @@ public class FallbackRoutingModuleTest{ @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void calcRoute(){ + void calcRoute(){ Config config = ConfigUtils.createConfig(); config.controller().setOutputDirectory( utils.getOutputDirectory() ); diff --git a/matsim/src/test/java/org/matsim/core/router/InvertertedNetworkRoutingTest.java b/matsim/src/test/java/org/matsim/core/router/InvertertedNetworkRoutingTest.java index 4f1a60665cd..22f15d7f73e 100644 --- a/matsim/src/test/java/org/matsim/core/router/InvertertedNetworkRoutingTest.java +++ b/matsim/src/test/java/org/matsim/core/router/InvertertedNetworkRoutingTest.java @@ -18,8 +18,7 @@ * * * *********************************************************************** */ package org.matsim.core.router; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.*; import org.matsim.api.core.v01.network.*; import org.matsim.api.core.v01.population.*; @@ -45,7 +44,7 @@ public class InvertertedNetworkRoutingTest { @Test - public void testInvertedNetworkLegRouter() { + void testInvertedNetworkLegRouter() { Fixture f = new Fixture(); LinkToLinkTravelTimeStub tt = new LinkToLinkTravelTimeStub(); TravelDisutilityFactory tc = new RandomizingTimeDistanceTravelDisutilityFactory( TransportMode.car, f.s.getConfig() ); diff --git a/matsim/src/test/java/org/matsim/core/router/MultimodalLinkChooserTest.java b/matsim/src/test/java/org/matsim/core/router/MultimodalLinkChooserTest.java index d3691722e80..c7dfc9741e8 100644 --- a/matsim/src/test/java/org/matsim/core/router/MultimodalLinkChooserTest.java +++ b/matsim/src/test/java/org/matsim/core/router/MultimodalLinkChooserTest.java @@ -20,7 +20,7 @@ package org.matsim.core.router; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -43,8 +43,8 @@ public class MultimodalLinkChooserTest { - @Test - public void testDecideOnLink() { + @Test + void testDecideOnLink() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); diff --git a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java index 4883342c79d..5329d4c68ee 100644 --- a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java @@ -1,7 +1,7 @@ package org.matsim.core.router; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.util.Assert; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -34,6 +34,7 @@ import java.util.stream.Collectors; import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.assertThrows; public class NetworkRoutingInclAccessEgressModuleTest { @@ -177,8 +178,8 @@ private static List> getNetworkRoute(List elements) { .collect(Collectors.toList()); } - @Test - public void calcRoute_modeVehiclesFromVehiclesData_differentTypesTakeDifferentRoutes() { + @Test + void calcRoute_modeVehiclesFromVehiclesData_differentTypesTakeDifferentRoutes() { Config config = createConfig(); @@ -230,10 +231,8 @@ public void calcRoute_modeVehiclesFromVehiclesData_differentTypesTakeDifferentRo } - - - @Test - public void calcRoute_defaultVehicle_defaultVehicleIsAssigned() { + @Test + void calcRoute_defaultVehicle_defaultVehicleIsAssigned() { Config config = createConfig(); config.qsim().setVehiclesSource(QSimConfigGroup.VehiclesSource.defaultVehicle); @@ -258,8 +257,8 @@ public void calcRoute_defaultVehicle_defaultVehicleIsAssigned() { } - @Test - public void useAccessEgressTimeFromLinkAttributes() { + @Test + void useAccessEgressTimeFromLinkAttributes() { Config config = createConfig(); config.qsim().setVehiclesSource(QSimConfigGroup.VehiclesSource.defaultVehicle); @@ -279,8 +278,8 @@ public void useAccessEgressTimeFromLinkAttributes() { Assert.equals(180.0,legs.get(2).getTravelTime().seconds()); } - @Test - public void useAccessEgressTimeFromConstantAndWalkTime() { + @Test + void useAccessEgressTimeFromConstantAndWalkTime() { Config config = createConfig(); config.qsim().setVehiclesSource(QSimConfigGroup.VehiclesSource.defaultVehicle); @@ -302,8 +301,8 @@ public void useAccessEgressTimeFromConstantAndWalkTime() { Assert.equals(180.0,legs.get(2).getTravelTime().seconds()); } - @Test - public void routingModeInEvents() { + @Test + void routingModeInEvents() { Config config = createConfig(); config.qsim().setVehiclesSource(QSimConfigGroup.VehiclesSource.defaultVehicle); @@ -344,37 +343,41 @@ public void handleEvent(PersonDepartureEvent event) { Assert.isTrue(routingModes.contains("car")); } - @Test(expected = RuntimeException.class) - public void failifNoAccessTimeSet() { - - Config config = createConfig(); - config.qsim().setVehiclesSource(QSimConfigGroup.VehiclesSource.defaultVehicle); - config.routing().setAccessEgressType(RoutingConfigGroup.AccessEgressType.walkConstantTimeToLink); - Scenario scenario = createScenario(config); - NetworkUtils.setLinkAccessTime(scenario.getNetwork().getLinks().get(Id.createLinkId(START_LINK)),TransportMode.car,75); - Person person = createPerson("slow-person", TransportMode.car, scenario.getPopulation().getFactory()); - scenario.getPopulation().addPerson(person); - Controler controler = createControler(scenario); - controler.run(); - } - - - @Test(expected = RuntimeException.class) - public void failifNoEgressTimeSet() { - - Config config = createConfig(); - config.qsim().setVehiclesSource(QSimConfigGroup.VehiclesSource.defaultVehicle); - config.routing().setAccessEgressType(AccessEgressType.walkConstantTimeToLink); - Scenario scenario = createScenario(config); - NetworkUtils.setLinkEgressTime(scenario.getNetwork().getLinks().get(Id.createLinkId(END_LINK)),TransportMode.car,180); - Person person = createPerson("slow-person", TransportMode.car, scenario.getPopulation().getFactory()); - scenario.getPopulation().addPerson(person); - Controler controler = createControler(scenario); - controler.run(); - } + @Test + void failifNoAccessTimeSet() { + assertThrows(RuntimeException.class, () -> { + + Config config = createConfig(); + config.qsim().setVehiclesSource(QSimConfigGroup.VehiclesSource.defaultVehicle); + config.routing().setAccessEgressType(RoutingConfigGroup.AccessEgressType.walkConstantTimeToLink); + Scenario scenario = createScenario(config); + NetworkUtils.setLinkAccessTime(scenario.getNetwork().getLinks().get(Id.createLinkId(START_LINK)), TransportMode.car, 75); + Person person = createPerson("slow-person", TransportMode.car, scenario.getPopulation().getFactory()); + scenario.getPopulation().addPerson(person); + Controler controler = createControler(scenario); + controler.run(); + }); + } + + + @Test + void failifNoEgressTimeSet() { + assertThrows(RuntimeException.class, () -> { + + Config config = createConfig(); + config.qsim().setVehiclesSource(QSimConfigGroup.VehiclesSource.defaultVehicle); + config.routing().setAccessEgressType(AccessEgressType.walkConstantTimeToLink); + Scenario scenario = createScenario(config); + NetworkUtils.setLinkEgressTime(scenario.getNetwork().getLinks().get(Id.createLinkId(END_LINK)), TransportMode.car, 180); + Person person = createPerson("slow-person", TransportMode.car, scenario.getPopulation().getFactory()); + scenario.getPopulation().addPerson(person); + Controler controler = createControler(scenario); + controler.run(); + }); + } - @Test - public void calcAccessTimeFromDistanceToLink() { + @Test + void calcAccessTimeFromDistanceToLink() { Config config = createConfig(); config.qsim().setVehiclesSource(QSimConfigGroup.VehiclesSource.defaultVehicle); @@ -398,8 +401,8 @@ public void calcAccessTimeFromDistanceToLink() { Assert.equals(0.0,legs.get(2).getTravelTime().seconds()); } - @Test - public void noBushwackingLegs() { + @Test + void noBushwackingLegs() { Config config = createConfig(); config.qsim().setVehiclesSource(QSimConfigGroup.VehiclesSource.defaultVehicle); diff --git a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingModuleTest.java b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingModuleTest.java index ac63754fd20..57ee84872c5 100644 --- a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingModuleTest.java @@ -22,7 +22,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -51,7 +51,7 @@ public class NetworkRoutingModuleTest { @Test - public void testRouteLeg() { + void testRouteLeg() { Fixture f = new Fixture(); FreespeedTravelTimeAndDisutility freespeed = new FreespeedTravelTimeAndDisutility(-6.0/3600, +6.0/3600, 0.0); LeastCostPathCalculator routeAlgo = new Dijkstra(f.s.getNetwork(), freespeed, freespeed); @@ -77,7 +77,7 @@ public void testRouteLeg() { } @Test - public void testRouteLegWithDistance() { + void testRouteLegWithDistance() { Fixture f = new Fixture(); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); diff --git a/matsim/src/test/java/org/matsim/core/router/PersonalizableDisutilityIntegrationTest.java b/matsim/src/test/java/org/matsim/core/router/PersonalizableDisutilityIntegrationTest.java index a2822d64d4a..703cf44b966 100644 --- a/matsim/src/test/java/org/matsim/core/router/PersonalizableDisutilityIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/router/PersonalizableDisutilityIntegrationTest.java @@ -20,7 +20,7 @@ package org.matsim.core.router; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -47,7 +47,7 @@ public class PersonalizableDisutilityIntegrationTest { @Test - public void testPersonAvailableForDisutility_Dijkstra() { + void testPersonAvailableForDisutility_Dijkstra() { Fixture f = new Fixture(); Dijkstra router = new Dijkstra(f.network, f.costFunction, new FreeSpeedTravelTime()); @@ -61,7 +61,7 @@ public void testPersonAvailableForDisutility_Dijkstra() { } @Test - public void testPersonAvailableForDisutility_AStarEuclidean() { + void testPersonAvailableForDisutility_AStarEuclidean() { Fixture f = new Fixture(); PreProcessEuclidean preprocess = new PreProcessEuclidean(f.costFunction); preprocess.run(f.network); @@ -76,7 +76,7 @@ public void testPersonAvailableForDisutility_AStarEuclidean() { } @Test - public void testPersonAvailableForDisutility_SpeedyALT() { + void testPersonAvailableForDisutility_SpeedyALT() { Fixture f = new Fixture(); LeastCostPathCalculatorFactory routerFactory = new SpeedyALTFactory(); LeastCostPathCalculator router = routerFactory.createPathCalculator(f.network, f.costFunction, new FreeSpeedTravelTime()); diff --git a/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java b/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java index 9061316cef6..be691aa8394 100644 --- a/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java @@ -22,8 +22,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -61,7 +61,7 @@ public class PseudoTransitRoutingModuleTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testRouteLeg() { + void testRouteLeg() { final Fixture f = new Fixture(); FreespeedTravelTimeAndDisutility freespeed = new FreespeedTravelTimeAndDisutility(-6.0/3600, +6.0/3600, 0.0); LeastCostPathCalculator routeAlgo = new Dijkstra(f.s.getNetwork(), freespeed, freespeed); diff --git a/matsim/src/test/java/org/matsim/core/router/RoutingIT.java b/matsim/src/test/java/org/matsim/core/router/RoutingIT.java index 33bf594d4c5..41da4c9aa46 100644 --- a/matsim/src/test/java/org/matsim/core/router/RoutingIT.java +++ b/matsim/src/test/java/org/matsim/core/router/RoutingIT.java @@ -25,8 +25,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; import org.matsim.api.core.v01.population.Person; @@ -61,8 +61,9 @@ private interface RouterProvider { public String getName(); public LeastCostPathCalculatorFactory getFactory(Network network, TravelDisutility costCalc, TravelTime timeCalc); } + @Test - public void testDijkstra() { + void testDijkstra() { doTest(new RouterProvider() { @Override public String getName() { @@ -74,8 +75,9 @@ public LeastCostPathCalculatorFactory getFactory(final Network network, final Tr } }); } + @Test - public void testSpeedyDijkstra() { + void testSpeedyDijkstra() { doTest(new RouterProvider() { @Override public String getName() { @@ -87,8 +89,9 @@ public LeastCostPathCalculatorFactory getFactory(final Network network, final Tr } }); } + @Test - public void testDijkstraPruneDeadEnds() { + void testDijkstraPruneDeadEnds() { doTest(new RouterProvider() { @Override public String getName() { @@ -102,7 +105,7 @@ public LeastCostPathCalculatorFactory getFactory(final Network network, final Tr } @Test - public void testAStarEuclidean() { + void testAStarEuclidean() { doTest(new RouterProvider() { @Override public String getName() { @@ -114,8 +117,9 @@ public LeastCostPathCalculatorFactory getFactory(final Network network, final Tr } }); } + @Test - public void testAStarLandmarks() { + void testAStarLandmarks() { doTest(new RouterProvider() { @Override public String getName() { @@ -129,7 +133,7 @@ public LeastCostPathCalculatorFactory getFactory(final Network network, final Tr } @Test - public void testSpeedyALT() { + void testSpeedyALT() { doTest(new RouterProvider() { @Override public String getName() { diff --git a/matsim/src/test/java/org/matsim/core/router/TeleportationRoutingModuleTest.java b/matsim/src/test/java/org/matsim/core/router/TeleportationRoutingModuleTest.java index a14ff151ccb..2245d7effe3 100644 --- a/matsim/src/test/java/org/matsim/core/router/TeleportationRoutingModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TeleportationRoutingModuleTest.java @@ -20,7 +20,7 @@ package org.matsim.core.router; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -41,7 +41,7 @@ public class TeleportationRoutingModuleTest { @Test - public void testRouteLeg() { + void testRouteLeg() { final Scenario scenario = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); PopulationFactory populationFactory = scenario.getPopulation().getFactory(); RouteFactories routeFactory = new RouteFactories(); diff --git a/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java b/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java index 160dd39a481..fb433b944c3 100644 --- a/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java +++ b/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java @@ -24,7 +24,7 @@ import org.junit.Assert; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -58,7 +58,7 @@ public void init() { } @Test - public void testWrapper() { + void testWrapper() { for (Activity activity : activities) { Facility wrapper = FacilitiesUtils.toFacility( activity, null ); diff --git a/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java b/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java index 25948e78d56..a49ac52dfd4 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java @@ -20,7 +20,7 @@ package org.matsim.core.router; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -64,7 +64,7 @@ public class TripRouterFactoryImplTest { * such as railways. */ @Test - public void testRestrictedNetworkNoPt() throws Exception { + void testRestrictedNetworkNoPt() throws Exception { Config config = ConfigUtils.createConfig(); config.transit().setUseTransit( false ); @@ -152,7 +152,7 @@ public void install() { * Checks that routes are found when using a monomodal network (ie modes are not restricted) */ @Test - public void testMonomodalNetwork() throws Exception { + void testMonomodalNetwork() throws Exception { final Config config = ConfigUtils.createConfig(); final Scenario scenario = ScenarioUtils.createScenario( config ); Network net = scenario.getNetwork(); diff --git a/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java b/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java index 20447170bcd..7fd09524d24 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java @@ -23,8 +23,8 @@ package org.matsim.core.router; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -41,8 +41,8 @@ public class TripRouterModuleTest { @RegisterExtension public MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); - @Test - public void testRouterCreation() { + @Test + void testRouterCreation() { for (ControllerConfigGroup.RoutingAlgorithmType routingAlgorithmType : ControllerConfigGroup.RoutingAlgorithmType.values()) { Config config = ConfigUtils.createConfig(); config.controller().setRoutingAlgorithmType(routingAlgorithmType); diff --git a/matsim/src/test/java/org/matsim/core/router/TripRouterTest.java b/matsim/src/test/java/org/matsim/core/router/TripRouterTest.java index c74e3736a71..d3150f2c945 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripRouterTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripRouterTest.java @@ -25,7 +25,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -43,7 +43,7 @@ */ public class TripRouterTest { @Test - public void testTripInsertion() { + void testTripInsertion() { Plan plan = PopulationUtils.createPlan(); PopulationUtils.createAndAddActivity(plan, "-4"); PopulationUtils.createAndAddLeg( plan, "-3" ); @@ -87,7 +87,7 @@ public void testTripInsertion() { } @Test - public void testTripInsertionIfActivitiesImplementEquals() { + void testTripInsertionIfActivitiesImplementEquals() { Plan plan = PopulationUtils.createPlan(); plan.addActivity( new EqualsActivity( "-4" , Id.create( 1, Link.class ) ) ); PopulationUtils.createAndAddLeg( plan, "-3" ); @@ -133,7 +133,7 @@ public void testTripInsertionIfActivitiesImplementEquals() { } @Test - public void testReturnedOldTrip() throws Exception { + void testReturnedOldTrip() throws Exception { List expected = new ArrayList(); Plan plan = PopulationUtils.createPlan(); diff --git a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java index 3606f570b2a..9ca21632379 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java @@ -29,7 +29,7 @@ import java.util.HashSet; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -749,45 +749,45 @@ private static Collection allFixtures(final boolean anchorAtFacilities) // tests // ///////////////////////////////////////////////////////////////////////// @Test - public void testOneSubtour() { + void testOneSubtour() { performTest( createMonoSubtourFixture( useFacilitiesAsAnchorPoint ) ); } @Test - public void testTwoNestedSubtours() { + void testTwoNestedSubtours() { performTest( createTwoNestedSubtours(useFacilitiesAsAnchorPoint) ); } @Test - public void testTwoChildren() { + void testTwoChildren() { performTest( createTwoChildren(useFacilitiesAsAnchorPoint) ); } @Test - public void testComplexSubtours() { + void testComplexSubtours() { performTest( createComplexSubtours(useFacilitiesAsAnchorPoint) ); } @Test - public void testOpenPlan() { + void testOpenPlan() { performTest( createOpenPlan(useFacilitiesAsAnchorPoint) ); } @Test - public void testLoops() { + void testLoops() { performTest( createPlanWithLoops(useFacilitiesAsAnchorPoint) ); } @Test - public void testTwoIndependentTours() { + void testTwoIndependentTours() { performTest( createTwoIndependentTours(useFacilitiesAsAnchorPoint) ); } @Test - public void testTripFromSomewhereElse() { performTest( createSingleTourComingFromSomewhereElse(useFacilitiesAsAnchorPoint));} + void testTripFromSomewhereElse() { performTest( createSingleTourComingFromSomewhereElse(useFacilitiesAsAnchorPoint));} @Test - public void testTripToSomewhereElse() { performTest( createSingleTourGoingToSomewhereElse(useFacilitiesAsAnchorPoint));} + void testTripToSomewhereElse() { performTest( createSingleTourGoingToSomewhereElse(useFacilitiesAsAnchorPoint));} private static void performTest(final Fixture fixture) { final Collection subtours = @@ -809,7 +809,7 @@ private static void performTest(final Fixture fixture) { } @Test - public void testInconsistentPlan() throws Exception { + void testInconsistentPlan() throws Exception { final Fixture fixture = createInconsistentTrips( useFacilitiesAsAnchorPoint ); boolean hadException = false; try { @@ -826,7 +826,7 @@ public void testInconsistentPlan() throws Exception { } @Test - public void testGetTripsWithoutSubSubtours() throws Exception { + void testGetTripsWithoutSubSubtours() throws Exception { for (Fixture f : allFixtures( useFacilitiesAsAnchorPoint )) { final int nTrips = TripStructureUtils.getTrips( f.plan ).size(); final Collection subtours = @@ -846,7 +846,7 @@ public void testGetTripsWithoutSubSubtours() throws Exception { } @Test - public void testFatherhood() throws Exception { + void testFatherhood() throws Exception { for (Fixture f : allFixtures( useFacilitiesAsAnchorPoint )) { final Collection subtours = TripStructureUtils.getSubtours( f.plan ); diff --git a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java index 1b72153915a..c27172a82ca 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java @@ -25,7 +25,10 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.*; +import org.junit.After; +import org.junit.Assert; +import org.junit.Before; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -40,6 +43,7 @@ import org.matsim.core.scenario.ScenarioUtils; import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.assertThrows; /** * @author thibautd @@ -375,9 +379,8 @@ public void createFixtureWithAccessEgress() { } - @Test - public void testActivities() throws Exception { + void testActivities() throws Exception { for (Fixture fixture : fixtures) { final List acts = TripStructureUtils.getActivities( @@ -398,7 +401,7 @@ public void testActivities() throws Exception { } @Test - public void testTrips() throws Exception { + void testTrips() throws Exception { for (Fixture fixture : fixtures) { final List trips = TripStructureUtils.getTrips(fixture.plan); @@ -436,7 +439,7 @@ public void testTrips() throws Exception { } @Test - public void testLegs() throws Exception { + void testLegs() throws Exception { for (Fixture fixture : fixtures) { final List trips = TripStructureUtils.getTrips(fixture.plan); @@ -454,29 +457,31 @@ public void testLegs() throws Exception { } - @Test( expected=NullPointerException.class ) - public void testNPEWhenLocationNullInSubtourAnalysis() { - // this may sound surprising, but for a long time the algorithm - // was perfectly fine with that if assertions were disabled... - - final Plan plan = populationFactory.createPlan(); - - // link ids are null - plan.addActivity( - populationFactory.createActivityFromCoord( - "type", - new Coord((double) 0, (double) 0)) ); - plan.addLeg( populationFactory.createLeg( "mode" ) ); - plan.addActivity( - populationFactory.createActivityFromCoord( - "type", - new Coord((double) 0, (double) 0)) ); - - TripStructureUtils.getSubtours( plan ); + @Test + void testNPEWhenLocationNullInSubtourAnalysis() { + assertThrows(NullPointerException.class, () -> { + // this may sound surprising, but for a long time the algorithm + // was perfectly fine with that if assertions were disabled... + + final Plan plan = populationFactory.createPlan(); + + // link ids are null + plan.addActivity( + populationFactory.createActivityFromCoord( + "type", + new Coord((double) 0, (double) 0))); + plan.addLeg(populationFactory.createLeg("mode")); + plan.addActivity( + populationFactory.createActivityFromCoord( + "type", + new Coord((double) 0, (double) 0))); + + TripStructureUtils.getSubtours(plan); + }); } @Test - public void testSubtourCoords() { + void testSubtourCoords() { final Plan plan = populationFactory.createPlan(); @@ -507,7 +512,7 @@ public void testSubtourCoords() { } @Test - public void testFindTripAtPlanElement() { + void testFindTripAtPlanElement() { Fixture theFixture = null ; for( Fixture fixture : fixtures ){ if ( fixture.name.equals( WITH_ACCESS_EGRESS ) ){ diff --git a/matsim/src/test/java/org/matsim/core/router/costcalculators/RandomizingTimeDistanceTravelDisutilityTest.java b/matsim/src/test/java/org/matsim/core/router/costcalculators/RandomizingTimeDistanceTravelDisutilityTest.java index 1cee2106490..b5526dd425a 100644 --- a/matsim/src/test/java/org/matsim/core/router/costcalculators/RandomizingTimeDistanceTravelDisutilityTest.java +++ b/matsim/src/test/java/org/matsim/core/router/costcalculators/RandomizingTimeDistanceTravelDisutilityTest.java @@ -24,7 +24,7 @@ import java.util.Set; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -57,7 +57,7 @@ public class RandomizingTimeDistanceTravelDisutilityTest { @Test - public void testRoutesForDifferentSigmas() { + void testRoutesForDifferentSigmas() { { Set routes = new HashSet<>(); diff --git a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java index 395299f5f62..128a511292e 100644 --- a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java +++ b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java @@ -23,8 +23,8 @@ package org.matsim.core.router.old; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -58,8 +58,8 @@ public class PlanRouterTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void passesVehicleFromOldPlan() { + @Test + void passesVehicleFromOldPlan() { final Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); config.plans().setInputFile("plans1.xml"); final Scenario scenario = ScenarioUtils.loadScenario(config); @@ -88,8 +88,8 @@ public void install() { } } - @Test - public void keepsVehicleIfTripRouterUsesOneAlready() { + @Test + void keepsVehicleIfTripRouterUsesOneAlready() { final Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); config.plans().setInputFile("plans1.xml"); final Scenario scenario = ScenarioUtils.loadScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/router/priorityqueue/BinaryMinHeapTest.java b/matsim/src/test/java/org/matsim/core/router/priorityqueue/BinaryMinHeapTest.java index bba6b88dab8..3cc3590ef0c 100644 --- a/matsim/src/test/java/org/matsim/core/router/priorityqueue/BinaryMinHeapTest.java +++ b/matsim/src/test/java/org/matsim/core/router/priorityqueue/BinaryMinHeapTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author cdobler @@ -38,9 +38,9 @@ public class BinaryMinHeapTest { protected static final Logger log = LogManager.getLogger(BinaryMinHeapTest.class); private int maxElements = 10; - + @Test - public void testAdd() { + void testAdd() { testAdd(createMinHeap(true)); testAdd(createMinHeap(false)); testAdd(createWrappedMinHeap(true)); @@ -65,7 +65,7 @@ private void testAdd(MinHeap pq) { } @Test - public void testAdd_Null() { + void testAdd_Null() { testAdd_Null(createMinHeap(true)); testAdd_Null(createMinHeap(false)); testAdd_Null(createWrappedMinHeap(true)); @@ -85,7 +85,7 @@ private void testAdd_Null(MinHeap pq) { } @Test - public void testPoll() { + void testPoll() { testPoll(createMinHeap(true)); testPoll(createMinHeap(false)); testPoll(createWrappedMinHeap(true)); @@ -119,9 +119,9 @@ private void testPoll(MinHeap pq) { Assert.assertEquals(0, pq.size()); Assert.assertNull(pq.poll()); } - + @Test - public void testPoll2() { + void testPoll2() { testPoll2(createMinHeap(true)); testPoll2(createMinHeap(false)); testPoll2(createWrappedMinHeap(true)); @@ -158,7 +158,7 @@ private void testPoll2(MinHeap pq) { } @Test - public void testIterator() { + void testIterator() { testIterator(createMinHeap(true)); testIterator(createMinHeap(false)); testIterator(createWrappedMinHeap(true)); @@ -182,7 +182,7 @@ private void testIterator(MinHeap pq) { } @Test - public void testIterator_ConcurrentModification_add() { + void testIterator_ConcurrentModification_add() { testIterator_ConcurrentModification_add(createMinHeap(true)); testIterator_ConcurrentModification_add(createMinHeap(false)); testIterator_ConcurrentModification_add(createWrappedMinHeap(true)); @@ -216,7 +216,7 @@ private void testIterator_ConcurrentModification_add(MinHeap pq) { } @Test - public void testIterator_ConcurrentModification_poll() { + void testIterator_ConcurrentModification_poll() { testIterator_ConcurrentModification_poll(createMinHeap(true)); testIterator_ConcurrentModification_poll(createMinHeap(false)); testIterator_ConcurrentModification_poll(createWrappedMinHeap(true)); @@ -249,7 +249,7 @@ private void testIterator_ConcurrentModification_poll(MinHeap pq) { } @Test - public void testIterator_ConcurrentModification_remove() { + void testIterator_ConcurrentModification_remove() { testIterator_ConcurrentModification_remove(createMinHeap(true)); testIterator_ConcurrentModification_remove(createMinHeap(false)); testIterator_ConcurrentModification_remove(createWrappedMinHeap(true)); @@ -285,7 +285,7 @@ private void testIterator_ConcurrentModification_remove(MinHeap pq) { } @Test - public void testIterator_RemoveUnsupported() { + void testIterator_RemoveUnsupported() { testIterator_RemoveUnsupported(createMinHeap(true)); testIterator_RemoveUnsupported(createMinHeap(false)); testIterator_RemoveUnsupported(createWrappedMinHeap(true)); @@ -312,7 +312,7 @@ private void testIterator_RemoveUnsupported(MinHeap pq) { } @Test - public void testRemove() { + void testRemove() { testRemove(createMinHeap(true)); testRemove(createMinHeap(false)); testRemove(createWrappedMinHeap(true)); @@ -365,7 +365,7 @@ private void testRemove(MinHeap pq) { } @Test - public void testRemoveAndAdd_LowerPriority() { + void testRemoveAndAdd_LowerPriority() { testRemoveAndAdd_LowerPriority(createMinHeap(true)); testRemoveAndAdd_LowerPriority(createMinHeap(false)); testRemoveAndAdd_LowerPriority(createWrappedMinHeap(true)); @@ -393,9 +393,9 @@ private void testRemoveAndAdd_LowerPriority(MinHeap pq) { Assert.assertNull(pq.poll()); } - @Test // increase priority -> decrease key since it is a min-heap - public void testIncreasePriority() { + @Test + void testIncreasePriority() { testIncreasePriority(createMinHeap(true)); testIncreasePriority(createMinHeap(false)); testIncreasePriority(createWrappedMinHeap(true)); @@ -447,9 +447,9 @@ private void testIncreasePriority(MinHeap pq) { assertEqualsHE(entry0, pq.poll()); Assert.assertNull(pq.poll()); } - + @Test - public void testRemoveAndAdd_HigherPriority() { + void testRemoveAndAdd_HigherPriority() { testRemoveAndAdd_HigherPriority(createMinHeap(true)); testRemoveAndAdd_HigherPriority(createMinHeap(false)); testRemoveAndAdd_HigherPriority(createWrappedMinHeap(true)); @@ -478,7 +478,7 @@ private void testRemoveAndAdd_HigherPriority(MinHeap pq) { } @Test - public void testEqualCosts() { + void testEqualCosts() { testEqualCosts(createMinHeap(true)); testEqualCosts(createMinHeap(false)); testEqualCosts(createWrappedMinHeap(true)); @@ -520,7 +520,7 @@ private void testEqualCosts(MinHeap pq) { } @Test - public void testEqualCosts2() { + void testEqualCosts2() { testEqualCosts2(createMinHeap(true)); testEqualCosts2(createMinHeap(false)); testEqualCosts2(createWrappedMinHeap(true)); @@ -579,9 +579,9 @@ private void testEqualCosts2(MinHeap pq) { assertEqualsHE(entry9, pq.poll()); Assert.assertNull(pq.poll()); } - + @Test - public void testExceedCapacity() { + void testExceedCapacity() { testExceedCapacity(createMinHeap(true)); testExceedCapacity(createMinHeap(false)); testExceedCapacity(createWrappedMinHeap(true)); @@ -620,9 +620,9 @@ private void testExceedCapacity(MinHeap pq) { log.info("catched expected exception. ", e); } } - + @Test - public void testOddOrder() { + void testOddOrder() { testOddOrder(createMinHeap(true)); testOddOrder(createMinHeap(false)); testOddOrder(createWrappedMinHeap(true)); diff --git a/matsim/src/test/java/org/matsim/core/router/speedy/DAryMinHeapTest.java b/matsim/src/test/java/org/matsim/core/router/speedy/DAryMinHeapTest.java index 3f2714b2818..f2737b2ed76 100644 --- a/matsim/src/test/java/org/matsim/core/router/speedy/DAryMinHeapTest.java +++ b/matsim/src/test/java/org/matsim/core/router/speedy/DAryMinHeapTest.java @@ -1,7 +1,7 @@ package org.matsim.core.router.speedy; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.util.Random; @@ -11,7 +11,7 @@ public class DAryMinHeapTest { @Test - public void testPoll() { + void testPoll() { double cost[] = new double[10]; DAryMinHeap pq = new DAryMinHeap(20, 3); @@ -52,7 +52,7 @@ public void testPoll() { } @Test - public void testDecreaseKey() { + void testDecreaseKey() { DAryMinHeap pq = new DAryMinHeap(20, 4); pq.insert(2, 4); @@ -68,7 +68,7 @@ public void testDecreaseKey() { } @Test - public void stresstest() { + void stresstest() { int cnt = 2000; double[] cost = new double[cnt]; Random r = new Random(20190210L); diff --git a/matsim/src/test/java/org/matsim/core/router/speedy/SpeedyGraphTest.java b/matsim/src/test/java/org/matsim/core/router/speedy/SpeedyGraphTest.java index a473bc5f700..2127d559b03 100644 --- a/matsim/src/test/java/org/matsim/core/router/speedy/SpeedyGraphTest.java +++ b/matsim/src/test/java/org/matsim/core/router/speedy/SpeedyGraphTest.java @@ -1,7 +1,7 @@ package org.matsim.core.router.speedy; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -16,8 +16,8 @@ */ public class SpeedyGraphTest { - @Test - public void testConstruction() { + @Test + void testConstruction() { Id.resetCaches(); Fixture f = new Fixture(); diff --git a/matsim/src/test/java/org/matsim/core/scenario/LoadScenarioByHTTPIT.java b/matsim/src/test/java/org/matsim/core/scenario/LoadScenarioByHTTPIT.java index 8fe8587ad72..01f7fcc56ba 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/LoadScenarioByHTTPIT.java +++ b/matsim/src/test/java/org/matsim/core/scenario/LoadScenarioByHTTPIT.java @@ -20,7 +20,7 @@ import static org.assertj.core.api.Assertions.assertThat; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -35,7 +35,7 @@ public class LoadScenarioByHTTPIT { @Test - public void testLoadingScenarioFromURLWorks() throws MalformedURLException { + void testLoadingScenarioFromURLWorks() throws MalformedURLException { // Config config = ConfigUtils.loadConfig(new URL("https://raw.githubusercontent.com/matsim-org/matsimExamples/master/tutorial/lesson-3/config.xml")); Config config = ConfigUtils.loadConfig(new URL("https://github.com/matsim-org/matsim/raw/master/examples/scenarios/lesson-3/config.xml")); Scenario scenario = ScenarioUtils.loadScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java b/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java index bc7cc4793ed..a11338e58e2 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java +++ b/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -42,7 +42,7 @@ import org.matsim.utils.objectattributes.ObjectAttributes; import org.matsim.utils.objectattributes.ObjectAttributesXmlWriter; -/** + /** * @author thibautd */ public class ScenarioByConfigInjectionTest { @@ -50,8 +50,8 @@ public class ScenarioByConfigInjectionTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testAttributeConvertersAreInjected_deprecated() { + @Test + void testAttributeConvertersAreInjected_deprecated() { log.info( "create test scenario" ); final Config config = createTestScenario(); diff --git a/matsim/src/test/java/org/matsim/core/scenario/ScenarioImplTest.java b/matsim/src/test/java/org/matsim/core/scenario/ScenarioImplTest.java index 01762ce553d..20585a8dd28 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/ScenarioImplTest.java +++ b/matsim/src/test/java/org/matsim/core/scenario/ScenarioImplTest.java @@ -20,7 +20,7 @@ package org.matsim.core.scenario; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.config.ConfigUtils; import org.matsim.households.Households; import org.matsim.pt.transitSchedule.api.TransitSchedule; @@ -31,7 +31,7 @@ */ public class ScenarioImplTest { @Test - public void testAddAndGetScenarioElement() { + void testAddAndGetScenarioElement() { final MutableScenario s = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Object element1 = new Object(); @@ -59,7 +59,7 @@ public void testAddAndGetScenarioElement() { } @Test - public void testCannotAddAnElementToAnExistingName() { + void testCannotAddAnElementToAnExistingName() { final MutableScenario s = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final String name = "bruce_wayne"; @@ -78,7 +78,7 @@ public void testCannotAddAnElementToAnExistingName() { } @Test - public void testRemoveElement() { + void testRemoveElement() { final MutableScenario s = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Object element = new Object(); diff --git a/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java b/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java index bca2d701757..1cdae1fd44a 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java +++ b/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java @@ -21,8 +21,8 @@ import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Person; @@ -49,7 +49,7 @@ public class ScenarioLoaderImplTest { @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test - public void testLoadScenario_loadTransitData() { + void testLoadScenario_loadTransitData() { // test the create/load sequence: { ScenarioBuilder builder = new ScenarioBuilder(ConfigUtils.loadConfig(IOUtils.extendUrl(this.util.classInputResourcePath(), "transitConfig.xml"))); @@ -71,7 +71,7 @@ public void testLoadScenario_loadTransitData() { } @Test - public void testLoadScenario_loadPersonAttributes_nowDeprecated() { + void testLoadScenario_loadPersonAttributes_nowDeprecated() { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(this.util.classInputResourcePath(), "personAttributesConfig.xml")); config.plans().addParam("inputPersonAttributesFile", "personAttributes.xml"); config.plans().setInsistingOnUsingDeprecatedPersonAttributeFile( true ); @@ -83,7 +83,7 @@ public void testLoadScenario_loadPersonAttributes_nowDeprecated() { } @Test - public void testLoadScenario_loadPersonAttributes() { + void testLoadScenario_loadPersonAttributes() { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(this.util.classInputResourcePath(), "personAttributesConfig.xml")); config.plans().addParam("inputPersonAttributesFile", "personAttributes.xml"); boolean caughtException=false ; @@ -99,7 +99,7 @@ public void testLoadScenario_loadPersonAttributes() { @Test - public void testLoadScenario_loadFacilitiesAttributes() { + void testLoadScenario_loadFacilitiesAttributes() { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(this.util.classInputResourcePath(), "facilityAttributesConfig.xml")); config.facilities().setInsistingOnUsingDeprecatedFacilitiesAttributeFile(true); config.facilities().addParam("inputFacilityAttributesFile", "facilityAttributes.xml"); @@ -113,7 +113,7 @@ public void testLoadScenario_loadFacilitiesAttributes() { } @Test - public void testLoadScenario_loadHouseholdAttributes() { + void testLoadScenario_loadHouseholdAttributes() { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(this.util.classInputResourcePath(), "householdAttributesConfig.xml")); config.households().addParam("inputHouseholdAttributesFile", "householdAttributes.xml"); config.households().setInsistingOnUsingDeprecatedHouseholdsAttributeFile(true); diff --git a/matsim/src/test/java/org/matsim/core/scenario/ScenarioUtilsTest.java b/matsim/src/test/java/org/matsim/core/scenario/ScenarioUtilsTest.java index 0a3c90f6e6e..2e6b2aa7e22 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/ScenarioUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/scenario/ScenarioUtilsTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; /** @@ -33,7 +33,7 @@ public class ScenarioUtilsTest { private final static Logger log = LogManager.getLogger(ScenarioUtilsTest.class); @Test - public void testCreateScenario_nullConfig() { + void testCreateScenario_nullConfig() { try { Scenario s = ScenarioUtils.createScenario(null); Assert.fail("expected NPE, but got none." + s.toString()); diff --git a/matsim/src/test/java/org/matsim/core/scoring/EventsToActivitiesTest.java b/matsim/src/test/java/org/matsim/core/scoring/EventsToActivitiesTest.java index 9a4b46a6dda..9af33789d81 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/EventsToActivitiesTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/EventsToActivitiesTest.java @@ -20,7 +20,7 @@ package org.matsim.core.scoring; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -33,7 +33,7 @@ public class EventsToActivitiesTest { @Test - public void testCreatesActivty() { + void testCreatesActivty() { EventsToActivities testee = new EventsToActivities(); MockActivityHandler ah = new MockActivityHandler(); testee.addActivityHandler(ah); @@ -50,7 +50,7 @@ public void testCreatesActivty() { } @Test - public void testCreateNightActivity() { + void testCreateNightActivity() { EventsToActivities testee = new EventsToActivities(); MockActivityHandler ah = new MockActivityHandler(); testee.addActivityHandler(ah); @@ -70,9 +70,9 @@ public void testCreateNightActivity() { Assert.assertEquals( 123., ah.handledActivity.getActivity().getCoord().getX(), 0. ); Assert.assertEquals( 4.56, ah.handledActivity.getActivity().getCoord().getY(), 0. ); } - + @Test - public void testDontCreateNightActivityIfNoneIsBeingPerformedWhenSimulationEnds() { + void testDontCreateNightActivityIfNoneIsBeingPerformedWhenSimulationEnds() { EventsToActivities testee = new EventsToActivities(); MockActivityHandler ah = new MockActivityHandler(); testee.addActivityHandler(ah); diff --git a/matsim/src/test/java/org/matsim/core/scoring/EventsToLegsTest.java b/matsim/src/test/java/org/matsim/core/scoring/EventsToLegsTest.java index 82ba5a610ba..e4867f43cad 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/EventsToLegsTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/EventsToLegsTest.java @@ -22,7 +22,7 @@ import java.util.Collections; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -61,7 +61,7 @@ public class EventsToLegsTest { @Test - public void testCreatesLeg() { + void testCreatesLeg() { Scenario scenario = createTriangularNetwork(); EventsToLegs eventsToLegs = new EventsToLegs(scenario); RememberingLegHandler lh = new RememberingLegHandler(); @@ -73,7 +73,7 @@ public void testCreatesLeg() { } @Test - public void testCreatesLegWithRoute() { + void testCreatesLegWithRoute() { Scenario scenario = createTriangularNetwork(); EventsToLegs eventsToLegs = new EventsToLegs(scenario); RememberingLegHandler lh = new RememberingLegHandler(); @@ -93,7 +93,7 @@ public void testCreatesLegWithRoute() { } @Test - public void testCreatesLegWithRoute_jointTrip() { + void testCreatesLegWithRoute_jointTrip() { Scenario scenario = createTriangularNetwork(); EventsToLegs eventsToLegs = new EventsToLegs(scenario); RememberingLegHandler lh = new RememberingLegHandler(); @@ -135,7 +135,7 @@ public void testCreatesLegWithRoute_jointTrip() { } @Test - public void testCreatesLegWithRoute_withoutEnteringTraffic() { + void testCreatesLegWithRoute_withoutEnteringTraffic() { Scenario scenario = createTriangularNetwork(); EventsToLegs eventsToLegs = new EventsToLegs(scenario); RememberingLegHandler lh = new RememberingLegHandler(); @@ -153,7 +153,7 @@ public void testCreatesLegWithRoute_withoutEnteringTraffic() { } @Test - public void testCreatesLegWithRoute_withLeavingTrafficOnTheSameLink() { + void testCreatesLegWithRoute_withLeavingTrafficOnTheSameLink() { Scenario scenario = createTriangularNetwork(); EventsToLegs eventsToLegs = new EventsToLegs(scenario); RememberingLegHandler lh = new RememberingLegHandler(); @@ -173,9 +173,9 @@ public void testCreatesLegWithRoute_withLeavingTrafficOnTheSameLink() { Assert.assertEquals(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME + " missing or incorrect!", 10.0, lh.handledLeg.getLeg().getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME)); } - + @Test - public void testCreatesTransitPassengerRoute() { + void testCreatesTransitPassengerRoute() { Config config = ConfigUtils.createConfig(); config.transit().setUseTransit(true); Scenario scenario = ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java b/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java index 4873a3759ec..ea8da87ea56 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java @@ -21,8 +21,8 @@ package org.matsim.core.scoring; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.PersonMoneyEvent; @@ -51,7 +51,8 @@ public class EventsToScoreTest { /** * Tests that an AgentUtilityEvent is handled by calling the method addUtility() of a scoring function. */ - @Test public void testAddMoney() { + @Test + void testAddMoney() { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); Population population = scenario.getPopulation(); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -67,7 +68,8 @@ public class EventsToScoreTest { Assert.assertEquals(3.4, e2s.getAgentScore(person.getId()), 0); } - @Test public void testMsaAveraging() { + @Test + void testMsaAveraging() { Config config = ConfigUtils.createConfig() ; config.controller().setFirstIteration(10); diff --git a/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java b/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java index 30f51ac024c..2f180299805 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java +++ b/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java @@ -21,7 +21,7 @@ package org.matsim.core.scoring; import org.junit.Ignore; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -45,36 +45,39 @@ import org.matsim.core.scoring.functions.CharyparNagelScoringFunctionFactory; import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertThrows; public class ScoringFunctionsForPopulationStressIT { static final int MAX = 1000000; - @Test(expected = RuntimeException.class) - public void exceptionInScoringFunctionPropagates() { - Config config = ConfigUtils.createConfig(); - Scenario scenario = ScenarioUtils.createScenario(config); - Id personId = Id.createPersonId(1); - scenario.getPopulation().addPerson(scenario.getPopulation().getFactory().createPerson(personId)); - EventsManager events = EventsUtils.createEventsManager(config); - ControlerListenerManagerImpl controlerListenerManager = new ControlerListenerManagerImpl(); - ScoringFunctionFactory throwingScoringFunctionFactory = new ThrowingScoringFunctionFactory(); - EventsToActivities e2acts = new EventsToActivities(controlerListenerManager); - EventsToLegs e2legs = new EventsToLegs(scenario.getNetwork()); - EventsToLegsAndActivities e2legsActs = new EventsToLegsAndActivities(e2legs, e2acts); - events.addHandler(e2legsActs); - ScoringFunctionsForPopulation scoringFunctionsForPopulation = new ScoringFunctionsForPopulation( - controlerListenerManager, - events, - e2acts, - e2legs, - scenario.getPopulation(), - throwingScoringFunctionFactory, - config - ); - controlerListenerManager.fireControlerIterationStartsEvent(0, false); - events.processEvent(new PersonMoneyEvent(3600.0, personId, 3.4, "tollRefund", "motorwayOperator")); - scoringFunctionsForPopulation.finishScoringFunctions(); + @Test + void exceptionInScoringFunctionPropagates() { + assertThrows(RuntimeException.class, () -> { + Config config = ConfigUtils.createConfig(); + Scenario scenario = ScenarioUtils.createScenario(config); + Id personId = Id.createPersonId(1); + scenario.getPopulation().addPerson(scenario.getPopulation().getFactory().createPerson(personId)); + EventsManager events = EventsUtils.createEventsManager(config); + ControlerListenerManagerImpl controlerListenerManager = new ControlerListenerManagerImpl(); + ScoringFunctionFactory throwingScoringFunctionFactory = new ThrowingScoringFunctionFactory(); + EventsToActivities e2acts = new EventsToActivities(controlerListenerManager); + EventsToLegs e2legs = new EventsToLegs(scenario.getNetwork()); + EventsToLegsAndActivities e2legsActs = new EventsToLegsAndActivities(e2legs, e2acts); + events.addHandler(e2legsActs); + ScoringFunctionsForPopulation scoringFunctionsForPopulation = new ScoringFunctionsForPopulation( + controlerListenerManager, + events, + e2acts, + e2legs, + scenario.getPopulation(), + throwingScoringFunctionFactory, + config + ); + controlerListenerManager.fireControlerIterationStartsEvent(0, false); + events.processEvent(new PersonMoneyEvent(3600.0, personId, 3.4, "tollRefund", "motorwayOperator")); + scoringFunctionsForPopulation.finishScoringFunctions(); + }); } private class ThrowingScoringFunctionFactory implements ScoringFunctionFactory { @@ -130,14 +133,14 @@ public void handleEvent(Event event) { } @Test - public void workWithNewEventsManager() { + void workWithNewEventsManager() { Config config = ConfigUtils.createConfig(); config.eventsManager().setOneThreadPerHandler(true); work(config); } @Test - public void workWithOldEventsManager() { + void workWithOldEventsManager() { Config config = ConfigUtils.createConfig(); config.eventsManager().setNumberOfThreads(8); work(config); @@ -241,15 +244,16 @@ public void handleEvent(Event event) { assertEquals(1.0/6.0 * MAX, scoringFunctionsForPopulation.getScoringFunctionForAgent(personId).getScore(), 1.0); } - /* I (mrieser, 2019-01-09) disabled this test. By definition, events for one person should come in the right sequence, - so this tests actually tests some additional (and potentially optional) behavior. But, more importantly, it poses - inherent problems with the addition of trip scoring: to detect trips, it is important that activities and legs - occur in the correct sequence, which means that also the corresponding events must be in the right sequence. - If the sequence is disturbed, the trip detection already fails. So, with trip scoring, this test would always fail - as it tests some non-required functionality. + /*I (mrieser, 2019-01-09) disabled this test. By definition, events for one person should come in the right sequence, + so this tests actually tests some additional (and potentially optional) behavior. But, more importantly, it poses + inherent problems with the addition of trip scoring: to detect trips, it is important that activities and legs + occur in the correct sequence, which means that also the corresponding events must be in the right sequence. + If the sequence is disturbed, the trip detection already fails. So, with trip scoring, this test would always fail + as it tests some non-required functionality. */ - @Test @Ignore - public void unlikelyTimingOfScoringFunctionStillWorks() { + @Test + @Ignore + void unlikelyTimingOfScoringFunctionStillWorks() { Config config = ConfigUtils.createConfig(); config.eventsManager().setNumberOfThreads(8); config.eventsManager().setOneThreadPerHandler(true); diff --git a/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationTest.java b/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationTest.java index 71ca0d7f584..9eec6681fb6 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationTest.java @@ -22,7 +22,7 @@ package org.matsim.core.scoring; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -44,13 +44,13 @@ import org.matsim.core.router.TripStructureUtils; import org.matsim.core.scenario.ScenarioUtils; -/** + /** * @author mrieser / Simunto GmbH */ public class ScoringFunctionsForPopulationTest { - @Test - public void testTripScoring() { + @Test + void testTripScoring() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Population population = scenario.getPopulation(); PopulationFactory pf = population.getFactory(); @@ -103,8 +103,8 @@ public void testTripScoring() { Assert.assertEquals("transit_walk", ((Leg) rs.lastTrip.getTripElements().get(4)).getMode()); } - @Test - public void testPersonScoreEventScoring() { + @Test + void testPersonScoreEventScoring() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Population population = scenario.getPopulation(); PopulationFactory pf = population.getFactory(); diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringDailyConstantsTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringDailyConstantsTest.java index 5b143bd9623..20f3e790285 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringDailyConstantsTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringDailyConstantsTest.java @@ -20,7 +20,7 @@ package org.matsim.core.scoring.functions; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -53,7 +53,7 @@ public class CharyparNagelLegScoringDailyConstantsTest { * Tests whether daily constants are considered in the scoring. */ @Test - public void test1() throws Exception { + void test1() throws Exception { final Network network = createNetwork(); final CharyparNagelLegScoring scoring1 = createScoringOnlyConstants( network ); final CharyparNagelLegScoring scoring2 = createDefaultPlusConstants( network ); diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringPtChangeTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringPtChangeTest.java index 6271fd0934c..7993c58251f 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringPtChangeTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringPtChangeTest.java @@ -22,7 +22,7 @@ import java.util.Random; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -63,7 +63,7 @@ public class CharyparNagelLegScoringPtChangeTest { * the start of the waiting). */ @Test - public void testPtParamsDoNotInfluenceCarScore() throws Exception { + void testPtParamsDoNotInfluenceCarScore() throws Exception { final Network network = createNetwork(); final CharyparNagelLegScoring scoring1 = createScoring( 1 , network ); final CharyparNagelLegScoring scoring2 = createScoring( 2 , network ); diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java index 5e87ef5bf27..be33cc41056 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java @@ -24,8 +24,8 @@ import org.junit.After; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -91,7 +91,8 @@ public class CharyparNagelOpenTimesScoringFunctionTest { this.facilities = null; } - @Test public void testGetOpeningInterval() { + @Test + void testGetOpeningInterval() { Activity act = (Activity) person.getSelectedPlan().getPlanElements().get(0) ; FacilityOpeningIntervalCalculator testee = diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java index 53358733184..c6d2b91d154 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java @@ -25,7 +25,7 @@ import java.util.Arrays; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameter; @@ -131,7 +131,7 @@ private double getZeroUtilDuration_hrs(final double typicalDuration_hrs, final d * Test the calculation of the zero-utility-duration. */ @Test - public void testZeroUtilityDuration() { + void testZeroUtilityDuration() { double zeroUtilDurW = getZeroUtilDuration_hrs(8.0, 1.0); double zeroUtilDurH = getZeroUtilDuration_hrs(16.0, 1.0); double zeroUtilDurW2 = getZeroUtilDuration_hrs(8.0, 2.0); @@ -181,13 +181,13 @@ public void testZeroUtilityDuration() { * Test the scoring function when all parameters are set to 0. */ @Test - public void testZero() { + void testZero() { Fixture f = new Fixture(); assertEquals(0.0, calcScore(f), EPSILON); } @Test - public void testTravelingAndConstantCar() { + void testTravelingAndConstantCar() { Fixture f = new Fixture(); final double traveling = -6.0; f.config.scoring().getModes().get(TransportMode.car).setMarginalUtilityOfTraveling(traveling); @@ -198,7 +198,7 @@ public void testTravelingAndConstantCar() { } @Test - public void testTravelingPtAndConstantPt() { + void testTravelingPtAndConstantPt() { Fixture f = new Fixture(); final double travelingPt = -9.0; f.config.scoring().getModes().get(TransportMode.pt).setMarginalUtilityOfTraveling(travelingPt); @@ -209,7 +209,7 @@ public void testTravelingPtAndConstantPt() { } @Test - public void testTravelingWalkAndConstantWalk() { + void testTravelingWalkAndConstantWalk() { Fixture f = new Fixture(); final double travelingWalk = -18.0; f.config.scoring().getModes().get(TransportMode.walk).setMarginalUtilityOfTraveling(travelingWalk); @@ -220,7 +220,7 @@ public void testTravelingWalkAndConstantWalk() { } @Test - public void testTravelingBikeAndConstantBike(){ + void testTravelingBikeAndConstantBike(){ Fixture f = new Fixture(); final double travelingBike = -6.0; f.config.scoring().getModes().get(TransportMode.bike).setMarginalUtilityOfTraveling(travelingBike); @@ -234,7 +234,7 @@ public void testTravelingBikeAndConstantBike(){ * Test the performing part of the scoring function. */ @Test - public void testPerforming() { + void testPerforming() { Fixture f = new Fixture(); double perf = +6.0; @@ -266,7 +266,7 @@ public void testPerforming() { * Test the performing part of the scoring function when an activity has an OpeningTime set. */ @Test - public void testOpeningTime() { + void testOpeningTime() { Fixture f = new Fixture(); double perf = +6.0; f.config.scoring().setPerforming_utils_hr(perf); @@ -284,7 +284,7 @@ public void testOpeningTime() { * Test the performing part of the scoring function when an activity has a ClosingTime set. */ @Test - public void testClosingTime() { + void testClosingTime() { Fixture f = new Fixture(); double perf = +6.0; f.config.scoring().setPerforming_utils_hr(perf); @@ -302,7 +302,7 @@ public void testClosingTime() { * Test the performing part of the scoring function when an activity has OpeningTime and ClosingTime set. */ @Test - public void testOpeningClosingTime() { + void testOpeningClosingTime() { Fixture f = new Fixture(); double perf_hrs = +6.0; f.config.scoring().setPerforming_utils_hr(perf_hrs); @@ -366,7 +366,7 @@ public void testOpeningClosingTime() { * Test the waiting part of the scoring function. */ @Test - public void testWaitingTime() { + void testWaitingTime() { Fixture f = new Fixture(); double waiting = -10.0; f.config.scoring().setMarginalUtlOfWaiting_utils_hr(waiting); @@ -383,7 +383,7 @@ public void testWaitingTime() { * Test the scoring function in regards to early departures. */ @Test - public void testEarlyDeparture() { + void testEarlyDeparture() { Fixture f = new Fixture(); double disutility = -10.0; f.config.scoring().setEarlyDeparture_utils_hr(disutility); @@ -399,7 +399,7 @@ public void testEarlyDeparture() { * Test the scoring function in regards to early departures. */ @Test - public void testMinimumDuration() { + void testMinimumDuration() { Fixture f = new Fixture(); double disutility = -10.0; f.config.scoring().setEarlyDeparture_utils_hr(disutility); @@ -415,7 +415,7 @@ public void testMinimumDuration() { * Test the scoring function in regards to late arrival. */ @Test - public void testLateArrival() { + void testLateArrival() { Fixture f = new Fixture(); double disutility = -10.0; f.config.scoring().setLateArrival_utils_hr(disutility); @@ -432,7 +432,7 @@ public void testLateArrival() { * could gain. */ @Test - public void testStuckPenalty() { + void testStuckPenalty() { Fixture f = new Fixture(); // test 1 where late arrival has the biggest impact f.config.scoring().setLateArrival_utils_hr(-18.0); @@ -469,7 +469,7 @@ public void testStuckPenalty() { } @Test - public void testDistanceCostScoringCar() { + void testDistanceCostScoringCar() { Fixture f = new Fixture(); // test 1 where marginalUtitityOfMoney is fixed to 1.0 f.config.scoring().setMarginalUtilityOfMoney(1.0); @@ -488,7 +488,7 @@ public void testDistanceCostScoringCar() { } @Test - public void testDistanceCostScoringPt() { + void testDistanceCostScoringPt() { Fixture f = new Fixture(); // test 1 where marginalUtitityOfMoney is fixed to 1.0 f.config.scoring().setMarginalUtilityOfMoney(1.0); @@ -510,7 +510,7 @@ public void testDistanceCostScoringPt() { * Test how the scoring function reacts when the first and the last activity do not have the same act-type. */ @Test - public void testDifferentFirstLastAct() { + void testDifferentFirstLastAct() { Fixture f = new Fixture(); // change the last act to something different than the first act ((Activity) f.plan.getPlanElements().get(8)).setType("h2"); @@ -546,7 +546,7 @@ public void testDifferentFirstLastAct() { * when the first and last activity aren't the same. */ @Test - public void testNoNightActivity() { + void testNoNightActivity() { double zeroUtilDurW = getZeroUtilDuration_hrs(3.0, 1.0); double zeroUtilDurH = getZeroUtilDuration_hrs(7.0, 1.0); @@ -587,7 +587,7 @@ public void testNoNightActivity() { * aforementioned plan. */ @Test - public void testAddMoney() { + void testAddMoney() { Fixture f = new Fixture(); // score the same plan twice @@ -629,7 +629,7 @@ public void testAddMoney() { * Tests if the scoring function correctly handles {@link PersonScoreEvent}. */ @Test - public void testAddScore() { + void testAddScore() { Fixture f = new Fixture(); // score the same plan twice @@ -668,7 +668,7 @@ public void testAddScore() { } @Test - public void testUnusualMode() { + void testUnusualMode() { Fixture f = new Fixture(); Leg leg = (Leg) f.plan.getPlanElements().get(1); leg.setMode("sackhuepfen"); diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelWithSubpopulationsTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelWithSubpopulationsTest.java index 80043ee95e8..0ea4ba8bcd4 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelWithSubpopulationsTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelWithSubpopulationsTest.java @@ -19,7 +19,7 @@ package org.matsim.core.scoring.functions; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Activity; @@ -41,7 +41,7 @@ */ public class CharyparNagelWithSubpopulationsTest { @Test - public void testLegsScoredDifferently() { + void testLegsScoredDifferently() { final Scenario sc = createTestScenario(); final CharyparNagelScoringFunctionFactory functionFactory = new CharyparNagelScoringFunctionFactory( sc ); @@ -77,7 +77,7 @@ public void testLegsScoredDifferently() { } @Test - public void testActivitiesScoredDifferently() { + void testActivitiesScoredDifferently() { final Scenario sc = createTestScenario(); final CharyparNagelScoringFunctionFactory functionFactory = new CharyparNagelScoringFunctionFactory( sc ); diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java index 179a9254981..8fa5e790ab5 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkEnterEvent; @@ -47,7 +47,8 @@ public class LinkToLinkTravelTimeCalculatorTest { /** * @author mrieser */ - @Test public void testLongTravelTimeInEmptySlot() { + @Test + void testLongTravelTimeInEmptySlot() { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(utils.loadConfig((String)null)); scenario.getConfig().travelTimeCalculator().setCalculateLinkToLinkTravelTimes(true); Network network = (Network) scenario.getNetwork(); diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java index 00654aa914e..5c20985f8cb 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java @@ -23,9 +23,9 @@ import com.google.inject.Key; import com.google.inject.Singleton; -import com.google.inject.name.Names; +import com.google.inject.name.Names; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -50,15 +50,15 @@ import java.util.LinkedHashSet; import static org.hamcrest.CoreMatchers.is; -import static org.junit.Assert.assertThat; - -public class TravelTimeCalculatorModuleTest { +import static org.junit.Assert.assertThat; + + public class TravelTimeCalculatorModuleTest { @RegisterExtension - private MatsimTestUtils utils = new MatsimTestUtils(); - - @Test - public void testOneTravelTimeCalculatorForAll() { + private MatsimTestUtils utils = new MatsimTestUtils(); + + @Test + void testOneTravelTimeCalculatorForAll() { Config config = ConfigUtils.createConfig(); config.travelTimeCalculator().setSeparateModes(false); Scenario scenario = ScenarioUtils.createScenario(config); @@ -90,11 +90,11 @@ public void install() { events.processEvent(new VehicleLeavesTrafficEvent(8.0, Id.createPersonId(1), linkId, Id.createVehicleId(1), "bike", 0.0)); assertThat(testee.getLinkTravelTimes().getLinkTravelTime(link, 0.0,null,null), is(5.0)); - } - - - @Test - public void testOneTravelTimeCalculatorPerMode() { + } + + + @Test + void testOneTravelTimeCalculatorPerMode() { Config config = ConfigUtils.createConfig(); // config.travelTimeCalculator().setAnalyzedModesAsString("car,bike" ); diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java index 45c0595a509..552d6399169 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java @@ -33,8 +33,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -76,7 +76,8 @@ public class TravelTimeCalculatorTest { private final static Logger log = LogManager.getLogger(TravelTimeCalculatorTest.class); - @Test public final void testTravelTimeCalculator_Array_Optimistic() throws IOException { + @Test + final void testTravelTimeCalculator_Array_Optimistic() throws IOException { int endTime = 30*3600; int binSize = 15*60; @@ -91,7 +92,8 @@ public class TravelTimeCalculatorTest { travelTimeAggregator, binSize, endTime, compareFile, false, utils.getClassInputDirectory(), travelTimeGetter ); } - @Test public final void testTravelTimeCalculator_Array_Optimistic_LinearInterpolation() throws IOException { + @Test + final void testTravelTimeCalculator_Array_Optimistic_LinearInterpolation() throws IOException { int endTime = 30*3600; int binSize = 15*60; @@ -189,7 +191,8 @@ private static void doTravelTimeCalculatorTest( final MutableScenario scenario, * * @author mrieser, tthunig */ - @Test public void testLongTravelTimeInEmptySlot() { + @Test + void testLongTravelTimeInEmptySlot() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); network.setCapacityPeriod(3600.0); @@ -226,7 +229,8 @@ private static void doTravelTimeCalculatorTest( final MutableScenario scenario, * * @author tthunig */ - @Test public void testLongTravelTimeInEmptySlotWithDoubleTimeBins() { + @Test + void testLongTravelTimeInEmptySlotWithDoubleTimeBins() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); network.setCapacityPeriod(3600.0); @@ -280,7 +284,8 @@ private static void doTravelTimeCalculatorTest( final MutableScenario scenario, * * @author tthunig */ - @Test public void testInterpolatedTravelTimes() { + @Test + void testInterpolatedTravelTimes() { Config config = ConfigUtils.createConfig(); config.travelTimeCalculator().setTravelTimeGetterType("linearinterpolation"); int timeBinSize = 15*60; @@ -327,7 +332,8 @@ private static void doTravelTimeCalculatorTest( final MutableScenario scenario, * @throws ParserConfigurationException * @throws SAXException */ - @Test public void testReadFromFile_LargeScenarioCase() throws SAXException, ParserConfigurationException, IOException { + @Test + void testReadFromFile_LargeScenarioCase() throws SAXException, ParserConfigurationException, IOException { /* Assume, you have a big events file from a huge scenario and you want to do data-mining... * Then you likely want to calculate link travel times. This requires the network, but NOT * the population. Thus, using "new Events(new EventsBuilderImpl(scenario))" is not appropriate @@ -360,7 +366,8 @@ private static void doTravelTimeCalculatorTest( final MutableScenario scenario, /** * @author mrieser / senozon */ - @Test public void testGetLinkTravelTime_ignorePtVehiclesAtStop() { + @Test + void testGetLinkTravelTime_ignorePtVehiclesAtStop() { Network network = NetworkUtils.createNetwork(); TravelTimeCalculatorConfigGroup config = new TravelTimeCalculatorConfigGroup(); config.setTraveltimeBinSize(900); @@ -388,7 +395,8 @@ private static void doTravelTimeCalculatorTest( final MutableScenario scenario, /** * @author mrieser / senozon */ - @Test public void testGetLinkTravelTime_usePtVehiclesWithoutStop() { + @Test + void testGetLinkTravelTime_usePtVehiclesWithoutStop() { Network network = NetworkUtils.createNetwork(); TravelTimeCalculatorConfigGroup config = new TravelTimeCalculatorConfigGroup(); config.setTraveltimeBinSize(900); @@ -418,7 +426,8 @@ private static void doTravelTimeCalculatorTest( final MutableScenario scenario, * Expect that all link travel times are ignored. * @author cdobler */ - @Test public void testGetLinkTravelTime_NoAnalyzedModes() { + @Test + void testGetLinkTravelTime_NoAnalyzedModes() { Network network = NetworkUtils.createNetwork(); TravelTimeCalculatorConfigGroup config = new TravelTimeCalculatorConfigGroup(); config.setTraveltimeBinSize(900); @@ -454,7 +463,8 @@ private static void doTravelTimeCalculatorTest( final MutableScenario scenario, * Expect that walk legs are ignored. * @author cdobler */ - @Test public void testGetLinkTravelTime_CarAnalyzedModes() { + @Test + void testGetLinkTravelTime_CarAnalyzedModes() { Network network = NetworkUtils.createNetwork(); TravelTimeCalculatorConfigGroup config = new TravelTimeCalculatorConfigGroup(); config.setTraveltimeBinSize(900); @@ -495,7 +505,8 @@ private static void doTravelTimeCalculatorTest( final MutableScenario scenario, * Expect that still all modes are counted. * @author cdobler */ - @Test public void testGetLinkTravelTime_NoFilterModes() { + @Test + void testGetLinkTravelTime_NoFilterModes() { Network network = NetworkUtils.createNetwork(); TravelTimeCalculatorConfigGroup config = new TravelTimeCalculatorConfigGroup(); config.setTraveltimeBinSize(900); @@ -536,7 +547,8 @@ private static void doTravelTimeCalculatorTest( final MutableScenario scenario, * Expect that the default value (=car) will be used for the modes to be counted. * @author cdobler */ - @Test public void testGetLinkTravelTime_FilterDefaultModes() { + @Test + void testGetLinkTravelTime_FilterDefaultModes() { Network network = NetworkUtils.createNetwork(); TravelTimeCalculatorConfigGroup config = new TravelTimeCalculatorConfigGroup(); config.setTraveltimeBinSize(900); diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeDataArrayTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeDataArrayTest.java index e56a8cb3a51..c002d90c52c 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeDataArrayTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeDataArrayTest.java @@ -2,8 +2,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -16,7 +16,7 @@ public class TravelTimeDataArrayTest{ @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void test() { + void test() { Network network = NetworkUtils.createNetwork(); Node from = NetworkUtils.createNode(Id.createNodeId("1")); Node to = NetworkUtils.createNode( Id.createNodeId( "2" ) ); diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java index b13c9fd28a8..4d9f848e412 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java @@ -29,8 +29,8 @@ import javax.imageio.ImageIO; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -48,7 +48,8 @@ public class BarChartTest { * Test that a file was really generated, and that the image, when loaded, has the specified size. * @throws IOException possible exception when reading the image for validation */ - @Test public void testBarChartDemo() throws IOException { + @Test + void testBarChartDemo() throws IOException { System.setProperty("java.awt.headless", "true"); String imageFilename = utils.getOutputDirectory() + "barchart.png"; diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java index 4c70f43a26d..d51e8a862ad 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java @@ -29,8 +29,8 @@ import javax.imageio.ImageIO; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -48,7 +48,8 @@ public class LineChartTest { * Test that a file was really generated, and that the image, when loaded, has the specified size. * @throws IOException possible exception when reading the image for validation */ - @Test public void testLineChartDemo() throws IOException { + @Test + void testLineChartDemo() throws IOException { String imageFilename = utils.getOutputDirectory() + "linechart.png"; Demo demo = new Demo(); demo.createLineChart(imageFilename); diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java index 1410b27b202..2820560dec5 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java @@ -29,8 +29,8 @@ import javax.imageio.ImageIO; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -48,7 +48,8 @@ public class XYLineChartTest { * Test that a file was really generated, and that the image, when loaded, has the specified size. * @throws IOException possible exception when reading the image for validation */ - @Test public void testXYLineChartDemo() throws IOException { + @Test + void testXYLineChartDemo() throws IOException { String imageFilename = utils.getOutputDirectory() + "xylinechart.png"; Demo demo = new Demo(); demo.createXYLineChart(imageFilename); diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java index 03c60398659..146203c96d9 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java @@ -29,8 +29,8 @@ import javax.imageio.ImageIO; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -48,7 +48,8 @@ public class XYScatterChartTest { * Test that a file was really generated, and that the image, when loaded, has the specified size. * @throws IOException possible exception when reading the image for validation */ - @Test public void testXYScatterChartDemo() throws IOException { + @Test + void testXYScatterChartDemo() throws IOException { String imageFilename = utils.getOutputDirectory() + "xyscatterchart.png"; Demo demo = new Demo(); demo.createXYScatterChart(imageFilename); diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/ArrayMapTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/ArrayMapTest.java index 6c82f754508..c50c2131c3e 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/ArrayMapTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/ArrayMapTest.java @@ -1,7 +1,7 @@ package org.matsim.core.utils.collections; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.util.ArrayList; import java.util.Collection; @@ -19,7 +19,7 @@ public class ArrayMapTest { @Test - public void testPutGetRemoveSize() { + void testPutGetRemoveSize() { ArrayMap map = new ArrayMap<>(); Assert.assertEquals(0, map.size()); @@ -55,7 +55,7 @@ public void testPutGetRemoveSize() { } @Test - public void testValuesIterable() { + void testValuesIterable() { ArrayMap map = new ArrayMap<>(); map.put("1", "one"); @@ -82,7 +82,7 @@ public void testValuesIterable() { } @Test - public void testForEach() { + void testForEach() { ArrayMap map = new ArrayMap<>(); map.put("1", "one"); @@ -108,7 +108,7 @@ public void testForEach() { } @Test - public void testContainsKey() { + void testContainsKey() { ArrayMap map = new ArrayMap<>(); map.put("1", "one"); @@ -132,7 +132,7 @@ public void testContainsKey() { } @Test - public void testContainsValue() { + void testContainsValue() { ArrayMap map = new ArrayMap<>(); map.put("1", "one"); @@ -149,7 +149,7 @@ public void testContainsValue() { } @Test - public void testPutAll_ArrayMap() { + void testPutAll_ArrayMap() { ArrayMap map = new ArrayMap<>(); ArrayMap map2 = new ArrayMap<>(); @@ -170,7 +170,7 @@ public void testPutAll_ArrayMap() { } @Test - public void testPutAll_GenericMap() { + void testPutAll_GenericMap() { ArrayMap map = new ArrayMap<>(); Map map2 = new HashMap<>(); @@ -191,7 +191,7 @@ public void testPutAll_GenericMap() { } @Test - public void testClear() { + void testClear() { ArrayMap map = new ArrayMap<>(); map.put("1", "one"); @@ -213,7 +213,7 @@ public void testClear() { } @Test - public void testValues() { + void testValues() { ArrayMap map = new ArrayMap<>(); map.put("1", "one"); @@ -247,7 +247,7 @@ public void testValues() { } @Test - public void testKeySet() { + void testKeySet() { String key1 = "1"; String key2 = "2"; String key3 = "3"; @@ -288,7 +288,7 @@ public void testKeySet() { } @Test - public void testEntrySet() { + void testEntrySet() { String key1 = "1"; String key2 = "2"; String key4 = "4"; @@ -342,7 +342,7 @@ public void testEntrySet() { } @Test - public void testValuesIterator_iterate() { + void testValuesIterator_iterate() { String key1 = "1"; String key2 = "2"; String key4 = "4"; @@ -381,7 +381,7 @@ public void testValuesIterator_iterate() { } @Test - public void testValuesIterator_remove() { + void testValuesIterator_remove() { String key1 = "1"; String key2 = "2"; String key4 = "4"; @@ -416,7 +416,7 @@ public void testValuesIterator_remove() { } @Test - public void testKeySetIterator_iterate() { + void testKeySetIterator_iterate() { String key1 = "1"; String key2 = "2"; String key4 = "4"; @@ -455,7 +455,7 @@ public void testKeySetIterator_iterate() { } @Test - public void testKeySetIterator_remove() { + void testKeySetIterator_remove() { String key1 = "1"; String key2 = "2"; String key4 = "4"; @@ -490,7 +490,7 @@ public void testKeySetIterator_remove() { } @Test - public void testKeySetToArray() { + void testKeySetToArray() { String key1 = "1"; String key2 = "2"; String key4 = "4"; @@ -512,7 +512,7 @@ public void testKeySetToArray() { } @Test - public void testCopyConstructor() { + void testCopyConstructor() { Map map0 = new HashMap<>(); map0.put("1", "one"); map0.put("2", "two"); diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/CollectionUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/CollectionUtilsTest.java index bf8adaa1fa4..40ad88c902d 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/CollectionUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/CollectionUtilsTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -38,7 +38,7 @@ public class CollectionUtilsTest { private final static Logger log = LogManager.getLogger(CollectionUtilsTest.class); @Test - public void testSetToString() { + void testSetToString() { Set set = new LinkedHashSet(); set.add("Aaa"); set.add("Bbb"); @@ -48,13 +48,13 @@ public void testSetToString() { } @Test - public void testArrayToString() { + void testArrayToString() { String[] array = new String[] {"Aaa", "Bbb", "Ddd", "Ccc"}; Assert.assertEquals("Aaa,Bbb,Ddd,Ccc", CollectionUtils.arrayToString(array)); } @Test - public void testStringToSet() { + void testStringToSet() { String[] testStrings = new String[] { "Aaa,Bbb,Ddd,Ccc", ",Aaa,Bbb,Ddd,Ccc", @@ -79,13 +79,13 @@ public void testStringToSet() { } @Test - public void testNullStringToSet() { + void testNullStringToSet() { Set set = CollectionUtils.stringToSet(null); Assert.assertEquals(0, set.size()); } @Test - public void testStringToArray() { + void testStringToArray() { String[] testStrings = new String[] { "Aaa,Bbb,Ddd,Ccc", ",Aaa,Bbb,Ddd,Ccc", @@ -108,13 +108,13 @@ public void testStringToArray() { } @Test - public void testNullStringToArray() { + void testNullStringToArray() { String[] array = CollectionUtils.stringToArray(null); Assert.assertEquals(0, array.length); } @Test - public void testIdSetToString() { + void testIdSetToString() { Set> set = new LinkedHashSet>(); set.add(Id.create("Aaa", Link.class)); set.add(Id.create("Bbb", Link.class)); diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/IdentifiableArrayMapTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/IdentifiableArrayMapTest.java index 642582ca629..d7ab9d6f2a6 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/IdentifiableArrayMapTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/IdentifiableArrayMapTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Identifiable; @@ -38,16 +38,16 @@ public class IdentifiableArrayMapTest { private final static Logger log = LogManager.getLogger(IdentifiableArrayMapTest.class); - + @Test - public void testConstructor() { + void testConstructor() { Map, TO> map = new IdentifiableArrayMap<>(); Assert.assertEquals(0, map.size()); Assert.assertTrue(map.isEmpty()); } - + @Test - public void testPutGet() { + void testPutGet() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -72,9 +72,9 @@ public void testPutGet() { Assert.assertEquals(to2, map.get(id2)); Assert.assertEquals(to1, map.get(id1)); } - + @Test - public void testPutGet_identifiablePut() { + void testPutGet_identifiablePut() { IdentifiableArrayMap map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -98,9 +98,9 @@ public void testPutGet_identifiablePut() { Assert.assertEquals(to2, map.get(id2)); Assert.assertEquals(to1, map.get(id1)); } - + @Test - public void testPut_multiple() { + void testPut_multiple() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -131,9 +131,9 @@ public void testPut_multiple() { map.put(id1, to1); Assert.assertEquals(3, map.size()); } - + @Test - public void testGet_equalKeys() { + void testGet_equalKeys() { Map, TO> map = new IdentifiableArrayMap<>(); Id id2a = Id.create(2, TO.class); Id id2b = Id.create(2, TO.class); @@ -147,7 +147,7 @@ public void testGet_equalKeys() { } @Test - public void testPut_Overwrite() { + void testPut_Overwrite() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2a = Id.create(2, TO.class); @@ -173,9 +173,9 @@ public void testPut_Overwrite() { Assert.assertEquals(to2b, map.get(id2b)); Assert.assertEquals(to2b, map.get(id2a)); } - + @Test - public void testContainsKey() { + void testContainsKey() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -209,9 +209,9 @@ public void testContainsKey() { Assert.assertTrue(map.containsKey(id2b)); Assert.assertTrue(map.containsKey(id3)); } - + @Test - public void testContainsValue() { + void testContainsValue() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -240,9 +240,9 @@ public void testContainsValue() { Assert.assertTrue(map.containsValue(to2)); Assert.assertTrue(map.containsValue(to3)); } - + @Test - public void testRemove_middle() { + void testRemove_middle() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -263,9 +263,9 @@ public void testRemove_middle() { Assert.assertFalse(map.containsValue(to2)); Assert.assertTrue(map.containsValue(to3)); } - + @Test - public void testRemove_start() { + void testRemove_start() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -286,9 +286,9 @@ public void testRemove_start() { Assert.assertTrue(map.containsValue(to2)); Assert.assertTrue(map.containsValue(to3)); } - + @Test - public void testRemove_end() { + void testRemove_end() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -309,9 +309,9 @@ public void testRemove_end() { Assert.assertTrue(map.containsValue(to2)); Assert.assertFalse(map.containsValue(to3)); } - + @Test - public void testClear() { + void testClear() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -334,9 +334,9 @@ public void testClear() { Assert.assertFalse(map.containsValue(to2)); Assert.assertNull(map.get(id2)); } - + @Test - public void testValues() { + void testValues() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -357,9 +357,9 @@ public void testValues() { Assert.assertTrue(values.contains(to2)); Assert.assertTrue(values.contains(to3)); } - + @Test - public void testKeySet() { + void testKeySet() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -380,9 +380,9 @@ public void testKeySet() { Assert.assertTrue(keys.contains(id2)); Assert.assertTrue(keys.contains(id3)); } - + @Test - public void testEntrySet() { + void testEntrySet() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -400,9 +400,9 @@ public void testEntrySet() { Assert.assertEquals(3, entries.size()); } - + @Test - public void testValuesIterator() { + void testValuesIterator() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -435,7 +435,7 @@ public void testValuesIterator() { } @Test - public void testValuesToArray() { + void testValuesToArray() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); Id id2 = Id.create(2, TO.class); @@ -469,7 +469,7 @@ public void testValuesToArray() { } @Test - public void testValuesIterator_SingleDiretor() { + void testValuesIterator_SingleDiretor() { Map, TO> map = new IdentifiableArrayMap<>(); Id id1 = Id.create(1, TO.class); diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/IntArrayMapTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/IntArrayMapTest.java index 6e2257639b5..a23afe67ad0 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/IntArrayMapTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/IntArrayMapTest.java @@ -1,7 +1,7 @@ package org.matsim.core.utils.collections; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.util.ArrayList; import java.util.Collection; @@ -19,7 +19,7 @@ public class IntArrayMapTest { @Test - public void testPutGetRemoveSize() { + void testPutGetRemoveSize() { IntArrayMap map = new IntArrayMap<>(); Assert.assertEquals(0, map.size()); @@ -55,7 +55,7 @@ public void testPutGetRemoveSize() { } @Test - public void testValuesIterable() { + void testValuesIterable() { IntArrayMap map = new IntArrayMap<>(); map.put(1, "one"); @@ -82,7 +82,7 @@ public void testValuesIterable() { } @Test - public void testForEach() { + void testForEach() { IntArrayMap map = new IntArrayMap<>(); map.put(1, "one"); @@ -108,7 +108,7 @@ public void testForEach() { } @Test - public void testContainsKey() { + void testContainsKey() { IntArrayMap map = new IntArrayMap<>(); map.put(1, "one"); @@ -132,7 +132,7 @@ public void testContainsKey() { } @Test - public void testContainsValue() { + void testContainsValue() { IntArrayMap map = new IntArrayMap<>(); map.put(1, "one"); @@ -149,7 +149,7 @@ public void testContainsValue() { } @Test - public void testPutAll_ArrayMap() { + void testPutAll_ArrayMap() { IntArrayMap map = new IntArrayMap<>(); IntArrayMap map2 = new IntArrayMap<>(); @@ -170,7 +170,7 @@ public void testPutAll_ArrayMap() { } @Test - public void testPutAll_GenericMap() { + void testPutAll_GenericMap() { IntArrayMap map = new IntArrayMap<>(); Map map2 = new HashMap<>(); @@ -191,7 +191,7 @@ public void testPutAll_GenericMap() { } @Test - public void testClear() { + void testClear() { IntArrayMap map = new IntArrayMap<>(); map.put(1, "one"); @@ -213,7 +213,7 @@ public void testClear() { } @Test - public void testValues() { + void testValues() { IntArrayMap map = new IntArrayMap<>(); map.put(1, "one"); @@ -247,7 +247,7 @@ public void testValues() { } @Test - public void testKeySet() { + void testKeySet() { int key1 = 1; int key2 = 2; int key3 = 3; @@ -288,7 +288,7 @@ public void testKeySet() { } @Test - public void testEntrySet() { + void testEntrySet() { int key1 = 1; int key2 = 2; int key4 = 4; @@ -342,7 +342,7 @@ public void testEntrySet() { } @Test - public void testValuesIterator_iterate() { + void testValuesIterator_iterate() { int key1 = 1; int key2 = 2; int key4 = 4; @@ -381,7 +381,7 @@ public void testValuesIterator_iterate() { } @Test - public void testValuesIterator_remove() { + void testValuesIterator_remove() { int key1 = 1; int key2 = 2; int key4 = 4; @@ -417,7 +417,7 @@ public void testValuesIterator_remove() { } @Test - public void testKeySetIterator_iterate() { + void testKeySetIterator_iterate() { int key1 = 1; int key2 = 2; int key4 = 4; @@ -456,7 +456,7 @@ public void testKeySetIterator_iterate() { } @Test - public void testKeySetIterator_remove() { + void testKeySetIterator_remove() { int key1 = 1; int key2 = 2; int key4 = 4; @@ -492,7 +492,7 @@ public void testKeySetIterator_remove() { } @Test - public void testKeySetToArray() { + void testKeySetToArray() { int key1 = 1; int key2 = 2; int key4 = 4; diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/PseudoRemovePriorityQueueTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/PseudoRemovePriorityQueueTest.java index 6eb6d83b918..d1f726ab458 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/PseudoRemovePriorityQueueTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/PseudoRemovePriorityQueueTest.java @@ -29,7 +29,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author mrieser @@ -38,7 +38,8 @@ public class PseudoRemovePriorityQueueTest { private static final Logger log = LogManager.getLogger(PseudoRemovePriorityQueueTest.class); - @Test public void testAdd() { + @Test + void testAdd() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); assertEquals(0, pq.size()); pq.add(Integer.valueOf(1), 1.0); @@ -52,7 +53,8 @@ public class PseudoRemovePriorityQueueTest { assertEquals(3, iteratorElementCount(pq.iterator())); } - @Test public void testAdd_Null() { + @Test + void testAdd_Null() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); try { pq.add(null, 1.0); @@ -65,7 +67,8 @@ public class PseudoRemovePriorityQueueTest { assertEquals(0, iteratorElementCount(pq.iterator())); } - @Test public void testPoll() { + @Test + void testPoll() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); pq.add(Integer.valueOf(5), 5.0); pq.add(Integer.valueOf(3), 3.0); @@ -86,7 +89,8 @@ public class PseudoRemovePriorityQueueTest { assertNull(pq.poll()); } - @Test public void testIterator() { + @Test + void testIterator() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); pq.add(Integer.valueOf(5), 5.0); pq.add(Integer.valueOf(3), 3.0); @@ -99,7 +103,8 @@ public class PseudoRemovePriorityQueueTest { assertFalse(coll.contains(Integer.valueOf(4))); } - @Test public void testIterator_ConcurrentModification_add() { + @Test + void testIterator_ConcurrentModification_add() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); pq.add(Integer.valueOf(5), 5.0); pq.add(Integer.valueOf(3), 3.0); @@ -122,7 +127,8 @@ public class PseudoRemovePriorityQueueTest { assertNotNull(iter.next()); } - @Test public void testIterator_ConcurrentModification_poll() { + @Test + void testIterator_ConcurrentModification_poll() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); pq.add(Integer.valueOf(5), 5.0); pq.add(Integer.valueOf(3), 3.0); @@ -145,7 +151,8 @@ public class PseudoRemovePriorityQueueTest { assertNotNull(iter.next()); } - @Test public void testIterator_ConcurrentModification_remove() { + @Test + void testIterator_ConcurrentModification_remove() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); pq.add(Integer.valueOf(5), 5.0); pq.add(Integer.valueOf(3), 3.0); @@ -171,7 +178,8 @@ public class PseudoRemovePriorityQueueTest { assertNotNull(iter.next()); } - @Test public void testIterator_RemoveUnsupported() { + @Test + void testIterator_RemoveUnsupported() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); pq.add(Integer.valueOf(5), 5.0); pq.add(Integer.valueOf(3), 3.0); @@ -188,7 +196,8 @@ public class PseudoRemovePriorityQueueTest { } } - @Test public void testRemove() { + @Test + void testRemove() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); pq.add(Integer.valueOf(5), 5.0); pq.add(Integer.valueOf(3), 3.0); @@ -230,7 +239,8 @@ public class PseudoRemovePriorityQueueTest { assertNull(pq.poll()); } - @Test public void testRemoveAndAdd_LowerPriority() { + @Test + void testRemoveAndAdd_LowerPriority() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); pq.add(Integer.valueOf(5), 5.0); pq.add(Integer.valueOf(3), 3.0); @@ -249,7 +259,8 @@ public class PseudoRemovePriorityQueueTest { assertNull(pq.poll()); } - @Test public void testRemoveAndAdd_HigherPriority() { + @Test + void testRemoveAndAdd_HigherPriority() { PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); pq.add(Integer.valueOf(5), 5.0); pq.add(Integer.valueOf(3), 3.0); @@ -268,7 +279,8 @@ public class PseudoRemovePriorityQueueTest { assertNull(pq.poll()); } - @Test public void testDecreaseKey() { + @Test + void testDecreaseKey() { // PseudoRemovePriorityQueue pq = new PseudoRemovePriorityQueue(10); // pq.add(Integer.valueOf(5), 5.0); // pq.add(Integer.valueOf(3), 3.0); diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/QuadTreeTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/QuadTreeTest.java index c479979a069..56a7867b1f9 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/QuadTreeTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/QuadTreeTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.collections.QuadTree.Rect; import org.matsim.core.utils.geometry.CoordUtils; @@ -75,7 +75,7 @@ private QuadTree getTestTree() { * Test {@link QuadTree#QuadTree(double, double, double, double)}. */ @Test - public void testConstructor() { + void testConstructor() { QuadTree qt = new QuadTree<>(-50.0, -40.0, +30.0, +20.0); assertEquals(-50.0, qt.getMinEasting(), 0.0); assertEquals(-40.0, qt.getMinNorthing(), 0.0); @@ -87,7 +87,7 @@ public void testConstructor() { * Test putting values into a QuadTree using {@link QuadTree#put(double, double, Object)}. */ @Test - public void testPut() { + void testPut() { QuadTree qt = new QuadTree<>(-50.0, -50.0, +150.0, +150.0); assertEquals(0, qt.size()); qt.put(10.0, 10.0, "10.0, 10.0"); @@ -107,7 +107,7 @@ public void testPut() { } @Test - public void testPutOutsideBounds() { + void testPutOutsideBounds() { QuadTree qt = new QuadTree<>(-50.0, -50.0, 50.0, 50.0); try { qt.put( -100 , 0 , "-100 0" ); @@ -147,7 +147,7 @@ public void testPutOutsideBounds() { * and {@link QuadTree#getDisk(double, double, double)}. */ @Test - public void testGet() { + void testGet() { QuadTree qt = getTestTree(); // test single get @@ -218,7 +218,7 @@ public void testGet() { } @Test - public void testGetXY_EntryOnDividingBorder() { + void testGetXY_EntryOnDividingBorder() { QuadTree qt = new QuadTree<>(0, 0, 40, 60); qt.put(10.0, 10.0, "10.0, 10.0"); qt.put(20.0, 20.0, "20.0, 20.0"); // on vertical border @@ -231,7 +231,7 @@ public void testGetXY_EntryOnDividingBorder() { } @Test - public void testGetXY_EntryOnOutsideBorder() { + void testGetXY_EntryOnOutsideBorder() { QuadTree qt = new QuadTree<>(0.0, 0.0, 40.0, 60.0); // the 4 corners qt.put(0.0, 0.0, "SW"); @@ -255,7 +255,7 @@ public void testGetXY_EntryOnOutsideBorder() { } @Test - public void testGetDistance_fromOutsideExtent() { + void testGetDistance_fromOutsideExtent() { QuadTree qt = getTestTree(); assertContains(new String[] {"100.0, 0.0"}, qt.getDisk(160.0, 0, 60.1)); // E assertContains(new String[] {"15.0, 15.0", "15.0, 15.0 B"}, qt.getDisk(15.0, 160, 145.1)); // N @@ -264,7 +264,7 @@ public void testGetDistance_fromOutsideExtent() { } @Test - public void testGetDistance_EntryOnDividingBorder() { + void testGetDistance_EntryOnDividingBorder() { QuadTree qt = new QuadTree<>(0, 0, 40, 60); qt.put(10.0, 10.0, "10.0, 10.0"); qt.put(20.0, 20.0, "20.0, 20.0"); // on vertical border @@ -286,7 +286,7 @@ public void testGetDistance_EntryOnDividingBorder() { } @Test - public void testGetDistance_EntryOnOutsideBorder() { + void testGetDistance_EntryOnOutsideBorder() { QuadTree qt = new QuadTree<>(0.0, 0.0, 40.0, 60.0); // the 4 corners qt.put(0.0, 0.0, "SW"); @@ -311,7 +311,7 @@ public void testGetDistance_EntryOnOutsideBorder() { } @Test - public void testGetElliptical() { + void testGetElliptical() { final Collection all = new ArrayList<>(); QuadTree qt = new QuadTree<>(0, 0, 40, 60); @@ -379,7 +379,7 @@ public void testGetElliptical() { } @Test - public void testGetRect() { + void testGetRect() { QuadTree qt = new QuadTree<>(0, 0, 1000, 1000); qt.put(100, 200, "node1"); qt.put(400, 900, "node2"); @@ -394,7 +394,7 @@ public void testGetRect() { } @Test - public void testGetRect_flatNetwork() { + void testGetRect_flatNetwork() { QuadTree qt = new QuadTree<>(0, 0, 1000, 0); qt.put(0, 0, "node1"); qt.put(100, 0, "node2"); @@ -418,7 +418,7 @@ public void testGetRect_flatNetwork() { * Test removing values from a QuadTree using {@link QuadTree#remove(double, double, Object)}. */ @Test - public void testRemove() { + void testRemove() { QuadTree qt = getTestTree(); int size = qt.size(); // test real removal @@ -452,7 +452,7 @@ public void testRemove() { * Test {@link QuadTree#clear()}. */ @Test - public void testClear() { + void testClear() { QuadTree qt = getTestTree(); int size = qt.size(); assertTrue(size > 0); // it makes no sense to test clear() on an empty tree @@ -465,7 +465,7 @@ public void testClear() { * Test {@link QuadTree#values()} that it returns the correct content. */ @Test - public void testValues() { + void testValues() { QuadTree qt = getTestTree(); int size = qt.size(); assertEquals(6, size); @@ -503,7 +503,7 @@ public void testValues() { * as well. */ @Test - public void testValues_isView() { + void testValues_isView() { QuadTree qt = getTestTree(); int size = qt.size(); Collection values = qt.values(); @@ -523,7 +523,7 @@ public void testValues_isView() { } @Test - public void testValuesIterator_ConcurrentModification() { + void testValuesIterator_ConcurrentModification() { QuadTree qt = getTestTree(); Iterator iter = qt.values().iterator(); assertTrue(iter.hasNext()); @@ -543,7 +543,7 @@ public void testValuesIterator_ConcurrentModification() { * Test {@link QuadTree#execute(double, double, double, double, QuadTree.Executor)}. */ @Test - public void testExecute() { + void testExecute() { QuadTree qt = getTestTree(); TestExecutor executor = new TestExecutor(); int count = qt.execute(0.0, 0.0, 20.1, 20.1, executor); @@ -573,7 +573,7 @@ public void testExecute() { * @throws ClassNotFoundException */ @Test - public void testSerialization() throws IOException, ClassNotFoundException { + void testSerialization() throws IOException, ClassNotFoundException { QuadTree qt = getTestTree(); ByteArrayOutputStream outStream = new ByteArrayOutputStream(); @@ -637,7 +637,7 @@ public void execute(final double x, final double y, final String object) { * Test read access on {@link QuadTree#getRing(double, double, double, double)}. */ @Test - public void testGetRing() { + void testGetRing() { QuadTree qt = new QuadTree(0, 0, 3, 3); for(int x = 0; x < 4; x++) { @@ -686,7 +686,7 @@ public void testGetRing() { * tests that also for a large number of entries, values() returns the correct result. */ @Test - public void testGetValues() { + void testGetValues() { double minX = -1000; double minY = -5000; double maxX = 20000; diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/TupleTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/TupleTest.java index ca81f47c19c..bb7a2d62046 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/TupleTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/TupleTest.java @@ -22,17 +22,19 @@ import static org.junit.Assert.*; -import org.junit.Test; +import org.junit.jupiter.api.Test; public class TupleTest { - @Test public void testOf() { + @Test + void testOf() { Tuple t1 = new Tuple<>(1, 1.1); Tuple t2 = Tuple.of(1, 1.1); assertEquals(t1, t2); } - @Test public void testEquals() { + @Test + void testEquals() { // the basic Tuple we will usually compare against Tuple t1 = new Tuple(1, 1.1); @@ -69,7 +71,8 @@ public class TupleTest { assertFalse(t1.equals(Integer.valueOf(1))); } - @Test public void testEquals_withNull() { + @Test + void testEquals_withNull() { Integer i1 = Integer.valueOf(1); Integer i2 = Integer.valueOf(2); Tuple tuple1a = new Tuple(i1, null); @@ -100,7 +103,8 @@ public class TupleTest { assertFalse(tuple3a.equals(tuple4)); } - @Test public void testHashCode_withNull() { + @Test + void testHashCode_withNull() { Integer i1 = Integer.valueOf(1); Integer i2 = Integer.valueOf(2); Tuple tuple = new Tuple(i1, i2); diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/CoordImplTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/CoordImplTest.java index da30eb32e76..ee6b99929f1 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/CoordImplTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/CoordImplTest.java @@ -22,7 +22,7 @@ import java.util.Arrays; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; /** @@ -36,7 +36,7 @@ public class CoordImplTest { * the new hashCode implementation does not have this problem. */ @Test - public void testHashCode() { + void testHashCode() { int[] hashCodes = new int[] { new Coord(1.0, 1.0).hashCode(), new Coord(2.0, 2.0).hashCode(), diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java index c2729e3e132..01bb58b1090 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java @@ -24,14 +24,14 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.testcases.MatsimTestUtils; public class CoordUtilsTest { @Test - public void testCreateCoord2D() { + void testCreateCoord2D() { Coord c1 = new Coord(0.0, 1.0); Coord c2 = CoordUtils.createCoord(0.0, 1.0); Coord c3 = CoordUtils.createCoord(0.0, 2.0); @@ -40,7 +40,7 @@ public void testCreateCoord2D() { } @Test - public void testCreateCoord3D() { + void testCreateCoord3D() { Coord c1 = new Coord(0.0, 1.0, 2.0); Coord c2 = CoordUtils.createCoord(0.0, 1.0, 2.0); Coord c3 = CoordUtils.createCoord(0.0, 2.0, 2.0); @@ -49,7 +49,7 @@ public void testCreateCoord3D() { } @Test - public void testPlus() { + void testPlus() { Coord c2a = CoordUtils.createCoord(1.0, 1.0); Coord c2b = CoordUtils.createCoord(2.0, 2.0); Coord c2c = CoordUtils.createCoord(3.0, 3.0); @@ -80,7 +80,7 @@ public void testPlus() { } @Test - public void testMinus() { + void testMinus() { Coord c2a = CoordUtils.createCoord(1.0, 1.0); Coord c2b = CoordUtils.createCoord(2.0, 2.0); Coord c2c = CoordUtils.createCoord(3.0, 3.0); @@ -111,7 +111,7 @@ public void testMinus() { } @Test - public void testScalarMult() { + void testScalarMult() { // 2D Coord c2a = CoordUtils.createCoord(1.0, 1.0); Coord c2b = CoordUtils.createCoord(2.0, 2.0); @@ -124,7 +124,7 @@ public void testScalarMult() { } @Test - public void testGetCenter() { + void testGetCenter() { // 2D Coord c2a = CoordUtils.createCoord(0.0, 0.0); Coord c2b = CoordUtils.createCoord(2.0, 2.0); @@ -139,7 +139,7 @@ public void testGetCenter() { } @Test - public void testLength() { + void testLength() { // 2D Coord c2 = CoordUtils.createCoord(2.0, 2.0); assertEquals(Math.sqrt(8.0), CoordUtils.length(c2), MatsimTestUtils.EPSILON); @@ -149,7 +149,7 @@ public void testLength() { } @Test - public void testRotateToRight() { + void testRotateToRight() { Coord coord1 = new Coord(3., 2.); Coord result = CoordUtils.rotateToRight( coord1 ) ; @@ -171,12 +171,12 @@ public void testRotateToRight() { @Test @Ignore - public void testGetCenterWOffset() { + void testGetCenterWOffset() { fail("Not yet implemented"); } @Test - public void testCalcEuclideanDistance() { + void testCalcEuclideanDistance() { // 2D Coord c2a = CoordUtils.createCoord(0.0, 0.0); Coord c2b = CoordUtils.createCoord(1.0, 0.0); @@ -200,10 +200,10 @@ public void testCalcEuclideanDistance() { // Mixed 2D and 3D assertEquals(Math.sqrt(2.0), CoordUtils.calcEuclideanDistance(c2a, c3e), MatsimTestUtils.EPSILON); } - - + + @Test - public void testCalcProjectedDistance() { + void testCalcProjectedDistance() { // 2D Coord c2a = CoordUtils.createCoord(0.0, 0.0); Coord c2b = CoordUtils.createCoord(1.0, 1.0); @@ -217,11 +217,10 @@ public void testCalcProjectedDistance() { // Mixed 2D and 3D assertEquals(Math.sqrt(2.0), CoordUtils.calcProjectedEuclideanDistance(c2a, c3b), MatsimTestUtils.EPSILON); } - - + @Test - public void testDistancePointLinesegment() { + void testDistancePointLinesegment() { /* First: 2D */ /* * (0,1) c1 @@ -268,9 +267,9 @@ public void testDistancePointLinesegment() { dist = CoordUtils.distancePointLinesegment(c2, c3, c1); assertEquals(CoordUtils.calcEuclideanDistance(c3, c1), dist, MatsimTestUtils.EPSILON); } - + @Test - public void testOrthogonalProjectionOnLineSegment(){ + void testOrthogonalProjectionOnLineSegment(){ /* First: 2D */ Coord point = CoordUtils.createCoord(2.0, 0.0); Coord lineFrom = CoordUtils.createCoord(0.0, 0.0); diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java index 4e4a7495248..10527d9d759 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java @@ -21,8 +21,8 @@ package org.matsim.core.utils.geometry; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.GeometryFactory; import org.locationtech.jts.geom.LineString; @@ -49,7 +49,7 @@ public class GeometryUtilsTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test - public final void testIntersectingLinks() { + final void testIntersectingLinks() { Config config = ConfigUtils.loadConfig( IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL("equil"), "config.xml" ) ) ; diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java index 65265390b9f..bef47a55d81 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java @@ -21,14 +21,14 @@ package org.matsim.core.utils.geometry.geotools; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Point; import org.matsim.api.core.v01.Coord; import org.matsim.testcases.MatsimTestUtils; -/** + /** * * @author laemmel * @@ -39,7 +39,8 @@ public class MGCTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testCoord2CoordinateAndViceVersa(){ + @Test + void testCoord2CoordinateAndViceVersa(){ double x = 123.456789; double y = 987.654321; double delta = 0.0000001; @@ -52,7 +53,8 @@ public class MGCTest { org.junit.Assert.assertEquals(y,y1,delta); } - @Test public void testCoord2PointAndViceVersa(){ + @Test + void testCoord2PointAndViceVersa(){ double x = 123.456789; double y = 987.654321; double delta = 0.0000001; @@ -66,7 +68,8 @@ public class MGCTest { } - @Test public void testGetUTMEPSGCodeForWGS84Coordinate() { + @Test + void testGetUTMEPSGCodeForWGS84Coordinate() { { //Hamburg - should be UTM 32 North --> EPSG:32632 double lat = 53.562021; @@ -111,7 +114,8 @@ public class MGCTest { } } - @Test public void testGetCRS(){ + @Test + void testGetCRS(){ // CH1903_LV03 Id org.junit.Assert.assertNotNull(MGC.getCRS("EPSG:21781")); diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustoWGS84Test.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustoWGS84Test.java index 3b9f5b6d5db..3c88bf71af1 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustoWGS84Test.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustoWGS84Test.java @@ -22,7 +22,7 @@ package org.matsim.core.utils.geometry.transformations; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; /** @@ -35,7 +35,7 @@ public class CH1903LV03PlustoWGS84Test { * http://www.swisstopo.admin.ch/internet/swisstopo/de/home/topics/survey/sys/refsys/switzerland.parsysrelated1.24280.downloadList.87003.DownloadFile.tmp/ch1903wgs84de.pdf */ @Test - public void testTransform() { + void testTransform() { double xx = 8.0 + 43.0/60 + 49.80/3600; double yy = 46.0 + 02.0/60 + 38.86/3600; double epsilon = 1e-6; diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustofromCH1903LV03Test.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustofromCH1903LV03Test.java index f0eacb3de92..3f7420d1340 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustofromCH1903LV03Test.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustofromCH1903LV03Test.java @@ -22,7 +22,7 @@ package org.matsim.core.utils.geometry.transformations; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; /** @@ -31,7 +31,7 @@ public class CH1903LV03PlustofromCH1903LV03Test { @Test - public void testCH1903LV03PlustoCH1903LV03() { + void testCH1903LV03PlustoCH1903LV03() { CH1903LV03PlustoCH1903LV03 converter = new CH1903LV03PlustoCH1903LV03(); Coord n = converter.transform(new Coord((double) 2700000, (double) 1100000)); Assert.assertEquals(700000, n.getX(), 0.0); @@ -39,7 +39,7 @@ public void testCH1903LV03PlustoCH1903LV03() { } @Test - public void testCH1903LV03toCH1903LV03Plus() { + void testCH1903LV03toCH1903LV03Plus() { CH1903LV03toCH1903LV03Plus converter = new CH1903LV03toCH1903LV03Plus(); Coord n = converter.transform(new Coord((double) 700000, (double) 100000)); Assert.assertEquals(2700000, n.getX(), 0.0); diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03toWGS84Test.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03toWGS84Test.java index 246195bb663..a8e43c4d8ed 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03toWGS84Test.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03toWGS84Test.java @@ -20,8 +20,7 @@ package org.matsim.core.utils.geometry.transformations; import org.junit.Assert; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; /** @@ -34,7 +33,7 @@ public class CH1903LV03toWGS84Test { * http://www.swisstopo.ch/pub/down/basics/geo/system/ch1903_wgs84_de.pdf */ @Test - public void testTransform() { + void testTransform() { double xx = 8.0 + 43.0/60 + 49.80/3600; double yy = 46.0 + 02.0/60 + 38.86/3600; double epsilon = 1e-6; diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java index 7fd2cacc8df..aac31a1b9be 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java @@ -20,8 +20,8 @@ package org.matsim.core.utils.geometry.transformations; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.geometry.CoordinateTransformation; import org.matsim.testcases.MatsimTestUtils; @@ -36,7 +36,8 @@ public class GeotoolsTransformationTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testTransform(){ + @Test + void testTransform(){ String toCRS = "WGS84"; String fromCRS = "WGS84_UTM47S"; diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/TransformationFactoryTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/TransformationFactoryTest.java index 1b1dcafc096..f55454c7314 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/TransformationFactoryTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/TransformationFactoryTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.core.utils.geometry.CoordinateTransformation; public class TransformationFactoryTest { @@ -35,7 +35,8 @@ public class TransformationFactoryTest { * Test if a custom implemented, non-GeoTools coordinate transformation can * be instantiated. */ - @Test public final void testKnownCustomTransformation() { + @Test + final void testKnownCustomTransformation() { CoordinateTransformation transformation = TransformationFactory.getCoordinateTransformation(TransformationFactory.GK4, TransformationFactory.WGS84); assertNotNull(transformation); assertTrue(transformation instanceof GK4toWGS84); @@ -44,7 +45,8 @@ public class TransformationFactoryTest { /** * Test if GeoTools handles the requested coordinate transformation. */ - @Test public final void testKnownGeotoolsTransformation() { + @Test + final void testKnownGeotoolsTransformation() { CoordinateTransformation transformation = TransformationFactory.getCoordinateTransformation(TransformationFactory.WGS84_UTM35S, TransformationFactory.WGS84); assertNotNull(transformation); assertTrue(transformation instanceof GeotoolsTransformation); @@ -54,7 +56,8 @@ public class TransformationFactoryTest { * Test if a correct, GeoTools' Well-Known-Text (WKT) is correctly recognized, * instead of our shortcut names. */ - @Test public final void testUnknownWKTTransformation() { + @Test + final void testUnknownWKTTransformation() { final String wgs84utm35s = "PROJCS[\"WGS_1984_UTM_Zone_35S\",GEOGCS[\"GCS_WGS_1984\",DATUM[\"D_WGS_1984\",SPHEROID[\"WGS_1984\",6378137,298.257223563]],PRIMEM[\"Greenwich\",0],UNIT[\"Degree\",0.017453292519943295]],PROJECTION[\"Transverse_Mercator\"],PARAMETER[\"latitude_of_origin\",0],PARAMETER[\"central_meridian\",27],PARAMETER[\"scale_factor\",0.9996],PARAMETER[\"false_easting\",500000],PARAMETER[\"false_northing\",10000000],UNIT[\"Meter\",1]]"; final String wgs84 = "GEOGCS[\"WGS84\", DATUM[\"WGS84\", SPHEROID[\"WGS84\", 6378137.0, 298.257223563]], PRIMEM[\"Greenwich\", 0.0], UNIT[\"degree\",0.017453292519943295], AXIS[\"Longitude\",EAST], AXIS[\"Latitude\",NORTH]]"; CoordinateTransformation transformation1 = TransformationFactory.getCoordinateTransformation(wgs84utm35s, TransformationFactory.WGS84); @@ -68,7 +71,8 @@ public class TransformationFactoryTest { /** * Test if a wrong, non-Well-Known-Text according to GeoTools is correctly rejected. */ - @Test public final void testUnknownBadTransformation() { + @Test + final void testUnknownBadTransformation() { // GeoTools recognize misspellings in WKTs, but not (possibly) missing parameters. // Don't be fooled by the many Strings in WKTs, many of them are just names, NOT identifiers! @@ -92,32 +96,38 @@ public class TransformationFactoryTest { } } - @Test public final void testIdentityTransformation() { + @Test + final void testIdentityTransformation() { CoordinateTransformation transformation = TransformationFactory.getCoordinateTransformation(TransformationFactory.ATLANTIS, TransformationFactory.ATLANTIS); assertTrue(transformation instanceof IdentityTransformation); } - @Test public final void testToCH1903LV03() { + @Test + final void testToCH1903LV03() { CoordinateTransformation transformation = TransformationFactory.getCoordinateTransformation(TransformationFactory.WGS84, TransformationFactory.CH1903_LV03); assertTrue(transformation instanceof WGS84toCH1903LV03); } - @Test public final void testFromCH1903LV03() { + @Test + final void testFromCH1903LV03() { CoordinateTransformation transformation = TransformationFactory.getCoordinateTransformation(TransformationFactory.CH1903_LV03, TransformationFactory.WGS84); assertTrue(transformation instanceof CH1903LV03toWGS84); } - @Test public final void testToCH1903LV03Plus() { + @Test + final void testToCH1903LV03Plus() { CoordinateTransformation transformation = TransformationFactory.getCoordinateTransformation(TransformationFactory.WGS84, TransformationFactory.CH1903_LV03_Plus); assertTrue(transformation instanceof WGS84toCH1903LV03Plus); } - @Test public final void testFromCH1903LV03Plus() { + @Test + final void testFromCH1903LV03Plus() { CoordinateTransformation transformation = TransformationFactory.getCoordinateTransformation(TransformationFactory.CH1903_LV03_Plus, TransformationFactory.WGS84); assertTrue(transformation instanceof CH1903LV03PlustoWGS84); } - @Test public final void testFromAtlantis() { + @Test + final void testFromAtlantis() { CoordinateTransformation transformation = TransformationFactory.getCoordinateTransformation(TransformationFactory.ATLANTIS, TransformationFactory.WGS84); assertTrue(transformation instanceof AtlantisToWGS84); } diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03PlusTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03PlusTest.java index 8d0078af315..93fecc49e19 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03PlusTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03PlusTest.java @@ -22,7 +22,7 @@ package org.matsim.core.utils.geometry.transformations; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; /** @@ -35,7 +35,7 @@ public class WGS84toCH1903LV03PlusTest { * http://www.swisstopo.admin.ch/internet/swisstopo/de/home/topics/survey/sys/refsys/switzerland.parsysrelated1.24280.downloadList.87003.DownloadFile.tmp/ch1903wgs84de.pdf */ @Test - public void testTransform() { + void testTransform() { double xx = 8.0 + 43.0/60 + 49.79/3600; double yy = 46.0 + 02.0/60 + 38.87/3600; double epsilon = 1e-2; diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03Test.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03Test.java index c32e329e80c..717fa4da70c 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03Test.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03Test.java @@ -20,8 +20,7 @@ package org.matsim.core.utils.geometry.transformations; import org.junit.Assert; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; /** @@ -30,7 +29,7 @@ public class WGS84toCH1903LV03Test { @Test - public void testTransform() { + void testTransform() { double xx = 8.0 + 43.0/60 + 49.79/3600; double yy = 46.0 + 02.0/60 + 38.87/3600; double epsilon = 1e-2; diff --git a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java index 155a9f62128..650293090b4 100644 --- a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java @@ -25,8 +25,8 @@ import org.geotools.data.FeatureSource; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -41,7 +41,7 @@ public class ShapeFileReaderTest { * @throws IOException */ @Test - public void testPlusInFilename() throws IOException { + void testPlusInFilename() throws IOException { String filename = "src/test/resources/" + utils.getInputDirectory() + "test+test.shp"; FeatureSource fs = ShapeFileReader.readDataFile(filename); Assert.assertEquals(3, fs.getFeatures().size()); diff --git a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java index bf9b3ee2a90..a953c2bfd62 100644 --- a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java @@ -33,8 +33,8 @@ import org.geotools.feature.simple.SimpleFeatureTypeBuilder; import org.geotools.referencing.crs.DefaultGeographicCRS; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; import org.locationtech.jts.geom.GeometryFactory; @@ -50,7 +50,7 @@ public class ShapeFileWriterTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testShapeFileWriter() throws IOException{ + void testShapeFileWriter() throws IOException{ String inFile = "src/test/resources/" + utils.getInputDirectory() + "test.shp"; @@ -75,7 +75,7 @@ public void testShapeFileWriter() throws IOException{ } @Test - public void testShapeFileWriterWithSelfCreatedContent() throws IOException { + void testShapeFileWriterWithSelfCreatedContent() throws IOException { String outFile = utils.getOutputDirectory() + "/test.shp"; SimpleFeatureTypeBuilder b = new SimpleFeatureTypeBuilder(); b.setName("EvacuationArea"); @@ -108,7 +108,7 @@ public void testShapeFileWriterWithSelfCreatedContent() throws IOException { } @Test - public void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Polygon() throws IOException { + void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Polygon() throws IOException { String outFile = utils.getOutputDirectory() + "test.shp"; PolygonFeatureFactory ff = new PolygonFeatureFactory.Builder() @@ -137,7 +137,7 @@ public void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Polygon( } @Test - public void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Polyline() throws IOException { + void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Polyline() throws IOException { String outFile = utils.getOutputDirectory() + "test.shp"; PolylineFeatureFactory ff = new PolylineFeatureFactory.Builder() @@ -166,7 +166,7 @@ public void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Polyline } @Test - public void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Point() throws IOException { + void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Point() throws IOException { String outFile = utils.getOutputDirectory() + "test.shp"; PointFeatureFactory ff = new PointFeatureFactory.Builder() diff --git a/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java index db3784f59e6..150f1982025 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java @@ -19,9 +19,11 @@ * *********************************************************************** */ package org.matsim.core.utils.io; +import static org.junit.jupiter.api.Assertions.assertThrows; + import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.controler.OutputDirectoryLogging; import org.matsim.core.utils.misc.CRCChecksum; import org.matsim.testcases.MatsimTestUtils; @@ -42,7 +44,7 @@ public class IOUtilsTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testInitOutputDirLogging() throws IOException { + void testInitOutputDirLogging() throws IOException { System.out.println(utils.getOutputDirectory()); String outDir = utils.getOutputDirectory(); OutputDirectoryLogging.initLoggingWithOutputDirectory(outDir); @@ -57,7 +59,7 @@ public void testInitOutputDirLogging() throws IOException { * @author mrieser */ @Test - public void testDeleteDir() throws IOException { + void testDeleteDir() throws IOException { String outputDir = utils.getOutputDirectory(); String testDir = outputDir + "a"; String someFilename = testDir + "/a.txt"; @@ -75,17 +77,19 @@ public void testDeleteDir() throws IOException { /** * @author mrieser */ - @Test(expected = UncheckedIOException.class) - public void testDeleteDir_InexistentDir() { - String outputDir = utils.getOutputDirectory(); - String testDir = outputDir + "a"; - File dir = new File(testDir); - IOUtils.deleteDirectoryRecursively(dir.toPath()); - Assert.assertFalse(dir.exists()); + @Test + void testDeleteDir_InexistentDir() { + assertThrows(UncheckedIOException.class, () -> { + String outputDir = utils.getOutputDirectory(); + String testDir = outputDir + "a"; + File dir = new File(testDir); + IOUtils.deleteDirectoryRecursively(dir.toPath()); + Assert.assertFalse(dir.exists()); + }); } @Test - public void testGetBufferedReader_encodingMacRoman() throws IOException { + void testGetBufferedReader_encodingMacRoman() throws IOException { URL url = IOUtils.resolveFileOrResource(this.utils.getClassInputDirectory() + "textsample_MacRoman.txt"); BufferedReader reader = IOUtils.getBufferedReader(url, Charset.forName("MacRoman")); String line = reader.readLine(); @@ -94,7 +98,7 @@ public void testGetBufferedReader_encodingMacRoman() throws IOException { } @Test - public void testGetBufferedReader_encodingIsoLatin1() throws IOException { + void testGetBufferedReader_encodingIsoLatin1() throws IOException { URL url = IOUtils.resolveFileOrResource(this.utils.getClassInputDirectory() + "textsample_IsoLatin1.txt"); BufferedReader reader = IOUtils.getBufferedReader(url, Charset.forName("ISO-8859-1")); String line = reader.readLine(); @@ -103,7 +107,7 @@ public void testGetBufferedReader_encodingIsoLatin1() throws IOException { } @Test - public void testGetBufferedReader_encodingUTF8() throws IOException { + void testGetBufferedReader_encodingUTF8() throws IOException { URL url = IOUtils.resolveFileOrResource(this.utils.getClassInputDirectory() + "textsample_UTF8.txt"); BufferedReader reader = IOUtils.getBufferedReader(url); String line = reader.readLine(); @@ -112,7 +116,7 @@ public void testGetBufferedReader_encodingUTF8() throws IOException { } @Test - public void testGetBufferedWriter_encodingMacRoman() throws IOException { + void testGetBufferedWriter_encodingMacRoman() throws IOException { String filename = this.utils.getOutputDirectory() + "textsample_MacRoman.txt"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url, Charset.forName("MacRoman"), false); @@ -124,7 +128,7 @@ public void testGetBufferedWriter_encodingMacRoman() throws IOException { } @Test - public void testGetBufferedWriter_encodingIsoLatin1() throws IOException { + void testGetBufferedWriter_encodingIsoLatin1() throws IOException { String filename = this.utils.getOutputDirectory() + "textsample_IsoLatin1.txt"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url, Charset.forName("ISO-8859-1"), false); @@ -136,7 +140,7 @@ public void testGetBufferedWriter_encodingIsoLatin1() throws IOException { } @Test - public void testGetBufferedWriter_encodingUTF8() throws IOException { + void testGetBufferedWriter_encodingUTF8() throws IOException { String filename = this.utils.getOutputDirectory() + "textsample_UTF8.txt"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url); @@ -148,7 +152,7 @@ public void testGetBufferedWriter_encodingUTF8() throws IOException { } @Test - public void testGetBufferedWriter_overwrite() throws IOException { + void testGetBufferedWriter_overwrite() throws IOException { String filename = this.utils.getOutputDirectory() + "test.txt"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url); @@ -163,7 +167,7 @@ public void testGetBufferedWriter_overwrite() throws IOException { } @Test - public void testGetBufferedWriter_append() throws IOException { + void testGetBufferedWriter_append() throws IOException { String filename = this.utils.getOutputDirectory() + "test.txt"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); @@ -178,7 +182,7 @@ public void testGetBufferedWriter_append() throws IOException { } @Test - public void testGetBufferedWriter_overwrite_gzipped() throws IOException { + void testGetBufferedWriter_overwrite_gzipped() throws IOException { String filename = this.utils.getOutputDirectory() + "test.txt.gz"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url); @@ -192,18 +196,20 @@ public void testGetBufferedWriter_overwrite_gzipped() throws IOException { Assert.assertEquals("bbb", line); } - @Test(expected = UncheckedIOException.class) - public void testGetBufferedWriter_append_gzipped() throws IOException { - String filename = this.utils.getOutputDirectory() + "test.txt.gz"; - URL url = IOUtils.getFileUrl(filename); - BufferedWriter writer = IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); - writer.write("aaa"); - writer.close(); - IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); + @Test + void testGetBufferedWriter_append_gzipped() throws IOException { + assertThrows(UncheckedIOException.class, () -> { + String filename = this.utils.getOutputDirectory() + "test.txt.gz"; + URL url = IOUtils.getFileUrl(filename); + BufferedWriter writer = IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); + writer.write("aaa"); + writer.close(); + IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); + }); } @Test - public void testGetBufferedWriter_gzipped() throws IOException { + void testGetBufferedWriter_gzipped() throws IOException { String filename = this.utils.getOutputDirectory() + "test.txt.gz"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url); @@ -213,18 +219,20 @@ public void testGetBufferedWriter_gzipped() throws IOException { Assert.assertTrue("compressed file should be less than 50 bytes, but is " + file.length(), file.length() < 50); } - @Test(expected = UncheckedIOException.class) - public void testGetBufferedWriter_append_lz4() throws IOException { - String filename = this.utils.getOutputDirectory() + "test.txt.lz4"; - URL url = IOUtils.getFileUrl(filename); - BufferedWriter writer = IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); - writer.write("aaa"); - writer.close(); - IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); + @Test + void testGetBufferedWriter_append_lz4() throws IOException { + assertThrows(UncheckedIOException.class, () -> { + String filename = this.utils.getOutputDirectory() + "test.txt.lz4"; + URL url = IOUtils.getFileUrl(filename); + BufferedWriter writer = IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); + writer.write("aaa"); + writer.close(); + IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); + }); } @Test - public void testGetBufferedWriter_lz4() throws IOException { + void testGetBufferedWriter_lz4() throws IOException { String filename = this.utils.getOutputDirectory() + "test.txt.lz4"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url); @@ -237,18 +245,20 @@ public void testGetBufferedWriter_lz4() throws IOException { Assert.assertEquals("12345678901234567890123456789012345678901234567890", content); } - @Test(expected = UncheckedIOException.class) - public void testGetBufferedWriter_append_bz2() throws IOException { - String filename = this.utils.getOutputDirectory() + "test.txt.bz2"; - URL url = IOUtils.getFileUrl(filename); - BufferedWriter writer = IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); - writer.write("aaa"); - writer.close(); - IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); + @Test + void testGetBufferedWriter_append_bz2() throws IOException { + assertThrows(UncheckedIOException.class, () -> { + String filename = this.utils.getOutputDirectory() + "test.txt.bz2"; + URL url = IOUtils.getFileUrl(filename); + BufferedWriter writer = IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); + writer.write("aaa"); + writer.close(); + IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); + }); } @Test - public void testGetBufferedWriter_bz2() throws IOException { + void testGetBufferedWriter_bz2() throws IOException { String filename = this.utils.getOutputDirectory() + "test.txt.bz2"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url); @@ -259,7 +269,7 @@ public void testGetBufferedWriter_bz2() throws IOException { } @Test - public void testGetBufferedWriter_append_zst() throws IOException { + void testGetBufferedWriter_append_zst() throws IOException { String filename = this.utils.getOutputDirectory() + "test.txt.zst"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url, IOUtils.CHARSET_UTF8, true); @@ -274,7 +284,7 @@ public void testGetBufferedWriter_append_zst() throws IOException { } @Test - public void testGetBufferedWriter_zst() throws IOException { + void testGetBufferedWriter_zst() throws IOException { String filename = this.utils.getOutputDirectory() + "test.txt.zst"; URL url = IOUtils.getFileUrl(filename); BufferedWriter writer = IOUtils.getBufferedWriter(url); @@ -285,7 +295,7 @@ public void testGetBufferedWriter_zst() throws IOException { } @Test - public void testGetInputStream_UTFwithoutBOM() throws IOException { + void testGetInputStream_UTFwithoutBOM() throws IOException { String filename = utils.getOutputDirectory() + "test.txt"; FileOutputStream out = new FileOutputStream(filename); out.write("ABCdef".getBytes()); @@ -297,7 +307,7 @@ public void testGetInputStream_UTFwithoutBOM() throws IOException { } @Test - public void testGetInputStream_UTFwithBOM() throws IOException { + void testGetInputStream_UTFwithBOM() throws IOException { String filename = utils.getOutputDirectory() + "test.txt"; FileOutputStream out = new FileOutputStream(filename); out.write(new byte[] {(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}); @@ -310,7 +320,7 @@ public void testGetInputStream_UTFwithBOM() throws IOException { } @Test - public void testGetInputStream_UTFwithBOM_Compressed() throws IOException { + void testGetInputStream_UTFwithBOM_Compressed() throws IOException { String filename = utils.getOutputDirectory() + "test.txt.gz"; OutputStream out = IOUtils.getOutputStream(IOUtils.getFileUrl(filename), false); out.write(new byte[] {(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}); @@ -323,7 +333,7 @@ public void testGetInputStream_UTFwithBOM_Compressed() throws IOException { } @Test - public void testGetInputStream_UTFwithBOM_Lz4() throws IOException { + void testGetInputStream_UTFwithBOM_Lz4() throws IOException { String filename = utils.getOutputDirectory() + "test.txt.lz4"; OutputStream out = IOUtils.getOutputStream(IOUtils.getFileUrl(filename), false); out.write(new byte[] {(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}); @@ -336,7 +346,7 @@ public void testGetInputStream_UTFwithBOM_Lz4() throws IOException { } @Test - public void testGetInputStream_UTFwithBOM_bz2() throws IOException { + void testGetInputStream_UTFwithBOM_bz2() throws IOException { String filename = utils.getOutputDirectory() + "test.txt.bz2"; OutputStream out = IOUtils.getOutputStream(IOUtils.getFileUrl(filename), false); out.write(new byte[] {(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}); @@ -349,7 +359,7 @@ public void testGetInputStream_UTFwithBOM_bz2() throws IOException { } @Test - public void testGetInputStream_UTFwithBOM_zst() throws IOException { + void testGetInputStream_UTFwithBOM_zst() throws IOException { String filename = utils.getOutputDirectory() + "test.txt.zst"; OutputStream out = IOUtils.getOutputStream(IOUtils.getFileUrl(filename), false); out.write(new byte[] {(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}); @@ -362,7 +372,7 @@ public void testGetInputStream_UTFwithBOM_zst() throws IOException { } @Test - public void testGetBufferedReader_UTFwithoutBOM() throws IOException { + void testGetBufferedReader_UTFwithoutBOM() throws IOException { String filename = utils.getOutputDirectory() + "test.txt"; FileOutputStream out = new FileOutputStream(filename); out.write("ABCdef".getBytes()); @@ -386,7 +396,7 @@ public void testGetBufferedReader_UTFwithoutBOM() throws IOException { } @Test - public void testGetBufferedReader_UTFwithBOM() throws IOException { + void testGetBufferedReader_UTFwithBOM() throws IOException { String filename = utils.getOutputDirectory() + "test.txt"; FileOutputStream out = new FileOutputStream(filename); out.write(new byte[] {(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}); @@ -411,7 +421,7 @@ public void testGetBufferedReader_UTFwithBOM() throws IOException { } @Test - public void testGetBufferedReader_UTFwithBOM_Compressed() throws IOException { + void testGetBufferedReader_UTFwithBOM_Compressed() throws IOException { String filename = utils.getOutputDirectory() + "test.txt.gz"; OutputStream out = IOUtils.getOutputStream(IOUtils.getFileUrl(filename), false); out.write(new byte[] {(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}); @@ -441,7 +451,7 @@ public void testGetBufferedReader_UTFwithBOM_Compressed() throws IOException { } @Test - public void testGetBufferedReader_UTFwithBOM_lz4() throws IOException { + void testGetBufferedReader_UTFwithBOM_lz4() throws IOException { String filename = utils.getOutputDirectory() + "test.txt.lz4"; OutputStream out = IOUtils.getOutputStream(IOUtils.getFileUrl(filename), false); out.write(new byte[] {(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}); @@ -466,7 +476,7 @@ public void testGetBufferedReader_UTFwithBOM_lz4() throws IOException { } @Test - public void testGetBufferedReader_UTFwithBOM_bz2() throws IOException { + void testGetBufferedReader_UTFwithBOM_bz2() throws IOException { String filename = utils.getOutputDirectory() + "test.txt.bz2"; OutputStream out = IOUtils.getOutputStream(IOUtils.getFileUrl(filename), false); out.write(new byte[] {(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}); @@ -491,7 +501,7 @@ public void testGetBufferedReader_UTFwithBOM_bz2() throws IOException { } @Test - public void testGetBufferedReader_UTFwithBOM_zst() throws IOException { + void testGetBufferedReader_UTFwithBOM_zst() throws IOException { String filename = utils.getOutputDirectory() + "test.txt.zst"; OutputStream out = IOUtils.getOutputStream(IOUtils.getFileUrl(filename), false); out.write(new byte[] {(byte) 0xEF, (byte) 0xBB, (byte) 0xBF}); @@ -522,7 +532,7 @@ public void testGetBufferedReader_UTFwithBOM_zst() throws IOException { * @throws IOException */ @Test - public void testGetBufferedWriter_withPlusInFilename() throws IOException { + void testGetBufferedWriter_withPlusInFilename() throws IOException { String filename = this.utils.getOutputDirectory() + "test+test.txt"; BufferedWriter writer = IOUtils.getBufferedWriter(IOUtils.getFileUrl(filename)); writer.write("hello world!"); @@ -534,7 +544,7 @@ public void testGetBufferedWriter_withPlusInFilename() throws IOException { } @Test - public void testNewUrl() throws MalformedURLException { + void testNewUrl() throws MalformedURLException { URL context = Paths.get("").toUri().toURL(); System.out.println(context.toString()); URL url = IOUtils.extendUrl(context, "C:\\windows\\directory\\filename.txt"); @@ -542,7 +552,7 @@ public void testNewUrl() throws MalformedURLException { } @Test - public void testResolveFileOrResource() throws URISyntaxException, IOException { + void testResolveFileOrResource() throws URISyntaxException, IOException { File jarFile = new File("test/input/org/matsim/core/utils/io/IOUtils/testfile.jar"); String jarUrlString = "file:" + jarFile.getAbsolutePath(); // URLs require absolute paths @@ -558,7 +568,7 @@ public void testResolveFileOrResource() throws URISyntaxException, IOException { } @Test - public void testResolveFileOrResource_withWhitespace() throws URISyntaxException, IOException { + void testResolveFileOrResource_withWhitespace() throws URISyntaxException, IOException { File jarFile = new File("test/input/org/matsim/core/utils/io/IOUtils/test directory/testfile.jar"); String fileUrlString = "jar:" + jarFile.toURI().toString() + "!/the_file.txt"; @@ -574,7 +584,7 @@ public void testResolveFileOrResource_withWhitespace() throws URISyntaxException } @Test - public void testEncryptedFile() throws IOException { + void testEncryptedFile() throws IOException { System.setProperty(CipherUtils.ENVIRONMENT_VARIABLE, "abc123"); diff --git a/matsim/src/test/java/org/matsim/core/utils/io/MatsimFileTypeGuesserTest.java b/matsim/src/test/java/org/matsim/core/utils/io/MatsimFileTypeGuesserTest.java index 34b26897bd8..3ec8ab16e69 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/MatsimFileTypeGuesserTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/MatsimFileTypeGuesserTest.java @@ -30,7 +30,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.lanes.LanesReader; /** @@ -42,7 +42,7 @@ public class MatsimFileTypeGuesserTest { private final static Logger log = LogManager.getLogger(MatsimFileTypeGuesserTest.class); @Test - public void testNetworkV1Dtd() throws IOException { + void testNetworkV1Dtd() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/scenarios/equil/network.xml"); assertEquals(MatsimFileTypeGuesser.FileType.Network, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -50,7 +50,7 @@ public void testNetworkV1Dtd() throws IOException { } @Test - public void testConfigV2Dtd() throws IOException { + void testConfigV2Dtd() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/scenarios/equil/config.xml"); assertEquals(MatsimFileTypeGuesser.FileType.Config, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -58,7 +58,7 @@ public void testConfigV2Dtd() throws IOException { } @Test - public void testPlansV4Dtd() throws IOException { + void testPlansV4Dtd() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/scenarios/equil/plans100.xml"); assertEquals(MatsimFileTypeGuesser.FileType.Population, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -66,7 +66,7 @@ public void testPlansV4Dtd() throws IOException { } @Test - public void testPopulationV5Dtd() throws IOException { + void testPopulationV5Dtd() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/core/utils/io/MatsimFileTypeGuesserTest/population_v5_example.xml"); assertEquals(MatsimFileTypeGuesser.FileType.Population, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -74,7 +74,7 @@ public void testPopulationV5Dtd() throws IOException { } @Test - public void testFacilitiesV1Dtd() throws IOException { + void testFacilitiesV1Dtd() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/scenarios/equil/facilities.xml"); assertEquals(MatsimFileTypeGuesser.FileType.Facilities, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -82,7 +82,7 @@ public void testFacilitiesV1Dtd() throws IOException { } @Test - public void testCountsV1Xsd() throws IOException { + void testCountsV1Xsd() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/scenarios/equil/counts100.xml"); assertEquals(MatsimFileTypeGuesser.FileType.Counts, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -90,7 +90,7 @@ public void testCountsV1Xsd() throws IOException { } @Test - public void testEventsV1Txt() throws IOException { + void testEventsV1Txt() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/events/EventsReadersTest/events.txt"); assertEquals(MatsimFileTypeGuesser.FileType.Events, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -98,7 +98,7 @@ public void testEventsV1Txt() throws IOException { } @Test - public void testEventsV1Xml() throws IOException { + void testEventsV1Xml() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/core/events/EventsReadersTest/events.xml"); assertEquals(MatsimFileTypeGuesser.FileType.Events, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -106,7 +106,7 @@ public void testEventsV1Xml() throws IOException { } @Test - public void testLanesV20XML() throws IOException { + void testLanesV20XML() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/lanes/data/LanesReaderWriterTest/testLanes.xml"); assertEquals(MatsimFileTypeGuesser.FileType.LaneDefinitions, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -115,7 +115,7 @@ public void testLanesV20XML() throws IOException { } @Test - public void testTransitScheduleV1XML() throws IOException { + void testTransitScheduleV1XML() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/pt/transitSchedule/TransitScheduleReaderTest/transitSchedule.xml"); assertEquals(MatsimFileTypeGuesser.FileType.TransitSchedule, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -124,7 +124,7 @@ public void testTransitScheduleV1XML() throws IOException { } @Test - public void testVehiclesV1XML() throws IOException { + void testVehiclesV1XML() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/vehicles/testVehicles_v1.xml"); assertEquals(MatsimFileTypeGuesser.FileType.Vehicles, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -133,7 +133,7 @@ public void testVehiclesV1XML() throws IOException { } @Test - public void testObjectAttributesV1XML_withDtd() throws IOException { + void testObjectAttributesV1XML_withDtd() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/utils/objectattributes/objectattributes_withDtd_v1.xml"); assertEquals(MatsimFileTypeGuesser.FileType.ObjectAttributes, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -142,7 +142,7 @@ public void testObjectAttributesV1XML_withDtd() throws IOException { } @Test - public void testObjectAttributesV1XML_withoutDtd() throws IOException { + void testObjectAttributesV1XML_withoutDtd() throws IOException { MatsimFileTypeGuesser g = new MatsimFileTypeGuesser("test/input/org/matsim/utils/objectattributes/objectattributes_withoutDtd_v1.xml"); assertEquals(MatsimFileTypeGuesser.FileType.ObjectAttributes, g.getGuessedFileType()); assertNull(g.getPublicId()); @@ -150,7 +150,7 @@ public void testObjectAttributesV1XML_withoutDtd() throws IOException { } @Test - public void testNotExistant() { + void testNotExistant() { try { new MatsimFileTypeGuesser("examples/equil/dummy.xml"); fail("expected IOException"); diff --git a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java index 972b0a99be4..7f692064d1d 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java @@ -20,8 +20,8 @@ package org.matsim.core.utils.io; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.jupiter.api.io.TempDir; import org.junit.rules.TemporaryFolder; import org.xml.sax.Attributes; @@ -48,7 +48,7 @@ public class MatsimXmlParserTest { public File tempFolder; @Test - public void testParsingReservedEntities_AttributeValue() { + void testParsingReservedEntities_AttributeValue() { String str = "\n" + "content"; @@ -66,7 +66,7 @@ public void testParsingReservedEntities_AttributeValue() { } @Test - public void testParsingReservedEntities_Content() { + void testParsingReservedEntities_Content() { String str = "\n" + "content"&<>content"; @@ -88,7 +88,7 @@ public void testParsingReservedEntities_Content() { * Based on a (non-reproducible) bug message on the users-mailing list 2012-04-26. */ @Test - public void testParsing_WindowsLinebreaks() { + void testParsing_WindowsLinebreaks() { String str = """ \r \r @@ -134,7 +134,7 @@ public void endTag(String name, String content, Stack context) { } @Test - public void testParsingPlusSign() { + void testParsingPlusSign() { String str = "\n" + "content+content"; @@ -152,7 +152,7 @@ public void testParsingPlusSign() { } @Test - public void testParse_parseEntities() { + void testParse_parseEntities() { String xml = """ context) { } @Test - public void testParse_dtdValidation() { + void testParse_dtdValidation() { String xml = """ @@ -220,7 +220,7 @@ public void endTag(String name, String content, Stack context) { } @Test - public void testParse_xsdValidationSuccess() { + void testParse_xsdValidationSuccess() { String xml = """ @@ -255,7 +255,7 @@ public void endTag(String name, String content, Stack context) { } @Test - public void testParse_xsdValidationFailure() { + void testParse_xsdValidationFailure() { String xml = """ @@ -298,7 +298,7 @@ public void endTag(String name, String content, Stack context) { } @Test - public void testParse_preventXEEattack_woodstox() throws IOException { + void testParse_preventXEEattack_woodstox() throws IOException { // XEE: XML eXternal Entity attack: https://en.wikipedia.org/wiki/XML_external_entity_attack String secretValue = "S3CR3T"; @@ -345,7 +345,7 @@ public void endTag(String name, String content, Stack context) { } @Test - public void testParse_preventXEEattack_xerces() throws IOException { + void testParse_preventXEEattack_xerces() throws IOException { // XEE: XML eXternal Entity attack: https://en.wikipedia.org/wiki/XML_external_entity_attack String secretValue = "S3CR3T"; diff --git a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlWriterTest.java b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlWriterTest.java index 9616d6108ef..031e405293e 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlWriterTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlWriterTest.java @@ -1,12 +1,12 @@ package org.matsim.core.utils.io; -import org.junit.Test; - import java.io.ByteArrayOutputStream; import java.util.List; import static org.junit.Assert.*; +import org.junit.jupiter.api.Test; + /** * @author mrieser / Simunto */ @@ -18,7 +18,7 @@ public class MatsimXmlWriterTest { * special values like infinity and not-a-number must be written as "INF", "-INF" and "NaN". */ @Test - public void testWriteInfiniteValuesInAttributes() { + void testWriteInfiniteValuesInAttributes() { ByteArrayOutputStream baos = new ByteArrayOutputStream(); DummyXmlWriter writer = new DummyXmlWriter(); diff --git a/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java b/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java index a43441e5c8f..b307e54c47d 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java @@ -20,8 +20,8 @@ package org.matsim.core.utils.io; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -44,7 +44,7 @@ public class OsmNetworkReaderTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testConversion() { + void testConversion() { String filename = this.utils.getClassInputDirectory() + "adliswil.osm.gz"; Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -63,7 +63,7 @@ public void testConversion() { } @Test - public void testConversionWithDetails() { + void testConversionWithDetails() { String filename = this.utils.getClassInputDirectory() + "adliswil.osm.gz"; Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -84,7 +84,7 @@ public void testConversionWithDetails() { } @Test - public void testConversionWithDetails_witMemoryOptimized() { + void testConversionWithDetails_witMemoryOptimized() { String filename = this.utils.getClassInputDirectory() + "adliswil.osm.gz"; Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -106,7 +106,7 @@ public void testConversionWithDetails_witMemoryOptimized() { } @Test - public void testConversionWithSettings() { + void testConversionWithSettings() { String filename = this.utils.getClassInputDirectory() + "adliswil.osm.gz"; Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -127,7 +127,7 @@ public void testConversionWithSettings() { } @Test - public void testConversionWithSettings_withMemoryOptimization() { + void testConversionWithSettings_withMemoryOptimization() { String filename = this.utils.getClassInputDirectory() + "adliswil.osm.gz"; Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -148,7 +148,7 @@ public void testConversionWithSettings_withMemoryOptimization() { } @Test - public void testConversionWithSettingsAndDetails() { + void testConversionWithSettingsAndDetails() { String filename = this.utils.getClassInputDirectory() + "adliswil.osm.gz"; Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -169,7 +169,7 @@ public void testConversionWithSettingsAndDetails() { } @Test - public void testConversion_MissingNodeRef() { + void testConversion_MissingNodeRef() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network net = sc.getNetwork(); CoordinateTransformation ct = new IdentityTransformation(); @@ -200,7 +200,7 @@ public void testConversion_MissingNodeRef() { } @Test - public void testConversion_maxspeeds() { + void testConversion_maxspeeds() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network net = sc.getNetwork(); CoordinateTransformation ct = new IdentityTransformation(); @@ -261,7 +261,7 @@ public void testConversion_maxspeeds() { * Reported by jjoubert,15nov2012. */ @Test - public void testConversion_emptyWay() { + void testConversion_emptyWay() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network net = sc.getNetwork(); CoordinateTransformation ct = new IdentityTransformation(); diff --git a/matsim/src/test/java/org/matsim/core/utils/io/XmlUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/io/XmlUtilsTest.java index e5d979ba8ca..1923fddcfae 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/XmlUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/XmlUtilsTest.java @@ -20,7 +20,7 @@ package org.matsim.core.utils.io; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author mrieser @@ -28,7 +28,7 @@ public class XmlUtilsTest { @Test - public void testEncodeAttributeValue() { + void testEncodeAttributeValue() { Assert.assertEquals("hello world!", XmlUtils.encodeAttributeValue("hello world!")); Assert.assertEquals("you & me", XmlUtils.encodeAttributeValue("you & me")); Assert.assertEquals("you & me & her", XmlUtils.encodeAttributeValue("you & me & her")); @@ -39,7 +39,7 @@ public void testEncodeAttributeValue() { } @Test - public void testEncodedContent() { + void testEncodedContent() { Assert.assertEquals("hello world!", XmlUtils.encodeContent("hello world!")); Assert.assertEquals("you & me", XmlUtils.encodeContent("you & me")); Assert.assertEquals("you & me & her", XmlUtils.encodeContent("you & me & her")); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java index 8b30ecbdf30..3e4e9948379 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java @@ -26,8 +26,8 @@ import java.util.Iterator; import java.util.NoSuchElementException; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -44,7 +44,8 @@ public class ArgumentParserTest { /** * Test if regular arguments (no options) are correctly recognized. */ - @Test public void testArguments() { + @Test + void testArguments() { ArgumentParser parser = new ArgumentParser( new String[] {"a", "bc", "def=g", "hjk=lmn opq"}); Iterator iter = parser.iterator(); @@ -58,7 +59,8 @@ public class ArgumentParserTest { /** * Test if short options (beginning with '-'), which can be written in a collapsed form, are correctly recognized. */ - @Test public void testShortOptions() { + @Test + void testShortOptions() { ArgumentParser parser = new ArgumentParser( new String[] {"-a", "-b", "-cd", "-efg", "-h=j", "-kl=m", "-nop=qrs", "-tu=vw xyz", "=", "-", "-=", "-1", "-2=", "-=3", "-=4=5"}, true); Iterator iter = parser.iterator(); @@ -96,7 +98,8 @@ public class ArgumentParserTest { /** * Test if long options (beginning with '--') are correctly recognized. */ - @Test public void testLongOptions() { + @Test + void testLongOptions() { ArgumentParser parser = new ArgumentParser( new String[] {"--a", "--bc", "--def=ghj", "--kl=mn op", "=", "--qr=", "--=", "--=st", "--=uv=wxy z"}, true); Iterator iter = parser.iterator(); @@ -118,7 +121,8 @@ public class ArgumentParserTest { /** * Test if a mix of arguments and options are correctly recognized. */ - @Test public void testMixed() { + @Test + void testMixed() { // first test it with short arguments enabled ArgumentParser parser = new ArgumentParser( new String[] {"-xcf", "myfile.tgz", "file1", "file2", "--verbose"}, true); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java index 8741b572cd5..2325de69101 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java @@ -26,8 +26,8 @@ import java.io.Serializable; import java.nio.ByteBuffer; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -43,7 +43,8 @@ public class ByteBufferUtilsTest { * Tests {@link ByteBufferUtils#putString(java.nio.ByteBuffer, String)} and * {@link ByteBufferUtils#getString(java.nio.ByteBuffer)}. */ - @Test public void testPutGetString() { + @Test + void testPutGetString() { final ByteBuffer buffer = ByteBuffer.allocate(100); buffer.putInt(5); ByteBufferUtils.putString(buffer, "foo bar"); @@ -65,7 +66,8 @@ public class ByteBufferUtilsTest { * Tests {@link ByteBufferUtils#putObject(java.nio.ByteBuffer, Serializable)} and * {@link ByteBufferUtils#getObject(java.nio.ByteBuffer)}. */ - @Test public void testPutGetObject() { + @Test + void testPutGetObject() { final ByteBuffer buffer = ByteBuffer.allocate(100); buffer.putInt(5); ByteBufferUtils.putObject(buffer, "foo bar"); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ClassUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ClassUtilsTest.java index 1f0b5bb0642..de4b6b6bb0c 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ClassUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ClassUtilsTest.java @@ -22,7 +22,7 @@ import java.util.Set; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author mrieser @@ -30,14 +30,14 @@ public class ClassUtilsTest { @Test - public void testInterfaceNoInheritance() { + void testInterfaceNoInheritance() { Set> set = ClassUtils.getAllTypes(A.class); Assert.assertEquals(1, set.size()); Assert.assertTrue(set.contains(A.class)); } @Test - public void testClassNoInheritance() { + void testClassNoInheritance() { Set> set = ClassUtils.getAllTypes(Z.class); Assert.assertEquals(2, set.size()); Assert.assertTrue(set.contains(Z.class)); @@ -45,7 +45,7 @@ public void testClassNoInheritance() { } @Test - public void testInterfaceSingleInheritance() { + void testInterfaceSingleInheritance() { Set> set = ClassUtils.getAllTypes(B.class); Assert.assertEquals(2, set.size()); Assert.assertTrue(set.contains(A.class)); @@ -53,7 +53,7 @@ public void testInterfaceSingleInheritance() { } @Test - public void testClassSingleInheritance() { + void testClassSingleInheritance() { Set> set = ClassUtils.getAllTypes(Y.class); Assert.assertEquals(3, set.size()); Assert.assertTrue(set.contains(Z.class)); @@ -62,7 +62,7 @@ public void testClassSingleInheritance() { } @Test - public void testInterfaceMultipleInheritance_SingleLevel() { + void testInterfaceMultipleInheritance_SingleLevel() { Set> set = ClassUtils.getAllTypes(AB.class); Assert.assertEquals(3, set.size()); Assert.assertTrue(set.contains(A.class)); @@ -71,7 +71,7 @@ public void testInterfaceMultipleInheritance_SingleLevel() { } @Test - public void testInterfaceMultipleInheritance_MultipleLevel() { + void testInterfaceMultipleInheritance_MultipleLevel() { Set> set = ClassUtils.getAllTypes(C.class); Assert.assertEquals(3, set.size()); Assert.assertTrue(set.contains(A.class)); @@ -80,7 +80,7 @@ public void testInterfaceMultipleInheritance_MultipleLevel() { } @Test - public void testClassMultipleInheritance_MultipleLevel() { + void testClassMultipleInheritance_MultipleLevel() { Set> set = ClassUtils.getAllTypes(X.class); Assert.assertEquals(4, set.size()); Assert.assertTrue(set.contains(Z.class)); @@ -90,7 +90,7 @@ public void testClassMultipleInheritance_MultipleLevel() { } @Test - public void testSingleInterfaceImplementation() { + void testSingleInterfaceImplementation() { Set> set = ClassUtils.getAllTypes(Aimpl.class); Assert.assertEquals(3, set.size()); Assert.assertTrue(set.contains(Aimpl.class)); @@ -99,7 +99,7 @@ public void testSingleInterfaceImplementation() { } @Test - public void testSingleInterfaceImplementation_MultipleLevel() { + void testSingleInterfaceImplementation_MultipleLevel() { Set> set = ClassUtils.getAllTypes(Bimpl.class); Assert.assertEquals(4, set.size()); Assert.assertTrue(set.contains(Bimpl.class)); @@ -109,7 +109,7 @@ public void testSingleInterfaceImplementation_MultipleLevel() { } @Test - public void testMultipleInterfaceImplementation() { + void testMultipleInterfaceImplementation() { Set> set = ClassUtils.getAllTypes(ABimpl.class); Assert.assertEquals(4, set.size()); Assert.assertTrue(set.contains(ABimpl.class)); @@ -119,7 +119,7 @@ public void testMultipleInterfaceImplementation() { } @Test - public void testComplexClass() { + void testComplexClass() { Set> set = ClassUtils.getAllTypes(Dimpl.class); Assert.assertEquals(5, set.size()); Assert.assertTrue(set.contains(Dimpl.class)); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java index cf2e00940eb..383eba26f43 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java @@ -25,8 +25,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.utils.io.IOUtils; @@ -44,14 +44,14 @@ public class ConfigUtilsTest { private MatsimTestUtils util = new MatsimTestUtils(); @Test - public void testLoadConfig_filenameOnly() throws IOException { + void testLoadConfig_filenameOnly() throws IOException { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); Assert.assertNotNull(config); Assert.assertEquals("network.xml", config.network().getInputFile()); } @Test - public void testLoadConfig_emptyConfig() throws IOException { + void testLoadConfig_emptyConfig() throws IOException { Config config = new Config(); Assert.assertNull(config.network()); ConfigUtils.loadConfig(config, IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); @@ -60,7 +60,7 @@ public void testLoadConfig_emptyConfig() throws IOException { } @Test - public void testLoadConfig_preparedConfig() throws IOException { + void testLoadConfig_preparedConfig() throws IOException { Config config = new Config(); config.addCoreModules(); Assert.assertNotNull(config.network()); @@ -70,7 +70,7 @@ public void testLoadConfig_preparedConfig() throws IOException { } @Test - public void testModifyPaths_missingSeparator() throws IOException { + void testModifyPaths_missingSeparator() throws IOException { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); Assert.assertEquals("network.xml", config.network().getInputFile()); ConfigUtils.modifyFilePaths(config, "/home/username/matsim"); @@ -79,7 +79,7 @@ public void testModifyPaths_missingSeparator() throws IOException { } @Test - public void testModifyPaths_withSeparator() throws IOException { + void testModifyPaths_withSeparator() throws IOException { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); Assert.assertEquals("network.xml", config.network().getInputFile()); ConfigUtils.modifyFilePaths(config, "/home/username/matsim/"); @@ -87,14 +87,15 @@ public void testModifyPaths_withSeparator() throws IOException { } @Test - public void loadConfigWithTypedArgs(){ + void loadConfigWithTypedArgs(){ final URL url = IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "equil" ), "config.xml" ); final String [] typedArgs = {"--config:controler.outputDirectory=abc"} ; Config config = ConfigUtils.loadConfig( url, typedArgs ); Assert.assertEquals("abc", config.controller().getOutputDirectory()); } + @Test - public void loadConfigWithTypedArgsWithTypo(){ + void loadConfigWithTypedArgsWithTypo(){ boolean hasFailed = false ; try{ final URL url = IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "equil" ), "config.xml" ); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/NetworkUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/NetworkUtilsTest.java index 23f22a269ea..8f9caadb543 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/NetworkUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/NetworkUtilsTest.java @@ -28,10 +28,9 @@ import java.util.List; import org.junit.Assert; - +import org.junit.jupiter.api.Test; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -51,7 +50,7 @@ public class NetworkUtilsTest { private final static double EPSILON = 1e-8; @Test - public void testGetNodes_Empty() { + void testGetNodes_Empty() { Network network = getTestNetwork(); List nodes = NetworkUtils.getNodes(network, ""); assertEquals(0, nodes.size()); @@ -64,14 +63,14 @@ public void testGetNodes_Empty() { } @Test - public void testGetNodes_Null() { + void testGetNodes_Null() { Network network = getTestNetwork(); List nodes = NetworkUtils.getNodes(network, null); assertEquals(0, nodes.size()); } @Test - public void testGetNodes_mixedDelimiters() { + void testGetNodes_mixedDelimiters() { Network network = getTestNetwork(); List nodes = NetworkUtils.getNodes(network, " 1\t\t2 \n4\t \t5 3 "); assertEquals(5, nodes.size()); @@ -83,7 +82,7 @@ public void testGetNodes_mixedDelimiters() { } @Test - public void testGetNodes_NonExistant() { + void testGetNodes_NonExistant() { Network network = getTestNetwork(); try { NetworkUtils.getNodes(network, "1 3 ab 5"); @@ -94,7 +93,7 @@ public void testGetNodes_NonExistant() { } @Test - public void testGetLinks_Empty() { + void testGetLinks_Empty() { Network network = getTestNetwork(); List links = NetworkUtils.getLinks(network, ""); assertEquals(0, links.size()); @@ -107,14 +106,14 @@ public void testGetLinks_Empty() { } @Test - public void testGetLinks_StringNull() { + void testGetLinks_StringNull() { Network network = getTestNetwork(); List links = NetworkUtils.getLinks(network, (String)null); assertEquals(0, links.size()); } @Test - public void testGetLinks_mixedDelimiters() { + void testGetLinks_mixedDelimiters() { Network network = getTestNetwork(); List links = NetworkUtils.getLinks(network, " 1\t\t2 \n4\t \t 3 "); assertEquals(4, links.size()); @@ -125,7 +124,7 @@ public void testGetLinks_mixedDelimiters() { } @Test - public void testGetLinks_NonExistant() { + void testGetLinks_NonExistant() { Network network = getTestNetwork(); try { NetworkUtils.getLinks(network, "1 3 ab 4"); @@ -136,19 +135,19 @@ public void testGetLinks_NonExistant() { } @Test - public void testGetLinksID_ListNull() { + void testGetLinksID_ListNull() { List> linkIds = NetworkUtils.getLinkIds((List) null); assertEquals(0, linkIds.size()); } @Test - public void testGetLinksID_StringNull() { + void testGetLinksID_StringNull() { List> linkIds = NetworkUtils.getLinkIds((String) null); assertEquals(0, linkIds.size()); } @Test - public void testGetNumberOfLanesAsInt() { + void testGetNumberOfLanesAsInt() { assertEquals(3, NetworkUtils.getNumberOfLanesAsInt(7*3600, new PseudoLink(3.2))); assertEquals(3, NetworkUtils.getNumberOfLanesAsInt(7*3600, new PseudoLink(3.1))); assertEquals(3, NetworkUtils.getNumberOfLanesAsInt(7*3600, new PseudoLink(3.0))); @@ -179,7 +178,7 @@ public void testGetNumberOfLanesAsInt() { } @Test - public void testGetBoundingBox() { + void testGetBoundingBox() { Collection nodes = new ArrayList(); Id id = Id.create("dummy", Node.class); nodes.add(new PseudoNode(id, new Coord((double) 100, (double) 100))); @@ -195,7 +194,7 @@ public void testGetBoundingBox() { } @Test - public void testGetBoundingBox_negativeNodesOnly() { + void testGetBoundingBox_negativeNodesOnly() { Collection nodes = new ArrayList(); Id id = Id.create("dummy", Node.class); final double x4 = -100; @@ -221,7 +220,7 @@ public void testGetBoundingBox_negativeNodesOnly() { } @Test - public void testIsMultimodal_carOnly() { + void testIsMultimodal_carOnly() { MultimodalFixture f = new MultimodalFixture(); for (Link l : f.links) { l.setAllowedModes(CollectionUtils.stringToSet("car")); @@ -230,7 +229,7 @@ public void testIsMultimodal_carOnly() { } @Test - public void testIsMultimodal_walkOnly() { + void testIsMultimodal_walkOnly() { // tests that isMultimodal is not somehow hard-coded on "car" MultimodalFixture f = new MultimodalFixture(); for (Link l : f.links) { @@ -240,7 +239,7 @@ public void testIsMultimodal_walkOnly() { } @Test - public void testIsMultimodal_2modesOnSingleLink() { + void testIsMultimodal_2modesOnSingleLink() { MultimodalFixture f = new MultimodalFixture(); for (Link l : f.links) { l.setAllowedModes(CollectionUtils.stringToSet("car")); @@ -250,7 +249,7 @@ public void testIsMultimodal_2modesOnSingleLink() { } @Test - public void testIsMultimodal_2modesOnDifferentLinks() { + void testIsMultimodal_2modesOnDifferentLinks() { MultimodalFixture f = new MultimodalFixture(); for (Link l : f.links) { l.setAllowedModes(CollectionUtils.stringToSet("car")); @@ -260,7 +259,7 @@ public void testIsMultimodal_2modesOnDifferentLinks() { } @Test - public void testIsMultimodal_3modes() { + void testIsMultimodal_3modes() { MultimodalFixture f = new MultimodalFixture(); for (Link l : f.links) { l.setAllowedModes(CollectionUtils.stringToSet("car")); @@ -270,7 +269,7 @@ public void testIsMultimodal_3modes() { } @Test - public void testIsMultimodal_onlyNoModes() { + void testIsMultimodal_onlyNoModes() { MultimodalFixture f = new MultimodalFixture(); for (Link l : f.links) { l.setAllowedModes(CollectionUtils.stringToSet("")); @@ -279,7 +278,7 @@ public void testIsMultimodal_onlyNoModes() { } @Test - public void testIsMultimodal_sometimesNoModes() { + void testIsMultimodal_sometimesNoModes() { MultimodalFixture f = new MultimodalFixture(); for (Link l : f.links) { l.setAllowedModes(CollectionUtils.stringToSet("car")); @@ -289,7 +288,7 @@ public void testIsMultimodal_sometimesNoModes() { } @Test - public void testGetConnectingLink() { + void testGetConnectingLink() { Network net = getTestNetwork(); Node node1 = net.getNodes().get(Id.create(1, Node.class)); Node node2 = net.getNodes().get(Id.create(2, Node.class)); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/OptionalTimeTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/OptionalTimeTest.java index 956184dbb2f..2dea7df7cf5 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/OptionalTimeTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/OptionalTimeTest.java @@ -26,14 +26,14 @@ import java.util.function.Supplier; import org.apache.commons.lang3.mutable.MutableDouble; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author Michal Maciejewski (michalm) */ public class OptionalTimeTest { @Test - public void test_defined_seconds() { + void test_defined_seconds() { //defined assertThat(OptionalTime.defined(0).seconds()).isEqualTo(0); assertThat(OptionalTime.defined(1).seconds()).isEqualTo(1); @@ -50,7 +50,7 @@ public void test_defined_seconds() { } @Test - public void test_undefined_seconds() { + void test_undefined_seconds() { assertThat(OptionalTime.undefined().isUndefined()).isTrue(); assertThatThrownBy(() -> OptionalTime.undefined().seconds()).isExactlyInstanceOf(NoSuchElementException.class) @@ -58,38 +58,38 @@ public void test_undefined_seconds() { } @Test - public void test_cachedValues() { + void test_cachedValues() { //currently 0 and undefined are cached assertThat(OptionalTime.defined(0)).isSameAs(OptionalTime.defined(0)); assertThat(OptionalTime.undefined()).isSameAs(OptionalTime.undefined()); } @Test - public void test_isUndefined() { + void test_isUndefined() { assertThat(OptionalTime.undefined().isUndefined()).isTrue(); assertThat(OptionalTime.defined(1).isUndefined()).isFalse(); } @Test - public void test_isDefined() { + void test_isDefined() { assertThat(OptionalTime.undefined().isDefined()).isFalse(); assertThat(OptionalTime.defined(1).isDefined()).isTrue(); } @Test - public void test_orElse() { + void test_orElse() { assertThat(OptionalTime.undefined().orElse(0)).isEqualTo(0); assertThat(OptionalTime.defined(1).orElse(0)).isEqualTo(1); } @Test - public void test_orElseGet() { + void test_orElseGet() { assertThat(OptionalTime.undefined().orElseGet(() -> 0)).isEqualTo(0); assertThat(OptionalTime.defined(1).orElseGet(() -> 0)).isEqualTo(1); } @Test - public void test_orElseThrow() { + void test_orElseThrow() { assertThatThrownBy(() -> OptionalTime.undefined() .orElseThrow(() -> new IllegalStateException("Undefined time error"))).isExactlyInstanceOf( IllegalStateException.class).hasMessage("Undefined time error"); @@ -99,7 +99,7 @@ public void test_orElseThrow() { } @Test - public void test_ifDefined() { + void test_ifDefined() { MutableDouble counter = new MutableDouble(0); OptionalTime.undefined().ifDefined(counter::add); @@ -110,7 +110,7 @@ public void test_ifDefined() { } @Test - public void test_ifDefinedOrElse() { + void test_ifDefinedOrElse() { MutableDouble ifCounter = new MutableDouble(0); MutableDouble elseCounter = new MutableDouble(0); @@ -124,14 +124,14 @@ public void test_ifDefinedOrElse() { } @Test - public void test_stream() { + void test_stream() { assertThat(OptionalTime.undefined().stream()).containsExactly(); assertThat(OptionalTime.defined(0).stream()).containsExactly(0.); assertThat(OptionalTime.defined(10).stream()).containsExactly(10.); } @Test - public void test_or_OptionalTime() { + void test_or_OptionalTime() { assertThat(OptionalTime.undefined().or(OptionalTime.undefined()).isUndefined()).isTrue(); assertThat(OptionalTime.undefined().or(OptionalTime.defined(3)).seconds()).isEqualTo(3); assertThat(OptionalTime.defined(1).or(OptionalTime.undefined()).seconds()).isEqualTo(1); @@ -142,7 +142,7 @@ public void test_or_OptionalTime() { } @Test - public void test_or_OptionalTimeSupplier() { + void test_or_OptionalTimeSupplier() { assertThat(OptionalTime.undefined().or(OptionalTime::undefined).isUndefined()).isTrue(); assertThat(OptionalTime.undefined().or(() -> OptionalTime.defined(3)).seconds()).isEqualTo(3); assertThat(OptionalTime.defined(1).or(OptionalTime::undefined).seconds()).isEqualTo(1); @@ -155,7 +155,7 @@ public void test_or_OptionalTimeSupplier() { } @Test - public void test_equals() { + void test_equals() { assertThat(OptionalTime.undefined()).isEqualTo(OptionalTime.undefined()); assertThat(OptionalTime.undefined()).isNotEqualTo(OptionalTime.defined(0)); @@ -165,7 +165,7 @@ public void test_equals() { } @Test - public void test_hashCode() { + void test_hashCode() { assertThat(OptionalTime.undefined()).hasSameHashCodeAs(Time.UNDEFINED_TIME); assertThat(OptionalTime.defined(0)).hasSameHashCodeAs(0.); assertThat(OptionalTime.defined(-Double.MAX_VALUE)).hasSameHashCodeAs(-Double.MAX_VALUE); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/OptionalTimesTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/OptionalTimesTest.java index 5010c22a8f2..b651884bb2e 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/OptionalTimesTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/OptionalTimesTest.java @@ -23,14 +23,14 @@ import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author Michal Maciejewski (michalm) */ public class OptionalTimesTest { @Test - public void requireDefined() { + void requireDefined() { assertThatThrownBy(() -> OptionalTimes.requireDefined(OptionalTime.undefined())).isExactlyInstanceOf( IllegalArgumentException.class).hasMessage("Time must be defined"); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java index 6e5a02f746e..5f30320cbd3 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java @@ -21,8 +21,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -51,7 +51,7 @@ public class PopulationUtilsTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; @Test - public void testLegOverlap() { + void testLegOverlap() { Fixture f = new Fixture() ; List legs1 = PopulationUtils.getLegs(f.plan1) ; List legs2 = PopulationUtils.getLegs(f.plan2); @@ -68,7 +68,7 @@ public void testLegOverlap() { } @Test - public void testActivityOverlap() { + void testActivityOverlap() { Fixture f = new Fixture() ; List acts1 = PopulationUtils.getActivities(f.plan1, StageActivityHandling.StagesAsNormalActivities ) ; List acts2 = PopulationUtils.getActivities(f.plan2, StageActivityHandling.StagesAsNormalActivities ) ; @@ -150,14 +150,14 @@ private static class Fixture { } @Test - public void testEmptyPopulation() { + void testEmptyPopulation() { Scenario s1 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario s2 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Assert.assertTrue(PopulationUtils.equalPopulation(s1.getPopulation(), s2.getPopulation())); } @Test - public void testEmptyPopulationVsOnePerson() { + void testEmptyPopulationVsOnePerson() { Scenario s1 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario s2 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Person person = s2.getPopulation().getFactory().createPerson(Id.create("1", Person.class)); @@ -167,7 +167,7 @@ public void testEmptyPopulationVsOnePerson() { } @Test - public void testCompareBigPopulationWithItself() { + void testCompareBigPopulationWithItself() { Scenario s1 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); String netFileName = "test/scenarios/berlin/network.xml"; String popFileName = "test/scenarios/berlin/plans_hwh_1pct.xml.gz"; diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/RouteUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/RouteUtilsTest.java index f0977d0396c..01c37c7d52f 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/RouteUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/RouteUtilsTest.java @@ -24,7 +24,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -40,9 +40,9 @@ import org.matsim.testcases.MatsimTestUtils; public class RouteUtilsTest { - + @Test - public void testCalculateCoverage() { + void testCalculateCoverage() { Fixture f = new Fixture(); f.network.getLinks().get(f.linkIds[0]).setLength(100.0); f.network.getLinks().get(f.linkIds[1]).setLength(200.0); @@ -85,7 +85,7 @@ public void testCalculateCoverage() { } @Test - public void testGetNodes() { + void testGetNodes() { Fixture f = new Fixture(); Link startLink = f.network.getLinks().get(f.linkIds[0]); Link endLink = f.network.getLinks().get(f.linkIds[5]); @@ -104,7 +104,7 @@ public void testGetNodes() { } @Test - public void testGetNodes_SameStartEndLink() { + void testGetNodes_SameStartEndLink() { Fixture f = new Fixture(); Link startLink = f.network.getLinks().get(f.linkIds[2]); Link endLink = f.network.getLinks().get(f.linkIds[2]); @@ -117,7 +117,7 @@ public void testGetNodes_SameStartEndLink() { } @Test - public void testGetNodes_NoLinksBetween() { + void testGetNodes_NoLinksBetween() { Fixture f = new Fixture(); Id startLinkId = f.linkIds[3]; Id endLinkId = f.linkIds[4]; @@ -131,7 +131,7 @@ public void testGetNodes_NoLinksBetween() { } @Test - public void testGetNodes_CircularRoute() { + void testGetNodes_CircularRoute() { Fixture f = new Fixture(); Id id99 = Id.create("99", Link.class); f.network.addLink(f.network.getFactory().createLink(id99, f.network.getNodes().get(f.nodeIds[6]), f.network.getNodes().get(f.nodeIds[0]))); @@ -155,7 +155,7 @@ public void testGetNodes_CircularRoute() { } @Test - public void testGetLinksFromNodes() { + void testGetLinksFromNodes() { Fixture f = new Fixture(); ArrayList nodes = new ArrayList(); List links = RouteUtils.getLinksFromNodes(nodes); @@ -186,7 +186,7 @@ public void testGetLinksFromNodes() { } @Test - public void testGetSubRoute() { + void testGetSubRoute() { Fixture f = new Fixture(); NetworkRoute route = RouteUtils.createLinkNetworkRouteImpl(f.linkIds[0], f.linkIds[5]); List> linkIds = new ArrayList>(); @@ -202,7 +202,7 @@ public void testGetSubRoute() { } @Test - public void testGetSubRoute_fullRoute() { + void testGetSubRoute_fullRoute() { Fixture f = new Fixture(); NetworkRoute route = RouteUtils.createLinkNetworkRouteImpl(f.linkIds[0], f.linkIds[5]); List> linkIds = new ArrayList>(); @@ -220,7 +220,7 @@ public void testGetSubRoute_fullRoute() { } @Test - public void testGetSubRoute_emptySubRoute() { + void testGetSubRoute_emptySubRoute() { Fixture f = new Fixture(); NetworkRoute route = RouteUtils.createLinkNetworkRouteImpl(f.linkIds[0], f.linkIds[5]); List> linkIds = new ArrayList>(); @@ -234,7 +234,7 @@ public void testGetSubRoute_emptySubRoute() { } @Test - public void testGetSubRoute_sameStartEnd() { + void testGetSubRoute_sameStartEnd() { Fixture f = new Fixture(); NetworkRoute route = RouteUtils.createLinkNetworkRouteImpl(f.linkIds[0], f.linkIds[5]); List> linkIds = new ArrayList>(); @@ -248,7 +248,7 @@ public void testGetSubRoute_sameStartEnd() { } @Test - public void testCalcDistance() { + void testCalcDistance() { Fixture f = new Fixture(); f.network.getLinks().get(f.linkIds[0]).setLength(100.0); f.network.getLinks().get(f.linkIds[1]).setLength(200.0); @@ -270,7 +270,7 @@ public void testCalcDistance() { } @Test - public void testCalcDistance_sameStartEndRoute() { + void testCalcDistance_sameStartEndRoute() { Fixture f = new Fixture(); f.network.getLinks().get(f.linkIds[0]).setLength(100.0); f.network.getLinks().get(f.linkIds[1]).setLength(200.0); @@ -287,7 +287,7 @@ public void testCalcDistance_sameStartEndRoute() { } @Test - public void testCalcDistance_subsequentStartEndRoute() { + void testCalcDistance_subsequentStartEndRoute() { Fixture f = new Fixture(); f.network.getLinks().get(f.linkIds[0]).setLength(100.0); f.network.getLinks().get(f.linkIds[1]).setLength(200.0); @@ -303,7 +303,7 @@ public void testCalcDistance_subsequentStartEndRoute() { } @Test - public void testCalcDistance_oneLinkRoute() { + void testCalcDistance_oneLinkRoute() { Fixture f = new Fixture(); f.network.getLinks().get(f.linkIds[0]).setLength(100.0); f.network.getLinks().get(f.linkIds[1]).setLength(200.0); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java index 873fad98d90..b4048bb20f6 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -41,7 +41,8 @@ public class StringUtilsTest { * Tests the method explode(String, char), which should always return the same as * String.split(String) does. */ - @Test public void testExplode() { + @Test + void testExplode() { String[] testStrings = {"a:b", "ab:cd", "ab::cd", ":ab:cd", "ab:cd:", ":ab:cd:", "::ab::cd::", "a", "ab", ""}; for (String test : testStrings) { String[] resultExplode = StringUtils.explode(test, ':'); @@ -57,7 +58,8 @@ public class StringUtilsTest { * Tests the method explode(String, char, int), which should always return the same as * String.split(String, int) does. */ - @Test public void testExplodeLimit() { + @Test + void testExplodeLimit() { String[] testStrings = {"a:b", "a:b:c", "a:b:c:d", "a:::b:c", ":::::", "a", ""}; for (String test : testStrings) { String[] resultExplode = StringUtils.explode(test, ':', 3); diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/TimeTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/TimeTest.java index 56209e8f4a0..1654c1330ba 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/TimeTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/TimeTest.java @@ -23,7 +23,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.fail; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * Tests for {@link Time}. @@ -32,7 +32,8 @@ */ public class TimeTest { - @Test public void testFormats() { + @Test + void testFormats() { double time = 12*3600 + 34*60 + 56.789; assertEquals("12:34:56", Time.writeTime(time, Time.TIMEFORMAT_HHMMSS)); assertEquals("12:34", Time.writeTime(time, Time.TIMEFORMAT_HHMM)); @@ -83,7 +84,8 @@ public class TimeTest { } catch (IllegalArgumentException expected) {} } - @Test public void testSeparators() { + @Test + void testSeparators() { // test writing double dTime = 12*3600 + 34*60 + 56.789; assertEquals("12:34:56", Time.writeTime(dTime, ':')); @@ -102,7 +104,8 @@ public class TimeTest { assertEquals(-iTime, Time.parseTime( "-12-34-56", '-').seconds(), 0.0); } - @Test public void testUndefined() { + @Test + void testUndefined() { // test writing assertEquals("undefined", Time.writeTime(OptionalTime.undefined())); @@ -112,7 +115,8 @@ public class TimeTest { assertEquals(OptionalTime.undefined(), Time.parseOptionalTime(null)); } - @Test public void testSetDefault() { + @Test + void testSetDefault() { Time.setDefaultTimeFormat(Time.TIMEFORMAT_HHMMSS); assertEquals("12:34:56", Time.writeTime(12*3600 + 34*60 + 56.789)); Time.setDefaultTimeFormat(Time.TIMEFORMAT_HHMM); @@ -127,7 +131,8 @@ public class TimeTest { // kai/gregor, nov'11) } - @Test public void testWriting() { + @Test + void testWriting() { Time.setDefaultTimeFormat(Time.TIMEFORMAT_HHMMSS); assertEquals( "12:34:56", Time.writeTime( 12*3600 + 34*60 + 56.789));// positive assertEquals( "01:02:03", Time.writeTime( 1*3600 + 2*60 + 3.4)); // positive with leading zero @@ -142,7 +147,8 @@ public class TimeTest { assertEquals("-596523:14:08", Time.writeTime(Integer.MIN_VALUE)); } - @Test public void testParsing() { + @Test + void testParsing() { assertEquals( 12*3600.0 + 34*60.0 + 56.0, Time.parseTime( "12:34:56"), 0.0); assertEquals( 12*3600.0 + 34*60.0 + 56.7, Time.parseTime( "12:34:56.7"), 0.0); assertEquals( 1*3600.0 + 2*60.0 + 3.0, Time.parseTime( "01:02:03"), 0.0); @@ -155,7 +161,8 @@ public class TimeTest { assertEquals(Long.MAX_VALUE, Time.parseTime("2562047788015215:28:07"), 0.0); } - @Test public void testConvertHHMMInteger() { + @Test + void testConvertHHMMInteger() { assertEquals( 12*3600.0 + 34*60.0, Time.convertHHMMInteger(Integer.valueOf("1234")), 0.0); assertEquals( 1*3600.0 + 2*60.0, Time.convertHHMMInteger(Integer.valueOf("0102")), 0.0); } diff --git a/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java b/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java index 58e06bfdf21..51722441ce6 100644 --- a/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java @@ -24,8 +24,8 @@ import java.util.List; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -52,7 +52,8 @@ public class TimeInterpretationTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testIgnoreDelays() { + @Test + void testIgnoreDelays() { Config config = ConfigUtils.createConfig(); config.plans().setTripDurationHandling(TripDurationHandling.ignoreDelays); @@ -72,7 +73,8 @@ public class TimeInterpretationTest { } - @Test public void testShiftActivityEndTime() { + @Test + void testShiftActivityEndTime() { Config config = ConfigUtils.createConfig(); config.plans().setTripDurationHandling(TripDurationHandling.shiftActivityEndTimes); diff --git a/matsim/src/test/java/org/matsim/counts/CountTest.java b/matsim/src/test/java/org/matsim/counts/CountTest.java index 7575c4bd529..7b5194b49c9 100644 --- a/matsim/src/test/java/org/matsim/counts/CountTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountTest.java @@ -25,8 +25,8 @@ import java.util.Iterator; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.testcases.MatsimTestUtils; @@ -43,20 +43,23 @@ public void setUp() throws Exception { this.counts = new Counts<>(); } - @Test public void testCreateVolume() { + @Test + void testCreateVolume() { Count count = counts.createAndAddCount(Id.create(0, Link.class), "1"); Volume volume = count.createVolume(1, 100.0); assertTrue("Creation and initialization of volume failed", volume.getHourOfDayStartingWithOne()==1); assertTrue("Creation and initialization of volume failed", volume.getValue()==100.0); } - @Test public void testGetVolume() { + @Test + void testGetVolume() { Count count = counts.createAndAddCount(Id.create(0, Link.class), "1"); count.createVolume(1, 100.0); assertTrue("Getting volume failed", count.getVolume(1).getValue() == 100.0); } - @Test public void testGetVolumes() { + @Test + void testGetVolumes() { Count count = counts.createAndAddCount(Id.create(0, Link.class), "1"); count.createVolume(1, 100.0); diff --git a/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java b/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java index ecefd40d4b1..7e652c0e25a 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java @@ -24,8 +24,8 @@ import java.util.List; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.counts.algorithms.CountsComparisonAlgorithm; import org.matsim.testcases.MatsimTestUtils; @@ -35,7 +35,8 @@ public class CountsComparisonAlgorithmTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testCompare() { + @Test + void testCompare() { CountsFixture fixture = new CountsFixture(); fixture.setUp(); @@ -52,7 +53,8 @@ public class CountsComparisonAlgorithmTest { }//while } - @Test public void testDistanceFilter() { + @Test + void testDistanceFilter() { CountsFixture fixture = new CountsFixture(); fixture.setUp(); diff --git a/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java b/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java index 21b0939f3d8..9327948fec4 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java @@ -27,8 +27,8 @@ import jakarta.inject.Singleton; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -62,7 +62,7 @@ public class CountsControlerListenerTest { @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test - public void testUseVolumesOfIteration() { + void testUseVolumesOfIteration() { Config config = ConfigUtils.createConfig(); Scenario scenario = ScenarioUtils.createScenario(config); CountsControlerListener ccl = new CountsControlerListener(config.global(), scenario.getNetwork(), config.controller(), config.counts(), null, null, null); @@ -249,7 +249,7 @@ public void testUseVolumesOfIteration() { } @Test - public void test_writeCountsInterval() { + void test_writeCountsInterval() { Config config = this.util.createConfig(ExamplesUtils.getTestScenarioURL("triangle")); CountsConfigGroup cConfig = config.counts(); @@ -285,7 +285,7 @@ public void install() { } @Test - public void testReset_CorrectlyExecuted() throws IOException { + void testReset_CorrectlyExecuted() throws IOException { Config config = this.util.createConfig(ExamplesUtils.getTestScenarioURL("triangle")); config.network().setInputFile("network.xml"); // network file which is used by the counts file @@ -326,7 +326,7 @@ public void install() { } @Test - public void testFilterAnalyzedModes() throws IOException { + void testFilterAnalyzedModes() throws IOException { Config config = util.createConfig(ExamplesUtils.getTestScenarioURL("triangle")); config.network().setInputFile("network.xml"); // network file which is used by the counts file diff --git a/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java b/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java index dd1627a5c0e..9b517b8e4e1 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertNotNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.counts.algorithms.graphs.BoxPlotErrorGraph; import org.matsim.testcases.MatsimTestUtils; @@ -33,7 +33,8 @@ public class CountsErrorGraphTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testCreateChart() { + @Test + void testCreateChart() { CountsFixture fixture = new CountsFixture(); fixture.setUp(); diff --git a/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java b/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java index 50dac9c7a41..853f4d548e7 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertTrue; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.counts.algorithms.CountsComparisonAlgorithm; import org.matsim.counts.algorithms.CountsHtmlAndGraphsWriter; import org.matsim.counts.algorithms.graphs.CountsErrorGraphCreator; @@ -42,7 +42,8 @@ public class CountsHtmlAndGraphsWriterTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testGraphCreation() { + @Test + void testGraphCreation() { CountsFixture fixture = new CountsFixture(); fixture.setUp(); diff --git a/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java b/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java index 63a2002b7af..b8dc6aecacb 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertNotNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.counts.algorithms.graphs.CountsLoadCurveGraph; import org.matsim.testcases.MatsimTestUtils; @@ -33,7 +33,8 @@ public class CountsLoadCurveGraphTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testCreateChart() { + @Test + void testCreateChart() { CountsFixture fixture = new CountsFixture(); fixture.setUp(); diff --git a/matsim/src/test/java/org/matsim/counts/CountsParserTest.java b/matsim/src/test/java/org/matsim/counts/CountsParserTest.java index 804c0be2f33..5dabdc4ac08 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsParserTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsParserTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.*; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.testcases.MatsimTestUtils; @@ -35,7 +35,8 @@ public class CountsParserTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testSEElementCounts() throws SAXException { + @Test + void testSEElementCounts() throws SAXException { AttributeFactory attributeFactory = new AttributeFactory(); final Counts counts = new Counts(); MatsimCountsReader reader = new MatsimCountsReader(counts); @@ -53,7 +54,8 @@ public class CountsParserTest { } } - @Test public void testSEElementCountWithoutCoords() throws SAXException { + @Test + void testSEElementCountWithoutCoords() throws SAXException { AttributeFactory attributeFactory = new AttributeFactory(); final Counts counts = new Counts(); MatsimCountsReader reader = new MatsimCountsReader(counts); @@ -70,7 +72,8 @@ public class CountsParserTest { reader.endElement("", "counts", "counts"); } - @Test public void testSEElementCountWithCoords() throws SAXException { + @Test + void testSEElementCountWithCoords() throws SAXException { AttributeFactory attributeFactory = new AttributeFactory(); final Counts counts = new Counts(); MatsimCountsReader reader = new MatsimCountsReader(counts); @@ -88,7 +91,8 @@ public class CountsParserTest { reader.endElement("", "counts", "counts"); } - @Test public void testSEElementVolume() throws SAXException { + @Test + void testSEElementVolume() throws SAXException { AttributeFactory attributeFactory = new AttributeFactory(); final Counts counts = new Counts(); MatsimCountsReader reader = new MatsimCountsReader(counts); diff --git a/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java b/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java index e548ece2bd0..6c7e2a9e76b 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java @@ -27,8 +27,8 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import org.xml.sax.SAXException; @@ -45,7 +45,7 @@ public class CountsParserWriterTest { * @author ahorni */ @Test - public void testParserWriter() { + void testParserWriter() { CountsFixture fixture = new CountsFixture(); fixture.setUp(); @@ -91,7 +91,7 @@ public void testParserWriter() { * @author mrieser */ @Test - public void testWriteParse_nameIsNull() throws SAXException, ParserConfigurationException, IOException { + void testWriteParse_nameIsNull() throws SAXException, ParserConfigurationException, IOException { CountsFixture f = new CountsFixture(); f.setUp(); f.counts.setName(null); diff --git a/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java b/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java index 70f99f38dd9..d4214f2485f 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java +++ b/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.testcases.MatsimTestUtils; @@ -34,7 +34,8 @@ public class CountsReaderHandlerImplV1Test { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testSECounts() { + @Test + void testSECounts() { AttributeFactory attributeFactory = new AttributeFactory(); final Counts counts = new Counts(); CountsReaderMatsimV1 reader = new CountsReaderMatsimV1(counts); @@ -45,7 +46,8 @@ public class CountsReaderHandlerImplV1Test { assertEquals("Counts attribute setting failed", 2000, counts.getYear()); } - @Test public void testSECount() { + @Test + void testSECount() { AttributeFactory attributeFactory = new AttributeFactory(); final Counts counts = new Counts(); CountsReaderMatsimV1 reader = new CountsReaderMatsimV1(counts); @@ -56,7 +58,8 @@ public class CountsReaderHandlerImplV1Test { assertEquals("Count attribute setting failed", "testNr", counts.getCount(Id.create(1, Link.class)).getCsLabel()); } - @Test public void testSEVolume() { + @Test + void testSEVolume() { AttributeFactory attributeFactory = new AttributeFactory(); final Counts counts = new Counts(); CountsReaderMatsimV1 reader = new CountsReaderMatsimV1(counts); diff --git a/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java b/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java index 627d918b98d..860767a6553 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java @@ -24,8 +24,8 @@ import com.google.inject.Key; import com.google.inject.TypeLiteral; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -38,15 +38,15 @@ import org.matsim.core.utils.geometry.transformations.TransformationFactory; import org.matsim.testcases.MatsimTestUtils; -/** + /** * @author thibautd */ public class CountsReprojectionIOTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testInput() { + @Test + void testInput() { final String file = utils.getOutputDirectory()+"/counts.xml"; final Counts originalCounts = createDummyCounts(); @@ -58,8 +58,8 @@ public void testInput() { assertCountsAreReprojectedCorrectly( originalCounts , reprojectedCounts ); } - @Test - public void testOutput() { + @Test + void testOutput() { final String file = utils.getOutputDirectory()+"/counts.xml"; final Counts originalCounts = createDummyCounts(); @@ -71,8 +71,8 @@ public void testOutput() { assertCountsAreReprojectedCorrectly( originalCounts , reprojectedCounts ); } - @Test - public void testWithControlerAndConfigParameters() { + @Test + void testWithControlerAndConfigParameters() { final String file = utils.getOutputDirectory()+"/counts.xml"; final Counts originalCounts = createDummyCounts(); diff --git a/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java b/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java index 93d404cbe68..2df385e8ab3 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertNotNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.counts.algorithms.graphs.CountsSimRealPerHourGraph; import org.matsim.testcases.MatsimTestUtils; @@ -33,7 +33,8 @@ public class CountsSimRealPerHourGraphTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testCreateChart() { + @Test + void testCreateChart() { CountsFixture fixture = new CountsFixture(); fixture.setUp(); diff --git a/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java b/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java index f869f6edaa3..f373db66b6f 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java @@ -25,8 +25,8 @@ import java.io.File; import java.util.Locale; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.counts.algorithms.CountSimComparisonTableWriter; import org.matsim.counts.algorithms.CountsComparisonAlgorithm; import org.matsim.testcases.MatsimTestUtils; @@ -38,7 +38,8 @@ public class CountsTableWriterTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testTableCreation() { + @Test + void testTableCreation() { CountsFixture fixture = new CountsFixture(); fixture.setUp(); diff --git a/matsim/src/test/java/org/matsim/counts/CountsTest.java b/matsim/src/test/java/org/matsim/counts/CountsTest.java index af9ae2d6249..f8ee0015e52 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.testcases.MatsimTestUtils; @@ -34,7 +34,8 @@ public class CountsTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testGetCounts() { + @Test + void testGetCounts() { final Counts counts = new Counts(); counts.createAndAddCount(Id.create(0, Link.class), "1"); assertEquals("Getting counts failed", 1, counts.getCounts().size()); diff --git a/matsim/src/test/java/org/matsim/counts/CountsV2Test.java b/matsim/src/test/java/org/matsim/counts/CountsV2Test.java index 46e306ae4d5..3ee67c26678 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsV2Test.java +++ b/matsim/src/test/java/org/matsim/counts/CountsV2Test.java @@ -2,8 +2,8 @@ import org.assertj.core.api.Assertions; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -22,6 +22,7 @@ import java.util.SplittableRandom; import static org.assertj.core.api.Assertions.assertThat; +import static org.junit.jupiter.api.Assertions.assertThrows; public class CountsV2Test { @@ -30,7 +31,7 @@ public class CountsV2Test { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void test_general_handling() throws IOException { + void test_general_handling() throws IOException { Counts counts = new Counts<>(); counts.setName("test"); @@ -49,7 +50,7 @@ public void test_general_handling() throws IOException { } @Test - public void test_reader_writer() throws IOException { + void test_reader_writer() throws IOException { String filename = utils.getOutputDirectory() + "test_counts.xml"; @@ -88,21 +89,24 @@ public void test_reader_writer() throws IOException { } - @Test(expected = IllegalArgumentException.class) - public void test_illegal() { + @Test + void test_illegal() { + assertThrows(IllegalArgumentException.class, () -> { - Counts dummyCounts = new Counts<>(); + Counts dummyCounts = new Counts<>(); + + MeasurementLocation station = dummyCounts.createAndAddMeasureLocation(Id.create("12", Link.class), "12_test"); + Measurable volume = station.createVolume(TransportMode.car, Measurable.HOURLY); - MeasurementLocation station = dummyCounts.createAndAddMeasureLocation(Id.create("12", Link.class), "12_test"); - Measurable volume = station.createVolume(TransportMode.car, Measurable.HOURLY); + volume.setAtHour(-1, 500); - volume.setAtHour(-1, 500); + }); } @Test - public void aggregate() { + void aggregate() { Counts counts = new Counts<>(); diff --git a/matsim/src/test/java/org/matsim/counts/MatsimCountsIOTest.java b/matsim/src/test/java/org/matsim/counts/MatsimCountsIOTest.java index 3e3ef220219..6f2da37f269 100644 --- a/matsim/src/test/java/org/matsim/counts/MatsimCountsIOTest.java +++ b/matsim/src/test/java/org/matsim/counts/MatsimCountsIOTest.java @@ -22,23 +22,23 @@ package org.matsim.counts; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.nio.charset.StandardCharsets; -/** + /** * @author mrieser / Simunto GmbH */ public class MatsimCountsIOTest { - /** - * Such a file with year 0 could be created by MATSim when the year was not explicitly set, - * but it could not be read back in as "0" was not recognized as a valid year by the XML validator originally. - */ - @Test - public void testReading_year0() { + /** + * Such a file with year 0 could be created by MATSim when the year was not explicitly set, + * but it could not be read back in as "0" was not recognized as a valid year by the XML validator originally. + */ + @Test + void testReading_year0() { String xml = "\n" + "\n" + " parameterObjects () { } @Test - public void testEquil() { + void testEquil() { Config config = ConfigUtils.createConfig() ; config.controller().setOutputDirectory( utils.getOutputDirectory() ); config.qsim().setUsingFastCapacityUpdate(this.isUsingFastCapacityUpdate); diff --git a/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java b/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java index 48c7bb036f8..5c3a02d326b 100644 --- a/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java +++ b/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.api.experimental.events.EventsManager; import org.matsim.core.config.Config; @@ -50,7 +50,8 @@ public class OnePercentBerlin10sIT { private static final Logger log = LogManager.getLogger(OnePercentBerlin10sIT.class); - @Test public void testOnePercent10sQSim() { + @Test + void testOnePercent10sQSim() { Config config = utils.loadConfig((String)null); // input files are in the main directory in the resource path! String netFileName = "test/scenarios/berlin/network.xml"; @@ -96,7 +97,8 @@ public class OnePercentBerlin10sIT { } - @Test public void testOnePercent10sQSimTryEndTimeThenDuration() { + @Test + void testOnePercent10sQSimTryEndTimeThenDuration() { Config config = utils.loadConfig((String)null); String netFileName = "test/scenarios/berlin/network.xml"; String popFileName = "test/scenarios/berlin/plans_hwh_1pct.xml.gz"; diff --git a/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java b/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java index 781f3587b01..3b7f7fd87ca 100644 --- a/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java +++ b/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -56,7 +56,7 @@ public class PtTutorialIT { public MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void ensure_tutorial_runs() throws MalformedURLException { + void ensure_tutorial_runs() throws MalformedURLException { Config config = this.utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-tutorial"), "0.config.xml")); config.controller().setLastIteration(1); diff --git a/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java b/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java index 0c63dacd949..a2ef3a5a8ec 100644 --- a/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java +++ b/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java @@ -22,8 +22,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameter; @@ -64,7 +64,7 @@ public static Object[] testParameters() { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void test_PtScoringLineswitch() { + void test_PtScoringLineswitch() { Config config = this.utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-simple-lineswitch"), "config.xml")); ScoringConfigGroup pcs = config.scoring() ; @@ -215,8 +215,9 @@ public void test_PtScoringLineswitch() { } } + @Test - public void test_PtScoringLineswitchAndPtConstant() { + void test_PtScoringLineswitchAndPtConstant() { Config config = this.utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-simple-lineswitch"), "config.xml")); ScoringConfigGroup pcs = config.scoring() ; @@ -370,8 +371,9 @@ public void test_PtScoringLineswitchAndPtConstant() { } } + @Test - public void test_PtScoring_Wait() { + void test_PtScoring_Wait() { Config config = this.utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-simple"), "config.xml")); ScoringConfigGroup pcs = config.scoring(); @@ -457,7 +459,7 @@ public void test_PtScoring_Wait() { } @Test - public void test_PtScoring() { + void test_PtScoring() { Config config = this.utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-simple"), "config.xml")); ScoringConfigGroup pcs = config.scoring() ; diff --git a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesFactoryImplTest.java b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesFactoryImplTest.java index 01dafb87234..e5f8838a405 100644 --- a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesFactoryImplTest.java +++ b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesFactoryImplTest.java @@ -20,7 +20,7 @@ package org.matsim.facilities; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -30,7 +30,7 @@ public class ActivityFacilitiesFactoryImplTest { @Test - public void testCreateActivityFacility() { + void testCreateActivityFacility() { ActivityFacilitiesFactoryImpl factory = new ActivityFacilitiesFactoryImpl(); ActivityFacility facility = factory.createActivityFacility(Id.create(1980, ActivityFacility.class), new Coord((double) 5, (double) 11)); @@ -40,7 +40,7 @@ public void testCreateActivityFacility() { } @Test - public void testCreateActivityOption() { + void testCreateActivityOption() { ActivityFacilitiesFactoryImpl factory = new ActivityFacilitiesFactoryImpl(); ActivityOption option = factory.createActivityOption("leisure"); diff --git a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesImplTest.java b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesImplTest.java index 1be2f455b55..223c6e20898 100644 --- a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesImplTest.java +++ b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesImplTest.java @@ -20,7 +20,7 @@ package org.matsim.facilities; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -30,7 +30,7 @@ public class ActivityFacilitiesImplTest { @Test - public void testAddActivityFacility() { + void testAddActivityFacility() { ActivityFacilities facilities = new ActivityFacilitiesImpl(); ActivityFacilitiesFactory factory = facilities.getFactory(); ActivityFacility facility1 = factory.createActivityFacility(Id.create(1, ActivityFacility.class), new Coord((double) 200, (double) 5000)); @@ -48,7 +48,7 @@ public void testAddActivityFacility() { } @Test - public void testAddActivityFacility_addingTwice() { + void testAddActivityFacility_addingTwice() { ActivityFacilities facilities = new ActivityFacilitiesImpl(); ActivityFacilitiesFactory factory = facilities.getFactory(); ActivityFacility facility1 = factory.createActivityFacility(Id.create(1, ActivityFacility.class), new Coord((double) 200, (double) 5000)); @@ -69,7 +69,7 @@ public void testAddActivityFacility_addingTwice() { } @Test - public void testAddActivityFacility_sameId() { + void testAddActivityFacility_sameId() { ActivityFacilities facilities = new ActivityFacilitiesImpl(); ActivityFacilitiesFactory factory = facilities.getFactory(); ActivityFacility facility1 = factory.createActivityFacility(Id.create(1, ActivityFacility.class), new Coord((double) 200, (double) 5000)); @@ -92,7 +92,7 @@ public void testAddActivityFacility_sameId() { * is used internally, and if the map is modifiable at all... */ @Test - public void testRemove() { + void testRemove() { ActivityFacilities facilities = new ActivityFacilitiesImpl(); ActivityFacilitiesFactory factory = facilities.getFactory(); ActivityFacility facility1 = factory.createActivityFacility(Id.create(1, ActivityFacility.class), new Coord((double) 200, (double) 5000)); diff --git a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java index 25b4d5a96ed..08eb702178b 100644 --- a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java +++ b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java @@ -20,8 +20,8 @@ package org.matsim.facilities; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Coord; @@ -80,7 +80,7 @@ public static Collection parametersForFacilitiesSourceTest() { } @Test - public void test(){ + void test(){ String outDir = utils.getOutputDirectory() ; String testOutDir = outDir + "/" + facilitiesSource.toString() + "_facilitiesWithCoordOnly_" + String.valueOf(facilitiesWithCoordOnly) + "/"; new File(testOutDir).mkdirs(); diff --git a/matsim/src/test/java/org/matsim/facilities/ActivityWithOnlyFacilityIdTest.java b/matsim/src/test/java/org/matsim/facilities/ActivityWithOnlyFacilityIdTest.java index 11666860066..8c768e8be87 100644 --- a/matsim/src/test/java/org/matsim/facilities/ActivityWithOnlyFacilityIdTest.java +++ b/matsim/src/test/java/org/matsim/facilities/ActivityWithOnlyFacilityIdTest.java @@ -4,9 +4,9 @@ import java.net.URL; import java.util.Set; -import java.util.stream.Collectors; - -import org.junit.Test; +import java.util.stream.Collectors; + +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Activity; import org.matsim.core.config.Config; @@ -15,12 +15,12 @@ import org.matsim.core.controler.OutputDirectoryHierarchy.OverwriteFileSetting; import org.matsim.core.scenario.ScenarioUtils; import org.matsim.core.utils.io.IOUtils; -import org.matsim.examples.ExamplesUtils; - -public class ActivityWithOnlyFacilityIdTest { - - @Test - public void testSiouxFallsWithOnlyFacilityIds() { +import org.matsim.examples.ExamplesUtils; + +public class ActivityWithOnlyFacilityIdTest { + + @Test + void testSiouxFallsWithOnlyFacilityIds() { URL scenarioURL = ExamplesUtils.getTestScenarioURL("siouxfalls-2014"); Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(scenarioURL, "config_default.xml")); diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java index 9120b176773..15ecc2fe919 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java @@ -22,8 +22,8 @@ package org.matsim.facilities; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.ConfigUtils; import org.matsim.core.scenario.ScenarioUtils; @@ -34,26 +34,26 @@ import java.util.Objects; import java.util.function.Consumer; -public class FacilitiesAttributeConvertionTest { + public class FacilitiesAttributeConvertionTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testDefaults() { + @Test + void testDefaults() { final String path = utils.getOutputDirectory()+"/facilities.xml"; testWriteAndReread(w -> w.write(path), w -> w.readFile(path)); } - @Test - public void testV1() { + @Test + void testV1() { final String path = utils.getOutputDirectory()+"/facilities.xml"; testWriteAndReread(w -> w.writeV1(path), w -> w.readFile(path)); } - @Test - public void testDefaultsStream() { + @Test + void testDefaultsStream() { final String path = utils.getOutputDirectory()+"/facilities.xml"; testWriteAndReread(w -> w.write(IOUtils.getOutputStream(IOUtils.getFileUrl(path), false)), w -> w.readFile(path)); diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesFromPopulationTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesFromPopulationTest.java index fa503cb96f4..9de3293c4ed 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesFromPopulationTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesFromPopulationTest.java @@ -23,7 +23,7 @@ import java.util.Map; import java.util.Set; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -47,7 +47,7 @@ public class FacilitiesFromPopulationTest { @Test - public void testRun_onePerLink_assignLinks() { + void testRun_onePerLink_assignLinks() { Fixture f = new Fixture(); FacilitiesFromPopulation generator = new FacilitiesFromPopulation(f.scenario.getActivityFacilities()); @@ -74,7 +74,7 @@ public void testRun_onePerLink_assignLinks() { } @Test - public void testRun_onePerLink_assignLinks_openingTimes() { + void testRun_onePerLink_assignLinks_openingTimes() { Fixture f = new Fixture(); FacilitiesFromPopulation generator = new FacilitiesFromPopulation(f.scenario.getActivityFacilities()); @@ -110,7 +110,7 @@ public void testRun_onePerLink_assignLinks_openingTimes() { } @Test - public void testRun_multiple_assignLinks() { + void testRun_multiple_assignLinks() { Fixture f = new Fixture(); FacilitiesFromPopulation generator = new FacilitiesFromPopulation(f.scenario.getActivityFacilities()); diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java index 90bde039ca5..a56aa037fdd 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java @@ -21,8 +21,8 @@ package org.matsim.facilities; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -45,7 +45,7 @@ public class FacilitiesParserWriterTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testParserWriter1() { + void testParserWriter1() { Config config = ConfigUtils.createConfig(); TriangleScenario.setUpScenarioConfig(config); @@ -62,7 +62,7 @@ public void testParserWriter1() { } @Test - public void testWriteReadV2_withActivities() { + void testWriteReadV2_withActivities() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); ActivityFacilities facilities = scenario.getActivityFacilities(); @@ -103,7 +103,7 @@ public void testWriteReadV2_withActivities() { } @Test - public void testWriteReadV2_withAttributes() { + void testWriteReadV2_withAttributes() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); ActivityFacilities facilities = scenario.getActivityFacilities(); @@ -140,7 +140,7 @@ public void testWriteReadV2_withAttributes() { } @Test - public void testWriteReadV2_withActivitiesAndAttributes() { // MATSIM-859 + void testWriteReadV2_withActivitiesAndAttributes() { // MATSIM-859 Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); ActivityFacilities facilities = scenario.getActivityFacilities(); diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java index f4154bb23d4..23682c3794b 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java @@ -22,8 +22,8 @@ package org.matsim.facilities; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -39,7 +39,7 @@ import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; -/** + /** * @author thibautd */ public class FacilitiesReprojectionIOTest { @@ -53,8 +53,8 @@ public class FacilitiesReprojectionIOTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testReprojectionAtImport() { + @Test + void testReprojectionAtImport() { final Scenario originalScenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); final Scenario reprojectedScenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -64,8 +64,8 @@ public void testReprojectionAtImport() { assertScenarioReprojectedCorrectly(originalScenario, reprojectedScenario); } - @Test - public void testReprojectionAtExport() { + @Test + void testReprojectionAtExport() { final Scenario originalScenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); new MatsimFacilitiesReader( originalScenario ).parse(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("chessboard"), "facilities.xml")); @@ -78,8 +78,8 @@ public void testReprojectionAtExport() { assertScenarioReprojectedCorrectly(originalScenario, reprojectedScenario); } - @Test - public void testWithControlerAndObjectAttributes() { + @Test + void testWithControlerAndObjectAttributes() { // accept a rounding error of 1 cm. // this is used both to compare equality and non-equality, so the more we accept difference between input // and output coordinates, the more we require the internally reprojected coordinates to be different. @@ -140,8 +140,8 @@ public void testWithControlerAndObjectAttributes() { } } - @Test - public void testWithControlerAndConfigParameters() { + @Test + void testWithControlerAndConfigParameters() { // accept a rounding error of 1 cm. // this is used both to compare equality and non-equality, so the more we accept difference between input // and output coordinates, the more we require the internally reprojected coordinates to be different. diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesWriterTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesWriterTest.java index a0d8396330c..2cef9ffb5d5 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesWriterTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesWriterTest.java @@ -22,7 +22,7 @@ package org.matsim.facilities; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -33,13 +33,13 @@ import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -/** + /** * @author mrieser */ public class FacilitiesWriterTest { - @Test - public void testWriteLinkId() { + @Test + void testWriteLinkId() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); ActivityFacilities facilities = scenario.getActivityFacilities(); ActivityFacilitiesFactory factory = facilities.getFactory(); @@ -83,8 +83,8 @@ public void testWriteLinkId() { Assert.assertEquals("pepsiCo", fac3b.getAttributes().getAttribute("owner")); } - @Test - public void testWrite3DCoord() { + @Test + void testWrite3DCoord() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); ActivityFacilities facilities = scenario.getActivityFacilities(); ActivityFacilitiesFactory factory = facilities.getFactory(); @@ -121,9 +121,9 @@ public void testWrite3DCoord() { Assert.assertFalse(fac3b.getCoord().hasZ()); } - @Test - // the better fix for https://github.com/matsim-org/matsim/pull/505 - public void testFacilityDescription() { + // the better fix for https://github.com/matsim-org/matsim/pull/505 + @Test + void testFacilityDescription() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); ActivityFacilities facilities = scenario.getActivityFacilities(); ActivityFacilitiesFactory factory = facilities.getFactory(); @@ -156,9 +156,9 @@ public void testFacilityDescription() { Assert.assertEquals(desc, desc2); } - @Test - // inspired by https://github.com/matsim-org/matsim/pull/505 - public void testFacilitiesName() { + // inspired by https://github.com/matsim-org/matsim/pull/505 + @Test + void testFacilitiesName() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); ActivityFacilities facilities = scenario.getActivityFacilities(); ActivityFacilitiesFactory factory = facilities.getFactory(); diff --git a/matsim/src/test/java/org/matsim/facilities/MatsimFacilitiesReaderTest.java b/matsim/src/test/java/org/matsim/facilities/MatsimFacilitiesReaderTest.java index 79414f1d327..e1b5329bb19 100644 --- a/matsim/src/test/java/org/matsim/facilities/MatsimFacilitiesReaderTest.java +++ b/matsim/src/test/java/org/matsim/facilities/MatsimFacilitiesReaderTest.java @@ -24,20 +24,20 @@ import java.io.ByteArrayInputStream; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; import org.matsim.core.config.ConfigUtils; import org.matsim.core.scenario.ScenarioUtils; -/** + /** * @author mrieser / Senozon AG */ public class MatsimFacilitiesReaderTest { - @Test - public void testReadLinkId() { + @Test + void testReadLinkId() { String str = "\n" + "\n" + "\n" + @@ -84,8 +84,8 @@ public void testReadLinkId() { Assert.assertNull(fac20.getLinkId()); } - @Test - public void testRead3DCoord() { + @Test + void testRead3DCoord() { String str = "\n" + "\n" + "\n" + diff --git a/matsim/src/test/java/org/matsim/facilities/StreamingActivityFacilitiesTest.java b/matsim/src/test/java/org/matsim/facilities/StreamingActivityFacilitiesTest.java index 06cc2bd7cbd..58a92229f5d 100644 --- a/matsim/src/test/java/org/matsim/facilities/StreamingActivityFacilitiesTest.java +++ b/matsim/src/test/java/org/matsim/facilities/StreamingActivityFacilitiesTest.java @@ -1,7 +1,7 @@ package org.matsim.facilities; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.io.ByteArrayInputStream; @@ -11,7 +11,7 @@ public class StreamingActivityFacilitiesTest { @Test - public void testFacilityIsComplete() { + void testFacilityIsComplete() { String str = "\n" + "\n" + "\n" + diff --git a/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java b/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java index 99083e55eb7..f115010be8a 100644 --- a/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java +++ b/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.facilities.ActivityFacilitiesImpl; @@ -36,7 +36,8 @@ public class AbstractFacilityAlgorithmTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testRunAlgorithms() { + @Test + void testRunAlgorithms() { final ActivityFacilitiesImpl facilities = new ActivityFacilitiesImpl(); // create 2 facilities facilities.createAndAddFacility(Id.create(1, ActivityFacility.class), new Coord(1.0, 1.0)); diff --git a/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java b/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java index 14d81eb0be3..3c3b207f51f 100644 --- a/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java @@ -24,8 +24,8 @@ import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.ConfigUtils; @@ -39,12 +39,12 @@ import java.util.Objects; import java.util.function.Consumer; -public class HouseholdAttributeConversionTest { + public class HouseholdAttributeConversionTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testDefaults() { + @Test + void testDefaults() { final String path = utils.getOutputDirectory()+"/households.xml"; testWriteAndReread(w -> w.writeFile(path), w -> w.readFile(path)); diff --git a/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java b/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java index 83f7d596c35..8aa02ede926 100644 --- a/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java +++ b/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.*; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -36,7 +36,8 @@ public class HouseholdImplTest { /** * Test that households with the same {@link Id} are not accepted. */ - @Test public void testAddHousehold_DuplicateId(){ + @Test + void testAddHousehold_DuplicateId(){ HouseholdsImpl hhs = new HouseholdsImpl(); Household hh1 = new HouseholdImpl(Id.create("1", Household.class)); Household hh2 = new HouseholdImpl(Id.create("1", Household.class)); @@ -56,7 +57,8 @@ public class HouseholdImplTest { /** * Test that households are accumulated if streaming is off. */ - @Test public void testAddHousehold_NoStreaming(){ + @Test + void testAddHousehold_NoStreaming(){ HouseholdsImpl hhs = new HouseholdsImpl(); Household hh1 = new HouseholdImpl(Id.create("1", Household.class)); Household hh2 = new HouseholdImpl(Id.create("2", Household.class)); diff --git a/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java b/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java index 28f68261192..bba8e6a3916 100644 --- a/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java +++ b/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java @@ -27,8 +27,8 @@ import java.util.Collections; import java.util.List; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.households.Income.IncomePeriod; @@ -59,7 +59,8 @@ public class HouseholdsIoTest { private final Id id24 = Id.create("24", Household.class); private final Id id25 = Id.create("25", Household.class); - @Test public void testBasicReaderWriter() throws IOException { + @Test + void testBasicReaderWriter() throws IOException { Households households = new HouseholdsImpl(); HouseholdsReaderV10 reader = new HouseholdsReaderV10(households); reader.readFile(utils.getPackageInputDirectory() + TESTHOUSEHOLDSINPUT); diff --git a/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java b/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java index d458b8af9a5..3db4c83d19f 100644 --- a/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java +++ b/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java @@ -21,8 +21,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -88,7 +88,7 @@ public class EquilTwoAgentsTest { private TestSingleIterationEventHandler handler; @Test - public void testSingleIterationPlansV4() { + void testSingleIterationPlansV4() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); ConfigUtils.loadConfig(config, IOUtils.extendUrl(utils.classInputResourcePath(), "config.xml")); config.plans().setInputFile(IOUtils.extendUrl(utils.classInputResourcePath(), "plans2.xml").toString()); diff --git a/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java b/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java index a7235c552d9..0ed09266633 100644 --- a/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java +++ b/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java @@ -24,8 +24,8 @@ import java.util.Arrays; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -86,7 +86,8 @@ public class SimulateAndScoreTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testRealPtScore() { + @Test + void testRealPtScore() { final Config config = ConfigUtils.createConfig(); config.transit().setUseTransit(true); @@ -237,7 +238,8 @@ public void install() { } - @Test public void testTeleportationScore() { + @Test + void testTeleportationScore() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); Node node1 = network.getFactory().createNode(Id.create("1", Node.class), new Coord(0, 0)); diff --git a/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java index d255daabe55..c99bcf65622 100644 --- a/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java @@ -26,8 +26,8 @@ import java.io.BufferedWriter; import java.io.IOException; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonMoneyEvent; import org.matsim.api.core.v01.population.Person; @@ -48,7 +48,8 @@ public class PersonMoneyEventIntegrationTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteReadXxml() { + @Test + void testWriteReadXxml() { final PersonMoneyEvent event1 = new PersonMoneyEvent(7.0*3600, Id.create(1, Person.class), 2.34, "tollRefund", "motorwayOperator"); final PersonMoneyEvent event2 = new PersonMoneyEvent(8.5*3600, Id.create(2, Person.class), -3.45, "toll", "motorwayOperator"); @@ -100,7 +101,8 @@ public class PersonMoneyEventIntegrationTest { * This test checks that old event files can still be parsed. * @throws IOException */ - @Test public void testWriteReadXml_oldName() throws IOException { + @Test + void testWriteReadXml_oldName() throws IOException { // write some events to file diff --git a/matsim/src/test/java/org/matsim/integration/events/PersonScoreEventTest.java b/matsim/src/test/java/org/matsim/integration/events/PersonScoreEventTest.java index 501d668165c..8e690949e5e 100644 --- a/matsim/src/test/java/org/matsim/integration/events/PersonScoreEventTest.java +++ b/matsim/src/test/java/org/matsim/integration/events/PersonScoreEventTest.java @@ -24,7 +24,7 @@ import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonScoreEvent; import org.matsim.api.core.v01.population.Person; @@ -42,7 +42,8 @@ */ public class PersonScoreEventTest { - @Test public void testWriteReadXml() { + @Test + void testWriteReadXml() { final PersonScoreEvent event1 = new PersonScoreEvent(7.0*3600, Id.create(1, Person.class), 2.34, "act"); final PersonScoreEvent event2 = new PersonScoreEvent(8.5*3600, Id.create(2, Person.class), -3.45, "leg"); @@ -92,7 +93,8 @@ public class PersonScoreEventTest { assertEquals(event2.getKind(), e2.getKind()); } - @Test public void testWriteReadJson() { + @Test + void testWriteReadJson() { final PersonScoreEvent event1 = new PersonScoreEvent(7.0*3600, Id.create(1, Person.class), 2.34, "act"); final PersonScoreEvent event2 = new PersonScoreEvent(8.5*3600, Id.create(2, Person.class), -3.45, "leg"); diff --git a/matsim/src/test/java/org/matsim/integration/events/TransitDriverStartsEventHandlerIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/events/TransitDriverStartsEventHandlerIntegrationTest.java index 485ec9befbf..4ed3071fb8e 100644 --- a/matsim/src/test/java/org/matsim/integration/events/TransitDriverStartsEventHandlerIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/events/TransitDriverStartsEventHandlerIntegrationTest.java @@ -23,7 +23,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; import org.matsim.api.core.v01.events.handler.TransitDriverStartsEventHandler; @@ -41,7 +41,7 @@ public class TransitDriverStartsEventHandlerIntegrationTest { @Test - public void testProcessEventIntegration() { + void testProcessEventIntegration() { EventsManager em = EventsUtils.createEventsManager(); TransitDriverStartsEvent e1 = new TransitDriverStartsEvent(12345, Id.create("driver", Person.class), Id.create("veh", Vehicle.class), Id.create("line", TransitLine.class), Id.create("route", TransitRoute.class), Id.create("dep", Departure.class)); diff --git a/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java b/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java index acf0bf75e71..438b9fa07c4 100644 --- a/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java +++ b/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java @@ -20,9 +20,8 @@ package org.matsim.integration.invertednetworks; import org.junit.Assert; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.controler.Controler; import org.matsim.core.controler.events.StartupEvent; import org.matsim.core.controler.listener.StartupListener; @@ -34,7 +33,7 @@ public class InvertedNetworkRoutingIT { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public final void testLanesInvertedNetworkRouting() { + final void testLanesInvertedNetworkRouting() { InvertedNetworkRoutingTestFixture f = new InvertedNetworkRoutingTestFixture(false, true, false); f.scenario.getConfig().controller().setOutputDirectory(testUtils.getOutputDirectory()); f.scenario.getConfig().travelTimeCalculator().setSeparateModes( false ); @@ -54,7 +53,7 @@ public void notifyStartup(StartupEvent event) { @Test - public final void testModesInvertedNetworkRouting() { + final void testModesInvertedNetworkRouting() { InvertedNetworkRoutingTestFixture f = new InvertedNetworkRoutingTestFixture(true, false, false); f.scenario.getConfig().controller().setOutputDirectory(testUtils.getOutputDirectory()); f.scenario.getConfig().travelTimeCalculator().setSeparateModes( false ); @@ -73,7 +72,7 @@ public void notifyStartup(StartupEvent event) { } @Test - public final void testModesNotInvertedNetworkRouting() { + final void testModesNotInvertedNetworkRouting() { InvertedNetworkRoutingTestFixture f = new InvertedNetworkRoutingTestFixture(true, false, false); f.scenario.getConfig().controller().setOutputDirectory(testUtils.getOutputDirectory()); f.scenario.getConfig().controller().setLinkToLinkRoutingEnabled(false); diff --git a/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java b/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java index e3f49875139..f5c0a37ec99 100644 --- a/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java +++ b/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.LinkEnterEvent; import org.matsim.api.core.v01.events.handler.LinkEnterEventHandler; @@ -60,7 +60,7 @@ public class LanesIT { private MatsimTestUtils testUtils = new MatsimTestUtils(); @Test - public void testLanes(){ + void testLanes(){ String configFilename = testUtils.getClassInputDirectory() + "config.xml"; Config config = ConfigUtils.loadConfig(configFilename); config.network().setInputFile("network.xml"); diff --git a/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java b/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java index 9e4952cb95a..8d745a9e89f 100644 --- a/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java +++ b/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java @@ -23,8 +23,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -63,7 +63,7 @@ public class NonAlternatingPlanElementsIT { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void test_Controler_QSim_Routechoice_acts() { + void test_Controler_QSim_Routechoice_acts() { Config config = this.utils.loadConfig("test/scenarios/equil/config.xml"); config.controller().setMobsim("qsim"); config.controller().setLastIteration(10); @@ -95,7 +95,7 @@ public void test_Controler_QSim_Routechoice_acts() { } @Test - public void test_Controler_QSim_Routechoice_legs() { + void test_Controler_QSim_Routechoice_legs() { Config config = this.utils.loadConfig("test/scenarios/equil/config.xml"); config.controller().setMobsim("qsim"); config.controller().setLastIteration(10); diff --git a/matsim/src/test/java/org/matsim/integration/pt/TransitIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/pt/TransitIntegrationTest.java index 7f957b6bf4e..910037148b6 100644 --- a/matsim/src/test/java/org/matsim/integration/pt/TransitIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/pt/TransitIntegrationTest.java @@ -19,8 +19,10 @@ package org.matsim.integration.pt; +import static org.junit.jupiter.api.Assertions.assertThrows; + +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.core.config.groups.ScoringConfigGroup; @@ -33,39 +35,43 @@ public class TransitIntegrationTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test(expected = RuntimeException.class) - public void testPtInteractionParams() { - Config config = ConfigUtils.createConfig(); - config.controller().setOutputDirectory(utils.getOutputDirectory()); - ScoringConfigGroup.ActivityParams params = new ScoringConfigGroup.ActivityParams(PtConstants.TRANSIT_ACTIVITY_TYPE); - params.setScoringThisActivityAtAll(true); - params.setTypicalDuration(60.0); - config.scoring().addActivityParams(params); - // --- - config.controller().setLastIteration(0); // in case the exception is _not_ thrown, we don't need 100 iterations to find that out ... - // --- - Controler controler = new Controler(config); - controler.run(); + @Test + void testPtInteractionParams() { + assertThrows(RuntimeException.class, () -> { + Config config = ConfigUtils.createConfig(); + config.controller().setOutputDirectory(utils.getOutputDirectory()); + ScoringConfigGroup.ActivityParams params = new ScoringConfigGroup.ActivityParams(PtConstants.TRANSIT_ACTIVITY_TYPE); + params.setScoringThisActivityAtAll(true); + params.setTypicalDuration(60.0); + config.scoring().addActivityParams(params); + // --- + config.controller().setLastIteration(0); // in case the exception is _not_ thrown, we don't need 100 iterations to find that out ... + // --- + Controler controler = new Controler(config); + controler.run(); + }); } - @Test(expected = RuntimeException.class) - public void testSubpopulationParams() { - Config config = ConfigUtils.createConfig(); - config.controller().setOutputDirectory(utils.getOutputDirectory()); - ScoringConfigGroup.ActivityParams params = new ScoringConfigGroup.ActivityParams("home"); - params.setScoringThisActivityAtAll(true); - params.setTypicalDuration(60.0); - ScoringParameterSet sps = config.scoring().getOrCreateScoringParameters("one"); - sps.addActivityParams(params); - ScoringParameterSet sps2 = config.scoring().getOrCreateScoringParameters("two"); - sps2.addActivityParams(params); - // --- - config.controller().setLastIteration(0); // in case the exception is _not_ thrown, we don't need 100 iterations to find that out ... - config.checkConsistency(); + @Test + void testSubpopulationParams() { + assertThrows(RuntimeException.class, () -> { + Config config = ConfigUtils.createConfig(); + config.controller().setOutputDirectory(utils.getOutputDirectory()); + ScoringConfigGroup.ActivityParams params = new ScoringConfigGroup.ActivityParams("home"); + params.setScoringThisActivityAtAll(true); + params.setTypicalDuration(60.0); + ScoringParameterSet sps = config.scoring().getOrCreateScoringParameters("one"); + sps.addActivityParams(params); + ScoringParameterSet sps2 = config.scoring().getOrCreateScoringParameters("two"); + sps2.addActivityParams(params); + // --- + config.controller().setLastIteration(0); // in case the exception is _not_ thrown, we don't need 100 iterations to find that out ... + config.checkConsistency(); - Controler controler = new Controler(config); - controler.run(); + Controler controler = new Controler(config); + controler.run(); + }); } } diff --git a/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java index 8dc31bb2b98..933fb43fbf6 100644 --- a/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java @@ -23,8 +23,8 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -74,7 +74,8 @@ public class ChangeTripModeIntegrationTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testStrategyManagerConfigLoaderIntegration() { + @Test + void testStrategyManagerConfigLoaderIntegration() { // setup config final Config config = utils.loadConfig((String)null); final MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); diff --git a/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java b/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java index eeba73759b9..2375b591263 100644 --- a/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java +++ b/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.PopulationWriter; import org.matsim.core.config.Config; @@ -77,7 +77,7 @@ private Scenario loadScenario() { } @Test - public void testReRoutingDijkstra() throws MalformedURLException { + void testReRoutingDijkstra() throws MalformedURLException { Scenario scenario = this.loadScenario(); scenario.getConfig().controller().setRoutingAlgorithmType(RoutingAlgorithmType.Dijkstra); Controler controler = new Controler(scenario); @@ -88,7 +88,7 @@ public void testReRoutingDijkstra() throws MalformedURLException { } @Test - public void testReRoutingAStarLandmarks() throws MalformedURLException { + void testReRoutingAStarLandmarks() throws MalformedURLException { Scenario scenario = this.loadScenario(); scenario.getConfig().controller().setRoutingAlgorithmType(RoutingAlgorithmType.AStarLandmarks); Controler controler = new Controler(scenario); @@ -99,7 +99,7 @@ public void testReRoutingAStarLandmarks() throws MalformedURLException { } @Test - public void testReRoutingSpeedyALT() throws MalformedURLException { + void testReRoutingSpeedyALT() throws MalformedURLException { Scenario scenario = this.loadScenario(); scenario.getConfig().controller().setRoutingAlgorithmType(RoutingAlgorithmType.SpeedyALT); Controler controler = new Controler(scenario); diff --git a/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java b/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java index feb4b69ff3c..23691588cff 100644 --- a/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java +++ b/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java @@ -21,8 +21,8 @@ package org.matsim.integration.replanning; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; import org.matsim.core.controler.Controler; @@ -56,7 +56,7 @@ public class ResumableRunsIT { * re-planning, which both could depend on random numbers. */ @Test - public void testResumableRuns() throws MalformedURLException { + void testResumableRuns() throws MalformedURLException { Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); config.controller().setLastIteration(11); config.controller().setWriteEventsInterval(1); diff --git a/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java index 9808f4b5f2c..214a92bc0a0 100644 --- a/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java @@ -26,8 +26,8 @@ import java.util.List; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -79,7 +79,8 @@ public class QSimIntegrationTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testFreespeed() { + @Test + void testFreespeed() { Config config = utils.loadConfig((String)null); config.network().setTimeVariantNetwork(true); Scenario scenario = ScenarioUtils.createScenario(config); @@ -125,7 +126,8 @@ public class QSimIntegrationTest { * * @author illenberger */ - @Test public void testCapacity() { + @Test + void testCapacity() { final int personsPerWave = 10; final double capacityFactor = 0.5; @@ -196,7 +198,8 @@ public class QSimIntegrationTest { * * @author dgrether */ - @Test public void testZeroCapacity() { + @Test + void testZeroCapacity() { final double capacityFactor = 0.0; Config config = utils.loadConfig((String)null); diff --git a/matsim/src/test/java/org/matsim/lanes/LanesUtilsTest.java b/matsim/src/test/java/org/matsim/lanes/LanesUtilsTest.java index 19abf4f1c3d..700a8bac5f7 100644 --- a/matsim/src/test/java/org/matsim/lanes/LanesUtilsTest.java +++ b/matsim/src/test/java/org/matsim/lanes/LanesUtilsTest.java @@ -1,6 +1,6 @@ package org.matsim.lanes; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -55,8 +55,8 @@ private LanesToLinkAssignment createLaneAssignment(Scenario scenario, double inL return laneLinkAssignment; } - @Test - public void correctOrder() { + @Test + void correctOrder() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); NetworkFactory f = scenario.getNetwork().getFactory(); diff --git a/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java b/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java index c032d3409c9..55ca134f315 100644 --- a/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java +++ b/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -79,14 +79,16 @@ private static final class Fixture{ } } - @Test public void testReader20() { + @Test + void testReader20() { Fixture f = new Fixture(); LanesReader reader = new LanesReader(f.scenario); reader.readFile(utils.getClassInputDirectory() + FILENAME); checkContent(f.scenario.getLanes()); } - @Test public void testWriter20() { + @Test + void testWriter20() { Fixture f = new Fixture(); String testoutput = utils.getOutputDirectory() + "testLaneDefinitions2.0out.xml.gz"; log.debug("reading file..."); diff --git a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java index caf4baac619..a76a672ff7a 100644 --- a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java +++ b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java @@ -29,8 +29,8 @@ import jakarta.inject.Inject; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @@ -71,7 +71,7 @@ public static Collection parameterObjects () { } @Test - public void testScoreStats() { + void testScoreStats() { Config config = utils.loadConfig("test/scenarios/equil/config.xml"); config.qsim().setUsingFastCapacityUpdate(this.isUsingFastCapacityUpdate); diff --git a/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java b/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java index 883aa930f3a..a2aa6eaf190 100644 --- a/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java +++ b/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java @@ -21,8 +21,8 @@ import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; import org.matsim.core.config.Config; @@ -42,11 +42,10 @@ public class DownloadAndReadXmlTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Ignore - @Test - /** + @Test /** * Http downloads from the SVN server will be forbidden soon, according to jwilk. */ - public final void testHttpFromSvn() { + final void testHttpFromSvn() { Config config = ConfigUtils.createConfig(); System.out.println(utils.getInputDirectory() + "../../"); @@ -66,7 +65,7 @@ public final void testHttpFromSvn() { } @Test - public final void testHttpsFromSvn() { + final void testHttpsFromSvn() { Config config = ConfigUtils.createConfig(); System.out.println(utils.getInputDirectory() + "../../"); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java index 6e0bb24b6d5..bcf1d9d33ee 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java @@ -25,7 +25,7 @@ import java.util.List; import java.util.Random; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Id; @@ -457,10 +457,10 @@ public static Collection createTests() { public ChooseRandomLegModeForSubtourComplexTripsTest( double proba ) { this.probaForRandomSingleTripMode = proba ; } - - + + @Test - public void testMutatedTrips() { + void testMutatedTrips() { Config config = ConfigUtils.createConfig(); config.subtourModeChoice().setModes(MODES); config.subtourModeChoice().setConsiderCarAvailability(false); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java index 5f4759c45c6..95030f763d7 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java @@ -25,7 +25,7 @@ import java.util.List; import java.util.Random; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Id; @@ -109,9 +109,9 @@ public static Collection createTests() { public ChooseRandomLegModeForSubtourDiffModesTest( double proba ) { this.probaForRandomSingleTripMode = proba ; } - + @Test - public void testMutatedTrips() { + void testMutatedTrips() { Config config = ConfigUtils.createConfig(); config.subtourModeChoice().setModes(MODES); config.subtourModeChoice().setConsiderCarAvailability(false); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java index 68c8df6fd01..091cb019655 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java @@ -30,8 +30,8 @@ import java.util.List; import java.util.Random; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.matsim.api.core.v01.Coord; @@ -119,7 +119,7 @@ public ChooseRandomLegModeForSubtourTest( double proba ) { @Test - public void testHandleEmptyPlan() { + void testHandleEmptyPlan() { String[] modes = new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}; ChooseRandomLegModeForSubtour algo = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() , new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, MatsimRandom.getRandom(), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); @@ -129,7 +129,7 @@ public void testHandleEmptyPlan() { } @Test - public void testHandlePlanWithoutLeg() { + void testHandlePlanWithoutLeg() { String[] modes = new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}; ChooseRandomLegModeForSubtour algo = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, MatsimRandom.getRandom(), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); @@ -141,7 +141,7 @@ public void testHandlePlanWithoutLeg() { @Test - public void testSubTourMutationNetworkBased() { + void testSubTourMutationNetworkBased() { Config config = utils.loadConfig(CONFIGFILE); Scenario scenario = ScenarioUtils.createScenario(config); Network network = scenario.getNetwork(); @@ -152,7 +152,7 @@ public void testSubTourMutationNetworkBased() { } @Test - public void testSubTourMutationFacilitiesBased() { + void testSubTourMutationFacilitiesBased() { Config config = utils.loadConfig(CONFIGFILE); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); ActivityFacilitiesImpl facilities = (ActivityFacilitiesImpl) scenario.getActivityFacilities(); @@ -163,7 +163,7 @@ public void testSubTourMutationFacilitiesBased() { } @Test - public void testCarDoesntTeleportFromHome() { + void testCarDoesntTeleportFromHome() { Config config = utils.loadConfig(CONFIGFILE); Scenario scenario = ScenarioUtils.createScenario(config); Network network = scenario.getNetwork(); @@ -173,7 +173,7 @@ public void testCarDoesntTeleportFromHome() { } @Test - public void testSingleTripSubtourHandling() { + void testSingleTripSubtourHandling() { String[] modes = new String[] {"car", "pt", "walk"}; ChooseRandomLegModeForSubtour testee = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, new Random(15102011), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); @@ -258,7 +258,7 @@ public void testSingleTripSubtourHandling() { @Test - public void testUnclosedSubtour() { + void testUnclosedSubtour() { String[] modes = new String[] {"car", "pt", "walk"}; diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java index e52d56eca60..3e9b98977f7 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java @@ -24,8 +24,8 @@ import java.util.Random; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -47,7 +47,8 @@ public class ChooseRandomLegModeTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testRandomChoice() { + @Test + void testRandomChoice() { ChooseRandomLegMode algo = new ChooseRandomLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(), false); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord(0, 0)); @@ -76,7 +77,8 @@ public class ChooseRandomLegModeTest { assertTrue("expected to find walk-mode", foundWalkMode); } - @Test public void testRandomChoiceWithinListedModesOnly() { + @Test + void testRandomChoiceWithinListedModesOnly() { ChooseRandomLegMode algo = new ChooseRandomLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(), true); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord(0, 0)); @@ -105,7 +107,8 @@ public class ChooseRandomLegModeTest { assertTrue("expected to find walk-mode", foundWalkMode); } - @Test public void testRandomChoiceWithinListedModesOnlyWorks() { + @Test + void testRandomChoiceWithinListedModesOnlyWorks() { ChooseRandomLegMode algo = new ChooseRandomLegMode(new String[] {TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(), true); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord(0, 0)); @@ -117,15 +120,16 @@ public class ChooseRandomLegModeTest { } - - @Test public void testHandleEmptyPlan() { + @Test + void testHandleEmptyPlan() { ChooseRandomLegMode algo = new ChooseRandomLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(), false); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); algo.run(plan); // no specific assert, but there should also be no NullPointerException or similar stuff that could theoretically happen } - @Test public void testHandlePlanWithoutLeg() { + @Test + void testHandlePlanWithoutLeg() { ChooseRandomLegMode algo = new ChooseRandomLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(), false); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord(0, 0)); @@ -136,7 +140,8 @@ public class ChooseRandomLegModeTest { /** * Test that all the legs have the same, changed mode */ - @Test public void testMultipleLegs() { + @Test + void testMultipleLegs() { ChooseRandomLegMode algo = new ChooseRandomLegMode(new String[] {TransportMode.car, TransportMode.pt}, MatsimRandom.getRandom(), false); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord(0, 0)); @@ -152,7 +157,8 @@ public class ChooseRandomLegModeTest { assertEquals("unexpected leg mode in leg 3.", TransportMode.pt, ((Leg) plan.getPlanElements().get(5)).getMode()); } - @Test public void testIgnoreCarAvailability_Never() { + @Test + void testIgnoreCarAvailability_Never() { ChooseRandomLegMode algo = new ChooseRandomLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.bike}, MatsimRandom.getRandom(), false); algo.setIgnoreCarAvailability(false); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -169,7 +175,8 @@ public class ChooseRandomLegModeTest { assertEquals("unexpected leg mode in leg 1.", TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode()); } - @Test public void testIgnoreCarAvailability_Never_noChoice() { + @Test + void testIgnoreCarAvailability_Never_noChoice() { ChooseRandomLegMode algo = new ChooseRandomLegMode(new String[] {TransportMode.car, TransportMode.pt}, MatsimRandom.getRandom(), false); algo.setIgnoreCarAvailability(false); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -182,7 +189,8 @@ public class ChooseRandomLegModeTest { assertEquals("unexpected leg mode in leg 1.", TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode()); } - @Test public void testIgnoreCarAvailability_Always() { + @Test + void testIgnoreCarAvailability_Always() { ChooseRandomLegMode algo = new ChooseRandomLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.bike}, new Random(1), false); algo.setIgnoreCarAvailability(false); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java index f4fd0a2ac7f..c8e4b31cefa 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java @@ -27,7 +27,7 @@ import java.util.Random; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -46,7 +46,7 @@ public class ChooseRandomSingleLegModeTest { @Test - public void testRandomChoice() { + void testRandomChoice() { ChooseRandomSingleLegMode algo = new ChooseRandomSingleLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(),false); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord((double) 0, (double) 0)); @@ -75,7 +75,7 @@ public void testRandomChoice() { @Test - public void testRandomChoiceWithListedModesOnly() { + void testRandomChoiceWithListedModesOnly() { ChooseRandomSingleLegMode algo = new ChooseRandomSingleLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(),true); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord((double) 0, (double) 0)); @@ -103,7 +103,7 @@ public void testRandomChoiceWithListedModesOnly() { } @Test - public void testRandomChoiceWithListedModesOnlyAndDifferentFromMode() { + void testRandomChoiceWithListedModesOnlyAndDifferentFromMode() { ChooseRandomSingleLegMode algo = new ChooseRandomSingleLegMode(new String[]{TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(), true); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord((double) 0, (double) 0)); @@ -113,8 +113,9 @@ public void testRandomChoiceWithListedModesOnlyAndDifferentFromMode() { String mode = leg.getMode(); Assert.assertSame(TransportMode.car, mode); } + @Test - public void testHandleEmptyPlan() { + void testHandleEmptyPlan() { ChooseRandomSingleLegMode algo = new ChooseRandomSingleLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(),false); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); algo.run(plan); @@ -122,7 +123,7 @@ public void testHandleEmptyPlan() { } @Test - public void testHandlePlanWithoutLeg() { + void testHandlePlanWithoutLeg() { ChooseRandomSingleLegMode algo = new ChooseRandomSingleLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(),false); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord(0, 0)); @@ -131,7 +132,7 @@ public void testHandlePlanWithoutLeg() { } @Test - public void testHandlePlan_DifferentThanLastMode() { + void testHandlePlan_DifferentThanLastMode() { ChooseRandomSingleLegMode algo = new ChooseRandomSingleLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(),false); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord((double) 0, (double) 0)); @@ -147,7 +148,7 @@ public void testHandlePlan_DifferentThanLastMode() { } @Test - public void testHandlePlan_OnlySingleLegChanged() { + void testHandlePlan_OnlySingleLegChanged() { ChooseRandomSingleLegMode algo = new ChooseRandomSingleLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}, MatsimRandom.getRandom(),false); Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord(0, 0)); @@ -175,7 +176,7 @@ public void testHandlePlan_OnlySingleLegChanged() { } @Test - public void testIgnoreCarAvailability_Never() { + void testIgnoreCarAvailability_Never() { ChooseRandomSingleLegMode algo = new ChooseRandomSingleLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.bike}, MatsimRandom.getRandom(),false); algo.setIgnoreCarAvailability(false); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -195,7 +196,7 @@ public void testIgnoreCarAvailability_Never() { } @Test - public void testIgnoreCarAvailability_Never_noChoice() { + void testIgnoreCarAvailability_Never_noChoice() { ChooseRandomSingleLegMode algo = new ChooseRandomSingleLegMode(new String[] {TransportMode.car, TransportMode.pt}, MatsimRandom.getRandom(),false); algo.setIgnoreCarAvailability(false); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -209,7 +210,7 @@ public void testIgnoreCarAvailability_Never_noChoice() { } @Test - public void testIgnoreCarAvailability_Always() { + void testIgnoreCarAvailability_Always() { ChooseRandomSingleLegMode algo = new ChooseRandomSingleLegMode(new String[] {TransportMode.car, TransportMode.pt, TransportMode.bike}, new Random(1),false); algo.setIgnoreCarAvailability(false); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ParallelPersonAlgorithmRunnerTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ParallelPersonAlgorithmRunnerTest.java index d6a11b6485d..319411270e0 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ParallelPersonAlgorithmRunnerTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ParallelPersonAlgorithmRunnerTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Population; @@ -49,7 +49,7 @@ public class ParallelPersonAlgorithmRunnerTest { * @author mrieser */ @Test - public void testNumberOfThreads() { + void testNumberOfThreads() { Population population = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getPopulation(); PersonAlgorithmTester algo = new PersonAlgorithmTester(); PersonAlgoProviderTester tester = new PersonAlgoProviderTester(algo); @@ -67,7 +67,7 @@ public void testNumberOfThreads() { * @author mrieser */ @Test - public void testNofPersons() { + void testNofPersons() { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); Population population = scenario.getPopulation(); for (int i = 0; i < 100; i++) { @@ -91,7 +91,7 @@ public void testNofPersons() { } @Test - public void testCrashingAlgorithm() { + void testCrashingAlgorithm() { try { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); Population population = scenario.getPopulation(); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java b/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java index a27adff51c5..e4889cb2097 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java @@ -28,7 +28,7 @@ import java.util.List; import org.junit.After; import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Person; @@ -101,7 +101,7 @@ public void fixtureWithCarSometimes() { } @Test - public void testWhenConsideringCarAvailability() throws Exception { + void testWhenConsideringCarAvailability() throws Exception { final List modesWithCar = Arrays.asList(TransportMode.car, "rail", "plane"); final List modesWithoutCar = Arrays.asList("rail", "plane"); Config config = ConfigUtils.createConfig(); @@ -120,7 +120,7 @@ public void testWhenConsideringCarAvailability() throws Exception { } @Test - public void testWhenNotConsideringCarAvailability() throws Exception { + void testWhenNotConsideringCarAvailability() throws Exception { final List modesWithCar = Arrays.asList(TransportMode.car, "rail", "plane"); Config config = ConfigUtils.createConfig(); config.subtourModeChoice().setModes(modesWithCar.toArray(new String[0])); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java b/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java index 1841a0b0a43..f7766a370df 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java @@ -24,7 +24,7 @@ import org.junit.Assert; import org.junit.Ignore; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -58,7 +58,7 @@ public class PersonPrepareForSimTest { @Test - public void testRun_MultimodalNetwork() { + void testRun_MultimodalNetwork() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createAndAddNetwork(sc); Id link1id = Id.createLinkId("1"); @@ -90,7 +90,7 @@ public void testRun_MultimodalNetwork() { } @Test - public void testRun_MultimodalScenario() { + void testRun_MultimodalScenario() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createAndAddNetwork(sc); Id link1id = Id.createLinkId("1"); @@ -120,9 +120,9 @@ public void testRun_MultimodalScenario() { Assert.assertEquals(link1id, a1.getLinkId()); Assert.assertEquals(link1id, a2.getLinkId()); // must also be linked to l1, as l2 has no car mode } - + @Test - public void testSingleLegTripRoutingMode() { + void testSingleLegTripRoutingMode() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createAndAddNetwork(sc); Population pop = sc.getPopulation(); @@ -171,7 +171,7 @@ public void testSingleLegTripRoutingMode() { TripStructureUtils.getRoutingMode(leg)); } } - + /** * Fallback modes are outdated with the introduction of routingMode. So, we want the simulation to crash if we encounter * them after {@link PrepareForSimImpl} was run (and adapted outdated plans). However, for the time being we do not @@ -181,7 +181,7 @@ public void testSingleLegTripRoutingMode() { * checked explicitly). */ @Test - public void testSingleFallbackModeLegTrip() { + void testSingleFallbackModeLegTrip() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createAndAddNetwork(sc); Population pop = sc.getPopulation(); @@ -231,9 +231,9 @@ public void testSingleFallbackModeLegTrip() { TripStructureUtils.getRoutingMode(leg)); } } - + @Test - public void testCorrectTripsRemainUnchanged() { + void testCorrectTripsRemainUnchanged() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createAndAddNetwork(sc); Population pop = sc.getPopulation(); @@ -358,9 +358,9 @@ public void testCorrectTripsRemainUnchanged() { Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg11)); } } - + @Test - public void testRoutingModeConsistency() { + void testRoutingModeConsistency() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createAndAddNetwork(sc); Population pop = sc.getPopulation(); @@ -429,7 +429,7 @@ public void testRoutingModeConsistency() { } @Test - public void testReplaceExperimentalTransitRoute() { + void testReplaceExperimentalTransitRoute() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createAndAddNetwork(sc); Id startLink = Id.createLinkId("1"); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/TripsToLegsAlgorithmTest.java b/matsim/src/test/java/org/matsim/population/algorithms/TripsToLegsAlgorithmTest.java index c6bda247ec9..2cb4da8a744 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/TripsToLegsAlgorithmTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/TripsToLegsAlgorithmTest.java @@ -26,7 +26,7 @@ import java.util.Iterator; import java.util.List; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -62,7 +62,7 @@ public Fixture( private static final String DUMMY_2 = "dummy_2 interaction"; @Test - public void testMonoLegPlan() throws Exception { + void testMonoLegPlan() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("id", Person.class))); final List structure = new ArrayList(); @@ -93,7 +93,7 @@ public void testMonoLegPlan() throws Exception { } @Test - public void testMultiLegPlan() throws Exception { + void testMultiLegPlan() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("id", Person.class))); final List structure = new ArrayList(); @@ -134,7 +134,7 @@ public void testMultiLegPlan() throws Exception { } @Test - public void testDummyActsPlan() throws Exception { + void testDummyActsPlan() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("id", Person.class))); final List structure = new ArrayList(); @@ -182,7 +182,7 @@ public void testDummyActsPlan() throws Exception { } @Test - public void testPtPlan() throws Exception { + void testPtPlan() throws Exception { final Plan plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create("id", Person.class))); final List structure = new ArrayList(); diff --git a/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java b/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java index 8e43b745d0a..d6b291abc83 100644 --- a/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java @@ -20,8 +20,8 @@ package org.matsim.pt.analysis; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.Config; @@ -44,7 +44,7 @@ public class TransitLoadIntegrationTest { @RegisterExtension private MatsimTestUtils util = new MatsimTestUtils(); @Test - public void testIntegration() { + void testIntegration() { final Config cfg = this.util.loadConfig("test/scenarios/pt-tutorial/0.config.xml"); cfg.controller().setLastIteration(0); cfg.plans().setHandlingOfPlansWithoutRoutingMode(HandlingOfPlansWithoutRoutingMode.useMainModeIdentifier); diff --git a/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadTest.java b/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadTest.java index 295d8b616bd..8e8aa411ba8 100644 --- a/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadTest.java +++ b/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadTest.java @@ -24,7 +24,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonEntersVehicleEvent; @@ -47,7 +47,7 @@ public class TransitLoadTest { @Test - public void testTransitLoad_singleLine() { + void testTransitLoad_singleLine() { TransitScheduleFactory factory = new TransitScheduleFactoryImpl(); TransitSchedule schedule = factory.createTransitSchedule(); TransitStopFacility stop1 = factory.createTransitStopFacility(Id.create(0, TransitStopFacility.class), new Coord((double) 0, (double) 0), false); diff --git a/matsim/src/test/java/org/matsim/pt/config/TransitConfigGroupTest.java b/matsim/src/test/java/org/matsim/pt/config/TransitConfigGroupTest.java index 0ec00c3e6bc..c00969cd10e 100644 --- a/matsim/src/test/java/org/matsim/pt/config/TransitConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/pt/config/TransitConfigGroupTest.java @@ -25,7 +25,7 @@ import java.util.HashSet; import java.util.Set; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; /** @@ -41,7 +41,8 @@ public class TransitConfigGroupTest { * {@link TransitConfigGroup#getParams()} for setting and getting * the transit schedule input file. */ - @Test public void testTransitScheduleFile() { + @Test + void testTransitScheduleFile() { TransitConfigGroup cg = new TransitConfigGroup(); // test initial value assertNull(cg.getTransitScheduleFile()); @@ -71,7 +72,8 @@ public class TransitConfigGroupTest { assertEquals(filename, cg.getParams().get(TransitConfigGroup.TRANSIT_SCHEDULE_FILE)); } - @Test public void testVehiclesFile() { + @Test + void testVehiclesFile() { TransitConfigGroup cg = new TransitConfigGroup(); // test initial value assertNull(cg.getVehiclesFile()); @@ -101,7 +103,8 @@ public class TransitConfigGroupTest { assertEquals(filename, cg.getParams().get(TransitConfigGroup.VEHICLES_FILE)); } - @Test public void testTransitModes() { + @Test + void testTransitModes() { TransitConfigGroup cg = new TransitConfigGroup(); Set modes; // test initial value diff --git a/matsim/src/test/java/org/matsim/pt/router/TransitActsRemoverTest.java b/matsim/src/test/java/org/matsim/pt/router/TransitActsRemoverTest.java index 962f0975417..e4f2d81ba07 100644 --- a/matsim/src/test/java/org/matsim/pt/router/TransitActsRemoverTest.java +++ b/matsim/src/test/java/org/matsim/pt/router/TransitActsRemoverTest.java @@ -23,7 +23,7 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNull; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.population.Activity; @@ -35,7 +35,8 @@ public class TransitActsRemoverTest { - @Test public void testNormalTransitPlan() { + @Test + void testNormalTransitPlan() { Plan plan = PopulationUtils.createPlan(); Coord dummyCoord = new Coord((double) 0, (double) 0); plan.addActivity(PopulationUtils.createActivityFromCoord("h", dummyCoord)); @@ -83,14 +84,16 @@ public class TransitActsRemoverTest { assertEquals("h", ((Activity) plan.getPlanElements().get(6)).getType()); } - @Test public void testEmptyPlan() { + @Test + void testEmptyPlan() { Plan plan = PopulationUtils.createPlan(); new TransitActsRemover().run(plan); assertEquals(0, plan.getPlanElements().size()); // this mostly checks that there is no exception } - @Test public void testPlanWithoutLegs() { + @Test + void testPlanWithoutLegs() { Plan plan = PopulationUtils.createPlan(); Coord dummyCoord = new Coord((double) 0, (double) 0); plan.addActivity(PopulationUtils.createActivityFromCoord("h", dummyCoord)); @@ -99,7 +102,8 @@ public class TransitActsRemoverTest { // this mostly checks that there is no exception } - @Test public void testWalkOnlyPlan() { + @Test + void testWalkOnlyPlan() { Plan plan = PopulationUtils.createPlan(); Coord dummyCoord = new Coord((double) 0, (double) 0); plan.addActivity(PopulationUtils.createActivityFromCoord("h", dummyCoord)); @@ -110,7 +114,8 @@ public class TransitActsRemoverTest { assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode()); } - @Test public void testNoTransitActPlan() { + @Test + void testNoTransitActPlan() { Plan plan = PopulationUtils.createPlan(); Coord dummyCoord = new Coord((double) 0, (double) 0); plan.addActivity(PopulationUtils.createActivityFromCoord("h", dummyCoord)); diff --git a/matsim/src/test/java/org/matsim/pt/router/TransitRouterConfigTest.java b/matsim/src/test/java/org/matsim/pt/router/TransitRouterConfigTest.java index a7a3f3cad17..3b2f4b585c0 100644 --- a/matsim/src/test/java/org/matsim/pt/router/TransitRouterConfigTest.java +++ b/matsim/src/test/java/org/matsim/pt/router/TransitRouterConfigTest.java @@ -20,8 +20,7 @@ package org.matsim.pt.router; import org.junit.Assert; - -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.groups.ScoringConfigGroup; import org.matsim.core.config.groups.RoutingConfigGroup; @@ -34,7 +33,7 @@ public class TransitRouterConfigTest { @Test - public void testConstructor() { + void testConstructor() { ScoringConfigGroup planScoring = new ScoringConfigGroup(); RoutingConfigGroup planRouting = new RoutingConfigGroup(); TransitRouterConfigGroup transitRouting = new TransitRouterConfigGroup(); diff --git a/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java b/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java index 7d573d29ed8..86df76d670e 100644 --- a/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java +++ b/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java @@ -3,8 +3,8 @@ import ch.sbb.matsim.routing.pt.raptor.SwissRailRaptor; import com.google.inject.Injector; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.controler.AbstractModule; import org.matsim.core.controler.Controler; import org.matsim.core.mobsim.framework.Mobsim; @@ -19,7 +19,7 @@ public class TransitRouterModuleTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testTransitRoutingAlgorithm_DependencyInjection_Raptor() { + void testTransitRoutingAlgorithm_DependencyInjection_Raptor() { Fixture f = new Fixture(); f.config.transit().setRoutingAlgorithmType(TransitRoutingAlgorithmType.SwissRailRaptor); f.config.controller().setOutputDirectory(this.utils.getOutputDirectory()); diff --git a/matsim/src/test/java/org/matsim/pt/routes/DefaultTransitPassengerRouteTest.java b/matsim/src/test/java/org/matsim/pt/routes/DefaultTransitPassengerRouteTest.java index f3ef18d4a24..b0dcdd68f44 100644 --- a/matsim/src/test/java/org/matsim/pt/routes/DefaultTransitPassengerRouteTest.java +++ b/matsim/src/test/java/org/matsim/pt/routes/DefaultTransitPassengerRouteTest.java @@ -24,7 +24,7 @@ import java.util.Collections; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -40,7 +40,8 @@ // Mainly copied from ExperimentalTransitRouteTest public class DefaultTransitPassengerRouteTest { - @Test public void testReadWrite_null() { + @Test + void testReadWrite_null() { DefaultTransitPassengerRoute routeA = new DefaultTransitPassengerRoute(null, null); String description = routeA.getRouteDescription(); @@ -53,7 +54,8 @@ public class DefaultTransitPassengerRouteTest { assertNull(routeB.getRouteId()); } - @Test public void testReadWrite() { + @Test + void testReadWrite() { Id accessId = Id.create("access", TransitStopFacility.class); Id egressId = Id.create("egress", TransitStopFacility.class); Id lineId = Id.create("line", TransitLine.class); @@ -71,7 +73,8 @@ public class DefaultTransitPassengerRouteTest { assertEquals(routeId, routeB.getRouteId()); } - @Test public void testInitializationLinks() { + @Test + void testInitializationLinks() { Link link1 = new FakeLink(Id.create(1, Link.class)); Link link2 = new FakeLink(Id.create(2, Link.class)); DefaultTransitPassengerRoute route = new DefaultTransitPassengerRoute(link1.getId(), link2.getId()); @@ -82,7 +85,8 @@ public class DefaultTransitPassengerRouteTest { assertNull(route.getEgressStopId()); } - @Test public void testInitializationStops() { + @Test + void testInitializationStops() { TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitStopFacility stop1 = builder.createTransitStopFacility(Id.create(1, TransitStopFacility.class), new Coord(5, 11), false); TransitStopFacility stop2 = builder.createTransitStopFacility(Id.create(2, TransitStopFacility.class), new Coord(18, 7), false); @@ -103,7 +107,8 @@ public class DefaultTransitPassengerRouteTest { assertEquals(123.0, route.getBoardingTime().seconds(), 1e-3); } - @Test public void testLinks() { + @Test + void testLinks() { Link link1 = new FakeLink(Id.create(1, Link.class)); Link link2 = new FakeLink(Id.create(2, Link.class)); Link link3 = new FakeLink(Id.create(3, Link.class)); @@ -117,7 +122,8 @@ public class DefaultTransitPassengerRouteTest { assertEquals(link4.getId(), route.getEndLinkId()); } - @Test public void testTravelTime() { + @Test + void testTravelTime() { DefaultTransitPassengerRoute route = new DefaultTransitPassengerRoute(null, null); assertTrue(route.getTravelTime().isUndefined()); double traveltime = 987.65; @@ -125,7 +131,8 @@ public class DefaultTransitPassengerRouteTest { assertEquals(traveltime, route.getTravelTime().seconds(), MatsimTestUtils.EPSILON); } - @Test public void testSetRouteDescription_PtRoute() { + @Test + void testSetRouteDescription_PtRoute() { DefaultTransitPassengerRoute route = new DefaultTransitPassengerRoute(null, null); route.setRouteDescription("" + "{" + @@ -142,7 +149,8 @@ public class DefaultTransitPassengerRouteTest { assertEquals("{\"transitRouteId\":\"1980\",\"boardingTime\":\"undefined\",\"transitLineId\":\"11\",\"accessFacilityId\":\"5\",\"egressFacilityId\":\"1055\"}", route.getRouteDescription()); } - @Test public void testSetRouteDescription_NonPtRoute() { + @Test + void testSetRouteDescription_NonPtRoute() { try { DefaultTransitPassengerRoute route = new DefaultTransitPassengerRoute(null, null); route.setRouteDescription("23 42 7 21"); diff --git a/matsim/src/test/java/org/matsim/pt/routes/ExperimentalTransitRouteTest.java b/matsim/src/test/java/org/matsim/pt/routes/ExperimentalTransitRouteTest.java index 1b1705471f1..68439b3b087 100644 --- a/matsim/src/test/java/org/matsim/pt/routes/ExperimentalTransitRouteTest.java +++ b/matsim/src/test/java/org/matsim/pt/routes/ExperimentalTransitRouteTest.java @@ -24,7 +24,7 @@ import java.util.Collections; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -39,7 +39,8 @@ public class ExperimentalTransitRouteTest { - @Test public void testInitializationLinks() { + @Test + void testInitializationLinks() { Link link1 = new FakeLink(Id.create(1, Link.class)); Link link2 = new FakeLink(Id.create(2, Link.class)); ExperimentalTransitRoute route = new ExperimentalTransitRoute(link1.getId(), link2.getId()); @@ -50,7 +51,8 @@ public class ExperimentalTransitRouteTest { assertNull(route.getEgressStopId()); } - @Test public void testInitializationStops() { + @Test + void testInitializationStops() { TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitStopFacility stop1 = builder.createTransitStopFacility(Id.create(1, TransitStopFacility.class), new Coord(5, 11), false); TransitStopFacility stop2 = builder.createTransitStopFacility(Id.create(2, TransitStopFacility.class), new Coord(18, 7), false); @@ -69,7 +71,8 @@ public class ExperimentalTransitRouteTest { assertEquals(link2.getId(), route.getEndLinkId()); } - @Test public void testLinks() { + @Test + void testLinks() { Link link1 = new FakeLink(Id.create(1, Link.class)); Link link2 = new FakeLink(Id.create(2, Link.class)); Link link3 = new FakeLink(Id.create(3, Link.class)); @@ -83,7 +86,8 @@ public class ExperimentalTransitRouteTest { assertEquals(link4.getId(), route.getEndLinkId()); } - @Test public void testTravelTime() { + @Test + void testTravelTime() { ExperimentalTransitRoute route = new ExperimentalTransitRoute(null, null); assertTrue(route.getTravelTime().isUndefined()); double traveltime = 987.65; @@ -91,7 +95,8 @@ public class ExperimentalTransitRouteTest { assertEquals(traveltime, route.getTravelTime().seconds(), MatsimTestUtils.EPSILON); } - @Test public void testSetRouteDescription_PtRoute() { + @Test + void testSetRouteDescription_PtRoute() { ExperimentalTransitRoute route = new ExperimentalTransitRoute(null, null); route.setRouteDescription("PT1===5===11===1980===1055"); assertEquals("5", route.getAccessStopId().toString()); @@ -101,7 +106,8 @@ public class ExperimentalTransitRouteTest { assertEquals("PT1===5===11===1980===1055", route.getRouteDescription()); } - @Test public void testSetRouteDescription_PtRouteWithDescription() { + @Test + void testSetRouteDescription_PtRouteWithDescription() { ExperimentalTransitRoute route = new ExperimentalTransitRoute(null, null); route.setRouteDescription("PT1===5===11===1980===1055===this is a===valid route"); assertEquals("5", route.getAccessStopId().toString()); @@ -111,7 +117,8 @@ public class ExperimentalTransitRouteTest { assertEquals("PT1===5===11===1980===1055===this is a===valid route", route.getRouteDescription()); } - @Test public void testSetRouteDescription_NonPtRoute() { + @Test + void testSetRouteDescription_NonPtRoute() { ExperimentalTransitRoute route = new ExperimentalTransitRoute(null, null); route.setRouteDescription("23 42 7 21"); assertNull(route.getAccessStopId()); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java index d79bcd590e4..57b725f2d9b 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java @@ -23,8 +23,8 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNull; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.pt.transitSchedule.api.Departure; import org.matsim.testcases.MatsimTestUtils; @@ -52,7 +52,8 @@ protected Departure createDeparture(final Id id, final double time) { return new DepartureImpl(id, time); } - @Test public void testInitialization() { + @Test + void testInitialization() { Id id = Id.create(1591, Departure.class); double time = 11.0 * 3600; Departure dep = createDeparture(id, time); @@ -60,7 +61,8 @@ protected Departure createDeparture(final Id id, final double time) { assertEquals(time, dep.getDepartureTime(), MatsimTestUtils.EPSILON); } - @Test public void testVehicleId() { + @Test + void testVehicleId() { Departure dep = createDeparture(Id.create(6791, Departure.class), 7.0*3600); assertNull(dep.getVehicleId()); Id vehId = Id.create(2491, Vehicle.class); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/MinimalTransferTimesImplTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/MinimalTransferTimesImplTest.java index e8b4e3458f6..f58e13bf1fd 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/MinimalTransferTimesImplTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/MinimalTransferTimesImplTest.java @@ -20,7 +20,7 @@ package org.matsim.pt.transitSchedule; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.pt.transitSchedule.api.MinimalTransferTimes; import org.matsim.pt.transitSchedule.api.TransitStopFacility; @@ -39,7 +39,7 @@ public class MinimalTransferTimesImplTest { private Id stopId5 = Id.create(5, TransitStopFacility.class); @Test - public void testSetGet() { + void testSetGet() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); Assert.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); mtt.set(this.stopId1, this.stopId2, 180.0); @@ -56,7 +56,7 @@ public void testSetGet() { } @Test - public void testGetWithDefault() { + void testGetWithDefault() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); double defaultSeconds = 60.0; Assert.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); @@ -71,7 +71,7 @@ public void testGetWithDefault() { } @Test - public void testRemove() { + void testRemove() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); Assert.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); mtt.set(this.stopId1, this.stopId2, 180.0); @@ -89,7 +89,7 @@ public void testRemove() { } @Test - public void testNotBidirection() { + void testNotBidirection() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); mtt.set(this.stopId1, this.stopId2, 180.0); mtt.set(this.stopId1, this.stopId3, 240.0); @@ -105,7 +105,7 @@ public void testNotBidirection() { } @Test - public void testNotTransitive() { + void testNotTransitive() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); mtt.set(this.stopId1, this.stopId2, 180.0); mtt.set(this.stopId2, this.stopId3, 240.0); @@ -120,7 +120,7 @@ public void testNotTransitive() { } @Test - public void testIterator_empty() { + void testIterator_empty() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); MinimalTransferTimes.MinimalTransferTimesIterator iter = mtt.iterator(); @@ -154,7 +154,7 @@ public void testIterator_empty() { } @Test - public void testIterator() { + void testIterator() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); MinimalTransferTimes.MinimalTransferTimesIterator iter = mtt.iterator(); @@ -223,7 +223,7 @@ public void testIterator() { } @Test - public void testIterator_withRemove() { + void testIterator_withRemove() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); mtt.set(this.stopId1, this.stopId2, 180); mtt.set(this.stopId2, this.stopId3, 240); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java index 05c4b721b6d..fa5bd256eb4 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java @@ -26,8 +26,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.pt.transitSchedule.api.TransitLine; import org.matsim.pt.transitSchedule.api.TransitRoute; @@ -57,14 +57,16 @@ protected TransitLine createTransitLine(final Id id) { return new TransitLineImpl(id); } - @Test public void testInitialization() { + @Test + void testInitialization() { Id id = Id.create(511, TransitLine.class); TransitLine tLine = createTransitLine(id); assertNotNull(tLine); assertEquals("different ids.", id.toString(), tLine.getId().toString()); } - @Test public void testAddRoute() { + @Test + void testAddRoute() { TransitLine tLine = createTransitLine(Id.create("0891", TransitLine.class)); TransitRoute route1 = new TransitRouteImpl(Id.create("1", TransitRoute.class), null, new ArrayList(), "bus"); TransitRoute route2 = new TransitRouteImpl(Id.create("2", TransitRoute.class), null, new ArrayList(), "bus"); @@ -78,7 +80,8 @@ protected TransitLine createTransitLine(final Id id) { assertNotNull(tLine.getRoutes().get(route2.getId())); } - @Test public void testAddRouteException() { + @Test + void testAddRouteException() { TransitLine tLine = createTransitLine(Id.create("0891", TransitLine.class)); TransitRoute route1a = new TransitRouteImpl(Id.create("1", TransitRoute.class), null, new ArrayList(), "bus"); TransitRoute route1b = new TransitRouteImpl(Id.create("1", TransitRoute.class), null, new ArrayList(), "bus"); @@ -104,7 +107,8 @@ protected TransitLine createTransitLine(final Id id) { } - @Test public void testRemoveRoute() { + @Test + void testRemoveRoute() { TransitLine tLine = createTransitLine(Id.create("1980", TransitLine.class)); TransitRoute route1 = new TransitRouteImpl(Id.create("11", TransitRoute.class), null, new ArrayList(), "bus"); TransitRoute route2 = new TransitRouteImpl(Id.create("5", TransitRoute.class), null, new ArrayList(), "bus"); @@ -131,7 +135,8 @@ protected TransitLine createTransitLine(final Id id) { assertNotNull(tLine.getRoutes().get(route1.getId())); } - @Test public void testGetRoutesImmutable() { + @Test + void testGetRoutesImmutable() { TransitLine tLine = createTransitLine(Id.create("1980", TransitLine.class)); TransitRoute route1 = new TransitRouteImpl(Id.create("11", TransitRoute.class), null, new ArrayList(), "bus"); try { diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java index 176ac89d5c3..812205dc8e8 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.*; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.pt.transitSchedule.api.TransitRouteStop; @@ -43,7 +43,8 @@ protected TransitRouteStop createTransitRouteStop(final TransitStopFacility stop return new TransitRouteStopImpl.Builder().stop(stop).arrivalOffset(arrivalDelay).departureOffset(departureDelay).build(); } - @Test public void testInitialization() { + @Test + void testInitialization() { TransitStopFacility stopFacility = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 2, (double) 3), false); double arrivalDelay = 4; double departureDelay = 5; @@ -53,7 +54,8 @@ protected TransitRouteStop createTransitRouteStop(final TransitStopFacility stop assertEquals(departureDelay, routeStop.getDepartureOffset().seconds(), MatsimTestUtils.EPSILON); } - @Test public void testStopFacility() { + @Test + void testStopFacility() { TransitStopFacility stopFacility1 = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 2, (double) 3), false); TransitStopFacility stopFacility2 = new TransitStopFacilityImpl(Id.create(2, TransitStopFacility.class), new Coord((double) 3, (double) 4), false); double arrivalDelay = 4; @@ -64,7 +66,8 @@ protected TransitRouteStop createTransitRouteStop(final TransitStopFacility stop assertEquals(stopFacility2, routeStop.getStopFacility()); } - @Test public void testAwaitDepartureTime() { + @Test + void testAwaitDepartureTime() { TransitStopFacility stopFacility = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 2, (double) 3), false); double arrivalDelay = 4; double departureDelay = 5; @@ -76,7 +79,8 @@ protected TransitRouteStop createTransitRouteStop(final TransitStopFacility stop assertFalse(routeStop.isAwaitDepartureTime()); } - @Test public void testEquals() { + @Test + void testEquals() { TransitStopFacility stopFacility1 = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 2, (double) 3), false); TransitStopFacility stopFacility2 = new TransitStopFacilityImpl(Id.create(2, TransitStopFacility.class), new Coord((double) 3, (double) 4), false); TransitRouteStop stop1 = createTransitRouteStop(stopFacility1, 10, 50); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java index d55881a2542..58da3c5f807 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -67,7 +67,8 @@ protected static TransitRoute createTransitRoute(final Id id, fina return new TransitRouteImpl(id, route, stops, mode); } - @Test public void testInitialization() { + @Test + void testInitialization() { Id id = Id.create(9791, TransitRoute.class); Link fromLink = new FakeLink(Id.create(10, Link.class), null, null); Link toLink = new FakeLink(Id.create(5, Link.class), null, null); @@ -84,7 +85,8 @@ protected static TransitRoute createTransitRoute(final Id id, fina assertEquals("train", tRoute.getTransportMode()); } - @Test public void testDescription() { + @Test + void testDescription() { Fixture f = new Fixture(); assertNull(f.tRoute.getDescription()); String desc = "some random description string."; @@ -95,7 +97,8 @@ protected static TransitRoute createTransitRoute(final Id id, fina assertEquals(desc, f.tRoute.getDescription()); } - @Test public void testTransportMode() { + @Test + void testTransportMode() { Fixture f = new Fixture(); // test default of Fixture assertEquals("train", f.tRoute.getTransportMode()); @@ -104,7 +107,8 @@ protected static TransitRoute createTransitRoute(final Id id, fina assertEquals("tram", f.tRoute.getTransportMode()); } - @Test public void testAddDepartures() { + @Test + void testAddDepartures() { Fixture f = new Fixture(); Departure dep1 = new DepartureImpl(Id.create(1, Departure.class), 7.0*3600); Departure dep2 = new DepartureImpl(Id.create(2, Departure.class), 8.0*3600); @@ -123,7 +127,8 @@ protected static TransitRoute createTransitRoute(final Id id, fina assertEquals(dep3, f.tRoute.getDepartures().get(dep3.getId())); } - @Test public void testAddDeparturesException() { + @Test + void testAddDeparturesException() { Fixture f = new Fixture(); Departure dep1a = new DepartureImpl(Id.create(1, Departure.class), 7.0*3600); Departure dep1b = new DepartureImpl(Id.create(1, Departure.class), 7.0*3600); @@ -139,7 +144,8 @@ protected static TransitRoute createTransitRoute(final Id id, fina } } - @Test public void testRemoveDepartures() { + @Test + void testRemoveDepartures() { Fixture f = new Fixture(); Departure dep1 = new DepartureImpl(Id.create(1, Departure.class), 7.0*3600); Departure dep2 = new DepartureImpl(Id.create(2, Departure.class), 8.0*3600); @@ -165,7 +171,8 @@ protected static TransitRoute createTransitRoute(final Id id, fina assertNotNull(f.tRoute.getDepartures().get(dep1.getId())); } - @Test public void testGetDeparturesImmutable() { + @Test + void testGetDeparturesImmutable() { Fixture f = new Fixture(); Departure dep1 = new DepartureImpl(Id.create(1, Departure.class), 7.0*3600); assertEquals(0, f.tRoute.getDepartures().size()); @@ -178,7 +185,8 @@ protected static TransitRoute createTransitRoute(final Id id, fina } } - @Test public void testRoute() { + @Test + void testRoute() { Fixture f = new Fixture(); Link link1 = new FakeLink(Id.create(1, Link.class), null, null); Link link2 = new FakeLink(Id.create(2, Link.class), null, null); @@ -192,7 +200,8 @@ protected static TransitRoute createTransitRoute(final Id id, fina assertEquals(route2, f.tRoute.getRoute()); } - @Test public void testStops() { + @Test + void testStops() { Id id = Id.create(9791, TransitRoute.class); Link fromLink = new FakeLink(Id.create(10, Link.class), null, null); Link toLink = new FakeLink(Id.create(5, Link.class), null, null); @@ -224,7 +233,8 @@ protected static TransitRoute createTransitRoute(final Id id, fina assertNull(tRoute.getStop(stopFacility4)); } - @Test public void testGetStopsImmutable() { + @Test + void testGetStopsImmutable() { Fixture f = new Fixture(); // test default of Fixture assertEquals(1, f.tRoute.getStops().size()); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFactoryTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFactoryTest.java index 4c0aec7ddcf..1940a5c8976 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFactoryTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFactoryTest.java @@ -24,7 +24,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -50,14 +50,14 @@ protected TransitScheduleFactory createTransitScheduleBuilder() { } @Test - public void testCreateTransitSchedule() { + void testCreateTransitSchedule() { TransitScheduleFactory builder = createTransitScheduleBuilder(); TransitSchedule schedule = builder.createTransitSchedule(); Assert.assertEquals(builder, schedule.getFactory()); } @Test - public void testCreateTransitLine() { + void testCreateTransitLine() { TransitScheduleFactory builder = createTransitScheduleBuilder(); Id id = Id.create(1, TransitLine.class); TransitLine line = builder.createTransitLine(id); @@ -65,7 +65,7 @@ public void testCreateTransitLine() { } @Test - public void testCreateTransitRoute() { + void testCreateTransitRoute() { TransitScheduleFactory builder = createTransitScheduleBuilder(); Id id = Id.create(2, TransitRoute.class); NetworkRoute route = RouteUtils.createLinkNetworkRouteImpl(Id.create(3, Link.class), Id.create(4, Link.class)); @@ -82,7 +82,7 @@ public void testCreateTransitRoute() { } @Test - public void testCreateTransitRouteStop() { + void testCreateTransitRouteStop() { TransitScheduleFactory builder = createTransitScheduleBuilder(); TransitStopFacility stopFacility = new TransitStopFacilityImpl(Id.create(5, TransitStopFacility.class), new Coord((double) 6, (double) 6), false); double arrivalOffset = 23; @@ -94,7 +94,7 @@ public void testCreateTransitRouteStop() { } @Test - public void testCreateTransitStopFacility() { + void testCreateTransitStopFacility() { TransitScheduleFactory builder = createTransitScheduleBuilder(); Id id1 = Id.create(6, TransitStopFacility.class); Coord coord1 = new Coord((double) 511, (double) 1980); @@ -113,7 +113,7 @@ public void testCreateTransitStopFacility() { } @Test - public void testCreateDeparture() { + void testCreateDeparture() { TransitScheduleFactory builder = createTransitScheduleBuilder(); Id id = Id.create(8, Departure.class); double time = 9.0*3600; diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java index 665f560b7db..d43aee23f33 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java @@ -28,8 +28,8 @@ import javax.xml.parsers.ParserConfigurationException; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -65,7 +65,8 @@ public class TransitScheduleFormatV1Test { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testWriteRead() throws IOException, SAXException, ParserConfigurationException { + @Test + void testWriteRead() throws IOException, SAXException, ParserConfigurationException { // prepare required data Network network = NetworkUtils.createNetwork(); Node n1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord((double) 0, (double) 0)); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleIOTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleIOTest.java index 2b3fb903657..8157150e23a 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleIOTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleIOTest.java @@ -25,7 +25,7 @@ import java.util.List; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -51,7 +51,7 @@ public class TransitScheduleIOTest { @Test - public void testWriteRead_V2() { + void testWriteRead_V2() { TransitScheduleFactory f = new TransitScheduleFactoryImpl(); TransitSchedule schedule = new TransitScheduleImpl(f); { // prepare data diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java index a634df0d228..d65d912f554 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java @@ -29,8 +29,8 @@ import javax.xml.parsers.ParserConfigurationException; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -63,7 +63,8 @@ public class TransitScheduleReaderTest { private static final String INPUT_TEST_FILE_TRANSITSCHEDULE = "transitSchedule.xml"; private static final String INPUT_TEST_FILE_NETWORK = "network.xml"; - @Test public void testReadFileV1() throws SAXException, ParserConfigurationException, IOException { + @Test + void testReadFileV1() throws SAXException, ParserConfigurationException, IOException { final String inputDir = utils.getClassInputDirectory(); Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -98,7 +99,8 @@ public class TransitScheduleReaderTest { assertEquals("wrong number of links in route.", 4, route.getLinkIds().size()); } - @Test public void testReadFile() throws IOException, SAXException, ParserConfigurationException { + @Test + void testReadFile() throws IOException, SAXException, ParserConfigurationException { final String inputDir = utils.getClassInputDirectory(); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderV1Test.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderV1Test.java index 890fac22ddd..c7e8c372a5e 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderV1Test.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderV1Test.java @@ -24,7 +24,7 @@ import java.util.Stack; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -56,7 +56,7 @@ public class TransitScheduleReaderV1Test { private static final String EMPTY_STRING = ""; @Test - public void testStopFacility_Minimalistic() { + void testStopFacility_Minimalistic() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -83,7 +83,7 @@ public void testStopFacility_Minimalistic() { } @Test - public void testStopFacility_withLink() { + void testStopFacility_withLink() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create(1, Node.class), new Coord((double) 10, (double) 5)); @@ -115,7 +115,7 @@ public void testStopFacility_withLink() { } @Test - public void testStopFacility_withBadLink() { + void testStopFacility_withBadLink() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create(1, Node.class), new Coord((double) 10, (double) 5)); @@ -146,7 +146,7 @@ public void testStopFacility_withBadLink() { } @Test - public void testStopFacility_withName() { + void testStopFacility_withName() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -171,7 +171,7 @@ public void testStopFacility_withName() { } @Test - public void testStopFacility_isBlocking() { + void testStopFacility_isBlocking() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); @@ -197,7 +197,7 @@ public void testStopFacility_isBlocking() { } @Test - public void testStopFacility_Multiple() { + void testStopFacility_Multiple() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -232,7 +232,7 @@ public void testStopFacility_Multiple() { } @Test - public void testTransitLine_Single() { + void testTransitLine_Single() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -250,7 +250,7 @@ public void testTransitLine_Single() { } @Test - public void testTransitLine_Multiple() { + void testTransitLine_Multiple() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -274,7 +274,7 @@ public void testTransitLine_Multiple() { } @Test - public void testTransitRoute_Single() { + void testTransitRoute_Single() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -313,7 +313,7 @@ public void testTransitRoute_Single() { } @Test - public void testTransitRoute_Multiple() { + void testTransitRoute_Multiple() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -368,7 +368,7 @@ public void testTransitRoute_Multiple() { } @Test - public void testTransitRoute_Description() { + void testTransitRoute_Description() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -406,7 +406,7 @@ public void testTransitRoute_Description() { } @Test - public void testRouteProfile_SingleStop() { + void testRouteProfile_SingleStop() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -460,7 +460,7 @@ public void testRouteProfile_SingleStop() { } @Test - public void testRouteProfile_MultipleStop() { + void testRouteProfile_MultipleStop() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -531,7 +531,7 @@ public void testRouteProfile_MultipleStop() { } @Test - public void testRouteProfileStop_Offsets() { + void testRouteProfileStop_Offsets() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -627,7 +627,7 @@ public void testRouteProfileStop_Offsets() { } @Test - public void testRouteProfileStop_AwaitDeparture() { + void testRouteProfileStop_AwaitDeparture() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -697,7 +697,7 @@ public void testRouteProfileStop_AwaitDeparture() { } @Test - public void testRouteProfileRoute_NoLink() { + void testRouteProfileRoute_NoLink() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -735,7 +735,7 @@ public void testRouteProfileRoute_NoLink() { } @Test - public void testRouteProfileRoute_OneLink() { + void testRouteProfileRoute_OneLink() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); Network network = NetworkUtils.createNetwork(); @@ -802,7 +802,7 @@ public void testRouteProfileRoute_OneLink() { } @Test - public void testRouteProfileRoute_TwoLinks() { + void testRouteProfileRoute_TwoLinks() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); Network network = NetworkUtils.createNetwork(); @@ -871,7 +871,7 @@ public void testRouteProfileRoute_TwoLinks() { } @Test - public void testRouteProfileRoute_MoreLinks() { + void testRouteProfileRoute_MoreLinks() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); Network network = NetworkUtils.createNetwork(); @@ -946,7 +946,7 @@ public void testRouteProfileRoute_MoreLinks() { } @Test - public void testDepartures_Single() { + void testDepartures_Single() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -988,7 +988,7 @@ public void testDepartures_Single() { } @Test - public void testDepartures_Multiple() { + void testDepartures_Multiple() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); @@ -1040,7 +1040,7 @@ public void testDepartures_Multiple() { } @Test - public void testDepartures_withVehicleRef() { + void testDepartures_withVehicleRef() { TransitSchedule schedule = new TransitScheduleFactoryImpl().createTransitSchedule(); TransitScheduleReaderV1 reader = new TransitScheduleReaderV1(schedule, new RouteFactories()); Stack context = new Stack<>(); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java index 460bb4930b3..d53fb2163cd 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -49,7 +49,7 @@ import java.io.File; import java.net.URL; -/** + /** * @author thibautd */ public class TransitScheduleReprojectionIOTest { @@ -65,8 +65,8 @@ public class TransitScheduleReprojectionIOTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); - @Test - public void testInput() { + @Test + void testInput() { URL transitSchedule = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-tutorial"), "transitschedule.xml"); final Scenario originalScenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); new TransitScheduleReader( originalScenario ).readURL(transitSchedule ); @@ -77,8 +77,8 @@ public void testInput() { assertCorrectlyReprojected( originalScenario.getTransitSchedule() , reprojectedScenario.getTransitSchedule() ); } - @Test - public void testOutput() { + @Test + void testOutput() { URL transitSchedule = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-tutorial"), "transitschedule.xml"); final Scenario originalScenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); new TransitScheduleReader(originalScenario).readURL(transitSchedule ); @@ -92,8 +92,8 @@ public void testOutput() { assertCorrectlyReprojected( originalScenario.getTransitSchedule() , reprojectedScenario.getTransitSchedule() ); } - @Test - public void testWithControlerAndConfigParameters() { + @Test + void testWithControlerAndConfigParameters() { // read transitschedule.xml into empty scenario: Scenario originalScenario ; { @@ -151,8 +151,8 @@ public void testWithControlerAndConfigParameters() { } } - @Test - public void testWithControlerAndAttributes() { + @Test + void testWithControlerAndAttributes() { // read transit schedule into empty scenario: Scenario originalScenario ; { diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleTest.java index 834bdce9be1..dc67a806b9d 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.pt.transitSchedule.api.TransitLine; @@ -42,14 +42,14 @@ public class TransitScheduleTest { private static final Logger log = LogManager.getLogger(TransitScheduleTest.class); @Test - public void testInitialization() { + void testInitialization() { TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); TransitSchedule schedule = new TransitScheduleImpl(builder); assertEquals(builder, schedule.getFactory()); } @Test - public void testAddTransitLine() { + void testAddTransitLine() { TransitSchedule schedule = new TransitScheduleImpl(new TransitScheduleFactoryImpl()); TransitLine line1 = new TransitLineImpl(Id.create(1, TransitLine.class)); TransitLine line2 = new TransitLineImpl(Id.create(2, TransitLine.class)); @@ -64,7 +64,7 @@ public void testAddTransitLine() { } @Test - public void testAddTransitLineException() { + void testAddTransitLineException() { TransitSchedule schedule = new TransitScheduleImpl(new TransitScheduleFactoryImpl()); TransitLine line1a = new TransitLineImpl(Id.create(1, TransitLine.class)); TransitLine line1b = new TransitLineImpl(Id.create(1, TransitLine.class)); @@ -93,7 +93,7 @@ public void testAddTransitLineException() { } @Test - public void testAddStopFacility() { + void testAddStopFacility() { TransitSchedule schedule = new TransitScheduleImpl(new TransitScheduleFactoryImpl()); TransitStopFacility stop1 = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 0, (double) 0), false); TransitStopFacility stop2 = new TransitStopFacilityImpl(Id.create(2, TransitStopFacility.class), new Coord((double) 1, (double) 1), false); @@ -108,7 +108,7 @@ public void testAddStopFacility() { } @Test - public void testAddStopFacilityException() { + void testAddStopFacilityException() { TransitSchedule schedule = new TransitScheduleImpl(new TransitScheduleFactoryImpl()); TransitStopFacility stop1a = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 2, (double) 2), false); TransitStopFacility stop1b = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 3, (double) 3), false); @@ -137,7 +137,7 @@ public void testAddStopFacilityException() { } @Test - public void testGetTransitLinesImmutable() { + void testGetTransitLinesImmutable() { TransitSchedule schedule = new TransitScheduleImpl(new TransitScheduleFactoryImpl()); TransitLine line1 = new TransitLineImpl(Id.create(1, TransitLine.class)); try { @@ -148,9 +148,9 @@ public void testGetTransitLinesImmutable() { log.info("catched expected exception.", e); } } - + @Test - public void testGetFacilitiesImmutable() { + void testGetFacilitiesImmutable() { TransitSchedule schedule = new TransitScheduleImpl(new TransitScheduleFactoryImpl()); TransitStopFacility stop1 = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 0, (double) 0), false); try { @@ -163,7 +163,7 @@ public void testGetFacilitiesImmutable() { } @Test - public void testRemoveStopFacility() { + void testRemoveStopFacility() { TransitSchedule schedule = new TransitScheduleImpl(new TransitScheduleFactoryImpl()); TransitStopFacility stop1 = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 0, (double) 0), false); TransitStopFacility stop1b = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 10, (double) 10), false); @@ -174,7 +174,7 @@ public void testRemoveStopFacility() { } @Test - public void testRemoveTransitLine() { + void testRemoveTransitLine() { TransitSchedule schedule = new TransitScheduleImpl(new TransitScheduleFactoryImpl()); TransitLine line1 = new TransitLineImpl(Id.create(1, TransitLine.class)); TransitLine line1b = new TransitLineImpl(Id.create(1, TransitLine.class)); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java index c628d33117e..ad6a354bbff 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java @@ -25,8 +25,8 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.population.routes.RouteFactories; import org.matsim.pt.transitSchedule.api.TransitLine; @@ -51,7 +51,7 @@ public class TransitScheduleWriterTest { * @throws ParserConfigurationException */ @Test - public void testDefaultV2() throws IOException, SAXException, ParserConfigurationException { + void testDefaultV2() throws IOException, SAXException, ParserConfigurationException { String filename = this.utils.getOutputDirectory() + "schedule.xml"; TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); @@ -69,7 +69,7 @@ public void testDefaultV2() throws IOException, SAXException, ParserConfiguratio } @Test - public void testTransitLineName() { + void testTransitLineName() { String filename = this.utils.getOutputDirectory() + "schedule.xml"; TransitScheduleFactory builder = new TransitScheduleFactoryImpl(); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java index 5f8cd61b7b1..1f0a7edb5ec 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.*; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -53,7 +53,8 @@ protected TransitStopFacility createTransitStopFacility(final Id id = Id.create(2491, TransitStopFacility.class); Coord coord = new Coord((double) 30, (double) 5); TransitStopFacility stop = createTransitStopFacility(id, coord, false); @@ -63,7 +64,8 @@ protected TransitStopFacility createTransitStopFacility(final Id id = Id.create(2491, TransitStopFacility.class); Coord coord = new Coord((double) 30, (double) 5); TransitStopFacility stop = createTransitStopFacility(id, coord, false); @@ -72,7 +74,8 @@ protected TransitStopFacility createTransitStopFacility(final Id id = Id.create(2491, TransitStopFacility.class); Coord coord = new Coord((double) 30, (double) 5); TransitStopFacility stop = createTransitStopFacility(id, coord, false); @@ -84,7 +87,8 @@ protected TransitStopFacility createTransitStopFacility(final Id id = Id.create(9791, TransitStopFacility.class); Coord coord = new Coord((double) 10, (double) 5); TransitStopFacility stop = createTransitStopFacility(id, coord, false); diff --git a/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java b/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java index 3c8e6327813..721bdffe4ec 100644 --- a/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java +++ b/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java @@ -23,7 +23,7 @@ import org.assertj.core.api.Assertions; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -42,7 +42,7 @@ public class TransitScheduleValidatorTest { @Test - public void testPtTutorial() { + void testPtTutorial() { Scenario scenario = ScenarioUtils.loadScenario( ConfigUtils.loadConfig("test/scenarios/pt-tutorial/0.config.xml")); TransitScheduleValidator.ValidationResult validationResult = TransitScheduleValidator.validateAll( @@ -51,7 +51,7 @@ public void testPtTutorial() { } @Test - public void testPtTutorialWithError() { + void testPtTutorialWithError() { Scenario scenario = ScenarioUtils.loadScenario( ConfigUtils.loadConfig("test/scenarios/pt-tutorial/0.config.xml")); TransitLine transitLine = scenario.getTransitSchedule() @@ -74,7 +74,7 @@ public void testPtTutorialWithError() { } @Test - public void testValidator_Transfers_implausibleTime() { + void testValidator_Transfers_implausibleTime() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); TransitSchedule schedule = scenario.getTransitSchedule(); TransitScheduleFactory factory = schedule.getFactory(); @@ -97,7 +97,7 @@ public void testValidator_Transfers_implausibleTime() { } @Test - public void testValidator_Transfers_missingStop() { + void testValidator_Transfers_missingStop() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); TransitSchedule schedule = scenario.getTransitSchedule(); TransitScheduleFactory factory = schedule.getFactory(); diff --git a/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java b/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java index cf324a220c0..fafc8d3307a 100644 --- a/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java +++ b/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -38,7 +38,7 @@ public class CreateFullConfigTest { @RegisterExtension private MatsimTestUtils helper = new MatsimTestUtils(); @Test - public void testMain() { + void testMain() { String[] args = new String[1]; args[0] = helper.getOutputDirectory() + "newConfig.xml"; diff --git a/matsim/src/test/java/org/matsim/run/InitRoutesTest.java b/matsim/src/test/java/org/matsim/run/InitRoutesTest.java index b44932b7cf4..ae311cd6fc6 100644 --- a/matsim/src/test/java/org/matsim/run/InitRoutesTest.java +++ b/matsim/src/test/java/org/matsim/run/InitRoutesTest.java @@ -24,8 +24,8 @@ import java.io.File; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -61,7 +61,8 @@ public class InitRoutesTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testMain() throws Exception { + @Test + void testMain() throws Exception { Config config = utils.loadConfig((String)null); final String NETWORK_FILE = "test/scenarios/equil/network.xml"; final String PLANS_FILE_TESTINPUT = utils.getOutputDirectory() + "plans.in.xml"; diff --git a/matsim/src/test/java/org/matsim/run/XY2LinksTest.java b/matsim/src/test/java/org/matsim/run/XY2LinksTest.java index b403682c30a..5d0e67a2f27 100644 --- a/matsim/src/test/java/org/matsim/run/XY2LinksTest.java +++ b/matsim/src/test/java/org/matsim/run/XY2LinksTest.java @@ -24,8 +24,8 @@ import java.io.File; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Network; @@ -58,7 +58,8 @@ public class XY2LinksTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testMain() throws Exception { + @Test + void testMain() throws Exception { Config config = utils.loadConfig((String)null); final String NETWORK_FILE = "test/scenarios/equil/network.xml"; final String PLANS_FILE_TESTINPUT = utils.getOutputDirectory() + "plans.in.xml"; diff --git a/matsim/src/test/java/org/matsim/testcases/utils/LogCounterTest.java b/matsim/src/test/java/org/matsim/testcases/utils/LogCounterTest.java index cdc1bf66cb6..0c32d32d939 100644 --- a/matsim/src/test/java/org/matsim/testcases/utils/LogCounterTest.java +++ b/matsim/src/test/java/org/matsim/testcases/utils/LogCounterTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.io.IOException; @@ -35,7 +35,7 @@ public class LogCounterTest { private final static Logger LOG = LogManager.getLogger(LogCounterTest.class); @Test - public void testLogCounter_INFO() throws IOException { + void testLogCounter_INFO() throws IOException { LogCounter counter = new LogCounter(Level.INFO); counter.activate(); LOG.info("hello world - this is just a test"); @@ -50,7 +50,7 @@ public void testLogCounter_INFO() throws IOException { } @Test - public void testLogCounter_WARN() throws IOException { + void testLogCounter_WARN() throws IOException { LogCounter counter = new LogCounter(Level.WARN); counter.activate(); LOG.info("hello world - this is just a test"); diff --git a/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java b/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java index 76c4b86140b..b0870fa8b7b 100644 --- a/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java +++ b/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; import static org.matsim.utils.eventsfilecomparison.EventsFileComparator.Result.*; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; /** @@ -36,7 +36,8 @@ public class EventsFileComparatorTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testRetCode0() { + @Test + void testRetCode0() { String f1 = utils.getClassInputDirectory() + "/events0.xml.gz"; String f2 = utils.getClassInputDirectory() + "/events5.xml.gz"; assertEquals("return val = " + FILES_ARE_EQUAL, FILES_ARE_EQUAL, EventsFileComparator.compare(f1, f2)); @@ -44,7 +45,8 @@ public class EventsFileComparatorTest { assertEquals("return val = " + FILES_ARE_EQUAL, FILES_ARE_EQUAL, EventsFileComparator.compare(f2, f1)); } - @Test public void testRetCodeM1() { + @Test + void testRetCodeM1() { String f1 = utils.getClassInputDirectory() + "/events0.xml.gz"; String f2 = utils.getClassInputDirectory() + "/events1.xml.gz"; assertEquals("return val " +DIFFERENT_NUMBER_OF_TIMESTEPS, DIFFERENT_NUMBER_OF_TIMESTEPS, EventsFileComparator.compare(f1, f2)); @@ -52,7 +54,8 @@ public class EventsFileComparatorTest { assertEquals("return val " +DIFFERENT_NUMBER_OF_TIMESTEPS, DIFFERENT_NUMBER_OF_TIMESTEPS, EventsFileComparator.compare(f2, f1)); } - @Test public void testRetCodeM2() { + @Test + void testRetCodeM2() { String f1 = utils.getClassInputDirectory() + "/events0.xml.gz"; String f2 = utils.getClassInputDirectory() + "/events2.xml.gz"; assertEquals("return val = " + DIFFERENT_TIMESTEPS, DIFFERENT_TIMESTEPS, EventsFileComparator.compare(f1, f2)); @@ -60,7 +63,8 @@ public class EventsFileComparatorTest { assertEquals("return val = " + DIFFERENT_TIMESTEPS, DIFFERENT_TIMESTEPS, EventsFileComparator.compare(f2, f1)); } - @Test public void testRetCodeM3() { + @Test + void testRetCodeM3() { String f1 = utils.getClassInputDirectory() + "/events0.xml.gz"; String f2 = utils.getClassInputDirectory() + "/events3.xml.gz"; assertEquals("return val = " + MISSING_EVENT, MISSING_EVENT, EventsFileComparator.compare(f1, f2)); @@ -68,7 +72,8 @@ public class EventsFileComparatorTest { assertEquals("return val = " + MISSING_EVENT, MISSING_EVENT, EventsFileComparator.compare(f2, f1)); } - @Test public void testRetCodeM4() { + @Test + void testRetCodeM4() { String f1 = utils.getClassInputDirectory() + "/events0.xml.gz"; String f2 = utils.getClassInputDirectory() + "/events4.xml.gz"; assertEquals("return val = " + WRONG_EVENT_COUNT, WRONG_EVENT_COUNT, EventsFileComparator.compare(f1, f2)); diff --git a/matsim/src/test/java/org/matsim/utils/geometry/CoordUtilsTest.java b/matsim/src/test/java/org/matsim/utils/geometry/CoordUtilsTest.java index b30f886d2bc..d2c2fc47982 100644 --- a/matsim/src/test/java/org/matsim/utils/geometry/CoordUtilsTest.java +++ b/matsim/src/test/java/org/matsim/utils/geometry/CoordUtilsTest.java @@ -21,7 +21,7 @@ package org.matsim.utils.geometry; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.geometry.CoordUtils; @@ -35,7 +35,7 @@ public class CoordUtilsTest { * Test method for {@link org.matsim.core.utils.geometry.CoordUtils#plus(org.matsim.api.core.v01.Coord, org.matsim.api.core.v01.Coord)}. */ @Test - public void testPlus() { + void testPlus() { Coord coord1 = new Coord(1., 2.); Coord coord2 = new Coord(3., 4.); Coord result = CoordUtils.plus( coord1, coord2 ) ; @@ -47,7 +47,7 @@ public void testPlus() { * Test method for {@link org.matsim.core.utils.geometry.CoordUtils#minus(org.matsim.api.core.v01.Coord, org.matsim.api.core.v01.Coord)}. */ @Test - public void testMinus() { + void testMinus() { Coord coord1 = new Coord(1., 2.); Coord coord2 = new Coord(3., 5.); Coord result = CoordUtils.minus( coord1, coord2 ) ; @@ -59,7 +59,7 @@ public void testMinus() { * Test method for {@link org.matsim.core.utils.geometry.CoordUtils#scalarMult(double, org.matsim.api.core.v01.Coord)}. */ @Test - public void testScalarMult() { + void testScalarMult() { Coord coord1 = new Coord(1., 2.); Coord result = CoordUtils.scalarMult( -0.33 , coord1 ) ; Assert.assertEquals( -0.33, result.getX(), delta) ; @@ -70,7 +70,7 @@ public void testScalarMult() { * Test method for {@link org.matsim.core.utils.geometry.CoordUtils#getCenter(org.matsim.api.core.v01.Coord, org.matsim.api.core.v01.Coord)}. */ @Test - public void testGetCenter() { + void testGetCenter() { Coord coord1 = new Coord(1., 2.); Coord coord2 = new Coord(3., 5.); Coord result = CoordUtils.getCenter( coord1, coord2 ) ; @@ -82,7 +82,7 @@ public void testGetCenter() { * Test method for {@link org.matsim.core.utils.geometry.CoordUtils#length(org.matsim.api.core.v01.Coord)}. */ @Test - public void testLength() { + void testLength() { Coord coord1 = new Coord(3., 2.); double result = CoordUtils.length( coord1 ) ; Assert.assertEquals( Math.sqrt( 9. + 4. ), result, delta) ; diff --git a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/LanesBasedWidthCalculatorTest.java b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/LanesBasedWidthCalculatorTest.java index 5bc21ef5dc1..dfb2d043f62 100644 --- a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/LanesBasedWidthCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/LanesBasedWidthCalculatorTest.java @@ -20,7 +20,7 @@ package org.matsim.utils.gis.matsim2esri.network; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -34,7 +34,7 @@ public class LanesBasedWidthCalculatorTest { @Test - public void testGetWidth_laneWidthNaN() { + void testGetWidth_laneWidthNaN() { Network net = NetworkUtils.createNetwork(); Node n1 = net.getFactory().createNode(Id.create("1", Node.class), new Coord((double) 0, (double) 0)); Node n2 = net.getFactory().createNode(Id.create("2", Node.class), new Coord((double) 1000, (double) 0)); diff --git a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java index 298f06bcbb0..4a5d5f918eb 100755 --- a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java +++ b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java @@ -23,8 +23,8 @@ import java.util.Collection; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; import org.matsim.core.config.ConfigUtils; @@ -41,7 +41,8 @@ public class Network2ESRIShapeTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testPolygonCapacityShape() { + @Test + void testPolygonCapacityShape() { String netFileName = "test/scenarios/equil/network.xml"; String outputFileP = utils.getOutputDirectory() + "./network.shp"; @@ -63,7 +64,8 @@ public class Network2ESRIShapeTest { Assert.assertEquals(network.getLinks().size(), writtenFeatures.size()); } - @Test public void testPolygonLanesShape() { + @Test + void testPolygonLanesShape() { String netFileName = "test/scenarios/equil/network.xml"; String outputFileP = utils.getOutputDirectory() + "./network.shp"; @@ -85,7 +87,8 @@ public class Network2ESRIShapeTest { Assert.assertEquals(network.getLinks().size(), writtenFeatures.size()); } - @Test public void testPolygonFreespeedShape() { + @Test + void testPolygonFreespeedShape() { String netFileName = "test/scenarios/equil/network.xml"; String outputFileP = utils.getOutputDirectory() + "./network.shp"; @@ -107,7 +110,8 @@ public class Network2ESRIShapeTest { Assert.assertEquals(network.getLinks().size(), writtenFeatures.size()); } - @Test public void testLineStringShape() { + @Test + void testLineStringShape() { String netFileName = "test/scenarios/equil/network.xml"; String outputFileShp = utils.getOutputDirectory() + "./network.shp"; @@ -129,7 +133,8 @@ public class Network2ESRIShapeTest { Assert.assertEquals(network.getLinks().size(), writtenFeatures.size()); } - @Test public void testNodesShape() { + @Test + void testNodesShape() { String netFileName = "test/scenarios/equil/network.xml"; String outputFileShp = utils.getOutputDirectory() + "./network.shp"; diff --git a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java index eb8441dce27..13f5e0eb3c4 100755 --- a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java +++ b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java @@ -25,8 +25,8 @@ import java.util.zip.GZIPInputStream; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; import org.matsim.api.core.v01.population.Population; @@ -45,7 +45,8 @@ public class SelectedPlans2ESRIShapeTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testSelectedPlansActsShape() throws IOException { + @Test + void testSelectedPlansActsShape() throws IOException { String outputDir = utils.getOutputDirectory(); String outShp = utils.getOutputDirectory() + "acts.shp"; @@ -69,7 +70,8 @@ public class SelectedPlans2ESRIShapeTest { Assert.assertEquals(2235, writtenFeatures.size()); } - @Test public void testSelectedPlansLegsShape() throws IOException { + @Test + void testSelectedPlansLegsShape() throws IOException { String outputDir = utils.getOutputDirectory(); String outShp = utils.getOutputDirectory() + "legs.shp"; diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesConverterTest.java index 320a488bd17..3ae0e9ed2ab 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesConverterTest.java @@ -22,7 +22,7 @@ package org.matsim.utils.objectattributes; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.time.Month; import java.util.Arrays; @@ -33,13 +33,13 @@ import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNull; -/** + /** * @author thibautd */ public class ObjectAttributesConverterTest { - @Test - public void testEnumToString() { + @Test + void testEnumToString() { final ObjectAttributesConverter converter = new ObjectAttributesConverter(); // cannot use an enum type defined here, because test classes are not on classpath for classes outside of test... // And is thus unavailable to the ObjectAttributesConverter @@ -48,15 +48,15 @@ public void testEnumToString() { Assert.assertEquals("unexpected string converted from enum value", "JANUARY", converted); } - @Test - public void testStringToEnum() { + @Test + void testStringToEnum() { final ObjectAttributesConverter converter = new ObjectAttributesConverter(); Object converted = converter.convert(Month.class.getCanonicalName(), "JANUARY"); Assert.assertEquals("unexpected enum converted from String value", Month.JANUARY, converted); } - @Test - public void testHashMap() { + @Test + void testHashMap() { var expectedString = "{\"a\":\"value-a\",\"b\":\"value-b\"}"; final var converter = new ObjectAttributesConverter(); @@ -67,8 +67,8 @@ public void testHashMap() { assertEquals(expectedString, serialized); } - @Test - public void testEmptyHashMap() { + @Test + void testEmptyHashMap() { var expectedString = "{}"; final var converter = new ObjectAttributesConverter(); @@ -79,8 +79,8 @@ public void testEmptyHashMap() { assertEquals(expectedString, serialized); } - @Test - public void testCollection() { + @Test + void testCollection() { var expectedString = "[\"a\",\"b\"]"; final var converter = new ObjectAttributesConverter(); @@ -91,8 +91,8 @@ public void testCollection() { assertEquals(expectedString, serialized); } - @Test - public void testEmptyCollection() { + @Test + void testEmptyCollection() { var expectedString = "[]"; final var converter = new ObjectAttributesConverter(); @@ -103,8 +103,8 @@ public void testEmptyCollection() { assertEquals(expectedString, serialized); } - @Test - public void testUnsupported() { + @Test + void testUnsupported() { final var converter = new ObjectAttributesConverter(); var serialized = converter.convertToString(new UnsupportedType()); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesTest.java index a4f2994f7e6..68d563e731a 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesTest.java @@ -20,7 +20,7 @@ package org.matsim.utils.objectattributes; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author mrieser @@ -28,7 +28,7 @@ public class ObjectAttributesTest { @Test - public void testPutGet() { + void testPutGet() { ObjectAttributes linkAttributes = new ObjectAttributes(); Assert.assertNull(linkAttributes.getAttribute("1", "osm:roadtype")); Assert.assertNull(linkAttributes.putAttribute("1", "osm:roadtype", "trunk")); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesUtilsTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesUtilsTest.java index 02e88fe5b0f..44b32343163 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesUtilsTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesUtilsTest.java @@ -23,7 +23,7 @@ import java.util.Iterator; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; /** * @author mrieser / Senozon AG @@ -31,7 +31,7 @@ public class ObjectAttributesUtilsTest { @Test - public void testGetAllAttributes() { + void testGetAllAttributes() { ObjectAttributes oa = new ObjectAttributes(); oa.putAttribute("1", "a", "A"); oa.putAttribute("1", "b", "B"); @@ -44,9 +44,9 @@ public void testGetAllAttributes() { Assert.assertTrue(names.contains("c")); Assert.assertFalse(names.contains("d")); } - + @Test - public void testGetAllAttributes_isImmutable() { + void testGetAllAttributes_isImmutable() { ObjectAttributes oa = new ObjectAttributes(); oa.putAttribute("1", "a", "A"); oa.putAttribute("1", "b", "B"); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java index 8cbc027a81b..dd98dd5db7b 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java @@ -24,8 +24,8 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import org.xml.sax.SAXException; @@ -38,7 +38,7 @@ public class ObjectAttributesXmlIOTest { public MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testReadWrite() throws IOException, SAXException, ParserConfigurationException { + void testReadWrite() throws IOException, SAXException, ParserConfigurationException { ObjectAttributes oa1 = new ObjectAttributes(); oa1.putAttribute("one", "a", "A"); oa1.putAttribute("one", "b", Integer.valueOf(1)); @@ -55,7 +55,7 @@ public void testReadWrite() throws IOException, SAXException, ParserConfiguratio } @Test - public void testReadWrite_CustomAttribute() { + void testReadWrite_CustomAttribute() { ObjectAttributes oa1 = new ObjectAttributes(); MyTuple t = new MyTuple(3, 4); oa1.putAttribute("1", "A", t); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java index b02914eaada..b9b0f592bb0 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java @@ -25,8 +25,8 @@ import javax.xml.parsers.ParserConfigurationException; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; import org.xml.sax.SAXException; @@ -38,7 +38,7 @@ public class ObjectAttributesXmlReaderTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testParse_customConverter() throws SAXException, ParserConfigurationException, IOException { + void testParse_customConverter() throws SAXException, ParserConfigurationException, IOException { String tupleClass = MyTuple.class.getCanonicalName(); String str = "\n" + "\n" + @@ -66,7 +66,7 @@ public void testParse_customConverter() throws SAXException, ParserConfiguration } @Test - public void testParse_missingConverter() throws SAXException, ParserConfigurationException, IOException { + void testParse_missingConverter() throws SAXException, ParserConfigurationException, IOException { String tupleClass = MyTuple.class.getCanonicalName(); String str = "\n" + "\n" + @@ -97,7 +97,7 @@ public void testParse_missingConverter() throws SAXException, ParserConfiguratio } @Test - public void testParse_withDtd() throws SAXException, ParserConfigurationException, IOException { + void testParse_withDtd() throws SAXException, ParserConfigurationException, IOException { String filename = this.utils.getPackageInputDirectory() + "objectattributes_withDtd_v1.xml"; ObjectAttributes oa = new ObjectAttributes(); new ObjectAttributesXmlReader(oa).readFile(filename); @@ -116,7 +116,7 @@ public void testParse_withDtd() throws SAXException, ParserConfigurationExceptio } @Test - public void testParse_withoutDtd() throws SAXException, ParserConfigurationException, IOException { + void testParse_withoutDtd() throws SAXException, ParserConfigurationException, IOException { String filename = this.utils.getPackageInputDirectory() + "objectattributes_withoutDtd_v1.xml"; ObjectAttributes oa = new ObjectAttributes(); new ObjectAttributesXmlReader(oa).readFile(filename); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesTest.java index 9f579912697..6b43346e33c 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesTest.java @@ -22,18 +22,18 @@ package org.matsim.utils.objectattributes.attributable; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.util.Iterator; import java.util.Map; import java.util.NoSuchElementException; -/** + /** * @author thibautd */ public class AttributesTest { - @Test - public void testInsertion() { + @Test + void testInsertion() { final Attributes attributes = new AttributesImpl(); attributes.putAttribute( "sun" , "nice" ); @@ -61,8 +61,8 @@ public void testInsertion() { attributes.getAttribute( "1 the begin" ) ); } - @Test - public void testReplacement() { + @Test + void testReplacement() { final Attributes attributes = new AttributesImpl(); attributes.putAttribute( "sun" , "nice" ); @@ -84,8 +84,8 @@ public void testReplacement() { attributes.getAttribute( "the answer" ) ); } - @Test - public void testRemoval() { + @Test + void testRemoval() { final Attributes attributes = new AttributesImpl(); attributes.putAttribute( "sun" , "nice" ); @@ -106,8 +106,8 @@ public void testRemoval() { attributes.getAttribute( "rain is nice" ) ); } - @Test - public void testGetAsMap() { + @Test + void testGetAsMap() { final Attributes attributes = new AttributesImpl(); attributes.putAttribute( "sun" , "nice" ); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesUtilsTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesUtilsTest.java index 6899fcafc30..7507806be8e 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesUtilsTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesUtilsTest.java @@ -1,13 +1,13 @@ package org.matsim.utils.objectattributes.attributable; -import org.junit.Test; - import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; + public class AttributesUtilsTest { @Test - public void testCopyToWithPrimitive() { + void testCopyToWithPrimitive() { var data = 1L; var attributeKey = "data-key"; diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordArrayConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordArrayConverterTest.java index d276dfa2fd1..c57aa1a4b75 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordArrayConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordArrayConverterTest.java @@ -21,14 +21,13 @@ package org.matsim.utils.objectattributes.attributeconverters; import org.junit.Assert; -import org.junit.Test; - +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; public class CoordArrayConverterTest { - @Test - public void testFromToString() { + @Test + void testFromToString() { final CoordArrayConverter converter = new CoordArrayConverter(); String a = "[(223380.4988791829;6758072.4280857295),(223404.67545027257;6758049.17275259),(223417.0127605943;6758038.021038004),(223450.67625251273;6757924.791645723),(223456.13332351885;6757906.359813054)]"; Coord[] coords = converter.convert(a); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordConverterTest.java index d0124325540..ee8b2db2c58 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordConverterTest.java @@ -21,14 +21,14 @@ package org.matsim.utils.objectattributes.attributeconverters; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; public class CoordConverterTest { - @Test - public void testFromToString() { + @Test + void testFromToString() { final CoordConverter converter = new CoordConverter(); String a = "(224489.3667496938;6757449.720111595)"; Coord coord = converter.convert(a); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/DoubleArrayConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/DoubleArrayConverterTest.java index 16a43974d74..e97d61653a8 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/DoubleArrayConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/DoubleArrayConverterTest.java @@ -22,16 +22,16 @@ package org.matsim.utils.objectattributes.attributeconverters; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; -/** + /** * @author jbischoff */ public class DoubleArrayConverterTest { - @Test - public void testFromToString() { + @Test + void testFromToString() { final DoubleArrayConverter converter = new DoubleArrayConverter(); String a = "-0.1,0,0.0005,17.3,5.2E22"; double[] array = converter.convert(a); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/EnumConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/EnumConverterTest.java index 5044319f55d..63318c6c71a 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/EnumConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/EnumConverterTest.java @@ -22,9 +22,9 @@ package org.matsim.utils.objectattributes.attributeconverters; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; -/** + /** * @author thibautd */ public class EnumConverterTest { @@ -38,8 +38,8 @@ public String toString() { } } - @Test - public void testFromString() { + @Test + void testFromString() { final EnumConverter converter = new EnumConverter<>( MyEnum.class ); MyEnum some = converter.convert( "SOME_CONSTANT" ); @@ -49,8 +49,8 @@ public void testFromString() { Assert.assertEquals("unexpected enum", MyEnum.SOME_OTHER_CONSTANT, other); } - @Test - public void testToString() { + @Test + void testToString() { final EnumConverter converter = new EnumConverter<>( MyEnum.class ); Assert.assertEquals( "unexpected String value", "SOME_CONSTANT", converter.convertToString( MyEnum.SOME_CONSTANT ) ); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringCollectionConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringCollectionConverterTest.java index 3eb55a83e1c..7470881f42d 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringCollectionConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringCollectionConverterTest.java @@ -1,16 +1,16 @@ package org.matsim.utils.objectattributes.attributeconverters; -import org.junit.Test; - import java.util.Collection; import java.util.Map; import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; + public class StringCollectionConverterTest { @Test - public void test() { + void test() { var expectedString = "[\"a\",\"b\"]"; var converter = new StringCollectionConverter(); diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringStringMapConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringStringMapConverterTest.java index 31e56474bf7..686cc3efe37 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringStringMapConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringStringMapConverterTest.java @@ -1,13 +1,13 @@ package org.matsim.utils.objectattributes.attributeconverters; -import org.junit.Test; - import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; + public class StringStringMapConverterTest { @Test - public void test() { + void test() { var expectedString = "{\"a\":\"value-a\",\"b\":\"value-b\"}"; var converter = new StringStringMapConverter(); diff --git a/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java b/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java index 6c0b4d9858e..152586c364d 100644 --- a/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java +++ b/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java @@ -29,8 +29,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -60,7 +60,8 @@ public class MatsimVehicleWriterTest { id42_23 = Id.create(" 42 23", Vehicle.class); } - @Test public void testWriter() throws FileNotFoundException, IOException { + @Test + void testWriter() throws FileNotFoundException, IOException { { String outfileName = utils.getOutputDirectory() + "testOutputVehicles.xml"; diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java index 4ff191bfbfc..7f6716c5acd 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java @@ -24,8 +24,8 @@ import java.util.Map; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -63,12 +63,14 @@ public class VehicleReaderV1Test { id42_23 = Id.create(" 42 23", Vehicle.class); } - @Test public void test_NumberOfVehicleTypeisReadCorrectly() { + @Test + void test_NumberOfVehicleTypeisReadCorrectly() { assertNotNull(vehicleTypes); assertEquals(2, vehicleTypes.size()); } - @Test public void test_VehicleTypeValuesAreReadCorrectly_normalCar() { + @Test + void test_VehicleTypeValuesAreReadCorrectly_normalCar() { assertNotNull(vehicleTypes); assertEquals(2, vehicleTypes.size()); VehicleType vehType = vehicleTypes.get(Id.create("normal&Car", VehicleType.class)); @@ -91,7 +93,8 @@ public class VehicleReaderV1Test { assertEquals(2.0, vehType.getPcuEquivalents(), 0); } - @Test public void test_VehicleTypeValuesAreReadCorrectly_defaultCar() { + @Test + void test_VehicleTypeValuesAreReadCorrectly_defaultCar() { VehicleType vehType = vehicleTypes.get(Id.create("defaultValue>Car", VehicleType.class)); assertNotNull(vehType); assertEquals(7.5, vehType.getLength(), MatsimTestUtils.EPSILON); @@ -101,12 +104,14 @@ public class VehicleReaderV1Test { assertEquals(1.0, vehType.getPcuEquivalents(), 0); } - @Test public void test_NumberOfVehiclesIsReadCorrectly() { + @Test + void test_NumberOfVehiclesIsReadCorrectly() { assertNotNull(vehicles); assertEquals(3, vehicles.size()); } - @Test public void test_VehicleTypeToVehiclesAssignmentIsReadCorrectly() { + @Test + void test_VehicleTypeToVehiclesAssignmentIsReadCorrectly() { assertNotNull(vehicles.get(id23)); assertEquals(id23, vehicles.get(id23).getId()); assertEquals(Id.create("normal&Car", VehicleType.class), vehicles.get(id23).getType().getId()); diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java index 5e2208a4a88..599b853217d 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java @@ -24,8 +24,8 @@ import java.util.Map; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -64,12 +64,14 @@ public class VehicleReaderV2Test { id42_23 = Id.create(" 42 23", Vehicle.class); } - @Test public void test_NumberOfVehicleTypeisReadCorrectly() { + @Test + void test_NumberOfVehicleTypeisReadCorrectly() { assertNotNull(vehicleTypes); assertEquals(3, vehicleTypes.size()); } - @Test public void test_VehicleAttributesReadCorrectly(){ + @Test + void test_VehicleAttributesReadCorrectly(){ assertNotNull(vehicleTypes); /* First vehicle has an attribute. */ Vehicle v1 = vehicles.get(Id.createVehicleId("23")); @@ -91,7 +93,8 @@ public class VehicleReaderV2Test { } - @Test public void test_VehicleTypeValuesAreReadCorrectly_normalCar() { + @Test + void test_VehicleTypeValuesAreReadCorrectly_normalCar() { VehicleType vehTypeNormalCar = vehicleTypes.get(Id.create("normal&Car", VehicleType.class)); assertNotNull(vehTypeNormalCar); assertEquals(9.5, vehTypeNormalCar.getLength(), MatsimTestUtils.EPSILON); @@ -131,7 +134,8 @@ public class VehicleReaderV2Test { assertEquals(VehicleType.DoorOperationMode.parallel, VehicleUtils.getDoorOperationMode(vehTypeNormalCar)); } - @Test public void test_VehicleTypeValuesAreReadCorrectly_defaultCar() { + @Test + void test_VehicleTypeValuesAreReadCorrectly_defaultCar() { VehicleType vehTypeDefaultCar = vehicleTypes.get(Id.create("defaultValue>Car", VehicleType.class)); assertNotNull(vehTypeDefaultCar); assertEquals(7.5, vehTypeDefaultCar.getLength(), MatsimTestUtils.EPSILON); @@ -147,7 +151,8 @@ public class VehicleReaderV2Test { assertEquals(2, vehTypeDefaultCar.getAttributes().getAttribute("Attribute2")); } - @Test public void test_VehicleTypeValuesAreReadCorrectly_smallTruck() { + @Test + void test_VehicleTypeValuesAreReadCorrectly_smallTruck() { VehicleType vehTypeSmallTruck = vehicleTypes.get(Id.create("smallTruck", VehicleType.class)); assertNotNull(vehTypeSmallTruck); assertEquals("This is a small truck", vehTypeSmallTruck.getDescription()); @@ -169,12 +174,14 @@ public class VehicleReaderV2Test { assertEquals(0.15, VehicleUtils.getCostsPerSecondInService(vehTypeSmallTruck.getCostInformation()), MatsimTestUtils.EPSILON); } - @Test public void test_NumberOfVehiclesIsReadCorrectly() { + @Test + void test_NumberOfVehiclesIsReadCorrectly() { assertNotNull(vehicles); assertEquals(3, vehicles.size()); } - @Test public void test_VehicleTypeToVehiclesAssignmentIsReadCorrectly() { + @Test + void test_VehicleTypeToVehiclesAssignmentIsReadCorrectly() { assertNotNull(vehicles.get(id23)); assertEquals(id23, vehicles.get(id23).getId()); assertEquals(Id.create("normal&Car", VehicleType.class), vehicles.get(id23).getType().getId()); diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java index ea13e5dd1b4..3caafd4c6af 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java @@ -6,8 +6,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.testcases.MatsimTestUtils; public class VehicleWriteReadTest{ @@ -28,7 +28,7 @@ public void setUp() throws IOException { } @Test - public void v1_isWrittenCorrect () throws FileNotFoundException, IOException { + void v1_isWrittenCorrect() throws FileNotFoundException, IOException { //----- V1 -------- //read it Vehicles vehicles1 = VehicleUtils.createVehiclesContainer(); @@ -46,7 +46,7 @@ public void v1_isWrittenCorrect () throws FileNotFoundException, IOException { } @Test - public void v2_isWrittenCorrect () throws FileNotFoundException, IOException { + void v2_isWrittenCorrect() throws FileNotFoundException, IOException { //----- V2 -------- //read it Vehicles vehicles2 = VehicleUtils.createVehiclesContainer(); diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java index 7625ba85319..d103a29f287 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -59,7 +59,8 @@ public class VehicleWriterV1Test { id42_23 = Id.create(" 42 23", Vehicle.class); } - @Test public void testWriter() { + @Test + void testWriter() { String outfileName = utils.getOutputDirectory() + "testOutputVehicles.xml"; diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java index d7242617d79..9b65d2f6608 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java @@ -28,8 +28,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.testcases.MatsimTestUtils; @@ -81,13 +81,15 @@ public class VehicleWriterV2Test { } - @Test public void test_NumberOfVehicleTypeisReadCorrectly() { + @Test + void test_NumberOfVehicleTypeisReadCorrectly() { assertNotNull(vehicleTypes); assertEquals(3, vehicleTypes.size()); } - @Test public void test_VehicleTypeValuesAreReadCorrectly_normalCar() { + @Test + void test_VehicleTypeValuesAreReadCorrectly_normalCar() { VehicleType vehTypeNormalCar = vehicleTypes.get(Id.create("normal&Car", VehicleType.class)); assertNotNull(vehTypeNormalCar); assertEquals(9.5, vehTypeNormalCar.getLength(), MatsimTestUtils.EPSILON); @@ -128,7 +130,8 @@ public class VehicleWriterV2Test { } - @Test public void test_VehicleTypeValuesAreReadCorrectly_defaultCar() { + @Test + void test_VehicleTypeValuesAreReadCorrectly_defaultCar() { VehicleType vehTypeDefaultCar = vehicleTypes.get(Id.create("defaultValue>Car", VehicleType.class)); assertNotNull(vehTypeDefaultCar); assertEquals(7.5, vehTypeDefaultCar.getLength(), MatsimTestUtils.EPSILON); @@ -147,7 +150,8 @@ public class VehicleWriterV2Test { } - @Test public void test_VehicleTypeValuesAreReadCorrectly_smallTruck() { + @Test + void test_VehicleTypeValuesAreReadCorrectly_smallTruck() { VehicleType vehTypeSmallTruck = vehicleTypes.get(Id.create("smallTruck", VehicleType.class)); assertNotNull(vehTypeSmallTruck); assertEquals("This is a small truck", vehTypeSmallTruck.getDescription()); @@ -163,13 +167,15 @@ public class VehicleWriterV2Test { } - @Test public void test_NumberOfVehiclesIsReadCorrectly() { + @Test + void test_NumberOfVehiclesIsReadCorrectly() { assertNotNull(vehicles); assertEquals(3, vehicles.size()); } - @Test public void test_VehicleAttributesReadCorrectly(){ + @Test + void test_VehicleAttributesReadCorrectly(){ assertNotNull(vehicleTypes); /* First vehicle has an attribute. */ Vehicle v1 = vehicles.get(Id.createVehicleId("23")); @@ -191,8 +197,8 @@ public class VehicleWriterV2Test { } - - @Test public void test_VehicleTypeToVehiclesAssignmentIsReadCorrectly() { + @Test + void test_VehicleTypeToVehiclesAssignmentIsReadCorrectly() { assertNotNull(vehicles.get(id23)); assertEquals(id23, vehicles.get(id23).getId()); assertEquals(Id.create("normal&Car", VehicleType.class), vehicles.get(id23).getType().getId()); diff --git a/matsim/src/test/java/org/matsim/vehicles/VehiclesImplTest.java b/matsim/src/test/java/org/matsim/vehicles/VehiclesImplTest.java index 96b8671f064..2cace0fd2e6 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehiclesImplTest.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehiclesImplTest.java @@ -20,7 +20,7 @@ package org.matsim.vehicles; import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; /** @@ -31,7 +31,7 @@ public class VehiclesImplTest { @Test - public void testAddVehicle() { + void testAddVehicle() { Vehicles vehicles = VehicleUtils.createVehiclesContainer(); VehicleType testType = vehicles.getFactory().createVehicleType(Id.create("test", VehicleType.class)); @@ -59,7 +59,7 @@ public void testAddVehicle() { @Test - public void testGetVehicles(){ + void testGetVehicles(){ Vehicles vehicles = VehicleUtils.createVehiclesContainer(); VehicleType testType = vehicles.getFactory().createVehicleType(Id.create("test", VehicleType.class)); @@ -78,7 +78,7 @@ public void testGetVehicles(){ @Test - public void testGetVehicleTypes(){ + void testGetVehicleTypes(){ Vehicles vehicles = VehicleUtils.createVehiclesContainer(); VehicleType t1 = vehicles.getFactory().createVehicleType(Id.create("type1", VehicleType.class)); @@ -92,7 +92,7 @@ public void testGetVehicleTypes(){ } @Test - public void testAddVehicleType(){ + void testAddVehicleType(){ Vehicles vehicles = VehicleUtils.createVehiclesContainer(); VehicleType t1 = vehicles.getFactory().createVehicleType(Id.create("type1", VehicleType.class)); @@ -108,7 +108,7 @@ public void testAddVehicleType(){ } @Test - public void testRemoveVehicle() { + void testRemoveVehicle() { Vehicles vehicles = VehicleUtils.createVehiclesContainer(); VehicleType t1 = vehicles.getFactory().createVehicleType(Id.create("type1", VehicleType.class)); vehicles.addVehicleType(t1); @@ -123,7 +123,7 @@ public void testRemoveVehicle() { } @Test - public void testRemoveVehicleType() { + void testRemoveVehicleType() { Vehicles vehicles = VehicleUtils.createVehiclesContainer(); VehicleType t1 = vehicles.getFactory().createVehicleType(Id.create("type1", VehicleType.class)); vehicles.addVehicleType(t1); diff --git a/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java b/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java index 84d11f60338..178b07d1236 100644 --- a/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java +++ b/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -46,7 +46,8 @@ public class PositionInfoTest { * * @author mrieser */ - @Test public void testDistanceOnLink_shortLink() { + @Test + void testDistanceOnLink_shortLink() { Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord(0, 0)); @@ -82,7 +83,8 @@ public class PositionInfoTest { * * @author mrieser */ - @Test public void testDistanceOnLink_longLink() { + @Test + void testDistanceOnLink_longLink() { Network network = NetworkUtils.createNetwork(); Node node1 = NetworkUtils.createAndAddNode(network, Id.create("1", Node.class), new Coord(0, 0)); diff --git a/matsim/src/test/java/org/matsim/withinday/controller/ExampleWithinDayControllerTest.java b/matsim/src/test/java/org/matsim/withinday/controller/ExampleWithinDayControllerTest.java index 4512cfea7e0..a20e95d2d0b 100644 --- a/matsim/src/test/java/org/matsim/withinday/controller/ExampleWithinDayControllerTest.java +++ b/matsim/src/test/java/org/matsim/withinday/controller/ExampleWithinDayControllerTest.java @@ -22,8 +22,8 @@ package org.matsim.withinday.controller; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Leg; import org.matsim.core.config.Config; @@ -43,7 +43,7 @@ public class ExampleWithinDayControllerTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testRun() { + void testRun() { Config config = utils.loadConfig("test/scenarios/equil/config.xml"); config.controller().setLastIteration(1); config.controller().setRoutingAlgorithmType(ControllerConfigGroup.RoutingAlgorithmType.Dijkstra); diff --git a/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java b/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java index c1b95aa5670..88ee4b705a2 100644 --- a/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java +++ b/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java @@ -23,8 +23,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -77,7 +77,7 @@ public class ExperiencedPlansWriterTest { private MatsimTestUtils utils = new MatsimTestUtils(); @Test - public void testWriteFile() { + void testWriteFile() { Config config = ConfigUtils.createConfig(); diff --git a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java index 59c2ed7e244..f0870a25f99 100644 --- a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java +++ b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java @@ -26,9 +26,8 @@ import java.util.Map; import jakarta.inject.Inject; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; import org.matsim.api.core.v01.population.Person; @@ -58,7 +57,8 @@ public class ActivityReplanningMapTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @Test public void testGetTimeBin() { + @Test + void testGetTimeBin() { ActivityReplanningMap arp = new ActivityReplanningMap(null, EventsUtils.createEventsManager()); // test default setting with start time = 0.0 and time step size = 1.0 @@ -97,7 +97,8 @@ public class ActivityReplanningMapTest { assertEquals(2, arp.getTimeBin(12.1)); } - @Test public void testScenarioRun() { + @Test + void testScenarioRun() { // load config and use ParallelQSim with 2 Threads Config config = utils.loadConfig("test/scenarios/equil/config.xml"); diff --git a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java index 4f5157fb784..ed3ffd5c1a7 100644 --- a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java +++ b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java @@ -23,9 +23,8 @@ import static org.junit.Assert.assertEquals; import jakarta.inject.Inject; - +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.core.config.Config; import org.matsim.core.config.groups.ControllerConfigGroup; import org.matsim.core.config.groups.QSimConfigGroup; @@ -49,8 +48,8 @@ public class LinkReplanningMapTest { private MatsimTestUtils utils = new MatsimTestUtils(); - - @Test public void testScenarioRun() { + @Test + void testScenarioRun() { // load config and use ParallelQSim with 2 Threads Config config = utils.loadConfig("test/scenarios/equil/config.xml"); diff --git a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java index 7af481f6af8..8bb4b9ca4f6 100644 --- a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java +++ b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Link; @@ -62,12 +62,12 @@ public class WithinDayTravelTimeTest { private double originalFreeSpeed22; @Test - public void testGetLinkTravelTime_fastCapacityUpdate() { + void testGetLinkTravelTime_fastCapacityUpdate() { testGetLinkTravelTime(true); } @Test - public void testGetLinkTravelTime_noFastCapacityUpdate() { + void testGetLinkTravelTime_noFastCapacityUpdate() { testGetLinkTravelTime(false); } diff --git a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java index 25f5076e8b9..85961c100a2 100644 --- a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java +++ b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java @@ -25,8 +25,8 @@ import java.util.Set; import org.junit.Assert; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -72,7 +72,7 @@ public class WithinDayTravelTimeWithNetworkChangeEventsTest { private Id link23 = Id.createLinkId("link_2_3"); @Test - public final void testTTviaMobSimAfterSimStepListener() { + final void testTTviaMobSimAfterSimStepListener() { String outputDirectory = testUtils.getOutputDirectory() + "output_TTviaMobsimAfterSimStepListener/"; diff --git a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java index 8c87bda545e..6931b60b91f 100644 --- a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java +++ b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java @@ -28,8 +28,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -87,7 +87,8 @@ public class EditRoutesTest { /** * @author cdobler */ - @Test public void testReplanFutureLegRoute() { + @Test + void testReplanFutureLegRoute() { // this is ok (we can still replan a single leg with the computer science router). kai, dec'15 createScenario(); @@ -144,7 +145,8 @@ public class EditRoutesTest { assertEquals(3, networkRouteWH.getLinkIds().size()); // l4, l5, l2 } - @Test public void testRelocateFutureLegRoute() { + @Test + void testRelocateFutureLegRoute() { // yyyy this test is misleading. "relocateFutureLegRoute" is ok, but it does not look after the overall plan consistency, // as this test implies. kai, feb'16 @@ -226,7 +228,8 @@ public class EditRoutesTest { /** * @author cdobler */ - @Test public void testReplanCurrentLegRouteOne() + @Test + void testReplanCurrentLegRouteOne() // this is ok (we can still replan a single leg with the computer science router). kai, dec'15 { createScenario(); @@ -270,7 +273,9 @@ public class EditRoutesTest { assertEquals(true, ed.replanCurrentLegRoute((Leg) plan.getPlanElements().get(scndCarLeg), plan.getPerson(), 4, 8.0*3600 )); // WH, end Link } - @Test public void testReplanCurrentLegRouteTwo() + + @Test + void testReplanCurrentLegRouteTwo() { /* * replace destinations and create new routes @@ -297,7 +302,9 @@ public class EditRoutesTest { log.warn( route ); assertEquals(true, checkRouteValidity(route)); } - @Test public void testReplanCurrentLegRouteThree() + + @Test + void testReplanCurrentLegRouteThree() { createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); @@ -317,7 +324,9 @@ public class EditRoutesTest { final NetworkRoute route = (NetworkRoute)((Leg)plan.getPlanElements().get(firstCarLeg)).getRoute(); assertEquals(true, checkRouteValidity(route)); } - @Test public void testReplanCurrentLegRouteFour() + + @Test + void testReplanCurrentLegRouteFour() { createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); @@ -337,7 +346,9 @@ public class EditRoutesTest { final NetworkRoute route = (NetworkRoute)((Leg)plan.getPlanElements().get(firstCarLeg)).getRoute(); assertEquals(true, checkRouteValidity(route)); } - @Test public void testReplanCurrentLegRouteFive() + + @Test + void testReplanCurrentLegRouteFive() { // create new routes for WH-trip createScenario(); // reset scenario @@ -357,7 +368,9 @@ public class EditRoutesTest { assertEquals(true, ed.replanCurrentLegRoute((Leg) plan.getPlanElements().get(scndCarLeg), plan.getPerson(), 0, 8.0*3600 )); // WH, start Link assertEquals(true, checkRouteValidity((NetworkRoute)((Leg)plan.getPlanElements().get(scndCarLeg)).getRoute())); } - @Test public void testReplanCurrentLegRouteSix() + + @Test + void testReplanCurrentLegRouteSix() { createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); @@ -376,7 +389,9 @@ public class EditRoutesTest { assertEquals(true, ed.replanCurrentLegRoute((Leg) plan.getPlanElements().get(scndCarLeg), plan.getPerson(), 1, 8.0*3600 )); // WH, en-route assertEquals(true, checkRouteValidity((NetworkRoute)((Leg)plan.getPlanElements().get(scndCarLeg)).getRoute())); } - @Test public void testReplanCurrentLegRouteSeven() + + @Test + void testReplanCurrentLegRouteSeven() { createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); @@ -395,7 +410,9 @@ public class EditRoutesTest { assertEquals(true, ed.replanCurrentLegRoute((Leg) plan.getPlanElements().get(scndCarLeg), plan.getPerson(), 2, 8.0*3600 )); // WH, en-route assertEquals(true, checkRouteValidity((NetworkRoute)((Leg)plan.getPlanElements().get(scndCarLeg)).getRoute())); } - @Test public void testReplanCurrentLegRouteEight() + + @Test + void testReplanCurrentLegRouteEight() { createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); @@ -414,7 +431,9 @@ public class EditRoutesTest { assertEquals(true, ed.replanCurrentLegRoute((Leg) plan.getPlanElements().get(scndCarLeg), plan.getPerson(), 3, 8.0*3600 ) ); // WH, en-route assertEquals(true, checkRouteValidity((NetworkRoute)((Leg)plan.getPlanElements().get(scndCarLeg)).getRoute())); } - @Test public void testReplanCurrentLegRouteNine() + + @Test + void testReplanCurrentLegRouteNine() { createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); @@ -434,7 +453,9 @@ public class EditRoutesTest { assertEquals(true, checkRouteValidity((NetworkRoute)((Leg)plan.getPlanElements().get(scndCarLeg)).getRoute())); } - @Test public void testReplanCurrentLegRouteTen() + + @Test + void testReplanCurrentLegRouteTen() { // expect EditRoutes to return false if the Route in the leg is not a NetworkRoute createScenario(); // reset scenario diff --git a/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java b/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java index 23c69bdc66d..3d2f16c8350 100644 --- a/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java +++ b/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java @@ -22,8 +22,8 @@ import static org.junit.Assert.assertEquals; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -44,7 +44,8 @@ public class ReplacePlanElementsTest { /** * @author cdobler */ - @Test public void testReplaceActivity() { + @Test + void testReplaceActivity() { Plan plan = createSamplePlan(); Activity oldActivity = (Activity)plan.getPlanElements().get(0); Activity newActivity = PopulationUtils.createActivityFromCoord("s", new Coord((double) 200, (double) 200)); @@ -67,7 +68,8 @@ public class ReplacePlanElementsTest { /** * @author cdobler */ - @Test public void testReplaceLeg() { + @Test + void testReplaceLeg() { Plan plan = createSamplePlan(); Leg oldLeg = (Leg)plan.getPlanElements().get(1); Leg newLeg = PopulationUtils.createLeg(TransportMode.walk); From 3416b4a62a0e3fa4885f315cd6ec6cbb67888e3a Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 19:42:25 +0100 Subject: [PATCH 29/43] Migrate JUnit 4 Assert To JUnit Jupiter Assertions --- .../accessibility/LeastCostPathTreeTest.java | 14 +- .../accessibility/grid/SpatialGridTest.java | 6 +- .../CompareLogsumFormulas2Test.java | 4 +- .../CompareLogsumFormulasTest.java | 4 +- .../ComputeLogsumFormulas3Test.java | 6 +- .../run/AccessibilityIntegrationTest.java | 112 ++-- .../accessibility/run/NetworkUtilTest.java | 106 +-- .../run/TinyAccessibilityTest.java | 18 +- .../run/TinyMultimodalAccessibilityTest.java | 26 +- .../BvwpAccidentsCostComputationTest.java | 8 +- .../org/matsim/contrib/accidents/RunTest.java | 6 +- .../contrib/accidents/RunTestEquil.java | 13 +- .../PersonIntersectAreaFilterTest.java | 18 +- .../population/RouteLinkFilterTest.java | 4 +- .../kai/KNAnalysisEventsHandlerTest.java | 4 +- .../contrib/analysis/spatial/GridTest.java | 4 +- .../spatial/SpatialInterpolationTest.java | 4 +- .../contrib/analysis/time/TimeBinMapTest.java | 3 +- .../GoogleMapRouteValidatorTest.java | 4 +- .../HereMapsRouteValidatorTest.java | 2 +- .../application/ApplicationUtilsTest.java | 2 +- .../application/MATSimApplicationTest.java | 4 +- .../application/options/ShpOptionsTest.java | 4 +- .../counts/CreateCountsFromBAStDataTest.java | 6 +- .../CarrierReaderFromCSVTest.java | 176 ++--- .../DemandReaderFromCSVTest.java | 286 ++++---- .../FreightDemandGenerationTest.java | 4 +- .../FreightDemandGenerationUtilsTest.java | 112 ++-- .../LanduseBuildingAnalysisTest.java | 252 +++---- ...nerateSmallScaleCommercialTrafficTest.java | 16 +- .../SmallScaleCommercialTrafficUtilsTest.java | 18 +- .../TrafficVolumeGenerationTest.java | 542 +++++++-------- .../TripDistributionMatrixTest.java | 34 +- .../contrib/av/flow/TestAvFlowFactor.java | 6 +- .../RunTaxiPTIntermodalExampleIT.java | 6 +- .../BicycleLinkSpeedCalculatorTest.java | 4 +- .../bicycle/BicycleUtilityUtilsTest.java | 2 +- .../contrib/bicycle/run/BicycleTest.java | 83 +-- .../contrib/cadyts/car/CadytsCarIT.java | 64 +- .../cadyts/car/CadytsCarWithPtScenarioIT.java | 8 +- .../utils/CalibrationStatReaderTest.java | 27 +- .../runExample/RunCarsharingIT.java | 50 +- .../ChangeCommercialJobOperatorTest.java | 10 +- .../DefaultCommercialServiceScoreTest.java | 10 +- .../IsTheRightCustomerScoredTest.java | 14 +- .../always/BetaTravelTest66IT.java | 4 +- .../integration/always/BetaTravelTest6IT.java | 4 +- .../DecongestionPricingTestIT.java | 66 +- .../SubtourModeChoiceReplacementTest.java | 4 +- .../VehicleTourConstraintTest.java | 4 +- .../components/readers/ApolloTest.java | 4 +- .../tour_finder/ActivityTourFinderTest.java | 4 +- .../ScheduleWaitingTimeEstimatorTest.java | 4 +- .../examples/TestSiouxFalls.java | 4 +- .../models/MaximumUtilityTest.java | 4 +- .../models/MultinomialLogitTest.java | 4 +- .../models/NestedLogitTest.java | 4 +- .../models/RandomUtilityTest.java | 4 +- .../models/nested/NestCalculatorTest.java | 2 +- .../modules/config/ConfigTest.java | 4 +- .../replanning/TestDepartureTimes.java | 4 +- .../DrtWithExtensionsConfigGroupTest.java | 10 +- .../extension/edrt/run/RunEDrtScenarioIT.java | 4 +- .../extension/fiss/RunFissDrtScenarioIT.java | 4 +- .../insertion/DrtInsertionExtensionIT.java | 4 +- .../OperationFacilitiesIOTest.java | 24 +- .../operations/shifts/ShiftsIOTest.java | 2 +- .../efficiency/ShiftEfficiencyTest.java | 12 +- .../analysis/zonal/DrtZonalSystemTest.java | 2 +- .../drt/config/ConfigBehaviorTest.java | 10 +- .../contrib/drt/fare/DrtFareHandlerTest.java | 6 +- .../insertion/DrtPoolingParameterTest.java | 98 +-- .../drt/prebooking/AbandonAndCancelTest.java | 4 +- .../prebooking/ComplexUnschedulerTest.java | 16 +- .../prebooking/PersonStuckPrebookingTest.java | 4 +- .../drt/prebooking/PrebookingTest.java | 2 +- .../drt/routing/DrtRoutingModuleTest.java | 50 +- .../MultiModeDrtMainModeIdentifierTest.java | 8 +- .../drt/run/examples/RunDrtExampleIT.java | 2 +- .../contrib/dvrp/router/DiversionTest.java | 17 +- .../contrib/emissions/EmissionModuleTest.java | 2 +- .../emissions/OsmHbefaMappingTest.java | 3 +- .../TestColdEmissionAnalysisModule.java | 6 +- .../TestColdEmissionAnalysisModuleCase1.java | 4 +- .../TestColdEmissionAnalysisModuleCase2.java | 4 +- .../TestColdEmissionAnalysisModuleCase3.java | 4 +- .../TestColdEmissionAnalysisModuleCase4.java | 4 +- .../TestColdEmissionAnalysisModuleCase6.java | 4 +- .../TestColdEmissionsFallbackBehaviour.java | 14 +- .../TestHbefaColdEmissionFactorKey.java | 26 +- .../emissions/TestHbefaVehicleAttributes.java | 42 +- .../TestHbefaWarmEmissionFactorKey.java | 24 +- .../emissions/TestPositionEmissionModule.java | 4 +- .../TestWarmEmissionAnalysisModule.java | 44 +- .../TestWarmEmissionAnalysisModuleCase1.java | 184 +++--- .../TestWarmEmissionAnalysisModuleCase2.java | 38 +- .../TestWarmEmissionAnalysisModuleCase3.java | 38 +- .../TestWarmEmissionAnalysisModuleCase4.java | 38 +- .../TestWarmEmissionAnalysisModuleCase5.java | 6 +- .../TestWarmEmissionsFallbackBehaviour.java | 14 +- .../VspHbefaRoadTypeMappingTest.java | 2 +- .../analysis/EmissionGridAnalyzerTest.java | 3 +- .../analysis/EmissionsByPollutantTest.java | 4 +- .../EmissionsOnLinkEventHandlerTest.java | 2 +- .../FastEmissionGridAnalyzerTest.java | 4 +- .../emissions/analysis/RasterTest.java | 4 +- .../analysis/RawEmissionEventsReaderTest.java | 2 +- .../events/TestColdEmissionEventImpl.java | 29 +- .../events/TestWarmEmissionEventImpl.java | 35 +- .../events/VehicleLeavesTrafficEventTest.java | 4 +- ...unAverageEmissionToolOfflineExampleIT.java | 10 +- ...nDetailedEmissionToolOfflineExampleIT.java | 8 +- ...EmissionToolOnlineExampleIT_vehTypeV1.java | 6 +- ...eExampleIT_vehTypeV1FallbackToAverage.java | 4 +- ...EmissionToolOnlineExampleIT_vehTypeV2.java | 6 +- ...eExampleIT_vehTypeV2FallbackToAverage.java | 4 +- .../emissions/utils/EmissionUtilsTest.java | 265 ++++---- ...nEvExampleWithLTHConsumptionModelTest.java | 8 +- ...emperatureChangeModuleIntegrationTest.java | 7 +- .../carriers/CarrierEventsReadersTest.java | 16 +- .../carriers/CarrierPlanReaderV1Test.java | 30 +- .../carriers/CarrierPlanXmlReaderV2Test.java | 50 +- .../CarrierPlanXmlReaderV2WithDtdTest.java | 36 +- .../carriers/CarrierPlanXmlWriterV2Test.java | 2 +- .../CarrierPlanXmlWriterV2_1Test.java | 2 +- .../CarrierVehicleTypeLoaderTest.java | 34 +- .../CarrierVehicleTypeReaderTest.java | 4 +- .../carriers/CarrierVehicleTypeTest.java | 50 +- .../freight/carriers/CarriersUtilsTest.java | 46 +- .../FreightCarriersConfigGroupTest.java | 22 +- .../EquilWithCarrierWithPersonsIT.java | 6 +- .../EquilWithCarrierWithoutPersonsIT.java | 16 +- ...istanceConstraintFromVehiclesFileTest.java | 100 +-- .../jsprit/DistanceConstraintTest.java | 134 ++-- .../carriers/jsprit/FixedCostsTest.java | 8 +- .../carriers/jsprit/IntegrationIT.java | 4 +- .../jsprit/MatsimTransformerTest.java | 2 +- .../NetworkBasedTransportCostsTest.java | 20 +- .../freight/carriers/jsprit/SkillsIT.java | 14 +- .../usecases/chessboard/RunChessboardIT.java | 8 +- .../RunPassengerAlongWithCarriersIT.java | 4 +- .../utils/CarrierControlerUtilsIT.java | 18 +- .../utils/CarrierControlerUtilsTest.java | 173 +++-- .../ReceiverCostAllocationFixedTest.java | 4 +- .../freightreceiver/ReceiverPlanTest.java | 6 +- .../freightreceiver/ReceiversReaderTest.java | 88 +-- .../freightreceiver/ReceiversTest.java | 64 +- .../freightreceiver/ReceiversWriterTest.java | 10 +- .../freightreceiver/SSReorderPolicyTest.java | 8 +- .../RelaxedSubtourConstraintTest.java | 2 +- .../integration/daily/SomeDailyTest.java | 4 +- .../integration/weekly/SomeWeeklyTest.java | 4 +- .../locationchoice/LocationChoiceIT.java | 4 +- .../frozenepsilons/FacilityPenaltyTest.java | 6 +- .../FrozenEpsilonLocaChoiceIT.java | 10 +- .../frozenepsilons/SamplerTest.java | 4 +- .../frozenepsilons/ScoringPenaltyTest.java | 4 +- .../LocationMutatorwChoiceSetTest.java | 4 +- .../timegeography/ManageSubchainsTest.java | 2 +- .../timegeography/SubChainTest.java | 2 +- .../router/BackwardFastMultiNodeTest.java | 210 +++--- .../matsim/core/router/FastMultiNodeTest.java | 210 +++--- .../core/router/MultiNodeDijkstraTest.java | 166 ++--- .../MatrixBasedPtRouterIT.java | 4 +- .../matrixbasedptrouter/PtMatrixTest.java | 39 +- .../matrixbasedptrouter/TestQuadTree.java | 6 +- .../genericUtils/TerminusStopFinderTest.java | 10 +- .../minibus/integration/PControlerTestIT.java | 52 +- .../integration/SubsidyContextTestIT.java | 46 +- .../minibus/integration/SubsidyTestIT.java | 6 +- .../replanning/EndRouteExtensionTest.java | 84 +-- .../MaxRandomEndTimeAllocatorTest.java | 28 +- .../MaxRandomStartTimeAllocatorTest.java | 28 +- .../SidewaysRouteExtensionTest.java | 146 ++-- .../minibus/replanning/TimeProviderTest.java | 18 +- .../WeightedEndTimeExtensionTest.java | 48 +- .../WeightedStartTimeExtensionTest.java | 48 +- .../ComplexCircleScheduleProviderTest.java | 34 +- .../SimpleCircleScheduleProviderTest.java | 20 +- ...tionApproachesAndBetweenJunctionsTest.java | 110 +-- .../CreateStopsForAllCarLinksTest.java | 6 +- ...eaBtwLinksVsTerminiBeelinePenaltyTest.java | 4 +- .../RouteDesignScoringManagerTest.java | 16 +- .../StopServedMultipleTimesPenaltyTest.java | 4 +- .../RecursiveStatsApproxContainerTest.java | 66 +- .../stats/RecursiveStatsContainerTest.java | 66 +- .../MultiModalControlerListenerTest.java | 54 +- .../multimodal/MultiModalTripRouterTest.java | 4 +- .../multimodal/RunMultimodalExampleTest.java | 4 +- .../pt/MultiModalPTCombinationTest.java | 10 +- .../router/util/BikeTravelTimeTest.java | 18 +- .../router/util/WalkTravelTimeTest.java | 16 +- .../multimodal/simengine/StuckAgentTest.java | 6 +- .../contrib/noise/NoiseConfigGroupIT.java | 18 +- .../org/matsim/contrib/noise/NoiseIT.java | 298 ++++----- .../contrib/noise/NoiseOnlineExampleIT.java | 8 +- .../matsim/contrib/noise/NoiseRLS19IT.java | 26 +- .../osm/networkReader/LinkPropertiesTest.java | 4 +- .../networkReader/OsmBicycleReaderTest.java | 2 +- .../networkReader/OsmNetworkParserTest.java | 4 +- .../networkReader/OsmSignalsParserTest.java | 4 +- .../SupersonicOsmNetworkReaderTest.java | 2 +- .../contrib/osm/networkReader/Utils.java | 28 +- ...SupersonicOsmNetworkReaderBuilderTest.java | 4 +- .../org/matsim/contrib/otfvis/OTFVisIT.java | 10 +- .../contrib/parking/lib/GeneralLibTest.java | 2 +- .../lib/obj/DoubleValueHashMapTest.java | 2 +- .../lib/obj/LinkedListValueHashMapTest.java | 4 +- .../ParkingCostVehicleTrackerTest.java | 44 +- .../RideParkingCostTrackerTest.java | 44 +- .../run/RunParkingSearchScenarioIT.java | 18 +- .../contrib/pseudosimulation/RunPSimTest.java | 6 +- .../integration/RailsimIntegrationTest.java | 16 +- .../roadpricing/AvoidTolledRouteTest.java | 10 +- .../contrib/roadpricing/CalcPaidTollTest.java | 6 +- .../RoadPricingConfigGroupTest.java | 12 +- .../roadpricing/RoadPricingControlerIT.java | 4 +- .../roadpricing/RoadPricingIOTest.java | 2 +- .../roadpricing/RoadPricingTestUtils.java | 10 +- .../TollTravelCostCalculatorTest.java | 4 +- .../run/RoadPricingByConfigfileTest.java | 10 +- .../run/RunRoadPricingExampleIT.java | 4 +- .../run/RunRoadPricingFromCodeIT.java | 4 +- ...unRoadPricingUsingTollFactorExampleIT.java | 4 +- .../analysis/skims/FloatMatrixIOTest.java | 21 +- .../analysis/skims/RooftopUtilsTest.java | 113 ++-- .../config/SBBTransitConfigGroupTest.java | 8 +- .../matsim/mobsim/qsim/SBBQSimModuleTest.java | 4 +- .../SBBTransitQSimEngineIntegrationTest.java | 14 +- .../qsim/pt/SBBTransitQSimEngineTest.java | 38 +- .../matsim/contrib/shared_mobility/RunIT.java | 40 +- .../CreateIntergreensExampleTest.java | 10 +- .../CreateSignalInputExampleTest.java | 24 +- ...CreateSignalInputExampleWithLanesTest.java | 28 +- .../RunSignalSystemsExampleTest.java | 6 +- ...sualizeSignalScenarioWithLanesGUITest.java | 6 +- .../FixResponsiveSignalResultsIT.java | 12 +- .../io/MatsimFileTypeGuesserSignalsTest.java | 4 +- .../contrib/signals/CalculateAngleTest.java | 25 +- .../contrib/signals/SignalUtilsTest.java | 24 +- .../analysis/DelayAnalysisToolTest.java | 6 +- .../signals/builder/QSimSignalTest.java | 10 +- .../builder/TravelTimeFourWaysTest.java | 4 +- .../builder/TravelTimeOneWayTestIT.java | 16 +- ...aultPlanbasedSignalSystemControllerIT.java | 184 +++--- .../controller/laemmerFix/LaemmerIT.java | 162 +++-- .../signals/controller/sylvia/SylviaIT.java | 30 +- .../v10/AmberTimesData10ReaderWriterTest.java | 26 +- .../SignalConflictDataReaderWriterTest.java | 32 +- .../UnprotectedLeftTurnLogicTest.java | 10 +- ...IntergreenTimesData10ReaderWriterTest.java | 28 +- .../SignalControlData20ReaderWriterTest.java | 48 +- .../v20/SignalGroups20ReaderWriterTest.java | 24 +- .../SignalSystemsData20ReaderWriterTest.java | 64 +- .../signals/integration/SignalSystemsIT.java | 54 +- .../InvertedNetworksSignalsIT.java | 6 +- .../SignalsAndLanesOsmNetworkReaderTest.java | 142 ++-- .../signals/oneagent/ControlerTest.java | 8 +- .../signals/sensor/LaneSensorTest.java | 4 +- .../signals/sensor/LinkSensorTest.java | 48 +- .../DefaultAnnealingAcceptorTest.java | 20 +- .../SimulatedAnnealingConfigGroupTest.java | 16 +- .../SimulatedAnnealingTest.java | 4 +- .../framework/events/CourtesyEventsTest.java | 8 +- .../population/JointPlanFactoryTest.java | 20 +- .../framework/population/JointPlanIOTest.java | 32 +- .../framework/population/JointPlansTest.java | 86 +-- .../population/SocialNetworkIOTest.java | 38 +- .../population/SocialNetworkTest.java | 68 +- .../grouping/DynamicGroupIdentifierTest.java | 14 +- .../replanning/grouping/FixedGroupsIT.java | 14 +- .../replanning/grouping/GroupPlansTest.java | 40 +- .../ActivitySequenceMutatorAlgorithmTest.java | 62 +- .../replanning/modules/MergingTest.java | 28 +- .../modules/TourModeUnifierAlgorithmTest.java | 100 +-- .../removers/LexicographicRemoverTest.java | 14 +- .../FullExplorationVsCuttoffTest.java | 10 +- .../selectors/HighestWeightSelectorTest.java | 20 +- .../selectors/RandomSelectorsTest.java | 16 +- .../CoalitionSelectorTest.java | 8 +- ...ghtJointPlanPruningConflictSolverTest.java | 14 +- ...tPointedPlanPruningConflictSolverTest.java | 14 +- .../WhoIsTheBossSelectorTest.java | 14 +- .../GroupCompositionPenalizerTest.java | 8 +- .../RecomposeJointPlanAlgorithmTest.java | 24 +- .../RandomJointLocationChoiceTest.java | 8 +- .../jointtrips/JointTravelUtilsTest.java | 22 +- ...intTravelingSimulationIntegrationTest.java | 32 +- ...InsertionRemovalIgnoranceBehaviorTest.java | 12 +- .../InsertionRemovalIterativeActionTest.java | 101 ++- ...intTripInsertionWithSocialNetworkTest.java | 8 +- .../JointTripRemoverAlgorithmTest.java | 32 +- ...nchronizeCoTravelerPlansAlgorithmTest.java | 14 +- .../router/JointPlanRouterTest.java | 30 +- .../router/JointTripRouterFactoryTest.java | 20 +- .../HouseholdBasedVehicleRessourcesTest.java | 8 +- .../PlanRouterWithVehicleRessourcesTest.java | 8 +- ...PopulationAgentSourceWithVehiclesTest.java | 12 +- ...ehicleToPlansInGroupPlanAlgorithmTest.java | 38 +- ...imizeVehicleAllocationAtTourLevelTest.java | 8 +- .../replanning/GroupPlanStrategyTest.java | 32 +- ...nableActivitiesPlanLinkIdentifierTest.java | 110 +-- .../VehicularPlanLinkIdentifierTest.java | 20 +- .../utils/JointScenarioUtilsTest.java | 28 +- .../socnetsim/utils/ObjectPoolTest.java | 20 +- .../utils/QuadTreeRebuilderTest.java | 32 +- .../contrib/etaxi/run/RunETaxiScenarioIT.java | 6 +- .../taxi/optimizer/TaxiOptimizerTests.java | 6 +- ...oringParametersFromPersonAttributesIT.java | 9 +- ...omPersonAttributesNoSubpopulationTest.java | 38 +- ...ingParametersFromPersonAttributesTest.java | 38 +- .../analysis/RunFreightAnalysisIT.java | 180 ++--- .../RunFreightAnalysisWithShipmentTest.java | 16 +- .../drtAndPt/PtAlongALine2Test.java | 44 +- .../EmissionCostFactorsTest.java | 2 +- .../emissions/TestColdEmissionHandler.java | 24 +- .../emissions/TestWarmEmissionHandler.java | 28 +- ...entId2DepartureDelayAtStopMapDataTest.java | 6 +- .../AgentId2DepartureDelayAtStopMapTest.java | 10 +- ...tId2EnterLeaveVehicleEventHandlerTest.java | 14 +- .../AgentId2PtTripTravelTimeMapDataTest.java | 6 +- .../AgentId2PtTripTravelTimeMapTest.java | 4 +- ...EnterLeaveVehicle2ActivityHandlerTest.java | 4 +- .../bvgAna/level1/StopId2LineId2PulkTest.java | 4 +- .../StopId2RouteId2DelayAtStopMapTest.java | 8 +- .../level1/VehId2DelayAtStopMapDataTest.java | 4 +- .../level1/VehId2DelayAtStopMapTest.java | 10 +- .../level1/VehId2OccupancyHandlerTest.java | 6 +- .../VehId2PersonEnterLeaveVehicleMapTest.java | 10 +- .../osmBB/PTCountsNetworkSimplifierTest.java | 92 +-- .../ModalDistanceAndCountsCadytsIT.java | 8 +- ...odalDistanceCadytsMultipleDistancesIT.java | 4 +- .../ModalDistanceCadytsSingleDistanceIT.java | 4 +- .../marginals/TripEventHandlerTest.java | 4 +- .../AdvancedMarginalCongestionPricingIT.java | 47 +- .../CombinedFlowAndStorageDelayTest.java | 10 +- .../vsp/congestion/CorridorNetworkTest.java | 40 +- ...nalCongestionHandlerFlowQueueQsimTest.java | 28 +- ...tionHandlerFlowSpillbackQueueQsimTest.java | 66 +- .../MarginalCongestionHandlerV3Test.java | 9 +- .../MarginalCongestionPricingTest.java | 36 +- .../MultipleSpillbackCausingLinksTest.java | 14 +- .../vsp/congestion/TestForEmergenceTime.java | 6 +- .../ev/TransferFinalSocToNextIterTest.java | 10 +- .../java/playground/vsp/ev/UrbanEVIT.java | 8 +- .../java/playground/vsp/ev/UrbanEVTests.java | 142 ++-- ...rarchicalFLowEfficiencyCalculatorTest.java | 20 +- .../cemdap/input/SynPopCreatorTest.java | 40 +- .../PlanFileModifierTest.java | 50 +- .../vsp/pt/ptdisturbances/EditTripsTest.java | 154 ++--- .../TransitRouteTrimmerTest.java | 264 ++++---- ...nScoringParametersNoSubpopulationTest.java | 12 +- ...ityOfMoneyPersonScoringParametersTest.java | 12 +- .../SwissRailRaptorConfigGroupTest.java | 122 ++-- .../raptor/CapacityDependentScoringTest.java | 6 +- .../pt/raptor/OccupancyTrackerTest.java | 56 +- .../pt/raptor/RaptorStopFinderTest.java | 624 +++++++++--------- .../routing/pt/raptor/RaptorUtilsTest.java | 22 +- .../raptor/SwissRailRaptorCapacitiesTest.java | 26 +- .../pt/raptor/SwissRailRaptorDataTest.java | 20 +- .../SwissRailRaptorInVehicleCostTest.java | 14 +- .../raptor/SwissRailRaptorIntermodalTest.java | 500 +++++++------- .../pt/raptor/SwissRailRaptorModuleTest.java | 114 ++-- .../pt/raptor/SwissRailRaptorTest.java | 160 ++--- .../pt/raptor/SwissRailRaptorTreeTest.java | 108 +-- .../analysis/CalcAverageTripLengthTest.java | 18 +- .../org/matsim/analysis/CalcLegTimesTest.java | 4 +- .../matsim/analysis/CalcLinkStatsTest.java | 54 +- ...ationTravelStatsControlerListenerTest.java | 16 +- .../org/matsim/analysis/LegHistogramTest.java | 4 +- .../LinkStatsControlerListenerTest.java | 394 +++++------ ...deChoiceCoverageControlerListenerTest.java | 80 +-- .../ModeStatsControlerListenerTest.java | 32 +- .../analysis/PHbyModeCalculatorTest.java | 25 +- .../analysis/PKMbyModeCalculatorTest.java | 9 +- .../ScoreStatsControlerListenerTest.java | 22 +- ...ansportPlanningMainModeIdentifierTest.java | 8 +- .../analysis/TravelDistanceStatsTest.java | 12 +- .../analysis/TripsAndLegsCSVWriterTest.java | 108 +-- .../matsim/analysis/VolumesAnalyzerTest.java | 22 +- .../LinkPaxVolumesAnalysisTest.java | 58 +- .../PersonMoneyEventAggregatorTest.java | 18 +- .../pt/stop2stop/PtStop2StopAnalysisTest.java | 110 +-- .../org/matsim/api/core/v01/CoordTest.java | 28 +- .../api/core/v01/DemandGenerationTest.java | 2 +- .../api/core/v01/IdAnnotationsTest.java | 26 +- .../core/v01/IdDeSerializationModuleTest.java | 18 +- .../org/matsim/api/core/v01/IdMapTest.java | 380 +++++------ .../org/matsim/api/core/v01/IdSetTest.java | 196 +++--- .../java/org/matsim/api/core/v01/IdTest.java | 38 +- .../api/core/v01/NetworkCreationTest.java | 4 +- .../core/v01/network/AbstractNetworkTest.java | 74 +-- .../matsim/core/config/CommandLineTest.java | 14 +- .../core/config/ConfigReaderMatsimV2Test.java | 32 +- .../org/matsim/core/config/ConfigTest.java | 26 +- .../core/config/MaterializeConfigTest.java | 19 +- .../config/ReflectiveConfigGroupTest.java | 5 +- .../ConfigConsistencyCheckerImplTest.java | 28 +- .../groups/ControllerConfigGroupTest.java | 78 +-- .../config/groups/CountsConfigGroupTest.java | 30 +- .../groups/LinkStatsConfigGroupTest.java | 30 +- .../groups/ReplanningConfigGroupTest.java | 36 +- .../config/groups/RoutingConfigGroupTest.java | 74 +-- .../config/groups/ScoringConfigGroupTest.java | 252 +++---- .../SubtourModeChoiceConfigGroupTest.java | 61 +- .../core/controler/ControlerEventsTest.java | 8 +- .../matsim/core/controler/ControlerIT.java | 65 +- .../ControlerListenerManagerImplTest.java | 84 +-- .../ControlerMobsimIntegrationTest.java | 4 +- .../controler/MatsimServicesImplTest.java | 6 +- .../OutputDirectoryHierarchyTest.java | 40 +- .../controler/OverrideCarTraveltimeTest.java | 10 +- .../core/controler/PrepareForSimImplTest.java | 154 ++--- .../core/controler/TerminationTest.java | 42 +- .../TransitControlerIntegrationTest.java | 4 +- .../corelisteners/ListenersInjectionTest.java | 8 +- .../corelisteners/PlansDumpingIT.java | 4 +- .../matsim/core/events/ActEndEventTest.java | 2 +- .../matsim/core/events/ActStartEventTest.java | 2 +- .../core/events/AgentMoneyEventTest.java | 2 +- .../events/AgentWaitingForPtEventTest.java | 10 +- .../core/events/BasicEventsHandlerTest.java | 4 +- .../matsim/core/events/CustomEventTest.java | 18 +- .../events/EventsHandlerHierarchyTest.java | 2 +- .../core/events/EventsManagerImplTest.java | 10 +- .../matsim/core/events/EventsReadersTest.java | 24 +- .../matsim/core/events/GenericEventTest.java | 2 +- .../core/events/LinkEnterEventTest.java | 2 +- .../core/events/LinkLeaveEventTest.java | 2 +- .../events/ParallelEventsManagerTest.java | 4 +- .../core/events/PersonArrivalEventTest.java | 2 +- .../core/events/PersonDepartureEventTest.java | 2 +- .../events/PersonEntersVehicleEventTest.java | 6 +- .../events/PersonLeavesVehicleEventTest.java | 6 +- .../core/events/PersonStuckEventTest.java | 2 +- .../events/TransitDriverStartsEventTest.java | 14 +- .../core/events/VehicleAbortsEventTest.java | 2 +- ...VehicleArrivesAtFacilityEventImplTest.java | 2 +- ...VehicleDepartsAtFacilityEventImplTest.java | 2 +- .../events/VehicleEntersTrafficEventTest.java | 2 +- .../events/VehicleLeavesTrafficEventTest.java | 2 +- .../matsim/core/events/XmlEventsTester.java | 11 +- .../algorithms/EventWriterJsonTest.java | 18 +- .../events/algorithms/EventWriterXMLTest.java | 18 +- .../org/matsim/core/gbl/MatsimRandomTest.java | 6 +- .../matsim/core/gbl/MatsimResourceTest.java | 4 +- .../core/mobsim/AbstractMobsimModuleTest.java | 10 +- .../matsim/core/mobsim/hermes/AgentTest.java | 3 +- .../core/mobsim/hermes/FlowCapacityTest.java | 50 +- .../matsim/core/mobsim/hermes/HermesTest.java | 272 ++++---- .../core/mobsim/hermes/HermesTransitTest.java | 190 +++--- .../mobsim/hermes/StorageCapacityTest.java | 23 +- .../core/mobsim/hermes/TravelTimeTest.java | 50 +- .../mobsim/jdeqsim/AbstractJDEQSimTest.java | 6 +- .../mobsim/jdeqsim/ConfigParameterTest.java | 2 +- .../core/mobsim/jdeqsim/EmptyCarLegTest.java | 10 +- .../core/mobsim/jdeqsim/EquilPlans1Test.java | 6 +- .../core/mobsim/jdeqsim/NonCarLegTest.java | 8 +- .../mobsim/jdeqsim/TestDESStarter_Berlin.java | 8 +- ...tarter_EquilPopulationPlans1Modified1.java | 8 +- .../jdeqsim/TestDESStarter_equilPlans100.java | 8 +- .../core/mobsim/jdeqsim/TestEventLog.java | 4 +- .../mobsim/jdeqsim/TestMessageFactory.java | 4 +- .../core/mobsim/jdeqsim/TestMessageQueue.java | 4 +- .../core/mobsim/jdeqsim/TestScheduler.java | 10 +- .../mobsim/jdeqsim/util/TestEventLibrary.java | 6 +- .../mobsim/qsim/AbstractQSimModuleTest.java | 18 +- .../mobsim/qsim/FlowStorageSpillbackTest.java | 5 +- .../qsim/MobsimListenerManagerTest.java | 26 +- .../qsim/NetsimRoutingConsistencyTest.java | 12 +- .../core/mobsim/qsim/NodeTransitionTest.java | 128 ++-- .../org/matsim/core/mobsim/qsim/QSimTest.java | 420 ++++++------ .../mobsim/qsim/TransitQueueNetworkTest.java | 4 +- .../core/mobsim/qsim/TravelTimeTest.java | 50 +- .../core/mobsim/qsim/VehicleSourceTest.java | 11 +- .../NetworkChangeEventsEngineTest.java | 14 +- .../qsim/components/QSimComponentsTest.java | 22 +- .../guice/ExplicitBindingsRequiredTest.java | 7 +- .../guice/MultipleBindingsTest.java | 7 +- .../mobsim/qsim/pt/QSimIntegrationTest.java | 136 ++-- .../core/mobsim/qsim/pt/TransitAgentTest.java | 4 +- .../mobsim/qsim/pt/TransitDriverTest.java | 33 +- .../qsim/pt/TransitQueueSimulationTest.java | 4 +- .../qsim/pt/TransitStopAgentTrackerTest.java | 2 +- .../mobsim/qsim/pt/TransitVehicleTest.java | 2 +- .../core/mobsim/qsim/pt/UmlaufDriverTest.java | 33 +- .../DeparturesOnSameLinkSameTimeTest.java | 8 +- .../EquiDistAgentSnapshotInfoBuilderTest.java | 2 +- .../FlowCapacityVariationTest.java | 6 +- .../FlowEfficiencyCalculatorTest.java | 10 +- .../JavaRoundingErrorInQsimTest.java | 6 +- .../LinkSpeedCalculatorIntegrationTest.java | 44 +- .../qsim/qnetsimengine/PassingTest.java | 8 +- .../qsim/qnetsimengine/QLinkLanesTest.java | 4 +- .../mobsim/qsim/qnetsimengine/QLinkTest.java | 20 +- .../QueueAgentSnapshotInfoBuilderTest.java | 4 +- .../qsim/qnetsimengine/SeepageTest.java | 8 +- .../SimulatedLaneFlowCapacityTest.java | 4 +- .../qnetsimengine/SpeedCalculatorTest.java | 4 +- .../qnetsimengine/VehVsLinkSpeedTest.java | 6 +- .../qnetsimengine/VehicleHandlerTest.java | 19 +- .../qnetsimengine/VehicleWaitingTest.java | 14 +- .../AbstractNetworkWriterReaderTest.java | 40 +- .../core/network/DisallowedNextLinksTest.java | 44 +- .../network/DisallowedNextLinksUtilsTest.java | 10 +- .../org/matsim/core/network/LinkImplTest.java | 204 +++--- .../matsim/core/network/LinkQuadTreeTest.java | 44 +- .../NetworkChangeEventsParserWriterTest.java | 46 +- .../core/network/NetworkCollectorTest.java | 4 +- .../matsim/core/network/NetworkImplTest.java | 106 +-- .../matsim/core/network/NetworkUtilsTest.java | 12 +- .../matsim/core/network/NetworkV2IOTest.java | 42 +- .../core/network/TimeVariantLinkImplTest.java | 2 +- .../TravelTimeCalculatorIntegrationTest.java | 2 +- .../algorithms/CalcBoundingBoxTest.java | 18 +- .../MultimodalNetworkCleanerTest.java | 590 ++++++++--------- .../algorithms/NetworkCleanerTest.java | 34 +- .../algorithms/NetworkExpandNodeTest.java | 404 ++++++------ .../NetworkMergeDoubleLinksTest.java | 128 ++-- .../NetworkSimplifierPass2WayTest.java | 17 +- .../algorithms/NetworkSimplifierTest.java | 92 +-- .../TransportModeNetworkFilterTest.java | 358 +++++----- .../DensityClusterTest.java | 8 +- .../HullConverterTest.java | 16 +- .../IntersectionSimplifierTest.java | 128 ++-- .../containers/ConcaveHullTest.java | 8 +- .../filter/NetworkFilterManagerTest.java | 22 +- .../io/NetworkAttributeConversionTest.java | 10 +- .../network/io/NetworkReaderMatsimV1Test.java | 36 +- .../network/io/NetworkReprojectionIOTest.java | 70 +- .../core/population/PersonImplTest.java | 28 +- .../matsim/core/population/PlanImplTest.java | 56 +- .../core/population/PopulationUtilsTest.java | 28 +- .../io/CompressedRoutesIntegrationTest.java | 4 +- .../io/MatsimPopulationReaderTest.java | 88 +-- .../io/ParallelPopulationReaderTest.java | 6 +- .../io/PopulationAttributeConversionTest.java | 10 +- .../io/PopulationReaderMatsimV4Test.java | 76 +-- .../io/PopulationReaderMatsimV5Test.java | 102 +-- .../io/PopulationReprojectionIOIT.java | 88 +-- .../population/io/PopulationV6IOTest.java | 112 ++-- .../io/PopulationWriterHandlerImplV4Test.java | 2 +- .../io/PopulationWriterHandlerImplV5Test.java | 22 +- ...mingPopulationAttributeConversionTest.java | 8 +- .../routes/AbstractNetworkRouteTest.java | 174 ++--- .../routes/LinkNetworkRouteTest.java | 8 +- .../population/routes/NetworkFactoryTest.java | 12 +- .../routes/RouteFactoryImplTest.java | 11 +- .../routes/RouteFactoryIntegrationTest.java | 8 +- .../HeavyCompressedNetworkRouteTest.java | 40 +- .../MediumCompressedNetworkRouteTest.java | 40 +- .../core/replanning/PlanStrategyTest.java | 2 +- .../StrategyManagerSubpopulationsTest.java | 22 +- .../core/replanning/StrategyManagerTest.java | 63 +- .../annealing/ReplanningAnnealerTest.java | 44 +- .../ForceInnovationStrategyChooserTest.java | 2 +- .../ReplanningWithConflictsTest.java | 2 +- .../AbstractMultithreadedModuleTest.java | 6 +- .../replanning/modules/ChangeLegModeTest.java | 8 +- .../modules/ChangeSingleLegModeTest.java | 8 +- .../modules/ExternalModuleTest.java | 6 +- .../selectors/AbstractPlanSelectorTest.java | 4 +- .../selectors/BestPlanSelectorTest.java | 4 +- .../selectors/ExpBetaPlanSelectorTest.java | 2 +- .../selectors/KeepSelectedTest.java | 2 +- .../selectors/PathSizeLogitSelectorTest.java | 4 +- .../selectors/RandomPlanSelectorTest.java | 2 +- .../WorstPlanForRemovalSelectorTest.java | 36 +- ...eterministicMultithreadedReplanningIT.java | 19 +- .../strategies/InnovationSwitchOffTest.java | 10 +- .../TimeAllocationMutatorModuleTest.java | 38 +- .../AbstractLeastCostPathCalculatorTest.java | 12 +- .../router/InvertertedNetworkRoutingTest.java | 44 +- .../router/MultimodalLinkChooserTest.java | 8 +- ...workRoutingInclAccessEgressModuleTest.java | 3 +- .../core/router/NetworkRoutingModuleTest.java | 24 +- ...rsonalizableDisutilityIntegrationTest.java | 12 +- .../PseudoTransitRoutingModuleTest.java | 18 +- .../org/matsim/core/router/RoutingIT.java | 4 +- .../TeleportationRoutingModuleTest.java | 20 +- .../router/TestActivityWrapperFacility.java | 14 +- .../router/TripRouterFactoryImplTest.java | 27 +- .../core/router/TripRouterModuleTest.java | 4 +- .../matsim/core/router/TripRouterTest.java | 24 +- .../TripStructureUtilsSubtoursTest.java | 38 +- .../core/router/TripStructureUtilsTest.java | 41 +- ...izingTimeDistanceTravelDisutilityTest.java | 8 +- .../core/router/old/PlanRouterTest.java | 10 +- .../priorityqueue/BinaryMinHeapTest.java | 190 +++--- .../core/router/speedy/DAryMinHeapTest.java | 42 +- .../core/router/speedy/SpeedyGraphTest.java | 100 +-- .../ScenarioByConfigInjectionTest.java | 46 +- .../core/scenario/ScenarioImplTest.java | 36 +- .../core/scenario/ScenarioLoaderImplTest.java | 30 +- .../core/scenario/ScenarioUtilsTest.java | 6 +- .../core/scoring/EventsToActivitiesTest.java | 36 +- .../matsim/core/scoring/EventsToLegsTest.java | 34 +- .../core/scoring/EventsToScoreTest.java | 28 +- ...ScoringFunctionsForPopulationStressIT.java | 2 +- .../ScoringFunctionsForPopulationTest.java | 44 +- ...yparNagelLegScoringDailyConstantsTest.java | 14 +- .../CharyparNagelLegScoringPtChangeTest.java | 8 +- ...yparNagelOpenTimesScoringFunctionTest.java | 2 +- .../CharyparNagelScoringFunctionTest.java | 4 +- .../CharyparNagelWithSubpopulationsTest.java | 14 +- .../LinkToLinkTravelTimeCalculatorTest.java | 2 +- .../TravelTimeCalculatorTest.java | 24 +- .../core/utils/charts/BarChartTest.java | 4 +- .../core/utils/charts/LineChartTest.java | 4 +- .../core/utils/charts/XYLineChartTest.java | 4 +- .../core/utils/charts/XYScatterChartTest.java | 4 +- .../core/utils/collections/ArrayMapTest.java | 376 +++++------ .../collections/CollectionUtilsTest.java | 34 +- .../collections/IdentifiableArrayMapTest.java | 248 +++---- .../utils/collections/IntArrayMapTest.java | 340 +++++----- .../PseudoRemovePriorityQueueTest.java | 2 +- .../core/utils/collections/QuadTreeTest.java | 60 +- .../core/utils/collections/TupleTest.java | 2 +- .../core/utils/geometry/CoordImplTest.java | 4 +- .../core/utils/geometry/CoordUtilsTest.java | 20 +- .../utils/geometry/GeometryUtilsTest.java | 10 +- .../core/utils/geometry/geotools/MGCTest.java | 29 +- .../CH1903LV03PlustoWGS84Test.java | 6 +- .../CH1903LV03PlustofromCH1903LV03Test.java | 10 +- .../CH1903LV03toWGS84Test.java | 6 +- .../GeotoolsTransformationTest.java | 5 +- .../TransformationFactoryTest.java | 2 +- .../WGS84toCH1903LV03PlusTest.java | 6 +- .../WGS84toCH1903LV03Test.java | 6 +- .../core/utils/gis/ShapeFileReaderTest.java | 4 +- .../core/utils/gis/ShapeFileWriterTest.java | 12 +- .../org/matsim/core/utils/io/IOUtilsTest.java | 120 ++-- .../utils/io/MatsimFileTypeGuesserTest.java | 5 +- .../core/utils/io/MatsimXmlParserTest.java | 122 ++-- .../core/utils/io/MatsimXmlWriterTest.java | 2 +- .../core/utils/io/OsmNetworkReaderTest.java | 72 +- .../matsim/core/utils/io/XmlUtilsTest.java | 30 +- .../core/utils/misc/ArgumentParserTest.java | 4 +- .../core/utils/misc/ByteBufferUtilsTest.java | 4 +- .../core/utils/misc/ClassUtilsTest.java | 106 +-- .../core/utils/misc/ConfigUtilsTest.java | 25 +- .../core/utils/misc/NetworkUtilsTest.java | 30 +- .../core/utils/misc/PopulationUtilsTest.java | 18 +- .../core/utils/misc/RouteUtilsTest.java | 122 ++-- .../core/utils/misc/StringUtilsTest.java | 10 +- .../org/matsim/core/utils/misc/TimeTest.java | 4 +- .../utils/timing/TimeInterpretationTest.java | 4 +- .../java/org/matsim/counts/CountTest.java | 12 +- .../counts/CountsComparisonAlgorithmTest.java | 8 +- .../counts/CountsControlerListenerTest.java | 352 +++++----- .../matsim/counts/CountsErrorGraphTest.java | 4 +- .../counts/CountsHtmlAndGraphsWriterTest.java | 2 +- .../counts/CountsLoadCurveGraphTest.java | 4 +- .../org/matsim/counts/CountsParserTest.java | 20 +- .../matsim/counts/CountsParserWriterTest.java | 20 +- .../counts/CountsReaderHandlerImplV1Test.java | 12 +- .../counts/CountsReprojectionIOTest.java | 46 +- .../counts/CountsSimRealPerHourGraphTest.java | 4 +- .../matsim/counts/CountsTableWriterTest.java | 4 +- .../java/org/matsim/counts/CountsTest.java | 4 +- .../java/org/matsim/counts/CountsV2Test.java | 6 +- .../org/matsim/counts/MatsimCountsIOTest.java | 8 +- .../org/matsim/counts/OutputDelegateTest.java | 10 +- .../java/org/matsim/examples/EquilTest.java | 4 +- .../examples/OnePercentBerlin10sIT.java | 12 +- .../org/matsim/examples/PtTutorialIT.java | 24 +- .../matsim/examples/simple/PtScoringTest.java | 18 +- .../ActivityFacilitiesFactoryImplTest.java | 12 +- .../ActivityFacilitiesImplTest.java | 30 +- .../ActivityFacilitiesSourceTest.java | 20 +- .../ActivityWithOnlyFacilityIdTest.java | 6 +- .../FacilitiesAttributeConvertionTest.java | 10 +- .../FacilitiesFromPopulationTest.java | 62 +- .../FacilitiesParserWriterTest.java | 58 +- .../FacilitiesReprojectionIOTest.java | 64 +- .../facilities/FacilitiesWriterTest.java | 36 +- .../MatsimFacilitiesReaderTest.java | 24 +- .../StreamingActivityFacilitiesTest.java | 26 +- .../AbstractFacilityAlgorithmTest.java | 4 +- .../HouseholdAttributeConversionTest.java | 10 +- .../matsim/households/HouseholdImplTest.java | 18 +- .../matsim/households/HouseholdsIoTest.java | 4 +- .../integration/EquilTwoAgentsTest.java | 2 +- .../integration/SimulateAndScoreTest.java | 6 +- .../PersonMoneyEventIntegrationTest.java | 4 +- .../events/PersonScoreEventTest.java | 4 +- ...iverStartsEventHandlerIntegrationTest.java | 8 +- .../InvertedNetworkRoutingIT.java | 8 +- .../integration/invertednetworks/LanesIT.java | 14 +- .../NonAlternatingPlanElementsIT.java | 6 +- .../ChangeTripModeIntegrationTest.java | 8 +- .../integration/replanning/ReRoutingIT.java | 4 +- .../replanning/ResumableRunsIT.java | 8 +- .../QSimIntegrationTest.java | 24 +- .../lanes/data/LanesReaderWriterTest.java | 4 +- .../matsim/modules/ScoreStatsModuleTest.java | 35 +- .../matsim/other/DownloadAndReadXmlTest.java | 10 +- ...ndomLegModeForSubtourComplexTripsTest.java | 32 +- ...eRandomLegModeForSubtourDiffModesTest.java | 38 +- .../ChooseRandomLegModeForSubtourTest.java | 54 +- .../algorithms/ChooseRandomLegModeTest.java | 42 +- .../ChooseRandomSingleLegModeTest.java | 37 +- .../ParallelPersonAlgorithmRunnerTest.java | 12 +- .../PermissibleModesCalculatorImplTest.java | 12 +- .../algorithms/PersonPrepareForSimTest.java | 81 +-- .../algorithms/TripsToLegsAlgorithmTest.java | 24 +- .../analysis/TransitLoadIntegrationTest.java | 4 +- .../matsim/pt/analysis/TransitLoadTest.java | 62 +- .../pt/config/TransitConfigGroupTest.java | 2 +- .../pt/router/TransitActsRemoverTest.java | 4 +- .../pt/router/TransitRouterConfigTest.java | 38 +- .../pt/router/TransitRouterModuleTest.java | 4 +- .../DefaultTransitPassengerRouteTest.java | 2 +- .../routes/ExperimentalTransitRouteTest.java | 2 +- .../pt/transitSchedule/DepartureTest.java | 4 +- .../MinimalTransferTimesImplTest.java | 108 +-- .../pt/transitSchedule/TransitLineTest.java | 4 +- .../transitSchedule/TransitRouteStopTest.java | 2 +- .../pt/transitSchedule/TransitRouteTest.java | 6 +- .../TransitScheduleFactoryTest.java | 42 +- .../TransitScheduleFormatV1Test.java | 56 +- .../TransitScheduleIOTest.java | 48 +- .../TransitScheduleReaderTest.java | 30 +- .../TransitScheduleReaderV1Test.java | 2 +- .../TransitScheduleReprojectionIOTest.java | 46 +- .../transitSchedule/TransitScheduleTest.java | 18 +- .../TransitScheduleWriterTest.java | 8 +- .../TransitStopFacilityTest.java | 2 +- .../utils/TransitScheduleValidatorTest.java | 14 +- .../org/matsim/run/CreateFullConfigTest.java | 6 +- .../java/org/matsim/run/InitRoutesTest.java | 16 +- .../java/org/matsim/run/XY2LinksTest.java | 14 +- .../testcases/utils/LogCounterTest.java | 18 +- .../EventsFileComparatorTest.java | 22 +- .../matsim/utils/geometry/CoordUtilsTest.java | 20 +- .../LanesBasedWidthCalculatorTest.java | 8 +- .../network/Network2ESRIShapeTest.java | 12 +- .../plans/SelectedPlans2ESRIShapeTest.java | 6 +- .../ObjectAttributesConverterTest.java | 12 +- .../ObjectAttributesTest.java | 12 +- .../ObjectAttributesUtilsTest.java | 18 +- .../ObjectAttributesXmlIOTest.java | 20 +- .../ObjectAttributesXmlReaderTest.java | 50 +- .../attributable/AttributesTest.java | 73 +- .../attributable/AttributesUtilsTest.java | 2 +- .../CoordArrayConverterTest.java | 36 +- .../CoordConverterTest.java | 10 +- .../DoubleArrayConverterTest.java | 18 +- .../EnumConverterTest.java | 12 +- .../StringCollectionConverterTest.java | 4 +- .../StringStringMapConverterTest.java | 2 +- .../vehicles/MatsimVehicleWriterTest.java | 2 +- .../matsim/vehicles/VehicleReaderV1Test.java | 2 +- .../matsim/vehicles/VehicleReaderV2Test.java | 2 +- .../matsim/vehicles/VehicleWriterV1Test.java | 2 +- .../matsim/vehicles/VehicleWriterV2Test.java | 2 +- .../org/matsim/vehicles/VehiclesImplTest.java | 20 +- .../vis/snapshotwriters/PositionInfoTest.java | 2 +- .../ExperiencedPlansWriterTest.java | 8 +- .../tools/ActivityReplanningMapTest.java | 4 +- .../tools/LinkReplanningMapTest.java | 2 +- .../trafficmonitoring/TtmobsimListener.java | 17 +- .../WithinDayTravelTimeTest.java | 2 +- ...TravelTimeWithNetworkChangeEventsTest.java | 6 +- .../withinday/utils/EditRoutesTest.java | 2 +- .../utils/ReplacePlanElementsTest.java | 2 +- 766 files changed, 13121 insertions(+), 13227 deletions(-) diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/LeastCostPathTreeTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/LeastCostPathTreeTest.java index 0de803d1434..23d32279ec6 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/LeastCostPathTreeTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/LeastCostPathTreeTest.java @@ -5,7 +5,7 @@ import java.util.List; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -55,11 +55,11 @@ private void compareRouteChoices(){ printResults(arrivalTime, travelTime); // travel time = cost = (50s+50s) = 100s // check route (visited nodes should be 1,2,4) List> spTimeVisitedNodes = getVisitedNodes(lcptTime, destination, "Travel Time"); - Assert.assertTrue( containsNode(spTimeVisitedNodes, Id.create("2", Node.class))); + Assertions.assertTrue( containsNode(spTimeVisitedNodes, Id.create("2", Node.class))); // check travel duration - Assert.assertTrue( travelTime == 100 ); + Assertions.assertTrue( travelTime == 100 ); // check travel time - Assert.assertTrue( arrivalTime - departureTime == 100 ); + Assertions.assertTrue( arrivalTime - departureTime == 100 ); lcptDistance.calculate(this.scenario.getNetwork(), origin, departureTime); double arrivalTimeTD = lcptDistance.getTree().get( destination.getId() ).getTime(); @@ -67,11 +67,11 @@ private void compareRouteChoices(){ printResults(arrivalTimeTD, travelDistance); // travel time = 1000s, cost = (50m+50m) = 100m // check route ( visited nodes should be 1,3,4) List> spDistenceVisitedNodes = getVisitedNodes(lcptDistance, destination, "Travel Distance"); - Assert.assertTrue( containsNode(spDistenceVisitedNodes, Id.create("3", Node.class))); + Assertions.assertTrue( containsNode(spDistenceVisitedNodes, Id.create("3", Node.class))); // check travel distance - Assert.assertTrue( travelDistance == 100 ); + Assertions.assertTrue( travelDistance == 100 ); // check travel time - Assert.assertTrue( arrivalTimeTD - departureTime == 1000 ); + Assertions.assertTrue( arrivalTimeTD - departureTime == 1000 ); } private void printResults(double tt, double tc){ diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java index 0a43df9c1b6..74bae0a5363 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/grid/SpatialGridTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.accessibility.grid; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.network.Network; @@ -32,11 +32,11 @@ void testSpatialGrid() { // get number of rows int rows = testGrid.getNumRows(); double numOfExpectedRows = ((nbb.getYMax() - nbb.getYMin()) / cellSize) + 1; - Assert.assertTrue(rows == numOfExpectedRows); + Assertions.assertTrue(rows == numOfExpectedRows); // get number of columns int cols = testGrid.getNumCols(0); double numOfExpectedCols = ((nbb.getXMax() - nbb.getXMin()) / cellSize) + 1; - Assert.assertTrue(cols == numOfExpectedCols); + Assertions.assertTrue(cols == numOfExpectedCols); } } diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java index 8d4c324a49a..f7e6672c053 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulas2Test.java @@ -22,7 +22,7 @@ */ package org.matsim.contrib.accessibility.logsumComputations; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -66,7 +66,7 @@ void testLogsumFormulas(){ double Sum2 =PreFactor * AggregationSum; System.out.println(Sum2); - Assert.assertTrue( Sum1 == Sum2 ); + Assertions.assertTrue( Sum1 == Sum2 ); } } diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java index 95517505f79..19501ebb49f 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/CompareLogsumFormulasTest.java @@ -22,7 +22,7 @@ */ package org.matsim.contrib.accessibility.logsumComputations; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -73,7 +73,7 @@ void testLogsumFormulas(){ double Ai = computeLogsum(betaWalkTT, betaWalkTD, cik1TT, cik2TT, cik3TT, cik1TD, cik2TD, cik3TD); double Ai2 =computeTransformedLogsum(betaWalkTT, betaWalkTD, cijTT, cjk1TT, cjk2TT, cjk3TT, cijTD, cjk1TD, cjk2TD, cjk3TD); - Assert.assertTrue( Ai == Ai2 ); + Assertions.assertTrue( Ai == Ai2 ); } /** diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java index a746fd57137..1b35497b3c7 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/logsumComputations/ComputeLogsumFormulas3Test.java @@ -22,7 +22,7 @@ */ package org.matsim.contrib.accessibility.logsumComputations; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -101,7 +101,7 @@ void testLogsumFormulas(){ // double expNewVhj= Math.exp( VhjNew ); // double expNewVhk= expNewVhj * sumExpVjk; - Assert.assertTrue(VhjOld == VhjNew); // old accessibility computation == new accessibility computation + Assertions.assertTrue(VhjOld == VhjNew); // old accessibility computation == new accessibility computation /////// // NEW @@ -113,7 +113,7 @@ void testLogsumFormulas(){ double dummyExp1 = Math.exp( dummyVijCar + dummyVhiWalk ); double dummyExp2 = Math.exp( dummyVijCar ) * Math.exp( dummyVhiWalk ); - Assert.assertEquals(dummyExp1,dummyExp2,1.e-10); // exp(VijCar + VijWalk) == exp(VijCar) * exp(VijWalk) + Assertions.assertEquals(dummyExp1,dummyExp2,1.e-10); // exp(VijCar + VijWalk) == exp(VijCar) * exp(VijWalk) } } diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java index 0b3aa1ebf8c..e859cf969bb 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.locationtech.jts.geom.Envelope; @@ -101,15 +101,15 @@ public void startRow(String[] row) { if (x == 50) { if (y == 50) { - Assert.assertEquals("Wrong work accessibility value at x=" + x + ", y=" + y + ":", 2.1486094237531126, value, utils.EPSILON); + Assertions.assertEquals(2.1486094237531126, value, utils.EPSILON, "Wrong work accessibility value at x=" + x + ", y=" + y + ":"); } else if (y == 150){ - Assert.assertEquals("Wrong work accessibility value at x=" + x + ", y=" + y + ":", 2.1766435716006005, value, utils.EPSILON); + Assertions.assertEquals(2.1766435716006005, value, utils.EPSILON, "Wrong work accessibility value at x=" + x + ", y=" + y + ":"); } } else if (x == 150) { if (y == 50) { - Assert.assertEquals("Wrong work accessibility value at x=" + x + ", y=" + y + ":", 2.1486094237531126, value, utils.EPSILON); + Assertions.assertEquals(2.1486094237531126, value, utils.EPSILON, "Wrong work accessibility value at x=" + x + ", y=" + y + ":"); } else if (y == 150){ - Assert.assertEquals("Wrong work accessibility value at x=" + x + ", y=" + y + ":", 2.2055702759681273, value, utils.EPSILON); + Assertions.assertEquals(2.2055702759681273, value, utils.EPSILON, "Wrong work accessibility value at x=" + x + ", y=" + y + ":"); } } } @@ -271,7 +271,7 @@ void testWithExtentDeterminedShapeFile() { if(!f.exists()){ LOG.error("Shape file not found! testWithExtentDeterminedShapeFile could not be tested..."); - Assert.assertTrue(f.exists()); + Assertions.assertTrue(f.exists()); } final AccessibilityConfigGroup acg = ConfigUtils.addOrGetModule(config, AccessibilityConfigGroup.class); @@ -311,7 +311,7 @@ void testWithPredefinedMeasuringPoints() { if(!f.exists()){ LOG.error("Facilities file with measuring points not found! testWithMeasuringPointsInFacilitiesFile could not be performed..."); - Assert.assertTrue(f.exists()); + Assertions.assertTrue(f.exists()); } Scenario measuringPointsSc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -359,7 +359,7 @@ void testWithFile(){ File f = new File(this.utils.getInputDirectory() + "pointFile.csv"); if(!f.exists()){ LOG.error("Point file not found! testWithFile could not be tested..."); - Assert.assertTrue(f.exists()); + Assertions.assertTrue(f.exists()); } final AccessibilityConfigGroup acg = ConfigUtils.addOrGetModule(config, AccessibilityConfigGroup.class); @@ -598,12 +598,12 @@ public void finish() { for (String mode : accessibilitiesMap.get(tuple).keySet()) { double value = accessibilitiesMap.get(tuple).get(mode); switch (mode) { // commented values are before (a) Marcel's change of the QuadTree in Oct'18, (b) change in TravelTimeCalculator in Apr'21 - case "freespeed": Assert.assertEquals(2.207441799716032, value, MatsimTestUtils.EPSILON); break; // (a) 2.1486094237531126 - case TransportMode.car: Assert.assertEquals(2.2058369602991204, value, MatsimTestUtils.EPSILON); break; // (a) 2.1482840466191093 (b) 2.205836861444427 - case TransportMode.bike: Assert.assertEquals(2.2645288908389554, value, MatsimTestUtils.EPSILON); break; // (a) 2.2257398663221 - case TransportMode.walk: Assert.assertEquals(1.8697283849051263, value, MatsimTestUtils.EPSILON); break; // (a) 1.70054725728361 - case TransportMode.pt: Assert.assertEquals(2.1581641260040683, value, MatsimTestUtils.EPSILON); break; - case "matrixBasedPt": Assert.assertEquals(1.6542905235735796, value, MatsimTestUtils.EPSILON); break; // (a) 0.461863556339195 + case "freespeed": Assertions.assertEquals(2.207441799716032, value, MatsimTestUtils.EPSILON); break; // (a) 2.1486094237531126 + case TransportMode.car: Assertions.assertEquals(2.2058369602991204, value, MatsimTestUtils.EPSILON); break; // (a) 2.1482840466191093 (b) 2.205836861444427 + case TransportMode.bike: Assertions.assertEquals(2.2645288908389554, value, MatsimTestUtils.EPSILON); break; // (a) 2.2257398663221 + case TransportMode.walk: Assertions.assertEquals(1.8697283849051263, value, MatsimTestUtils.EPSILON); break; // (a) 1.70054725728361 + case TransportMode.pt: Assertions.assertEquals(2.1581641260040683, value, MatsimTestUtils.EPSILON); break; + case "matrixBasedPt": Assertions.assertEquals(1.6542905235735796, value, MatsimTestUtils.EPSILON); break; // (a) 0.461863556339195 } } } @@ -611,12 +611,12 @@ else if (tuple.getFirst().getCoord().getY() == 150.) { for (String mode : accessibilitiesMap.get(tuple).keySet()) { double value = accessibilitiesMap.get(tuple).get(mode); switch (mode) { - case "freespeed": Assert.assertEquals(2.207441799716032, value, MatsimTestUtils.EPSILON); break; // (a) 2.1766435716006005 - case TransportMode.car: Assert.assertEquals(2.207441960299121, value, MatsimTestUtils.EPSILON); break; // (a) 2.176238564675181 (b) 2.207441799716032 - case TransportMode.bike: Assert.assertEquals(2.2645288908389554, value, MatsimTestUtils.EPSILON); break; // (a) 2.2445468698643367 - case TransportMode.walk: Assert.assertEquals(1.8697283849051263, value, MatsimTestUtils.EPSILON); break; // (a) 1.7719146868026079 - case TransportMode.pt: Assert.assertEquals(2.1581641260040683, value, MatsimTestUtils.EPSILON); break; // (a) 2.057596373646452 - case "matrixBasedPt": Assert.assertEquals(1.6542905235735796, value, MatsimTestUtils.EPSILON); break; // (a) 0.461863556339195 + case "freespeed": Assertions.assertEquals(2.207441799716032, value, MatsimTestUtils.EPSILON); break; // (a) 2.1766435716006005 + case TransportMode.car: Assertions.assertEquals(2.207441960299121, value, MatsimTestUtils.EPSILON); break; // (a) 2.176238564675181 (b) 2.207441799716032 + case TransportMode.bike: Assertions.assertEquals(2.2645288908389554, value, MatsimTestUtils.EPSILON); break; // (a) 2.2445468698643367 + case TransportMode.walk: Assertions.assertEquals(1.8697283849051263, value, MatsimTestUtils.EPSILON); break; // (a) 1.7719146868026079 + case TransportMode.pt: Assertions.assertEquals(2.1581641260040683, value, MatsimTestUtils.EPSILON); break; // (a) 2.057596373646452 + case "matrixBasedPt": Assertions.assertEquals(1.6542905235735796, value, MatsimTestUtils.EPSILON); break; // (a) 0.461863556339195 } } } @@ -626,12 +626,12 @@ else if (tuple.getFirst().getCoord().getY() == 150.) { for (String mode : accessibilitiesMap.get(tuple).keySet()) { double value = accessibilitiesMap.get(tuple).get(mode); switch (mode) { - case "freespeed": Assert.assertEquals(2.235503385314382, value, MatsimTestUtils.EPSILON); break; // (a) 2.1486094237531126 - case TransportMode.car: Assert.assertEquals(2.23550352057971, value, MatsimTestUtils.EPSILON); break; // (a) 2.1482840466191093 (b) 2.235503385314382 - case TransportMode.bike: Assert.assertEquals(2.2833435568892395, value, MatsimTestUtils.EPSILON); break; // (a) 2.2257398663221 - case TransportMode.walk: Assert.assertEquals(1.9418539664691532, value, MatsimTestUtils.EPSILON); break; // (a) 1.70054725728361 - case TransportMode.pt: Assert.assertEquals(2.0032465393091434, value, MatsimTestUtils.EPSILON); break; - case "matrixBasedPt": Assert.assertEquals(1.6542905235735796, value, MatsimTestUtils.EPSILON); break; // (a) 0.461863556339195 + case "freespeed": Assertions.assertEquals(2.235503385314382, value, MatsimTestUtils.EPSILON); break; // (a) 2.1486094237531126 + case TransportMode.car: Assertions.assertEquals(2.23550352057971, value, MatsimTestUtils.EPSILON); break; // (a) 2.1482840466191093 (b) 2.235503385314382 + case TransportMode.bike: Assertions.assertEquals(2.2833435568892395, value, MatsimTestUtils.EPSILON); break; // (a) 2.2257398663221 + case TransportMode.walk: Assertions.assertEquals(1.9418539664691532, value, MatsimTestUtils.EPSILON); break; // (a) 1.70054725728361 + case TransportMode.pt: Assertions.assertEquals(2.0032465393091434, value, MatsimTestUtils.EPSILON); break; + case "matrixBasedPt": Assertions.assertEquals(1.6542905235735796, value, MatsimTestUtils.EPSILON); break; // (a) 0.461863556339195 } } } @@ -639,12 +639,12 @@ else if (tuple.getFirst().getCoord().getY() == 150.) { for (String mode : accessibilitiesMap.get(tuple).keySet()) { double value = accessibilitiesMap.get(tuple).get(mode); switch (mode) { - case "freespeed": Assert.assertEquals(2.235503385314382, value, MatsimTestUtils.EPSILON); break; // (a) 2.2055702759681273 - case TransportMode.car: Assert.assertEquals(2.23550352057971, value, MatsimTestUtils.EPSILON); break; // (a) 2.2052225231109226 (b) 2.235503385314382 - case TransportMode.bike: Assert.assertEquals(2.2833435568892395, value, MatsimTestUtils.EPSILON); break; // (a) 2.2637376515333636 - case TransportMode.walk: Assert.assertEquals(1.9418539664691532, value, MatsimTestUtils.EPSILON); break; // (a) 1.851165291193725 - case TransportMode.pt: Assert.assertEquals(2.0032465393091434, value, MatsimTestUtils.EPSILON); break; // (a) 1.9202710265495115 - case "matrixBasedPt": Assert.assertEquals(1.5073890466447624, value, MatsimTestUtils.EPSILON); break; // (a) 0.624928280738513 + case "freespeed": Assertions.assertEquals(2.235503385314382, value, MatsimTestUtils.EPSILON); break; // (a) 2.2055702759681273 + case TransportMode.car: Assertions.assertEquals(2.23550352057971, value, MatsimTestUtils.EPSILON); break; // (a) 2.2052225231109226 (b) 2.235503385314382 + case TransportMode.bike: Assertions.assertEquals(2.2833435568892395, value, MatsimTestUtils.EPSILON); break; // (a) 2.2637376515333636 + case TransportMode.walk: Assertions.assertEquals(1.9418539664691532, value, MatsimTestUtils.EPSILON); break; // (a) 1.851165291193725 + case TransportMode.pt: Assertions.assertEquals(2.0032465393091434, value, MatsimTestUtils.EPSILON); break; // (a) 1.9202710265495115 + case "matrixBasedPt": Assertions.assertEquals(1.5073890466447624, value, MatsimTestUtils.EPSILON); break; // (a) 0.624928280738513 } } } @@ -656,12 +656,12 @@ else if (tuple.getFirst().getCoord().getY() == 150.) { for (String mode : accessibilitiesMap.get(tuple).keySet()) { double value = accessibilitiesMap.get(tuple).get(mode); switch (mode) { - case "freespeed": Assert.assertEquals(3.5937361608359226, value, MatsimTestUtils.EPSILON); break; // (a) 3.534903784873003 - case TransportMode.car: Assert.assertEquals(3.592131321419011, value, MatsimTestUtils.EPSILON); break; // (a) 3.534578407739 (b) 3.592131222564318 - case TransportMode.bike: Assert.assertEquals(3.650823251958846, value, MatsimTestUtils.EPSILON); break; // (a) 3.6120342274419914 - case TransportMode.walk: Assert.assertEquals(3.256022746025017, value, MatsimTestUtils.EPSILON); break; // (a) 3.086841618403501 - case TransportMode.pt: Assert.assertEquals(3.5444584871239586, value, MatsimTestUtils.EPSILON); break; - case "matrixBasedPt": Assert.assertEquals(3.0405848846934704, value, MatsimTestUtils.EPSILON); break; // (a) 1.8481579174590859 + case "freespeed": Assertions.assertEquals(3.5937361608359226, value, MatsimTestUtils.EPSILON); break; // (a) 3.534903784873003 + case TransportMode.car: Assertions.assertEquals(3.592131321419011, value, MatsimTestUtils.EPSILON); break; // (a) 3.534578407739 (b) 3.592131222564318 + case TransportMode.bike: Assertions.assertEquals(3.650823251958846, value, MatsimTestUtils.EPSILON); break; // (a) 3.6120342274419914 + case TransportMode.walk: Assertions.assertEquals(3.256022746025017, value, MatsimTestUtils.EPSILON); break; // (a) 3.086841618403501 + case TransportMode.pt: Assertions.assertEquals(3.5444584871239586, value, MatsimTestUtils.EPSILON); break; + case "matrixBasedPt": Assertions.assertEquals(3.0405848846934704, value, MatsimTestUtils.EPSILON); break; // (a) 1.8481579174590859 } } } @@ -669,12 +669,12 @@ else if (tuple.getFirst().getCoord().getY() == 150.) { for (String mode : accessibilitiesMap.get(tuple).keySet()) { double value = accessibilitiesMap.get(tuple).get(mode); switch (mode) { - case "freespeed": Assert.assertEquals(3.5937361608359226, value, MatsimTestUtils.EPSILON); break; // (a) 3.562937932720491 - case TransportMode.car: Assert.assertEquals(3.5937363214190112, value, MatsimTestUtils.EPSILON); break; // (a) 3.5625329257950717 (b) 3.5937361608359226 - case TransportMode.bike: Assert.assertEquals(3.650823251958846, value, MatsimTestUtils.EPSILON); break; // (a) 3.6308412309842275 - case TransportMode.walk: Assert.assertEquals(3.256022746025017, value, MatsimTestUtils.EPSILON); break; // (a) 3.1582090479224982 - case TransportMode.pt: Assert.assertEquals(3.5444584871239586, value, MatsimTestUtils.EPSILON); break; // (a) 3.443890734766343 - case "matrixBasedPt": Assert.assertEquals(3.0405848846934704, value, MatsimTestUtils.EPSILON); break; // (a) 1.8481579174590859 + case "freespeed": Assertions.assertEquals(3.5937361608359226, value, MatsimTestUtils.EPSILON); break; // (a) 3.562937932720491 + case TransportMode.car: Assertions.assertEquals(3.5937363214190112, value, MatsimTestUtils.EPSILON); break; // (a) 3.5625329257950717 (b) 3.5937361608359226 + case TransportMode.bike: Assertions.assertEquals(3.650823251958846, value, MatsimTestUtils.EPSILON); break; // (a) 3.6308412309842275 + case TransportMode.walk: Assertions.assertEquals(3.256022746025017, value, MatsimTestUtils.EPSILON); break; // (a) 3.1582090479224982 + case TransportMode.pt: Assertions.assertEquals(3.5444584871239586, value, MatsimTestUtils.EPSILON); break; // (a) 3.443890734766343 + case "matrixBasedPt": Assertions.assertEquals(3.0405848846934704, value, MatsimTestUtils.EPSILON); break; // (a) 1.8481579174590859 } } } @@ -684,12 +684,12 @@ else if (tuple.getFirst().getCoord().getY() == 150.) { for (String mode : accessibilitiesMap.get(tuple).keySet()) { double value = accessibilitiesMap.get(tuple).get(mode); switch (mode) { - case "freespeed": Assert.assertEquals(3.621797746434273, value, MatsimTestUtils.EPSILON); break; // (a) 3.534903784873003 - case TransportMode.car: Assert.assertEquals(3.621797881699601, value, MatsimTestUtils.EPSILON); break; // (a) 3.534578407739 (b) 3.621797746434273 - case TransportMode.bike: Assert.assertEquals(3.66963791800913, value, MatsimTestUtils.EPSILON); break; // (a) 3.6120342274419914 - case TransportMode.walk: Assert.assertEquals(3.328148327589044, value, MatsimTestUtils.EPSILON); break; // (a) 3.086841618403501 - case TransportMode.pt: Assert.assertEquals(3.389540900429034, value, MatsimTestUtils.EPSILON); break; - case "matrixBasedPt": Assert.assertEquals(3.0405848846934704, value, MatsimTestUtils.EPSILON); break; // (a) 1.8481579174590859 + case "freespeed": Assertions.assertEquals(3.621797746434273, value, MatsimTestUtils.EPSILON); break; // (a) 3.534903784873003 + case TransportMode.car: Assertions.assertEquals(3.621797881699601, value, MatsimTestUtils.EPSILON); break; // (a) 3.534578407739 (b) 3.621797746434273 + case TransportMode.bike: Assertions.assertEquals(3.66963791800913, value, MatsimTestUtils.EPSILON); break; // (a) 3.6120342274419914 + case TransportMode.walk: Assertions.assertEquals(3.328148327589044, value, MatsimTestUtils.EPSILON); break; // (a) 3.086841618403501 + case TransportMode.pt: Assertions.assertEquals(3.389540900429034, value, MatsimTestUtils.EPSILON); break; + case "matrixBasedPt": Assertions.assertEquals(3.0405848846934704, value, MatsimTestUtils.EPSILON); break; // (a) 1.8481579174590859 } } } @@ -697,12 +697,12 @@ else if (tuple.getFirst().getCoord().getY() == 150.) { for (String mode : accessibilitiesMap.get(tuple).keySet()) { double value = accessibilitiesMap.get(tuple).get(mode); switch (mode) { - case "freespeed": Assert.assertEquals(3.621797746434273, value, MatsimTestUtils.EPSILON); break; // (a) 3.5918646370880176 - case TransportMode.car: Assert.assertEquals(3.621797881699601, value, MatsimTestUtils.EPSILON); break; // (a) 3.591516884230813 (b) 3.621797746434273 - case TransportMode.bike: Assert.assertEquals(3.66963791800913, value, MatsimTestUtils.EPSILON); break; // (a) 3.6500320126532544 - case TransportMode.walk: Assert.assertEquals(3.328148327589044, value, MatsimTestUtils.EPSILON); break; // (a) 3.2374596523136154 - case TransportMode.pt: Assert.assertEquals(3.389540900429034, value, MatsimTestUtils.EPSILON); break; // (a) 3.3065653876694023 - case "matrixBasedPt": Assert.assertEquals(2.893683407764653, value, MatsimTestUtils.EPSILON); break; // (a) 2.0112226418584043 + case "freespeed": Assertions.assertEquals(3.621797746434273, value, MatsimTestUtils.EPSILON); break; // (a) 3.5918646370880176 + case TransportMode.car: Assertions.assertEquals(3.621797881699601, value, MatsimTestUtils.EPSILON); break; // (a) 3.591516884230813 (b) 3.621797746434273 + case TransportMode.bike: Assertions.assertEquals(3.66963791800913, value, MatsimTestUtils.EPSILON); break; // (a) 3.6500320126532544 + case TransportMode.walk: Assertions.assertEquals(3.328148327589044, value, MatsimTestUtils.EPSILON); break; // (a) 3.2374596523136154 + case TransportMode.pt: Assertions.assertEquals(3.389540900429034, value, MatsimTestUtils.EPSILON); break; // (a) 3.3065653876694023 + case "matrixBasedPt": Assertions.assertEquals(2.893683407764653, value, MatsimTestUtils.EPSILON); break; // (a) 2.0112226418584043 } } } diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java index e131507e5ad..cf03d50fa9d 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/NetworkUtilTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -89,119 +89,119 @@ void testNetworkUtil() { Distances distanceA11 = NetworkUtil.getDistances2NodeViaGivenLink(a, link1, node1); - Assert.assertEquals("distanceA11.getDistancePoint2Road()", 100., distanceA11.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceA11.getDistanceRoad2Node()", 0., distanceA11.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(100., distanceA11.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceA11.getDistancePoint2Road()"); + Assertions.assertEquals(0., distanceA11.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceA11.getDistanceRoad2Node()"); Coord projectionA11 = CoordUtils.orthogonalProjectionOnLineSegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), a); - Assert.assertEquals("projectionA11.getX()", 0., projectionA11.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionA11.getY()", 0., projectionA11.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., projectionA11.getX(), MatsimTestUtils.EPSILON, "projectionA11.getX()"); + Assertions.assertEquals(0., projectionA11.getY(), MatsimTestUtils.EPSILON, "projectionA11.getY()"); Distances distanceB11 = NetworkUtil.getDistances2NodeViaGivenLink(b, link1, node1); - Assert.assertEquals("distanceB11.getDistancePoint2Road()", 100., distanceB11.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceB11.getDistanceRoad2Node()", 100., distanceB11.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(100., distanceB11.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceB11.getDistancePoint2Road()"); + Assertions.assertEquals(100., distanceB11.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceB11.getDistanceRoad2Node()"); Coord projectionB11 = CoordUtils.orthogonalProjectionOnLineSegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), b); - Assert.assertEquals("projectionB11.getX()", 0., projectionB11.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionB11.getY()", 100., projectionB11.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., projectionB11.getX(), MatsimTestUtils.EPSILON, "projectionB11.getX()"); + Assertions.assertEquals(100., projectionB11.getY(), MatsimTestUtils.EPSILON, "projectionB11.getY()"); Distances distanceB12 = NetworkUtil.getDistances2NodeViaGivenLink(b, link1, node2); - Assert.assertEquals("distanceB12.getDistancePoint2Road()", 100., distanceB12.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceB12.getDistanceRoad2Node()", 900., distanceB12.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(100., distanceB12.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceB12.getDistancePoint2Road()"); + Assertions.assertEquals(900., distanceB12.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceB12.getDistanceRoad2Node()"); Coord projectionB12 = CoordUtils.orthogonalProjectionOnLineSegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), b); - Assert.assertEquals("projectionB12.getX()", 0., projectionB12.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionB12.getY()", 100., projectionB12.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., projectionB12.getX(), MatsimTestUtils.EPSILON, "projectionB12.getX()"); + Assertions.assertEquals(100., projectionB12.getY(), MatsimTestUtils.EPSILON, "projectionB12.getY()"); Distances distanceC11 = NetworkUtil.getDistances2NodeViaGivenLink(c, link1, node1); - Assert.assertEquals("distanceC11.getDistancePoint2Road()", 100., distanceC11.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceC11.getDistanceRoad2Node()", 1000., distanceC11.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(100., distanceC11.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceC11.getDistancePoint2Road()"); + Assertions.assertEquals(1000., distanceC11.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceC11.getDistanceRoad2Node()"); Coord projectionC11 = CoordUtils.orthogonalProjectionOnLineSegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), c); - Assert.assertEquals("projectionC11.getX()", 0., projectionC11.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionC11.getY()", 1000., projectionC11.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., projectionC11.getX(), MatsimTestUtils.EPSILON, "projectionC11.getX()"); + Assertions.assertEquals(1000., projectionC11.getY(), MatsimTestUtils.EPSILON, "projectionC11.getY()"); Distances distanceC12 = NetworkUtil.getDistances2NodeViaGivenLink(c, link1, node2); - Assert.assertEquals("distanceC12.getDistancePoint2Road()", 100., distanceC12.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceC12.getDistanceRoad2Node()", 0., distanceC12.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(100., distanceC12.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceC12.getDistancePoint2Road()"); + Assertions.assertEquals(0., distanceC12.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceC12.getDistanceRoad2Node()"); Coord projectionC12 = CoordUtils.orthogonalProjectionOnLineSegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), c); - Assert.assertEquals("projectionC12.getX()", 0., projectionC12.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionC12.getY()", 1000., projectionC12.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., projectionC12.getX(), MatsimTestUtils.EPSILON, "projectionC12.getX()"); + Assertions.assertEquals(1000., projectionC12.getY(), MatsimTestUtils.EPSILON, "projectionC12.getY()"); Distances distanceC22 = NetworkUtil.getDistances2NodeViaGivenLink(c, link2, node2); - Assert.assertEquals("distanceC22.getDistancePoint2Road()", Math.sqrt(2.) / 2. * 100., distanceC22.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceC22.getDistanceRoad2Node()", Math.sqrt(2.) / 2. * 100., distanceC22.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Math.sqrt(2.) / 2. * 100., distanceC22.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceC22.getDistancePoint2Road()"); + Assertions.assertEquals(Math.sqrt(2.) / 2. * 100., distanceC22.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceC22.getDistanceRoad2Node()"); Coord projectionC22 = CoordUtils.orthogonalProjectionOnLineSegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), c); - Assert.assertEquals("projectionC22.getX()", 50., projectionC22.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionC22.getY()", 1050., projectionC22.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(50., projectionC22.getX(), MatsimTestUtils.EPSILON, "projectionC22.getX()"); + Assertions.assertEquals(1050., projectionC22.getY(), MatsimTestUtils.EPSILON, "projectionC22.getY()"); Distances distanceC23 = NetworkUtil.getDistances2NodeViaGivenLink(c, link2, node3); - Assert.assertEquals("distanceC23.getDistancePoint2Road()", Math.sqrt(2.) / 2. * 100., distanceC23.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceC23.getDistanceRoad2Node()", Math.sqrt(2) * 1000. - Math.sqrt(2.) / 2. * 100., distanceC23.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Math.sqrt(2.) / 2. * 100., distanceC23.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceC23.getDistancePoint2Road()"); + Assertions.assertEquals(Math.sqrt(2) * 1000. - Math.sqrt(2.) / 2. * 100., distanceC23.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceC23.getDistanceRoad2Node()"); Coord projectionC23 = CoordUtils.orthogonalProjectionOnLineSegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), c); - Assert.assertEquals("projectionC23.getX()", 50., projectionC23.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionC23.getY()", 1050., projectionC23.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(50., projectionC23.getX(), MatsimTestUtils.EPSILON, "projectionC23.getX()"); + Assertions.assertEquals(1050., projectionC23.getY(), MatsimTestUtils.EPSILON, "projectionC23.getY()"); Distances distanceD22 = NetworkUtil.getDistances2NodeViaGivenLink(d, link2, node2); - Assert.assertEquals("distanceD22.getDistancePoint2Road()", Math.sqrt(2.) / 2. * 100.0, distanceD22.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceD22.getDistanceRoad2Node()", Math.sqrt(2.) / 2. * 100.0 + Math.sqrt(2) * 200., distanceD22.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Math.sqrt(2.) / 2. * 100.0, distanceD22.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceD22.getDistancePoint2Road()"); + Assertions.assertEquals(Math.sqrt(2.) / 2. * 100.0 + Math.sqrt(2) * 200., distanceD22.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceD22.getDistanceRoad2Node()"); Coord projectionD22 = CoordUtils.orthogonalProjectionOnLineSegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), d); - Assert.assertEquals("projectionD22.getX()", 250., projectionD22.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionD22.getY()", 1250., projectionD22.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(250., projectionD22.getX(), MatsimTestUtils.EPSILON, "projectionD22.getX()"); + Assertions.assertEquals(1250., projectionD22.getY(), MatsimTestUtils.EPSILON, "projectionD22.getY()"); Distances distanceD23 = NetworkUtil.getDistances2NodeViaGivenLink(d, link2, node3); - Assert.assertEquals("distanceD23.getDistancePoint2Road()", Math.sqrt(2.)/2.*100.0, distanceD23.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceD23.getDistanceRoad2Node()", Math.sqrt(2.)/2.*100.0 + Math.sqrt(2) * 700., distanceD23.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Math.sqrt(2.)/2.*100.0, distanceD23.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceD23.getDistancePoint2Road()"); + Assertions.assertEquals(Math.sqrt(2.)/2.*100.0 + Math.sqrt(2) * 700., distanceD23.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceD23.getDistanceRoad2Node()"); Coord projectionD23 = CoordUtils.orthogonalProjectionOnLineSegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), d); - Assert.assertEquals("projectionD23.getX()", 250., projectionD23.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionD23.getY()", 1250., projectionD23.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(250., projectionD23.getX(), MatsimTestUtils.EPSILON, "projectionD23.getX()"); + Assertions.assertEquals(1250., projectionD23.getY(), MatsimTestUtils.EPSILON, "projectionD23.getY()"); Distances distanceE33 = NetworkUtil.getDistances2NodeViaGivenLink(e, link3, node3); - Assert.assertEquals("distanceE33.getDistancePoint2Road()", 100.0, distanceE33.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceE33.getDistanceRoad2Node()", 300.0, distanceE33.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(100.0, distanceE33.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceE33.getDistancePoint2Road()"); + Assertions.assertEquals(300.0, distanceE33.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceE33.getDistanceRoad2Node()"); Coord projectionE33 = CoordUtils.orthogonalProjectionOnLineSegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), e); - Assert.assertEquals("projectionE33.getX()", 1300., projectionE33.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionE33.getY()", 2000., projectionE33.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1300., projectionE33.getX(), MatsimTestUtils.EPSILON, "projectionE33.getX()"); + Assertions.assertEquals(2000., projectionE33.getY(), MatsimTestUtils.EPSILON, "projectionE33.getY()"); Distances distanceE34 = NetworkUtil.getDistances2NodeViaGivenLink(e, link3, node4); - Assert.assertEquals("distanceE34.getDistancePoint2Road()", 100.0, distanceE34.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceE34.getDistanceRoad2Node()", 700.0, distanceE34.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(100.0, distanceE34.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceE34.getDistancePoint2Road()"); + Assertions.assertEquals(700.0, distanceE34.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceE34.getDistanceRoad2Node()"); Coord projectionE34 = CoordUtils.orthogonalProjectionOnLineSegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), e); - Assert.assertEquals("projectionE34.getX()", 1300., projectionE34.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionE34.getY()", 2000., projectionE34.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1300., projectionE34.getX(), MatsimTestUtils.EPSILON, "projectionE34.getX()"); + Assertions.assertEquals(2000., projectionE34.getY(), MatsimTestUtils.EPSILON, "projectionE34.getY()"); Distances distanceF33 = NetworkUtil.getDistances2NodeViaGivenLink(f, link3, node3); - Assert.assertEquals("distanceF33.getDistancePoint2Road()", Math.sqrt(Math.pow(100, 2) + Math.pow(300, 2)), distanceF33.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceF33.getDistanceRoad2Node()", 1000., distanceF33.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Math.sqrt(Math.pow(100, 2) + Math.pow(300, 2)), distanceF33.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceF33.getDistancePoint2Road()"); + Assertions.assertEquals(1000., distanceF33.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceF33.getDistanceRoad2Node()"); Coord projectionF33 = CoordUtils.orthogonalProjectionOnLineSegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), e); - Assert.assertEquals("projectionF33.getX()", 1300., projectionF33.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionF33.getY()", 2000., projectionF33.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1300., projectionF33.getX(), MatsimTestUtils.EPSILON, "projectionF33.getX()"); + Assertions.assertEquals(2000., projectionF33.getY(), MatsimTestUtils.EPSILON, "projectionF33.getY()"); Distances distanceF34 = NetworkUtil.getDistances2NodeViaGivenLink(f, link3, node4); - Assert.assertEquals("distanceF34.getDistancePoint2Road()", Math.sqrt(Math.pow(100, 2) + Math.pow(300, 2)), distanceF34.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON); - Assert.assertEquals("distanceF34.getDistanceRoad2Node()", 0., distanceF34.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Math.sqrt(Math.pow(100, 2) + Math.pow(300, 2)), distanceF34.getDistancePoint2Intersection(), MatsimTestUtils.EPSILON, "distanceF34.getDistancePoint2Road()"); + Assertions.assertEquals(0., distanceF34.getDistanceIntersection2Node(), MatsimTestUtils.EPSILON, "distanceF34.getDistanceRoad2Node()"); Coord projectionF34 = CoordUtils.orthogonalProjectionOnLineSegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), f); - Assert.assertEquals("projectionF34.getX()", 2000., projectionF34.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals("projectionF34.getY()", 2000., projectionF34.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2000., projectionF34.getX(), MatsimTestUtils.EPSILON, "projectionF34.getX()"); + Assertions.assertEquals(2000., projectionF34.getY(), MatsimTestUtils.EPSILON, "projectionF34.getY()"); } } diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java index 9e7a6eb30f1..8c1e52924b4 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyAccessibilityTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -262,20 +262,20 @@ public void finish() { LOG.warn("CHECK X = " + tuple.getFirst().getCoord().getX() + " -- Y = " + tuple.getFirst().getCoord().getY() + " -- car value = " + accessibilitiesMap.get(tuple).get(TransportMode.car)); if (tuple.getFirst().getCoord().getX() == 50.) { if (tuple.getFirst().getCoord().getY() == 50.) { - Assert.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.017240250823867296, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.017240250823867296, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); } else if (tuple.getFirst().getCoord().getY() == 150.) { - Assert.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.017240250823867296, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.017240250823867296, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); } } if (tuple.getFirst().getCoord().getX() == 150.) { if (tuple.getFirst().getCoord().getY() == 50.) { - Assert.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); - Assert.assertEquals(0.27582980607476704, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.27582980607476704, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); } else if (tuple.getFirst().getCoord().getY() == 150.) { - Assert.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); - Assert.assertEquals(0.27582980607476704, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.27582980607476704, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); } } } diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java index 3f407b42ffb..d7ab5eaaf3c 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java @@ -21,8 +21,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -310,24 +310,24 @@ public void finish() { LOG.warn("CHECK X = " + tuple.getFirst().getCoord().getX() + " -- Y = " + tuple.getFirst().getCoord().getY() + " -- car value = " + accessibilitiesMap.get(tuple).get(TransportMode.car)); if (tuple.getFirst().getCoord().getX() == 50.) { if (tuple.getFirst().getCoord().getY() == 50.) { - Assert.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0020510618020555325, accessibilitiesMap.get(tuple).get(TransportMode.pt), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0020510618020555325, accessibilitiesMap.get(tuple).get(TransportMode.pt), MatsimTestUtils.EPSILON); } else if (tuple.getFirst().getCoord().getY() == 150.) { - Assert.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.04152005026781742, accessibilitiesMap.get(tuple).get(TransportMode.pt), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.017248522428805767, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.04152005026781742, accessibilitiesMap.get(tuple).get(TransportMode.pt), MatsimTestUtils.EPSILON); } } if (tuple.getFirst().getCoord().getX() == 150.) { if (tuple.getFirst().getCoord().getY() == 50.) { - Assert.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); - Assert.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); - Assert.assertEquals(0.25069951470887114, accessibilitiesMap.get(tuple).get(TransportMode.pt), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.25069951470887114, accessibilitiesMap.get(tuple).get(TransportMode.pt), MatsimTestUtils.EPSILON); } else if (tuple.getFirst().getCoord().getY() == 150.) { - Assert.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); - Assert.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); - Assert.assertEquals(0.25069951470887114, accessibilitiesMap.get(tuple).get(TransportMode.pt), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get("freespeed"), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.2758252376673665, accessibilitiesMap.get(tuple).get(TransportMode.car), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.25069951470887114, accessibilitiesMap.get(tuple).get(TransportMode.pt), MatsimTestUtils.EPSILON); } } } diff --git a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/BvwpAccidentsCostComputationTest.java b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/BvwpAccidentsCostComputationTest.java index 5e6bd4a91d0..3cb595ee1e6 100644 --- a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/BvwpAccidentsCostComputationTest.java +++ b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/BvwpAccidentsCostComputationTest.java @@ -2,7 +2,7 @@ import java.util.ArrayList; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -40,7 +40,7 @@ void test1() { list.add(2, 2); //2 Lanes double costs = AccidentCostComputationBVWP.computeAccidentCosts(4820, link1, list); - Assert.assertEquals("wrong cost", 1772.13863066011, costs, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1772.13863066011, costs, MatsimTestUtils.EPSILON, "wrong cost"); } @Test @@ -62,7 +62,7 @@ void test2() { list.add(2, 2); //2 Lanes double costs = AccidentCostComputationBVWP.computeAccidentCosts(1000, link1, list); - Assert.assertEquals("wrong cost", 23.165, costs, MatsimTestUtils.EPSILON); + Assertions.assertEquals(23.165, costs, MatsimTestUtils.EPSILON, "wrong cost"); } @Test @@ -84,6 +84,6 @@ void test3() { list.add(2, 3); //2 Lanes double costs = AccidentCostComputationBVWP.computeAccidentCosts(1000, link1, list); - Assert.assertEquals("wrong cost", 101.53, costs, MatsimTestUtils.EPSILON); + Assertions.assertEquals(101.53, costs, MatsimTestUtils.EPSILON, "wrong cost"); } } diff --git a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java index b087e316b5b..f07d1d8d5f9 100644 --- a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java +++ b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTest.java @@ -3,7 +3,7 @@ import java.io.BufferedReader; import java.io.IOException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -86,12 +86,12 @@ void test1() { if (lineCounter == 0 && column == 25) { double accidentCosts = Double.valueOf(columns[column]); - Assert.assertEquals("wrong accident costs", 10.38, accidentCosts , MatsimTestUtils.EPSILON); + Assertions.assertEquals(10.38, accidentCosts , MatsimTestUtils.EPSILON, "wrong accident costs"); } if (lineCounter == 1 && column == 25) { double accidentCosts = Double.valueOf(columns[column]); - Assert.assertEquals("wrong accident costs", 16.68, accidentCosts , MatsimTestUtils.EPSILON); + Assertions.assertEquals(16.68, accidentCosts , MatsimTestUtils.EPSILON, "wrong accident costs"); } } diff --git a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java index 94e8df01123..486baf7f3ec 100644 --- a/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java +++ b/contribs/accidents/src/test/java/org/matsim/contrib/accidents/RunTestEquil.java @@ -1,8 +1,9 @@ package org.matsim.contrib.accidents; import java.io.BufferedReader; -import java.io.IOException; -import org.junit.Assert; +import java.io.IOException; + +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -88,7 +89,7 @@ void test1() { int agents = 100; int lengthKM = 35; double accidentCostsManualCalculation = (agents * lengthKM * 61.785) / 1000. * 10; - Assert.assertEquals("wrong accident costs", accidentCostsManualCalculation, accidentCosts , 0.01); + Assertions.assertEquals(accidentCostsManualCalculation, accidentCosts , 0.01, "wrong accident costs"); } // link 1 if (lineCounter == 11 && column == 121) { @@ -96,7 +97,7 @@ void test1() { int agents = 100; int lengthKM = 10; double accidentCostsManualCalculation = (agents * lengthKM * 61.785) / 1000. * 10; - Assert.assertEquals("wrong accident costs", accidentCostsManualCalculation, accidentCosts , 0.01); + Assertions.assertEquals(accidentCostsManualCalculation, accidentCosts , 0.01, "wrong accident costs"); } // link 6 @@ -105,7 +106,7 @@ void test1() { int agents = 100; int lengthKM = 10; double accidentCostsManualCalculation = (agents * lengthKM * 34.735) / 1000. * 10; - Assert.assertEquals("wrong accident costs", accidentCostsManualCalculation, accidentCosts , 0.01); + Assertions.assertEquals(accidentCostsManualCalculation, accidentCosts , 0.01, "wrong accident costs"); } // link 15 @@ -114,7 +115,7 @@ void test1() { int agents = 100; int lengthKM = 5; double accidentCostsManualCalculation = (agents * lengthKM * 31.63) / 1000. * 10; - Assert.assertEquals("wrong accident costs", accidentCostsManualCalculation, accidentCosts , 0.01); + Assertions.assertEquals(accidentCostsManualCalculation, accidentCosts , 0.01, "wrong accident costs"); } } diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java index 53501436d54..aed33926f02 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/PersonIntersectAreaFilterTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.analysis.filters.population; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertFalse; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.HashMap; @@ -114,25 +114,25 @@ void testFilter() throws Exception { aoi.clear(); aoi.put(link2.getId(), link2); filter = new PersonIntersectAreaFilter(null, aoi, network); - assertTrue("test route through aoi", filter.judge(person)); + assertTrue(filter.judge(person), "test route through aoi"); // test departure link aoi.clear(); aoi.put(link0.getId(), link0); filter = new PersonIntersectAreaFilter(null, aoi, network); - assertTrue("test departure link as aoi", filter.judge(person)); + assertTrue(filter.judge(person), "test departure link as aoi"); // test arrival link aoi.clear(); aoi.put(link5.getId(), link5); filter = new PersonIntersectAreaFilter(null, aoi, network); - assertTrue("test arrival link as aoi", filter.judge(person)); + assertTrue(filter.judge(person), "test arrival link as aoi"); // test route outside aoi aoi.clear(); aoi.put(link4.getId(), link4); filter = new PersonIntersectAreaFilter(null, aoi, network); - assertFalse("test route outside aoi", filter.judge(person)); + assertFalse(filter.judge(person), "test route outside aoi"); // prepare bee-line tests leg.setMode(TransportMode.walk); @@ -142,21 +142,21 @@ void testFilter() throws Exception { aoi.clear(); aoi.put(link2.getId(), link2); filter = new PersonIntersectAreaFilter(null, aoi, network); - assertFalse("test bee-line without alternative aoi", filter.judge(person)); + assertFalse(filter.judge(person), "test bee-line without alternative aoi"); // test bee-line with too small alternative aoi aoi.clear(); aoi.put(link2.getId(), link2); filter = new PersonIntersectAreaFilter(null, aoi, network); filter.setAlternativeAOI(new Coord((double) 100, (double) 0), 20.0); - assertFalse("test bee-line with too small alternative aoi", filter.judge(person)); + assertFalse(filter.judge(person), "test bee-line with too small alternative aoi"); // test bee-line with big enough alternative aoi aoi.clear(); aoi.put(link2.getId(), link2); filter = new PersonIntersectAreaFilter(null, aoi, network); filter.setAlternativeAOI(new Coord((double) 100, (double) 0), 80.0); - assertTrue("test bee-line with big enough alternative aoi", filter.judge(person)); + assertTrue(filter.judge(person), "test bee-line with big enough alternative aoi"); } diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java index 4f5b186f055..c434dca8a24 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/filters/population/RouteLinkFilterTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.analysis.filters.population; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java index f474729f527..a42e5780cc4 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java @@ -23,9 +23,9 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.After; -import org.junit.Assert; import org.junit.Before; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -172,7 +172,7 @@ protected void runTest(KNAnalysisEventsHandler calcLegTimes) { LogManager.getLogger(this.getClass()).info( "comparing " + str ); final long expectedChecksum = CRCChecksum.getCRCFromFile(utils.getInputDirectory() + str); final long actualChecksum = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + str); - Assert.assertEquals("Output files differ.", expectedChecksum, actualChecksum); + Assertions.assertEquals(expectedChecksum, actualChecksum, "Output files differ."); } } diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/GridTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/GridTest.java index 1b223b21821..804de493d3a 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/GridTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/GridTest.java @@ -1,10 +1,10 @@ package org.matsim.contrib.analysis.spatial; -import static org.junit.Assert.assertEquals; - import java.util.Collection; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.GeometryFactory; diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/SpatialInterpolationTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/SpatialInterpolationTest.java index e739ab2b847..1fe102d3534 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/SpatialInterpolationTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/spatial/SpatialInterpolationTest.java @@ -1,8 +1,6 @@ package org.matsim.contrib.analysis.spatial; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.fail; -import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.Coordinate; diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/time/TimeBinMapTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/time/TimeBinMapTest.java index 3acb0feeec5..13e5e7f291c 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/time/TimeBinMapTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/time/TimeBinMapTest.java @@ -2,8 +2,7 @@ import java.util.Map; -import static org.junit.Assert.*; -import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java index 3d322dec849..96b87268dc9 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/GoogleMapRouteValidatorTest.java @@ -8,8 +8,8 @@ import java.io.*; import java.util.Optional; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; public class GoogleMapRouteValidatorTest { @RegisterExtension diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java index 72ec7f44e30..bd95386c9a0 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/vsp/traveltimedistance/HereMapsRouteValidatorTest.java @@ -8,7 +8,7 @@ import java.io.*; import java.util.Optional; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class HereMapsRouteValidatorTest { @RegisterExtension diff --git a/contribs/application/src/test/java/org/matsim/application/ApplicationUtilsTest.java b/contribs/application/src/test/java/org/matsim/application/ApplicationUtilsTest.java index 85a1f820674..31d1d3d1970 100644 --- a/contribs/application/src/test/java/org/matsim/application/ApplicationUtilsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/ApplicationUtilsTest.java @@ -5,7 +5,7 @@ import org.matsim.application.analysis.TestDependentAnalysis; import org.matsim.application.options.ShpOptions; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class ApplicationUtilsTest { diff --git a/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java b/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java index 1abf0991cf0..0db41fd13eb 100644 --- a/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java +++ b/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java @@ -24,7 +24,7 @@ import java.util.List; import static org.assertj.core.api.Assertions.assertThat; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; public class MATSimApplicationTest { @@ -36,7 +36,7 @@ void help() { int ret = MATSimApplication.execute(TestScenario.class, "--help"); - assertEquals("Return code should be 0", 0, ret); + assertEquals(0, ret, "Return code should be 0"); } @Test diff --git a/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java b/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java index ca5a7785d4b..e38c4b764c7 100644 --- a/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java @@ -1,7 +1,7 @@ package org.matsim.application.options; -import org.junit.Assert; import org.junit.Assume; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.locationtech.jts.geom.Geometry; @@ -86,6 +86,6 @@ void testGetGeometry() { expectedGeometry = expectedGeometry.union(geometryToJoin); } - Assert.assertTrue(geometry.equals(expectedGeometry)); + Assertions.assertTrue(geometry.equals(expectedGeometry)); } } diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java index 4c35b94c282..c74d59b7801 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/counts/CreateCountsFromBAStDataTest.java @@ -1,6 +1,6 @@ package org.matsim.application.prepare.counts; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -159,7 +159,7 @@ void testManualMatchedCounts() { MeasurementLocation actual = map.get(supposed); String actualStation = actual.getStationName(); - Assert.assertEquals(station, actualStation); + Assertions.assertEquals(station, actualStation); } } @@ -181,6 +181,6 @@ void testManualMatchingWithWrongInput() { "--manual-matched-counts=" + utils.getPackageInputDirectory() + wrongManualMatchedCounts, }; - Assert.assertThrows(RuntimeException.class, () -> new CreateCountsFromBAStData().execute(args)); + Assertions.assertThrows(RuntimeException.class, () -> new CreateCountsFromBAStData().execute(args)); } } diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java index e66b63d3dd1..1bcb22e6b80 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/CarrierReaderFromCSVTest.java @@ -9,7 +9,7 @@ import java.util.Map; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -61,101 +61,101 @@ void carrierCreation() throws IOException { CarrierReaderFromCSV.checkNewCarrier(allNewCarrierInformation, freightCarriersConfigGroup, scenario, polygonsInShape, shapeCategory); CarrierReaderFromCSV.createNewCarrierAndAddVehicleTypes(scenario, allNewCarrierInformation, freightCarriersConfigGroup, polygonsInShape, 1, null); - Assert.assertEquals(3, CarriersUtils.getCarriers(scenario).getCarriers().size()); - Assert.assertTrue( + Assertions.assertEquals(3, CarriersUtils.getCarriers(scenario).getCarriers().size()); + Assertions.assertTrue( CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("testCarrier1", Carrier.class))); - Assert.assertTrue( + Assertions.assertTrue( CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("testCarrier2", Carrier.class))); - Assert.assertTrue( + Assertions.assertTrue( CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("testCarrier3", Carrier.class))); // check carrier 1 Carrier testCarrier1 = CarriersUtils.getCarriers(scenario).getCarriers() .get(Id.create("testCarrier1", Carrier.class)); - Assert.assertEquals(FleetSize.INFINITE, testCarrier1.getCarrierCapabilities().getFleetSize()); - Assert.assertEquals(10, CarriersUtils.getJspritIterations(testCarrier1)); - Assert.assertEquals(4, testCarrier1.getCarrierCapabilities().getCarrierVehicles().size()); + Assertions.assertEquals(FleetSize.INFINITE, testCarrier1.getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(10, CarriersUtils.getJspritIterations(testCarrier1)); + Assertions.assertEquals(4, testCarrier1.getCarrierCapabilities().getCarrierVehicles().size()); Object2IntMap depotSums = new Object2IntOpenHashMap<>(); Map> typesPerDepot = new HashMap<>(); for (CarrierVehicle carrierVehicle : testCarrier1.getCarrierCapabilities().getCarrierVehicles().values()) { typesPerDepot.computeIfAbsent(carrierVehicle.getLinkId().toString(), ( k) -> new ArrayList<>() ) .add(carrierVehicle.getVehicleTypeId().toString()); depotSums.merge(carrierVehicle.getLinkId().toString(), 1, Integer::sum ); - Assert.assertEquals(3600, carrierVehicle.getEarliestStartTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(50000, carrierVehicle.getLatestEndTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3600, carrierVehicle.getEarliestStartTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(50000, carrierVehicle.getLatestEndTime(), MatsimTestUtils.EPSILON); } - Assert.assertEquals(2, depotSums.size()); - Assert.assertTrue(depotSums.containsKey("i(2,0)")); - Assert.assertEquals(2, depotSums.getInt("i(2,0)")); - Assert.assertTrue(depotSums.containsKey("j(2,4)R")); - Assert.assertEquals(2, depotSums.getInt("j(2,4)R")); - Assert.assertEquals(2, typesPerDepot.size()); - Assert.assertTrue(typesPerDepot.containsKey("i(2,0)")); - Assert.assertEquals(2, typesPerDepot.get("i(2,0)").size()); - Assert.assertTrue(typesPerDepot.get("i(2,0)").contains("testVehicle1")); - Assert.assertTrue(typesPerDepot.get("i(2,0)").contains("testVehicle2")); - Assert.assertTrue(typesPerDepot.containsKey("j(2,4)R")); - Assert.assertEquals(2, typesPerDepot.get("j(2,4)R").size()); - Assert.assertTrue(typesPerDepot.get("j(2,4)R").contains("testVehicle1")); - Assert.assertTrue(typesPerDepot.get("j(2,4)R").contains("testVehicle2")); + Assertions.assertEquals(2, depotSums.size()); + Assertions.assertTrue(depotSums.containsKey("i(2,0)")); + Assertions.assertEquals(2, depotSums.getInt("i(2,0)")); + Assertions.assertTrue(depotSums.containsKey("j(2,4)R")); + Assertions.assertEquals(2, depotSums.getInt("j(2,4)R")); + Assertions.assertEquals(2, typesPerDepot.size()); + Assertions.assertTrue(typesPerDepot.containsKey("i(2,0)")); + Assertions.assertEquals(2, typesPerDepot.get("i(2,0)").size()); + Assertions.assertTrue(typesPerDepot.get("i(2,0)").contains("testVehicle1")); + Assertions.assertTrue(typesPerDepot.get("i(2,0)").contains("testVehicle2")); + Assertions.assertTrue(typesPerDepot.containsKey("j(2,4)R")); + Assertions.assertEquals(2, typesPerDepot.get("j(2,4)R").size()); + Assertions.assertTrue(typesPerDepot.get("j(2,4)R").contains("testVehicle1")); + Assertions.assertTrue(typesPerDepot.get("j(2,4)R").contains("testVehicle2")); // check carrier 2 Carrier testCarrier2 = CarriersUtils.getCarriers(scenario).getCarriers() .get(Id.create("testCarrier2", Carrier.class)); - Assert.assertEquals(FleetSize.FINITE, testCarrier2.getCarrierCapabilities().getFleetSize()); - Assert.assertEquals(15, CarriersUtils.getJspritIterations(testCarrier2)); - Assert.assertEquals(9, testCarrier2.getCarrierCapabilities().getCarrierVehicles().size()); + Assertions.assertEquals(FleetSize.FINITE, testCarrier2.getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(15, CarriersUtils.getJspritIterations(testCarrier2)); + Assertions.assertEquals(9, testCarrier2.getCarrierCapabilities().getCarrierVehicles().size()); depotSums = new Object2IntOpenHashMap<>(); typesPerDepot = new HashMap<>(); for (CarrierVehicle carrierVehicle : testCarrier2.getCarrierCapabilities().getCarrierVehicles().values()) { typesPerDepot.computeIfAbsent(carrierVehicle.getLinkId().toString(), ( k) -> new ArrayList<>() ) .add(carrierVehicle.getVehicleTypeId().toString()); depotSums.merge(carrierVehicle.getLinkId().toString(), 1, Integer::sum ); - Assert.assertEquals(3600, carrierVehicle.getEarliestStartTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(50000, carrierVehicle.getLatestEndTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3600, carrierVehicle.getEarliestStartTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(50000, carrierVehicle.getLatestEndTime(), MatsimTestUtils.EPSILON); } - Assert.assertEquals(3, depotSums.size()); - Assert.assertTrue(depotSums.containsKey("j(4,3)R")); - Assert.assertEquals(3, depotSums.getInt("j(4,3)R")); - Assert.assertEquals(3, typesPerDepot.size()); - Assert.assertTrue(typesPerDepot.containsKey("j(4,3)R")); - Assert.assertEquals(3, typesPerDepot.get("j(4,3)R").size()); - Assert.assertTrue(typesPerDepot.get("j(4,3)R").contains("testVehicle2")); + Assertions.assertEquals(3, depotSums.size()); + Assertions.assertTrue(depotSums.containsKey("j(4,3)R")); + Assertions.assertEquals(3, depotSums.getInt("j(4,3)R")); + Assertions.assertEquals(3, typesPerDepot.size()); + Assertions.assertTrue(typesPerDepot.containsKey("j(4,3)R")); + Assertions.assertEquals(3, typesPerDepot.get("j(4,3)R").size()); + Assertions.assertTrue(typesPerDepot.get("j(4,3)R").contains("testVehicle2")); // check carrier 3 Network network = NetworkUtils.readNetwork( "https://raw.githubusercontent.com/matsim-org/matsim-libs/master/examples/scenarios/freight-chessboard-9x9/grid9x9.xml"); Carrier testCarrier3 = CarriersUtils.getCarriers(scenario).getCarriers() .get(Id.create("testCarrier3", Carrier.class)); - Assert.assertEquals(FleetSize.INFINITE, testCarrier3.getCarrierCapabilities().getFleetSize()); - Assert.assertEquals(1, CarriersUtils.getJspritIterations(testCarrier3)); - Assert.assertEquals(2, testCarrier3.getCarrierCapabilities().getCarrierVehicles().size()); + Assertions.assertEquals(FleetSize.INFINITE, testCarrier3.getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(1, CarriersUtils.getJspritIterations(testCarrier3)); + Assertions.assertEquals(2, testCarrier3.getCarrierCapabilities().getCarrierVehicles().size()); depotSums = new Object2IntOpenHashMap<>(); typesPerDepot = new HashMap<>(); for (CarrierVehicle carrierVehicle : testCarrier3.getCarrierCapabilities().getCarrierVehicles().values()) { typesPerDepot.computeIfAbsent(carrierVehicle.getLinkId().toString(), ( k) -> new ArrayList<>() ) .add(carrierVehicle.getVehicleTypeId().toString()); depotSums.merge(carrierVehicle.getLinkId().toString(), 1, Integer::sum ); - Assert.assertEquals(50000, carrierVehicle.getEarliestStartTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(80000, carrierVehicle.getLatestEndTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(50000, carrierVehicle.getEarliestStartTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(80000, carrierVehicle.getLatestEndTime(), MatsimTestUtils.EPSILON); } - Assert.assertEquals(2, depotSums.size()); - Assert.assertTrue(depotSums.containsKey("j(2,6)R")); - Assert.assertEquals(1, depotSums.getInt("j(2,6)R")); + Assertions.assertEquals(2, depotSums.size()); + Assertions.assertTrue(depotSums.containsKey("j(2,6)R")); + Assertions.assertEquals(1, depotSums.getInt("j(2,6)R")); for (String depot : depotSums.keySet()) { if (!depot.equals("j(2,6)R")) { Link link = network.getLinks().get(Id.createLinkId(depot)); - Assert.assertTrue( + Assertions.assertTrue( FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, null, null)); - Assert.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area1"}, null)); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area2"}, null)); + Assertions.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area1"}, null)); + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area2"}, null)); } } - Assert.assertEquals(2, typesPerDepot.size()); - Assert.assertTrue(typesPerDepot.containsKey("j(2,6)R")); - Assert.assertEquals(1, typesPerDepot.get("j(2,6)R").size()); - Assert.assertTrue(typesPerDepot.get("j(2,6)R").contains("testVehicle1")); + Assertions.assertEquals(2, typesPerDepot.size()); + Assertions.assertTrue(typesPerDepot.containsKey("j(2,6)R")); + Assertions.assertEquals(1, typesPerDepot.get("j(2,6)R").size()); + Assertions.assertTrue(typesPerDepot.get("j(2,6)R").contains("testVehicle1")); } @@ -165,53 +165,53 @@ void csvCarrierReader() throws IOException { Path carrierCSVLocation = Path.of(utils.getPackageInputDirectory() + "testCarrierCSV.csv"); Set allNewCarrierInformation = CarrierReaderFromCSV .readCarrierInformation(carrierCSVLocation); - Assert.assertEquals(3, allNewCarrierInformation.size()); + Assertions.assertEquals(3, allNewCarrierInformation.size()); for (CarrierInformationElement carrierInformationElement : allNewCarrierInformation) { if (carrierInformationElement.getName().equals("testCarrier1")) { - Assert.assertNull(carrierInformationElement.getAreaOfAdditionalDepots()); - Assert.assertEquals(0, carrierInformationElement.getFixedNumberOfVehiclePerTypeAndLocation()); - Assert.assertEquals(FleetSize.INFINITE, carrierInformationElement.getFleetSize()); - Assert.assertEquals(10, carrierInformationElement.getJspritIterations()); - Assert.assertEquals(2, carrierInformationElement.getNumberOfDepotsPerType()); - Assert.assertEquals(3600, carrierInformationElement.getVehicleStartTime()); - Assert.assertEquals(50000, carrierInformationElement.getVehicleEndTime()); - Assert.assertEquals(2, carrierInformationElement.getVehicleDepots().size()); - Assert.assertTrue(carrierInformationElement.getVehicleDepots().contains("i(2,0)") + Assertions.assertNull(carrierInformationElement.getAreaOfAdditionalDepots()); + Assertions.assertEquals(0, carrierInformationElement.getFixedNumberOfVehiclePerTypeAndLocation()); + Assertions.assertEquals(FleetSize.INFINITE, carrierInformationElement.getFleetSize()); + Assertions.assertEquals(10, carrierInformationElement.getJspritIterations()); + Assertions.assertEquals(2, carrierInformationElement.getNumberOfDepotsPerType()); + Assertions.assertEquals(3600, carrierInformationElement.getVehicleStartTime()); + Assertions.assertEquals(50000, carrierInformationElement.getVehicleEndTime()); + Assertions.assertEquals(2, carrierInformationElement.getVehicleDepots().size()); + Assertions.assertTrue(carrierInformationElement.getVehicleDepots().contains("i(2,0)") && carrierInformationElement.getVehicleDepots().contains("j(2,4)R")); - Assert.assertEquals(2, carrierInformationElement.getVehicleTypes().length); - Assert.assertTrue(carrierInformationElement.getVehicleTypes()[0].equals("testVehicle1") + Assertions.assertEquals(2, carrierInformationElement.getVehicleTypes().length); + Assertions.assertTrue(carrierInformationElement.getVehicleTypes()[0].equals("testVehicle1") || carrierInformationElement.getVehicleTypes()[0].equals("testVehicle2")); - Assert.assertNotEquals(carrierInformationElement.getVehicleTypes()[0], carrierInformationElement.getVehicleTypes()[1]); + Assertions.assertNotEquals(carrierInformationElement.getVehicleTypes()[0], carrierInformationElement.getVehicleTypes()[1]); } else if (carrierInformationElement.getName().equals("testCarrier3")) { - Assert.assertEquals(1, carrierInformationElement.getAreaOfAdditionalDepots().length); - Assert.assertEquals("area1", carrierInformationElement.getAreaOfAdditionalDepots()[0]); - Assert.assertEquals(0, carrierInformationElement.getFixedNumberOfVehiclePerTypeAndLocation()); - Assert.assertEquals(FleetSize.INFINITE, carrierInformationElement.getFleetSize()); - Assert.assertEquals(0, carrierInformationElement.getJspritIterations()); - Assert.assertEquals(2, carrierInformationElement.getNumberOfDepotsPerType()); - Assert.assertEquals(50000, carrierInformationElement.getVehicleStartTime()); - Assert.assertEquals(80000, carrierInformationElement.getVehicleEndTime()); - Assert.assertEquals(1, carrierInformationElement.getVehicleDepots().size()); - Assert.assertEquals("j(2,6)R", carrierInformationElement.getVehicleDepots().get(0)); - Assert.assertEquals(1, carrierInformationElement.getVehicleTypes().length); - Assert.assertEquals("testVehicle1", carrierInformationElement.getVehicleTypes()[0]); + Assertions.assertEquals(1, carrierInformationElement.getAreaOfAdditionalDepots().length); + Assertions.assertEquals("area1", carrierInformationElement.getAreaOfAdditionalDepots()[0]); + Assertions.assertEquals(0, carrierInformationElement.getFixedNumberOfVehiclePerTypeAndLocation()); + Assertions.assertEquals(FleetSize.INFINITE, carrierInformationElement.getFleetSize()); + Assertions.assertEquals(0, carrierInformationElement.getJspritIterations()); + Assertions.assertEquals(2, carrierInformationElement.getNumberOfDepotsPerType()); + Assertions.assertEquals(50000, carrierInformationElement.getVehicleStartTime()); + Assertions.assertEquals(80000, carrierInformationElement.getVehicleEndTime()); + Assertions.assertEquals(1, carrierInformationElement.getVehicleDepots().size()); + Assertions.assertEquals("j(2,6)R", carrierInformationElement.getVehicleDepots().get(0)); + Assertions.assertEquals(1, carrierInformationElement.getVehicleTypes().length); + Assertions.assertEquals("testVehicle1", carrierInformationElement.getVehicleTypes()[0]); } else if (carrierInformationElement.getName().equals("testCarrier2")) { - Assert.assertNull(carrierInformationElement.getAreaOfAdditionalDepots()); - Assert.assertEquals(3, carrierInformationElement.getFixedNumberOfVehiclePerTypeAndLocation()); - Assert.assertEquals(FleetSize.FINITE, carrierInformationElement.getFleetSize()); - Assert.assertEquals(15, carrierInformationElement.getJspritIterations()); - Assert.assertEquals(3, carrierInformationElement.getNumberOfDepotsPerType()); - Assert.assertEquals(3600, carrierInformationElement.getVehicleStartTime()); - Assert.assertEquals(50000, carrierInformationElement.getVehicleEndTime()); - Assert.assertEquals(1, carrierInformationElement.getVehicleDepots().size()); - Assert.assertEquals("j(4,3)R", carrierInformationElement.getVehicleDepots().get(0)); - Assert.assertEquals(1, carrierInformationElement.getVehicleTypes().length); - Assert.assertEquals("testVehicle2", carrierInformationElement.getVehicleTypes()[0]); + Assertions.assertNull(carrierInformationElement.getAreaOfAdditionalDepots()); + Assertions.assertEquals(3, carrierInformationElement.getFixedNumberOfVehiclePerTypeAndLocation()); + Assertions.assertEquals(FleetSize.FINITE, carrierInformationElement.getFleetSize()); + Assertions.assertEquals(15, carrierInformationElement.getJspritIterations()); + Assertions.assertEquals(3, carrierInformationElement.getNumberOfDepotsPerType()); + Assertions.assertEquals(3600, carrierInformationElement.getVehicleStartTime()); + Assertions.assertEquals(50000, carrierInformationElement.getVehicleEndTime()); + Assertions.assertEquals(1, carrierInformationElement.getVehicleDepots().size()); + Assertions.assertEquals("j(4,3)R", carrierInformationElement.getVehicleDepots().get(0)); + Assertions.assertEquals(1, carrierInformationElement.getVehicleTypes().length); + Assertions.assertEquals("testVehicle2", carrierInformationElement.getVehicleTypes()[0]); } else { - Assert.fail("No expected carrierInformationElement found"); + Assertions.fail("No expected carrierInformationElement found"); } } diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java index 7db97056e79..da396bb7a9e 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/DemandReaderFromCSVTest.java @@ -8,7 +8,7 @@ import java.util.Map; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -53,14 +53,14 @@ void testLinkForPerson() throws IOException { for (Person person : population.getPersons().values()) { DemandReaderFromCSV.findLinksForPersons(scenario, nearestLinkPerPerson, person); } - Assert.assertEquals("j(1,8)",nearestLinkPerPerson.get(Id.createPersonId("person1")).values().iterator().next()); - Assert.assertEquals("j(3,3)",nearestLinkPerPerson.get(Id.createPersonId("person2")).values().iterator().next()); - Assert.assertEquals("j(4,5)R",nearestLinkPerPerson.get(Id.createPersonId("person3")).values().iterator().next()); - Assert.assertEquals("j(5,3)",nearestLinkPerPerson.get(Id.createPersonId("person4")).values().iterator().next()); - Assert.assertEquals("j(5,6)",nearestLinkPerPerson.get(Id.createPersonId("person5")).values().iterator().next()); - Assert.assertEquals("j(8,8)R",nearestLinkPerPerson.get(Id.createPersonId("person6")).values().iterator().next()); - Assert.assertEquals("i(5,9)R",nearestLinkPerPerson.get(Id.createPersonId("person7")).values().iterator().next()); - Assert.assertEquals("i(9,5)R",nearestLinkPerPerson.get(Id.createPersonId("person8")).values().iterator().next()); + Assertions.assertEquals("j(1,8)",nearestLinkPerPerson.get(Id.createPersonId("person1")).values().iterator().next()); + Assertions.assertEquals("j(3,3)",nearestLinkPerPerson.get(Id.createPersonId("person2")).values().iterator().next()); + Assertions.assertEquals("j(4,5)R",nearestLinkPerPerson.get(Id.createPersonId("person3")).values().iterator().next()); + Assertions.assertEquals("j(5,3)",nearestLinkPerPerson.get(Id.createPersonId("person4")).values().iterator().next()); + Assertions.assertEquals("j(5,6)",nearestLinkPerPerson.get(Id.createPersonId("person5")).values().iterator().next()); + Assertions.assertEquals("j(8,8)R",nearestLinkPerPerson.get(Id.createPersonId("person6")).values().iterator().next()); + Assertions.assertEquals("i(5,9)R",nearestLinkPerPerson.get(Id.createPersonId("person7")).values().iterator().next()); + Assertions.assertEquals("i(9,5)R",nearestLinkPerPerson.get(Id.createPersonId("person8")).values().iterator().next()); @@ -95,12 +95,12 @@ void demandCreation() throws IOException { DemandReaderFromCSV.checkNewDemand(scenario, demandInformation, polygonsInShape, shapeCategory); DemandReaderFromCSV.createDemandForCarriers(scenario, polygonsInShape, demandInformation, population, false, null); - Assert.assertEquals(3, CarriersUtils.getCarriers(scenario).getCarriers().size()); - Assert.assertTrue( + Assertions.assertEquals(3, CarriersUtils.getCarriers(scenario).getCarriers().size()); + Assertions.assertTrue( CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("testCarrier1", Carrier.class))); - Assert.assertTrue( + Assertions.assertTrue( CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("testCarrier2", Carrier.class))); - Assert.assertTrue( + Assertions.assertTrue( CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("testCarrier3", Carrier.class))); // check carrier 1 @@ -108,8 +108,8 @@ void demandCreation() throws IOException { "https://raw.githubusercontent.com/matsim-org/matsim-libs/master/examples/scenarios/freight-chessboard-9x9/grid9x9.xml"); Carrier testCarrier1 = CarriersUtils.getCarriers(scenario).getCarriers() .get(Id.create("testCarrier1", Carrier.class)); - Assert.assertEquals(14, testCarrier1.getServices().size()); - Assert.assertEquals(0, testCarrier1.getShipments().size()); + Assertions.assertEquals(14, testCarrier1.getServices().size()); + Assertions.assertEquals(0, testCarrier1.getShipments().size()); Object2IntMap countServicesWithCertainDemand = new Object2IntOpenHashMap<>(); Map> locationsPerServiceElement = new HashMap<>(); int countDemand = 0; @@ -117,45 +117,45 @@ void demandCreation() throws IOException { countServicesWithCertainDemand.merge((Integer) service.getCapacityDemand(), 1, Integer::sum); countDemand = countDemand + service.getCapacityDemand(); if (service.getCapacityDemand() == 0) { - Assert.assertEquals(180, service.getServiceDuration(), MatsimTestUtils.EPSILON); - Assert.assertEquals(TimeWindow.newInstance(3000, 13000), service.getServiceStartTimeWindow()); + Assertions.assertEquals(180, service.getServiceDuration(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(TimeWindow.newInstance(3000, 13000), service.getServiceStartTimeWindow()); locationsPerServiceElement.computeIfAbsent("serviceElement1", (k) -> new HashSet<>()) .add(service.getLocationLinkId().toString()); } else if (service.getCapacityDemand() == 1) { - Assert.assertEquals(100, service.getServiceDuration(), MatsimTestUtils.EPSILON); - Assert.assertEquals(TimeWindow.newInstance(5000, 20000), service.getServiceStartTimeWindow()); + Assertions.assertEquals(100, service.getServiceDuration(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(TimeWindow.newInstance(5000, 20000), service.getServiceStartTimeWindow()); locationsPerServiceElement.computeIfAbsent("serviceElement2", (k) -> new HashSet<>()) .add(service.getLocationLinkId().toString()); } else if (service.getCapacityDemand() == 2) { - Assert.assertEquals(200, service.getServiceDuration(), MatsimTestUtils.EPSILON); - Assert.assertEquals(TimeWindow.newInstance(5000, 20000), service.getServiceStartTimeWindow()); + Assertions.assertEquals(200, service.getServiceDuration(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(TimeWindow.newInstance(5000, 20000), service.getServiceStartTimeWindow()); locationsPerServiceElement.computeIfAbsent("serviceElement2", (k) -> new HashSet<>()) .add(service.getLocationLinkId().toString()); } else - Assert.fail("Service has a wrong demand."); + Assertions.fail("Service has a wrong demand."); } - Assert.assertEquals(12, countDemand); - Assert.assertEquals(4, countServicesWithCertainDemand.getInt(0)); - Assert.assertEquals(8, countServicesWithCertainDemand.getInt(1)); - Assert.assertEquals(2, countServicesWithCertainDemand.getInt(2)); - Assert.assertEquals(4, locationsPerServiceElement.get("serviceElement1").size()); + Assertions.assertEquals(12, countDemand); + Assertions.assertEquals(4, countServicesWithCertainDemand.getInt(0)); + Assertions.assertEquals(8, countServicesWithCertainDemand.getInt(1)); + Assertions.assertEquals(2, countServicesWithCertainDemand.getInt(2)); + Assertions.assertEquals(4, locationsPerServiceElement.get("serviceElement1").size()); for (String locationsOfServiceElement : locationsPerServiceElement.get("serviceElement1")) { Link link = network.getLinks().get(Id.createLinkId(locationsOfServiceElement)); - Assert.assertTrue( + Assertions.assertTrue( FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, null, null)); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[] { "area1" }, null)); - Assert.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, + Assertions.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[] { "area2" }, null)); } - Assert.assertEquals(4, locationsPerServiceElement.get("serviceElement2").size()); - Assert.assertTrue(locationsPerServiceElement.get("serviceElement2").contains("i(2,0)")); + Assertions.assertEquals(4, locationsPerServiceElement.get("serviceElement2").size()); + Assertions.assertTrue(locationsPerServiceElement.get("serviceElement2").contains("i(2,0)")); // check carrier 2 Carrier testCarrier2 = CarriersUtils.getCarriers(scenario).getCarriers() .get(Id.create("testCarrier2", Carrier.class)); - Assert.assertEquals(0, testCarrier2.getServices().size()); - Assert.assertEquals(11, testCarrier2.getShipments().size()); + Assertions.assertEquals(0, testCarrier2.getServices().size()); + Assertions.assertEquals(11, testCarrier2.getShipments().size()); Object2IntMap countShipmentsWithCertainDemand = new Object2IntOpenHashMap<>(); Map> locationsPerShipmentElement = new HashMap<>(); countDemand = 0; @@ -163,77 +163,77 @@ void demandCreation() throws IOException { countShipmentsWithCertainDemand.merge((Integer) shipment.getSize(), 1, Integer::sum); countDemand = countDemand + shipment.getSize(); if (shipment.getSize() == 0) { - Assert.assertEquals(300, shipment.getPickupServiceTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(350, shipment.getDeliveryServiceTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(TimeWindow.newInstance(10000, 45000), shipment.getPickupTimeWindow()); - Assert.assertEquals(TimeWindow.newInstance(11000, 44000), shipment.getDeliveryTimeWindow()); + Assertions.assertEquals(300, shipment.getPickupServiceTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(350, shipment.getDeliveryServiceTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(TimeWindow.newInstance(10000, 45000), shipment.getPickupTimeWindow()); + Assertions.assertEquals(TimeWindow.newInstance(11000, 44000), shipment.getDeliveryTimeWindow()); locationsPerShipmentElement.computeIfAbsent("ShipmenElement1_pickup", (k) -> new HashSet<>()) .add(shipment.getFrom().toString()); locationsPerShipmentElement.computeIfAbsent("ShipmenElement1_delivery", (k) -> new HashSet<>()) .add(shipment.getTo().toString()); } else if (shipment.getSize() == 2) { - Assert.assertEquals(400, shipment.getPickupServiceTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(400, shipment.getDeliveryServiceTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(TimeWindow.newInstance(11000, 44000), shipment.getPickupTimeWindow()); - Assert.assertEquals(TimeWindow.newInstance(20000, 40000), shipment.getDeliveryTimeWindow()); + Assertions.assertEquals(400, shipment.getPickupServiceTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(400, shipment.getDeliveryServiceTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(TimeWindow.newInstance(11000, 44000), shipment.getPickupTimeWindow()); + Assertions.assertEquals(TimeWindow.newInstance(20000, 40000), shipment.getDeliveryTimeWindow()); locationsPerShipmentElement.computeIfAbsent("ShipmenElement2_pickup", (k) -> new HashSet<>()) .add(shipment.getFrom().toString()); locationsPerShipmentElement.computeIfAbsent("ShipmenElement2_delivery", (k) -> new HashSet<>()) .add(shipment.getTo().toString()); } else if (shipment.getSize() == 3) { - Assert.assertEquals(600, shipment.getPickupServiceTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(600, shipment.getDeliveryServiceTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(TimeWindow.newInstance(11000, 44000), shipment.getPickupTimeWindow()); - Assert.assertEquals(TimeWindow.newInstance(20000, 40000), shipment.getDeliveryTimeWindow()); + Assertions.assertEquals(600, shipment.getPickupServiceTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(600, shipment.getDeliveryServiceTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(TimeWindow.newInstance(11000, 44000), shipment.getPickupTimeWindow()); + Assertions.assertEquals(TimeWindow.newInstance(20000, 40000), shipment.getDeliveryTimeWindow()); locationsPerShipmentElement.computeIfAbsent("ShipmenElement2_pickup", (k) -> new HashSet<>()) .add(shipment.getFrom().toString()); locationsPerShipmentElement.computeIfAbsent("ShipmenElement2_delivery", (k) -> new HashSet<>()) .add(shipment.getTo().toString()); } else - Assert.fail("Shipment has an unexpected demand."); + Assertions.fail("Shipment has an unexpected demand."); } - Assert.assertEquals(15, countDemand); - Assert.assertEquals(4, countShipmentsWithCertainDemand.getInt(0)); - Assert.assertEquals(6, countShipmentsWithCertainDemand.getInt(2)); - Assert.assertEquals(1, countShipmentsWithCertainDemand.getInt(3)); - Assert.assertEquals(4, locationsPerShipmentElement.get("ShipmenElement1_pickup").size()); - Assert.assertEquals(1, locationsPerShipmentElement.get("ShipmenElement1_delivery").size()); - Assert.assertTrue(locationsPerShipmentElement.get("ShipmenElement1_delivery").contains("i(2,0)")); - Assert.assertEquals(1, locationsPerShipmentElement.get("ShipmenElement2_pickup").size()); - Assert.assertEquals(2, locationsPerShipmentElement.get("ShipmenElement2_delivery").size()); + Assertions.assertEquals(15, countDemand); + Assertions.assertEquals(4, countShipmentsWithCertainDemand.getInt(0)); + Assertions.assertEquals(6, countShipmentsWithCertainDemand.getInt(2)); + Assertions.assertEquals(1, countShipmentsWithCertainDemand.getInt(3)); + Assertions.assertEquals(4, locationsPerShipmentElement.get("ShipmenElement1_pickup").size()); + Assertions.assertEquals(1, locationsPerShipmentElement.get("ShipmenElement1_delivery").size()); + Assertions.assertTrue(locationsPerShipmentElement.get("ShipmenElement1_delivery").contains("i(2,0)")); + Assertions.assertEquals(1, locationsPerShipmentElement.get("ShipmenElement2_pickup").size()); + Assertions.assertEquals(2, locationsPerShipmentElement.get("ShipmenElement2_delivery").size()); // check carrier 3 Carrier testCarrier3 = CarriersUtils.getCarriers(scenario).getCarriers() .get(Id.create("testCarrier3", Carrier.class)); - Assert.assertEquals(0, testCarrier3.getServices().size()); - Assert.assertEquals(4, testCarrier3.getShipments().size()); + Assertions.assertEquals(0, testCarrier3.getServices().size()); + Assertions.assertEquals(4, testCarrier3.getShipments().size()); countShipmentsWithCertainDemand = new Object2IntOpenHashMap<>(); locationsPerShipmentElement = new HashMap<>(); countDemand = 0; for (CarrierShipment shipment : testCarrier3.getShipments().values()) { countShipmentsWithCertainDemand.merge((Integer) shipment.getSize(), 1, Integer::sum); countDemand = countDemand + shipment.getSize(); - Assert.assertEquals(5, shipment.getSize()); - Assert.assertEquals(2000, shipment.getPickupServiceTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1250, shipment.getDeliveryServiceTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(TimeWindow.newInstance(8000, 50000), shipment.getPickupTimeWindow()); - Assert.assertEquals(TimeWindow.newInstance(10000, 60000), shipment.getDeliveryTimeWindow()); + Assertions.assertEquals(5, shipment.getSize()); + Assertions.assertEquals(2000, shipment.getPickupServiceTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1250, shipment.getDeliveryServiceTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(TimeWindow.newInstance(8000, 50000), shipment.getPickupTimeWindow()); + Assertions.assertEquals(TimeWindow.newInstance(10000, 60000), shipment.getDeliveryTimeWindow()); locationsPerShipmentElement.computeIfAbsent("ShipmenElement1_pickup", (k) -> new HashSet<>()) .add(shipment.getFrom().toString()); locationsPerShipmentElement.computeIfAbsent("ShipmenElement1_delivery", (k) -> new HashSet<>()) .add(shipment.getTo().toString()); } - Assert.assertEquals(20, countDemand); - Assert.assertEquals(4, countShipmentsWithCertainDemand.getInt(5)); - Assert.assertEquals(2, locationsPerShipmentElement.get("ShipmenElement1_pickup").size()); - Assert.assertEquals(4, locationsPerShipmentElement.get("ShipmenElement1_delivery").size()); + Assertions.assertEquals(20, countDemand); + Assertions.assertEquals(4, countShipmentsWithCertainDemand.getInt(5)); + Assertions.assertEquals(2, locationsPerShipmentElement.get("ShipmenElement1_pickup").size()); + Assertions.assertEquals(4, locationsPerShipmentElement.get("ShipmenElement1_delivery").size()); for (String locationsOfShipmentElement : locationsPerShipmentElement.get("ShipmenElement1_delivery")) { Link link = network.getLinks().get(Id.createLinkId(locationsOfShipmentElement)); - Assert.assertTrue( + Assertions.assertTrue( FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, null, null)); - Assert.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, + Assertions.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[] { "area1" }, null)); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[] { "area2" }, null)); } } @@ -243,101 +243,101 @@ void csvDemandReader() throws IOException { Path demandCSVLocation = Path.of(utils.getPackageInputDirectory() + "testDemandCSV.csv"); Set demandInformation = DemandReaderFromCSV.readDemandInformation(demandCSVLocation); - Assert.assertEquals(5, demandInformation.size()); + Assertions.assertEquals(5, demandInformation.size()); for (DemandInformationElement demandInformationElement : demandInformation) { if (demandInformationElement.getCarrierName().equals("testCarrier1") && demandInformationElement.getNumberOfJobs() == 4) { - Assert.assertEquals(0, (int) demandInformationElement.getDemandToDistribute()); - Assert.assertNull(demandInformationElement.getShareOfPopulationWithFirstJobElement()); - Assert.assertEquals(1, demandInformationElement.getAreasFirstJobElement().length); - Assert.assertEquals("area2", demandInformationElement.getAreasFirstJobElement()[0]); - Assert.assertNull(demandInformationElement.getNumberOfFirstJobElementLocations()); - Assert.assertNull(demandInformationElement.getLocationsOfFirstJobElement()); - Assert.assertEquals(180, (int) demandInformationElement.getFirstJobElementTimePerUnit()); - Assert.assertEquals(TimeWindow.newInstance(3000, 13000), + Assertions.assertEquals(0, (int) demandInformationElement.getDemandToDistribute()); + Assertions.assertNull(demandInformationElement.getShareOfPopulationWithFirstJobElement()); + Assertions.assertEquals(1, demandInformationElement.getAreasFirstJobElement().length); + Assertions.assertEquals("area2", demandInformationElement.getAreasFirstJobElement()[0]); + Assertions.assertNull(demandInformationElement.getNumberOfFirstJobElementLocations()); + Assertions.assertNull(demandInformationElement.getLocationsOfFirstJobElement()); + Assertions.assertEquals(180, (int) demandInformationElement.getFirstJobElementTimePerUnit()); + Assertions.assertEquals(TimeWindow.newInstance(3000, 13000), demandInformationElement.getFirstJobElementTimeWindow()); - Assert.assertNull(demandInformationElement.getShareOfPopulationWithSecondJobElement()); - Assert.assertNull(demandInformationElement.getNumberOfSecondJobElementLocations()); - Assert.assertNull(demandInformationElement.getLocationsOfSecondJobElement()); - Assert.assertNull(demandInformationElement.getSecondJobElementTimePerUnit()); - Assert.assertNull(demandInformationElement.getSecondJobElementTimeWindow()); + Assertions.assertNull(demandInformationElement.getShareOfPopulationWithSecondJobElement()); + Assertions.assertNull(demandInformationElement.getNumberOfSecondJobElementLocations()); + Assertions.assertNull(demandInformationElement.getLocationsOfSecondJobElement()); + Assertions.assertNull(demandInformationElement.getSecondJobElementTimePerUnit()); + Assertions.assertNull(demandInformationElement.getSecondJobElementTimeWindow()); } else if (demandInformationElement.getCarrierName().equals("testCarrier1") && demandInformationElement.getNumberOfJobs() == 10) { - Assert.assertEquals(12, (int) demandInformationElement.getDemandToDistribute()); - Assert.assertNull(demandInformationElement.getShareOfPopulationWithFirstJobElement()); - Assert.assertNull(demandInformationElement.getAreasFirstJobElement()); - Assert.assertEquals(4, (int) demandInformationElement.getNumberOfFirstJobElementLocations()); - Assert.assertEquals(1, demandInformationElement.getLocationsOfFirstJobElement().length); - Assert.assertEquals("i(2,0)", demandInformationElement.getLocationsOfFirstJobElement()[0]); - Assert.assertEquals(100, (int) demandInformationElement.getFirstJobElementTimePerUnit()); - Assert.assertEquals(TimeWindow.newInstance(5000, 20000), + Assertions.assertEquals(12, (int) demandInformationElement.getDemandToDistribute()); + Assertions.assertNull(demandInformationElement.getShareOfPopulationWithFirstJobElement()); + Assertions.assertNull(demandInformationElement.getAreasFirstJobElement()); + Assertions.assertEquals(4, (int) demandInformationElement.getNumberOfFirstJobElementLocations()); + Assertions.assertEquals(1, demandInformationElement.getLocationsOfFirstJobElement().length); + Assertions.assertEquals("i(2,0)", demandInformationElement.getLocationsOfFirstJobElement()[0]); + Assertions.assertEquals(100, (int) demandInformationElement.getFirstJobElementTimePerUnit()); + Assertions.assertEquals(TimeWindow.newInstance(5000, 20000), demandInformationElement.getFirstJobElementTimeWindow()); - Assert.assertNull(demandInformationElement.getShareOfPopulationWithSecondJobElement()); - Assert.assertNull(demandInformationElement.getAreasSecondJobElement()); - Assert.assertNull(demandInformationElement.getNumberOfSecondJobElementLocations()); - Assert.assertNull(demandInformationElement.getLocationsOfSecondJobElement()); - Assert.assertNull(demandInformationElement.getSecondJobElementTimePerUnit()); - Assert.assertNull(demandInformationElement.getSecondJobElementTimeWindow()); + Assertions.assertNull(demandInformationElement.getShareOfPopulationWithSecondJobElement()); + Assertions.assertNull(demandInformationElement.getAreasSecondJobElement()); + Assertions.assertNull(demandInformationElement.getNumberOfSecondJobElementLocations()); + Assertions.assertNull(demandInformationElement.getLocationsOfSecondJobElement()); + Assertions.assertNull(demandInformationElement.getSecondJobElementTimePerUnit()); + Assertions.assertNull(demandInformationElement.getSecondJobElementTimeWindow()); } else if (demandInformationElement.getCarrierName().equals("testCarrier2") && demandInformationElement.getDemandToDistribute() == 0) { - Assert.assertEquals(0, (int) demandInformationElement.getDemandToDistribute()); - Assert.assertEquals(4, (int) demandInformationElement.getNumberOfJobs()); - Assert.assertNull(demandInformationElement.getShareOfPopulationWithFirstJobElement()); - Assert.assertNull(demandInformationElement.getAreasFirstJobElement()); - Assert.assertNull(demandInformationElement.getNumberOfFirstJobElementLocations()); - Assert.assertNull(demandInformationElement.getLocationsOfFirstJobElement()); - Assert.assertEquals(300, (int) demandInformationElement.getFirstJobElementTimePerUnit()); - Assert.assertEquals(TimeWindow.newInstance(10000, 45000), + Assertions.assertEquals(0, (int) demandInformationElement.getDemandToDistribute()); + Assertions.assertEquals(4, (int) demandInformationElement.getNumberOfJobs()); + Assertions.assertNull(demandInformationElement.getShareOfPopulationWithFirstJobElement()); + Assertions.assertNull(demandInformationElement.getAreasFirstJobElement()); + Assertions.assertNull(demandInformationElement.getNumberOfFirstJobElementLocations()); + Assertions.assertNull(demandInformationElement.getLocationsOfFirstJobElement()); + Assertions.assertEquals(300, (int) demandInformationElement.getFirstJobElementTimePerUnit()); + Assertions.assertEquals(TimeWindow.newInstance(10000, 45000), demandInformationElement.getFirstJobElementTimeWindow()); - Assert.assertNull(demandInformationElement.getShareOfPopulationWithSecondJobElement()); - Assert.assertNull(demandInformationElement.getAreasSecondJobElement()); - Assert.assertEquals(1, (int) demandInformationElement.getNumberOfSecondJobElementLocations()); - Assert.assertEquals(1, demandInformationElement.getLocationsOfSecondJobElement().length); - Assert.assertTrue(demandInformationElement.getLocationsOfSecondJobElement()[0].equals("i(2,0)")); - Assert.assertEquals(350, (int) demandInformationElement.getSecondJobElementTimePerUnit()); - Assert.assertEquals(TimeWindow.newInstance(11000, 44000), + Assertions.assertNull(demandInformationElement.getShareOfPopulationWithSecondJobElement()); + Assertions.assertNull(demandInformationElement.getAreasSecondJobElement()); + Assertions.assertEquals(1, (int) demandInformationElement.getNumberOfSecondJobElementLocations()); + Assertions.assertEquals(1, demandInformationElement.getLocationsOfSecondJobElement().length); + Assertions.assertTrue(demandInformationElement.getLocationsOfSecondJobElement()[0].equals("i(2,0)")); + Assertions.assertEquals(350, (int) demandInformationElement.getSecondJobElementTimePerUnit()); + Assertions.assertEquals(TimeWindow.newInstance(11000, 44000), demandInformationElement.getSecondJobElementTimeWindow()); } else if (demandInformationElement.getCarrierName().equals("testCarrier2") && demandInformationElement.getDemandToDistribute() == 15) { - Assert.assertEquals(15, (int) demandInformationElement.getDemandToDistribute()); - Assert.assertEquals(7, (int) demandInformationElement.getNumberOfJobs()); - Assert.assertNull(demandInformationElement.getShareOfPopulationWithFirstJobElement()); - Assert.assertNull(demandInformationElement.getAreasFirstJobElement()); - Assert.assertEquals(1, (int) demandInformationElement.getNumberOfFirstJobElementLocations()); - Assert.assertNull(demandInformationElement.getLocationsOfFirstJobElement()); - Assert.assertEquals(200, (int) demandInformationElement.getFirstJobElementTimePerUnit()); - Assert.assertEquals(TimeWindow.newInstance(11000, 44000), + Assertions.assertEquals(15, (int) demandInformationElement.getDemandToDistribute()); + Assertions.assertEquals(7, (int) demandInformationElement.getNumberOfJobs()); + Assertions.assertNull(demandInformationElement.getShareOfPopulationWithFirstJobElement()); + Assertions.assertNull(demandInformationElement.getAreasFirstJobElement()); + Assertions.assertEquals(1, (int) demandInformationElement.getNumberOfFirstJobElementLocations()); + Assertions.assertNull(demandInformationElement.getLocationsOfFirstJobElement()); + Assertions.assertEquals(200, (int) demandInformationElement.getFirstJobElementTimePerUnit()); + Assertions.assertEquals(TimeWindow.newInstance(11000, 44000), demandInformationElement.getFirstJobElementTimeWindow()); - Assert.assertNull(demandInformationElement.getShareOfPopulationWithSecondJobElement()); - Assert.assertNull(demandInformationElement.getAreasSecondJobElement()); - Assert.assertEquals(2, (int) demandInformationElement.getNumberOfSecondJobElementLocations()); - Assert.assertNull(demandInformationElement.getLocationsOfSecondJobElement()); - Assert.assertEquals(200, (int) demandInformationElement.getSecondJobElementTimePerUnit()); - Assert.assertEquals(TimeWindow.newInstance(20000, 40000), + Assertions.assertNull(demandInformationElement.getShareOfPopulationWithSecondJobElement()); + Assertions.assertNull(demandInformationElement.getAreasSecondJobElement()); + Assertions.assertEquals(2, (int) demandInformationElement.getNumberOfSecondJobElementLocations()); + Assertions.assertNull(demandInformationElement.getLocationsOfSecondJobElement()); + Assertions.assertEquals(200, (int) demandInformationElement.getSecondJobElementTimePerUnit()); + Assertions.assertEquals(TimeWindow.newInstance(20000, 40000), demandInformationElement.getSecondJobElementTimeWindow()); } else if (demandInformationElement.getCarrierName().equals("testCarrier3")) { - Assert.assertEquals(20, (int) demandInformationElement.getDemandToDistribute()); - Assert.assertNull(demandInformationElement.getNumberOfJobs()); - Assert.assertEquals(0.125, (double) demandInformationElement.getShareOfPopulationWithFirstJobElement(), + Assertions.assertEquals(20, (int) demandInformationElement.getDemandToDistribute()); + Assertions.assertNull(demandInformationElement.getNumberOfJobs()); + Assertions.assertEquals(0.125, (double) demandInformationElement.getShareOfPopulationWithFirstJobElement(), MatsimTestUtils.EPSILON); - Assert.assertNull(demandInformationElement.getAreasFirstJobElement()); - Assert.assertNull(demandInformationElement.getNumberOfFirstJobElementLocations()); - Assert.assertNull(demandInformationElement.getLocationsOfFirstJobElement()); - Assert.assertEquals(400, (int) demandInformationElement.getFirstJobElementTimePerUnit()); - Assert.assertEquals(TimeWindow.newInstance(8000, 50000), + Assertions.assertNull(demandInformationElement.getAreasFirstJobElement()); + Assertions.assertNull(demandInformationElement.getNumberOfFirstJobElementLocations()); + Assertions.assertNull(demandInformationElement.getLocationsOfFirstJobElement()); + Assertions.assertEquals(400, (int) demandInformationElement.getFirstJobElementTimePerUnit()); + Assertions.assertEquals(TimeWindow.newInstance(8000, 50000), demandInformationElement.getFirstJobElementTimeWindow()); - Assert.assertEquals(0.4, (double) demandInformationElement.getShareOfPopulationWithSecondJobElement(), + Assertions.assertEquals(0.4, (double) demandInformationElement.getShareOfPopulationWithSecondJobElement(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, demandInformationElement.getAreasSecondJobElement().length); - Assert.assertEquals("area1", demandInformationElement.getAreasSecondJobElement()[0]); - Assert.assertNull(demandInformationElement.getNumberOfSecondJobElementLocations()); - Assert.assertNull(demandInformationElement.getLocationsOfSecondJobElement()); - Assert.assertEquals(250, (int) demandInformationElement.getSecondJobElementTimePerUnit()); - Assert.assertEquals(TimeWindow.newInstance(10000, 60000), + Assertions.assertEquals(1, demandInformationElement.getAreasSecondJobElement().length); + Assertions.assertEquals("area1", demandInformationElement.getAreasSecondJobElement()[0]); + Assertions.assertNull(demandInformationElement.getNumberOfSecondJobElementLocations()); + Assertions.assertNull(demandInformationElement.getLocationsOfSecondJobElement()); + Assertions.assertEquals(250, (int) demandInformationElement.getSecondJobElementTimePerUnit()); + Assertions.assertEquals(TimeWindow.newInstance(10000, 60000), demandInformationElement.getSecondJobElementTimeWindow()); } else - Assert.fail("No expected demandInformationElement found"); + Assertions.fail("No expected demandInformationElement found"); } } } diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java index f1285ff809a..a79ca63b52d 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationTest.java @@ -1,7 +1,7 @@ package org.matsim.freightDemandGeneration; import org.apache.logging.log4j.LogManager; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -57,7 +57,7 @@ void testMain() { LogManager.getLogger(this.getClass()).fatal("there was an exception: \n" + ee); ee.printStackTrace(); // if one catches an exception, then one needs to explicitly fail the test: - Assert.fail(); + Assertions.fail(); } } } diff --git a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java index cedeccd9dfb..e1528caf871 100644 --- a/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java +++ b/contribs/application/src/test/java/org/matsim/freightDemandGeneration/FreightDemandGenerationUtilsTest.java @@ -3,7 +3,7 @@ import java.nio.file.Path; import java.util.Collection; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.locationtech.jts.geom.Point; @@ -34,50 +34,50 @@ void testPreparePopulation() { String populationLocation = utils.getPackageInputDirectory() + "testPopulation.xml"; Population population = PopulationUtils.readPopulation(populationLocation); FreightDemandGenerationUtils.preparePopulation(population, 1.0, 1.0, "changeNumberOfLocationsWithDemand"); - Assert.assertEquals(8, population.getPersons().size()); - Assert.assertEquals(1.0,population.getAttributes().getAttribute("sampleSize")); - Assert.assertEquals(1.0,population.getAttributes().getAttribute("samplingTo")); - Assert.assertEquals("changeNumberOfLocationsWithDemand",population.getAttributes().getAttribute("samplingOption")); + Assertions.assertEquals(8, population.getPersons().size()); + Assertions.assertEquals(1.0,population.getAttributes().getAttribute("sampleSize")); + Assertions.assertEquals(1.0,population.getAttributes().getAttribute("samplingTo")); + Assertions.assertEquals("changeNumberOfLocationsWithDemand",population.getAttributes().getAttribute("samplingOption")); Person person = population.getPersons().get(Id.createPersonId("person1")); - Assert.assertEquals(1200.0,person.getAttributes().getAttribute("homeX")); - Assert.assertEquals(7700.0,person.getAttributes().getAttribute("homeY")); - Assert.assertEquals(0, person.getPlans().size()); - Assert.assertNull(person.getSelectedPlan()); + Assertions.assertEquals(1200.0,person.getAttributes().getAttribute("homeX")); + Assertions.assertEquals(7700.0,person.getAttributes().getAttribute("homeY")); + Assertions.assertEquals(0, person.getPlans().size()); + Assertions.assertNull(person.getSelectedPlan()); person = population.getPersons().get(Id.createPersonId("person2")); - Assert.assertEquals(2900.0,person.getAttributes().getAttribute("homeX")); - Assert.assertEquals(2800.0,person.getAttributes().getAttribute("homeY")); - Assert.assertEquals(0, person.getPlans().size()); - Assert.assertNull(person.getSelectedPlan()); + Assertions.assertEquals(2900.0,person.getAttributes().getAttribute("homeX")); + Assertions.assertEquals(2800.0,person.getAttributes().getAttribute("homeY")); + Assertions.assertEquals(0, person.getPlans().size()); + Assertions.assertNull(person.getSelectedPlan()); person = population.getPersons().get(Id.createPersonId("person3")); - Assert.assertEquals(4200.0,person.getAttributes().getAttribute("homeX")); - Assert.assertEquals(4400.0,person.getAttributes().getAttribute("homeY")); - Assert.assertEquals(0, person.getPlans().size()); - Assert.assertNull(person.getSelectedPlan()); + Assertions.assertEquals(4200.0,person.getAttributes().getAttribute("homeX")); + Assertions.assertEquals(4400.0,person.getAttributes().getAttribute("homeY")); + Assertions.assertEquals(0, person.getPlans().size()); + Assertions.assertNull(person.getSelectedPlan()); person = population.getPersons().get(Id.createPersonId("person4")); - Assert.assertEquals(5200.0,person.getAttributes().getAttribute("homeX")); - Assert.assertEquals(2600.0,person.getAttributes().getAttribute("homeY")); - Assert.assertEquals(0, person.getPlans().size()); - Assert.assertNull(person.getSelectedPlan()); + Assertions.assertEquals(5200.0,person.getAttributes().getAttribute("homeX")); + Assertions.assertEquals(2600.0,person.getAttributes().getAttribute("homeY")); + Assertions.assertEquals(0, person.getPlans().size()); + Assertions.assertNull(person.getSelectedPlan()); person = population.getPersons().get(Id.createPersonId("person5")); - Assert.assertEquals(5200.0,person.getAttributes().getAttribute("homeX")); - Assert.assertEquals(5500.0,person.getAttributes().getAttribute("homeY")); - Assert.assertEquals(0, person.getPlans().size()); - Assert.assertNull(person.getSelectedPlan()); + Assertions.assertEquals(5200.0,person.getAttributes().getAttribute("homeX")); + Assertions.assertEquals(5500.0,person.getAttributes().getAttribute("homeY")); + Assertions.assertEquals(0, person.getPlans().size()); + Assertions.assertNull(person.getSelectedPlan()); person = population.getPersons().get(Id.createPersonId("person6")); - Assert.assertEquals(7900.0,person.getAttributes().getAttribute("homeX")); - Assert.assertEquals(7500.0,person.getAttributes().getAttribute("homeY")); - Assert.assertEquals(0, person.getPlans().size()); - Assert.assertNull(person.getSelectedPlan()); + Assertions.assertEquals(7900.0,person.getAttributes().getAttribute("homeX")); + Assertions.assertEquals(7500.0,person.getAttributes().getAttribute("homeY")); + Assertions.assertEquals(0, person.getPlans().size()); + Assertions.assertNull(person.getSelectedPlan()); person = population.getPersons().get(Id.createPersonId("person7")); - Assert.assertEquals(4900.0,person.getAttributes().getAttribute("homeX")); - Assert.assertEquals(8900.0,person.getAttributes().getAttribute("homeY")); - Assert.assertEquals(0, person.getPlans().size()); - Assert.assertNull(person.getSelectedPlan()); + Assertions.assertEquals(4900.0,person.getAttributes().getAttribute("homeX")); + Assertions.assertEquals(8900.0,person.getAttributes().getAttribute("homeY")); + Assertions.assertEquals(0, person.getPlans().size()); + Assertions.assertNull(person.getSelectedPlan()); person = population.getPersons().get(Id.createPersonId("person8")); - Assert.assertEquals(8400.0,person.getAttributes().getAttribute("homeX")); - Assert.assertEquals(5200.0,person.getAttributes().getAttribute("homeY")); - Assert.assertEquals(0, person.getPlans().size()); - Assert.assertNull(person.getSelectedPlan()); + Assertions.assertEquals(8400.0,person.getAttributes().getAttribute("homeX")); + Assertions.assertEquals(5200.0,person.getAttributes().getAttribute("homeY")); + Assertions.assertEquals(0, person.getPlans().size()); + Assertions.assertNull(person.getSelectedPlan()); } @Test @@ -85,12 +85,12 @@ void testCoordOfMiddlePointOfLink() { Network network = NetworkUtils.readNetwork("https://raw.githubusercontent.com/matsim-org/matsim-libs/master/examples/scenarios/freight-chessboard-9x9/grid9x9.xml"); Link link = network.getLinks().get(Id.createLinkId("i(8,8)")); Coord middlePoint = FreightDemandGenerationUtils.getCoordOfMiddlePointOfLink(link); - Assert.assertEquals(7500, middlePoint.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals(8000, middlePoint.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7500, middlePoint.getX(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8000, middlePoint.getY(), MatsimTestUtils.EPSILON); Link link2 = network.getLinks().get(Id.createLinkId("j(5,8)")); Coord middlePoint2 = FreightDemandGenerationUtils.getCoordOfMiddlePointOfLink(link2); - Assert.assertEquals(5000, middlePoint2.getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals(7500, middlePoint2.getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5000, middlePoint2.getX(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7500, middlePoint2.getY(), MatsimTestUtils.EPSILON); } @Test @@ -102,9 +102,9 @@ void testReducePopulationToShapeArea() { ShpOptions shp = new ShpOptions(shapeFilePath,"WGS84", null); ShpOptions.Index index = shp.createIndex("WGS84", "_"); FreightDemandGenerationUtils.reducePopulationToShapeArea(population, index); - Assert.assertEquals(6, population.getPersons().size()); - Assert.assertFalse(population.getPersons().containsKey(Id.createPersonId("person2"))); - Assert.assertFalse(population.getPersons().containsKey(Id.createPersonId("person4"))); + Assertions.assertEquals(6, population.getPersons().size()); + Assertions.assertFalse(population.getPersons().containsKey(Id.createPersonId("person2"))); + Assertions.assertFalse(population.getPersons().containsKey(Id.createPersonId("person4"))); } @Test @@ -114,13 +114,13 @@ void testCheckPositionInShape_link() { Path shapeFilePath = Path.of(utils.getPackageInputDirectory() + "testShape/testShape.shp"); ShpOptions shp = new ShpOptions(shapeFilePath,"WGS84", null); Collection polygonsInShape = shp.readFeatures(); - Assert.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, null, null)); - Assert.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area1"}, null)); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area2"}, null)); + Assertions.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, null, null)); + Assertions.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area1"}, null)); + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area2"}, null)); link = network.getLinks().get(Id.createLinkId("i(6,3)R")); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, null, null)); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area1"}, null)); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area2"}, null)); + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, null, null)); + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area1"}, null)); + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(link, null, polygonsInShape, new String[]{"area2"}, null)); } @@ -130,13 +130,13 @@ void testCheckPositionInShape_point() { ShpOptions shp = new ShpOptions(shapeFilePath,"WGS84", null); Collection polygonsInShape = shp.readFeatures(); Point point = MGC.xy2Point(6000, 6000); - Assert.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, null, null)); - Assert.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, new String[]{"area1"}, null)); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, new String[]{"area2"}, null)); + Assertions.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, null, null)); + Assertions.assertTrue(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, new String[]{"area1"}, null)); + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, new String[]{"area2"}, null)); point = MGC.xy2Point(2000, 2000); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, null, null)); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, new String[]{"area1"}, null)); - Assert.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, new String[]{"area2"}, null)); + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, null, null)); + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, new String[]{"area1"}, null)); + Assertions.assertFalse(FreightDemandGenerationUtils.checkPositionInShape(null, point, polygonsInShape, new String[]{"area2"}, null)); } } diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java index 4255b694d0e..9957d7ef446 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/LanduseBuildingAnalysisTest.java @@ -20,7 +20,7 @@ package org.matsim.smallScaleCommercialTrafficGeneration; import it.unimi.dsi.fastutil.objects.Object2DoubleMap; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.application.options.ShpOptions; @@ -65,24 +65,24 @@ void testReadOfDataDistributionPerZoneAndBuildingAnalysis() throws IOException { inputDataDirectory, usedLanduseConfiguration, shapeFileLandusePath, shapeFileZonePath, shapeFileBuildingsPath, null, buildingsPerZone); - Assert.assertEquals(3, resultingDataPerZone.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, resultingDataPerZone.size(), MatsimTestUtils.EPSILON); - Assert.assertTrue(resultingDataPerZone.containsKey("testArea1_area1")); - Assert.assertTrue(resultingDataPerZone.containsKey("testArea1_area2")); - Assert.assertTrue(resultingDataPerZone.containsKey("testArea2_area3")); + Assertions.assertTrue(resultingDataPerZone.containsKey("testArea1_area1")); + Assertions.assertTrue(resultingDataPerZone.containsKey("testArea1_area2")); + Assertions.assertTrue(resultingDataPerZone.containsKey("testArea2_area3")); for (String zone : resultingDataPerZone.keySet()) { Object2DoubleMap categories = resultingDataPerZone.get(zone); int employeeSum = 0; - Assert.assertEquals(8, categories.size(), MatsimTestUtils.EPSILON); - Assert.assertTrue(categories.containsKey("Inhabitants")); - Assert.assertTrue(categories.containsKey("Employee")); - Assert.assertTrue(categories.containsKey("Employee Primary Sector")); - Assert.assertTrue(categories.containsKey("Employee Construction")); - Assert.assertTrue(categories.containsKey("Employee Secondary Sector Rest")); - Assert.assertTrue(categories.containsKey("Employee Retail")); - Assert.assertTrue(categories.containsKey("Employee Traffic/Parcels")); - Assert.assertTrue(categories.containsKey("Employee Tertiary Sector Rest")); + Assertions.assertEquals(8, categories.size(), MatsimTestUtils.EPSILON); + Assertions.assertTrue(categories.containsKey("Inhabitants")); + Assertions.assertTrue(categories.containsKey("Employee")); + Assertions.assertTrue(categories.containsKey("Employee Primary Sector")); + Assertions.assertTrue(categories.containsKey("Employee Construction")); + Assertions.assertTrue(categories.containsKey("Employee Secondary Sector Rest")); + Assertions.assertTrue(categories.containsKey("Employee Retail")); + Assertions.assertTrue(categories.containsKey("Employee Traffic/Parcels")); + Assertions.assertTrue(categories.containsKey("Employee Tertiary Sector Rest")); employeeSum += (int) categories.getDouble("Employee Primary Sector"); employeeSum += (int) categories.getDouble("Employee Construction"); @@ -91,60 +91,60 @@ void testReadOfDataDistributionPerZoneAndBuildingAnalysis() throws IOException { employeeSum += (int) categories.getDouble("Employee Traffic/Parcels"); employeeSum += (int) categories.getDouble("Employee Tertiary Sector Rest"); - Assert.assertEquals(categories.getDouble("Employee"), employeeSum, MatsimTestUtils.EPSILON); + Assertions.assertEquals(categories.getDouble("Employee"), employeeSum, MatsimTestUtils.EPSILON); if (zone.equals("testArea1_area1")) { - Assert.assertEquals(4000, resultingDataPerZone.get(zone).getDouble("Inhabitants"), + Assertions.assertEquals(4000, resultingDataPerZone.get(zone).getDouble("Inhabitants"), MatsimTestUtils.EPSILON); - Assert.assertEquals(3500, resultingDataPerZone.get(zone).getDouble("Employee"), + Assertions.assertEquals(3500, resultingDataPerZone.get(zone).getDouble("Employee"), MatsimTestUtils.EPSILON); - Assert.assertEquals(0, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), + Assertions.assertEquals(0, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Construction"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Construction"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), MatsimTestUtils.EPSILON); - Assert.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee Retail"), + Assertions.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee Retail"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), MatsimTestUtils.EPSILON); - Assert.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), + Assertions.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), MatsimTestUtils.EPSILON); } if (zone.equals("testArea1_area2")) { - Assert.assertEquals(4000, resultingDataPerZone.get(zone).getDouble("Inhabitants"), + Assertions.assertEquals(4000, resultingDataPerZone.get(zone).getDouble("Inhabitants"), MatsimTestUtils.EPSILON); - Assert.assertEquals(6500, resultingDataPerZone.get(zone).getDouble("Employee"), + Assertions.assertEquals(6500, resultingDataPerZone.get(zone).getDouble("Employee"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), MatsimTestUtils.EPSILON); - Assert.assertEquals(1500, resultingDataPerZone.get(zone).getDouble("Employee Construction"), + Assertions.assertEquals(1500, resultingDataPerZone.get(zone).getDouble("Employee Construction"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Retail"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Retail"), MatsimTestUtils.EPSILON); - Assert.assertEquals(1500, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), + Assertions.assertEquals(1500, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), MatsimTestUtils.EPSILON); - Assert.assertEquals(2000, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), + Assertions.assertEquals(2000, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), MatsimTestUtils.EPSILON); } if (zone.equals("testArea2_area3")) { - Assert.assertEquals(800, resultingDataPerZone.get(zone).getDouble("Inhabitants"), + Assertions.assertEquals(800, resultingDataPerZone.get(zone).getDouble("Inhabitants"), MatsimTestUtils.EPSILON); - Assert.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee"), + Assertions.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee"), MatsimTestUtils.EPSILON); - Assert.assertEquals(50, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), + Assertions.assertEquals(50, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), MatsimTestUtils.EPSILON); - Assert.assertEquals(200, resultingDataPerZone.get(zone).getDouble("Employee Construction"), + Assertions.assertEquals(200, resultingDataPerZone.get(zone).getDouble("Employee Construction"), MatsimTestUtils.EPSILON); - Assert.assertEquals(100, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), + Assertions.assertEquals(100, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), MatsimTestUtils.EPSILON); - Assert.assertEquals(150, resultingDataPerZone.get(zone).getDouble("Employee Retail"), + Assertions.assertEquals(150, resultingDataPerZone.get(zone).getDouble("Employee Retail"), MatsimTestUtils.EPSILON); - Assert.assertEquals(200, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), + Assertions.assertEquals(200, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), MatsimTestUtils.EPSILON); - Assert.assertEquals(300, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), + Assertions.assertEquals(300, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), MatsimTestUtils.EPSILON); } } @@ -153,89 +153,89 @@ void testReadOfDataDistributionPerZoneAndBuildingAnalysis() throws IOException { Index indexZones = SmallScaleCommercialTrafficUtils.getIndexZones(shapeFileZonePath, shapeCRS); ShpOptions shpBuildings = new ShpOptions(shapeFileBuildingsPath, null, StandardCharsets.UTF_8); List buildingsFeatures = shpBuildings.readFeatures(); - Assert.assertEquals(31, buildingsFeatures.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(31, buildingsFeatures.size(), MatsimTestUtils.EPSILON); LanduseBuildingAnalysis.analyzeBuildingType(buildingsFeatures, buildingsPerZone, landuseCategoriesAndDataConnection, shapeFileLandusePath, indexZones, shapeCRS); - Assert.assertEquals(3, buildingsPerZone.size(), MatsimTestUtils.EPSILON); - Assert.assertTrue(buildingsPerZone.containsKey("testArea1_area1")); - Assert.assertTrue(buildingsPerZone.containsKey("testArea1_area2")); - Assert.assertTrue(buildingsPerZone.containsKey("testArea2_area3")); + Assertions.assertEquals(3, buildingsPerZone.size(), MatsimTestUtils.EPSILON); + Assertions.assertTrue(buildingsPerZone.containsKey("testArea1_area1")); + Assertions.assertTrue(buildingsPerZone.containsKey("testArea1_area2")); + Assertions.assertTrue(buildingsPerZone.containsKey("testArea2_area3")); // test for area1 HashMap> builingsPerArea1 = buildingsPerZone.get("testArea1_area1"); - Assert.assertEquals(7, builingsPerArea1.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7, builingsPerArea1.size(), MatsimTestUtils.EPSILON); ArrayList inhabitantsBuildings = builingsPerArea1.get("Inhabitants"); - Assert.assertEquals(4, inhabitantsBuildings.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, inhabitantsBuildings.size(), MatsimTestUtils.EPSILON); for (SimpleFeature singleBuilding : inhabitantsBuildings) { int id = (int) (long) singleBuilding.getAttribute("osm_id"); if (id == 11) { - Assert.assertEquals("2", String.valueOf(singleBuilding.getAttribute("levels"))); - Assert.assertEquals("apartments", String.valueOf(singleBuilding.getAttribute("type"))); + Assertions.assertEquals("2", String.valueOf(singleBuilding.getAttribute("levels"))); + Assertions.assertEquals("apartments", String.valueOf(singleBuilding.getAttribute("type"))); } else if (id == 12) { - Assert.assertEquals("1", String.valueOf(singleBuilding.getAttribute("levels"))); - Assert.assertEquals("house", String.valueOf(singleBuilding.getAttribute("type"))); + Assertions.assertEquals("1", String.valueOf(singleBuilding.getAttribute("levels"))); + Assertions.assertEquals("house", String.valueOf(singleBuilding.getAttribute("type"))); } else if (id == 13) { - Assert.assertEquals("2", String.valueOf(singleBuilding.getAttribute("levels"))); - Assert.assertEquals("residential", String.valueOf(singleBuilding.getAttribute("type"))); + Assertions.assertEquals("2", String.valueOf(singleBuilding.getAttribute("levels"))); + Assertions.assertEquals("residential", String.valueOf(singleBuilding.getAttribute("type"))); } else if (id == 19) { - Assert.assertEquals("2", String.valueOf(singleBuilding.getAttribute("levels"))); - Assert.assertEquals("detached", String.valueOf(singleBuilding.getAttribute("type"))); + Assertions.assertEquals("2", String.valueOf(singleBuilding.getAttribute("levels"))); + Assertions.assertEquals("detached", String.valueOf(singleBuilding.getAttribute("type"))); } else - Assert.fail(); + Assertions.fail(); } - Assert.assertFalse(builingsPerArea1.containsKey("Employee Primary Sector")); - Assert.assertEquals(1, builingsPerArea1.get("Employee Construction").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, builingsPerArea1.get("Employee Secondary Sector Rest").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, builingsPerArea1.get("Employee Retail").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, builingsPerArea1.get("Employee Traffic/Parcels").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, builingsPerArea1.get("Employee Tertiary Sector Rest").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(6, builingsPerArea1.get("Employee").size(), MatsimTestUtils.EPSILON); + Assertions.assertFalse(builingsPerArea1.containsKey("Employee Primary Sector")); + Assertions.assertEquals(1, builingsPerArea1.get("Employee Construction").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, builingsPerArea1.get("Employee Secondary Sector Rest").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, builingsPerArea1.get("Employee Retail").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, builingsPerArea1.get("Employee Traffic/Parcels").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, builingsPerArea1.get("Employee Tertiary Sector Rest").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, builingsPerArea1.get("Employee").size(), MatsimTestUtils.EPSILON); // test for area2 HashMap> builingsPerArea2 = buildingsPerZone.get("testArea1_area2"); - Assert.assertEquals(8, builingsPerArea2.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8, builingsPerArea2.size(), MatsimTestUtils.EPSILON); ArrayList employeeRetail = builingsPerArea2.get("Employee Retail"); - Assert.assertEquals(2, employeeRetail.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, employeeRetail.size(), MatsimTestUtils.EPSILON); for (SimpleFeature singleBuilding : employeeRetail) { int id = (int) (long) singleBuilding.getAttribute("osm_id"); if (id == 1) { - Assert.assertEquals("1", String.valueOf(singleBuilding.getAttribute("levels"))); - Assert.assertEquals("retail", String.valueOf(singleBuilding.getAttribute("type"))); + Assertions.assertEquals("1", String.valueOf(singleBuilding.getAttribute("levels"))); + Assertions.assertEquals("retail", String.valueOf(singleBuilding.getAttribute("type"))); } else if (id == 3) { - Assert.assertEquals("2", String.valueOf(singleBuilding.getAttribute("levels"))); - Assert.assertEquals("retail", String.valueOf(singleBuilding.getAttribute("type"))); + Assertions.assertEquals("2", String.valueOf(singleBuilding.getAttribute("levels"))); + Assertions.assertEquals("retail", String.valueOf(singleBuilding.getAttribute("type"))); } else - Assert.fail(); + Assertions.fail(); } - Assert.assertEquals(2, builingsPerArea2.get("Inhabitants").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, builingsPerArea2.get("Employee Primary Sector").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, builingsPerArea2.get("Employee Construction").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, builingsPerArea2.get("Employee Secondary Sector Rest").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, builingsPerArea2.get("Employee Traffic/Parcels").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, builingsPerArea2.get("Employee Tertiary Sector Rest").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(8, builingsPerArea2.get("Employee").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, builingsPerArea2.get("Inhabitants").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, builingsPerArea2.get("Employee Primary Sector").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, builingsPerArea2.get("Employee Construction").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, builingsPerArea2.get("Employee Secondary Sector Rest").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, builingsPerArea2.get("Employee Traffic/Parcels").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, builingsPerArea2.get("Employee Tertiary Sector Rest").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8, builingsPerArea2.get("Employee").size(), MatsimTestUtils.EPSILON); // test for area3 HashMap> builingsPerArea3 = buildingsPerZone.get("testArea2_area3"); - Assert.assertEquals(8, builingsPerArea3.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8, builingsPerArea3.size(), MatsimTestUtils.EPSILON); ArrayList tertiaryRetail = builingsPerArea3.get("Employee Tertiary Sector Rest"); - Assert.assertEquals(1, tertiaryRetail.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, tertiaryRetail.size(), MatsimTestUtils.EPSILON); for (SimpleFeature singleBuilding : tertiaryRetail) { int id = (int) (long) singleBuilding.getAttribute("osm_id"); if (id == 26) { - Assert.assertEquals("2", String.valueOf(singleBuilding.getAttribute("levels"))); - Assert.assertEquals("foundation", String.valueOf(singleBuilding.getAttribute("type"))); + Assertions.assertEquals("2", String.valueOf(singleBuilding.getAttribute("levels"))); + Assertions.assertEquals("foundation", String.valueOf(singleBuilding.getAttribute("type"))); } else - Assert.fail(); + Assertions.fail(); } - Assert.assertEquals(3, builingsPerArea3.get("Inhabitants").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, builingsPerArea3.get("Employee Primary Sector").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, builingsPerArea3.get("Employee Construction").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, builingsPerArea3.get("Employee Secondary Sector Rest").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, builingsPerArea3.get("Employee Traffic/Parcels").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, builingsPerArea3.get("Employee Retail").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(7, builingsPerArea3.get("Employee").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, builingsPerArea3.get("Inhabitants").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, builingsPerArea3.get("Employee Primary Sector").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, builingsPerArea3.get("Employee Construction").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, builingsPerArea3.get("Employee Secondary Sector Rest").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, builingsPerArea3.get("Employee Traffic/Parcels").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, builingsPerArea3.get("Employee Retail").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7, builingsPerArea3.get("Employee").size(), MatsimTestUtils.EPSILON); } @Test @@ -257,24 +257,24 @@ void testLanduseDistribution() throws IOException { inputDataDirectory, usedLanduseConfiguration, shapeFileLandusePath, shapeFileZonePath, shapeFileBuildingsPath, null, buildingsPerZone); - Assert.assertEquals(3, resultingDataPerZone.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, resultingDataPerZone.size(), MatsimTestUtils.EPSILON); - Assert.assertTrue(resultingDataPerZone.containsKey("testArea1_area1")); - Assert.assertTrue(resultingDataPerZone.containsKey("testArea1_area2")); - Assert.assertTrue(resultingDataPerZone.containsKey("testArea2_area3")); + Assertions.assertTrue(resultingDataPerZone.containsKey("testArea1_area1")); + Assertions.assertTrue(resultingDataPerZone.containsKey("testArea1_area2")); + Assertions.assertTrue(resultingDataPerZone.containsKey("testArea2_area3")); for (String zone : resultingDataPerZone.keySet()) { Object2DoubleMap categories = resultingDataPerZone.get(zone); int employeeSum = 0; - Assert.assertEquals(8, categories.size(), MatsimTestUtils.EPSILON); - Assert.assertTrue(categories.containsKey("Inhabitants")); - Assert.assertTrue(categories.containsKey("Employee")); - Assert.assertTrue(categories.containsKey("Employee Primary Sector")); - Assert.assertTrue(categories.containsKey("Employee Construction")); - Assert.assertTrue(categories.containsKey("Employee Secondary Sector Rest")); - Assert.assertTrue(categories.containsKey("Employee Retail")); - Assert.assertTrue(categories.containsKey("Employee Traffic/Parcels")); - Assert.assertTrue(categories.containsKey("Employee Tertiary Sector Rest")); + Assertions.assertEquals(8, categories.size(), MatsimTestUtils.EPSILON); + Assertions.assertTrue(categories.containsKey("Inhabitants")); + Assertions.assertTrue(categories.containsKey("Employee")); + Assertions.assertTrue(categories.containsKey("Employee Primary Sector")); + Assertions.assertTrue(categories.containsKey("Employee Construction")); + Assertions.assertTrue(categories.containsKey("Employee Secondary Sector Rest")); + Assertions.assertTrue(categories.containsKey("Employee Retail")); + Assertions.assertTrue(categories.containsKey("Employee Traffic/Parcels")); + Assertions.assertTrue(categories.containsKey("Employee Tertiary Sector Rest")); employeeSum += (int) categories.getDouble("Employee Primary Sector"); employeeSum += (int) categories.getDouble("Employee Construction"); @@ -283,60 +283,60 @@ void testLanduseDistribution() throws IOException { employeeSum += (int) categories.getDouble("Employee Traffic/Parcels"); employeeSum += (int) categories.getDouble("Employee Tertiary Sector Rest"); - Assert.assertEquals(categories.getDouble("Employee"), employeeSum, MatsimTestUtils.EPSILON); + Assertions.assertEquals(categories.getDouble("Employee"), employeeSum, MatsimTestUtils.EPSILON); if (zone.equals("testArea1_area1")) { - Assert.assertEquals(4000, resultingDataPerZone.get(zone).getDouble("Inhabitants"), + Assertions.assertEquals(4000, resultingDataPerZone.get(zone).getDouble("Inhabitants"), MatsimTestUtils.EPSILON); - Assert.assertEquals(3500, resultingDataPerZone.get(zone).getDouble("Employee"), + Assertions.assertEquals(3500, resultingDataPerZone.get(zone).getDouble("Employee"), MatsimTestUtils.EPSILON); - Assert.assertEquals(0, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), + Assertions.assertEquals(0, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Construction"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Construction"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), MatsimTestUtils.EPSILON); - Assert.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee Retail"), + Assertions.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee Retail"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), MatsimTestUtils.EPSILON); - Assert.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), + Assertions.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), MatsimTestUtils.EPSILON); } if (zone.equals("testArea1_area2")) { - Assert.assertEquals(4000, resultingDataPerZone.get(zone).getDouble("Inhabitants"), + Assertions.assertEquals(4000, resultingDataPerZone.get(zone).getDouble("Inhabitants"), MatsimTestUtils.EPSILON); - Assert.assertEquals(6500, resultingDataPerZone.get(zone).getDouble("Employee"), + Assertions.assertEquals(6500, resultingDataPerZone.get(zone).getDouble("Employee"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), MatsimTestUtils.EPSILON); - Assert.assertEquals(1500, resultingDataPerZone.get(zone).getDouble("Employee Construction"), + Assertions.assertEquals(1500, resultingDataPerZone.get(zone).getDouble("Employee Construction"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), MatsimTestUtils.EPSILON); - Assert.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Retail"), + Assertions.assertEquals(500, resultingDataPerZone.get(zone).getDouble("Employee Retail"), MatsimTestUtils.EPSILON); - Assert.assertEquals(1500, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), + Assertions.assertEquals(1500, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), MatsimTestUtils.EPSILON); - Assert.assertEquals(2000, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), + Assertions.assertEquals(2000, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), MatsimTestUtils.EPSILON); } if (zone.equals("testArea2_area3")) { - Assert.assertEquals(800, resultingDataPerZone.get(zone).getDouble("Inhabitants"), + Assertions.assertEquals(800, resultingDataPerZone.get(zone).getDouble("Inhabitants"), MatsimTestUtils.EPSILON); - Assert.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee"), + Assertions.assertEquals(1000, resultingDataPerZone.get(zone).getDouble("Employee"), MatsimTestUtils.EPSILON); - Assert.assertEquals(50, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), + Assertions.assertEquals(50, resultingDataPerZone.get(zone).getDouble("Employee Primary Sector"), MatsimTestUtils.EPSILON); - Assert.assertEquals(200, resultingDataPerZone.get(zone).getDouble("Employee Construction"), + Assertions.assertEquals(200, resultingDataPerZone.get(zone).getDouble("Employee Construction"), MatsimTestUtils.EPSILON); - Assert.assertEquals(100, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), + Assertions.assertEquals(100, resultingDataPerZone.get(zone).getDouble("Employee Secondary Sector Rest"), MatsimTestUtils.EPSILON); - Assert.assertEquals(150, resultingDataPerZone.get(zone).getDouble("Employee Retail"), + Assertions.assertEquals(150, resultingDataPerZone.get(zone).getDouble("Employee Retail"), MatsimTestUtils.EPSILON); - Assert.assertEquals(200, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), + Assertions.assertEquals(200, resultingDataPerZone.get(zone).getDouble("Employee Traffic/Parcels"), MatsimTestUtils.EPSILON); - Assert.assertEquals(300, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), + Assertions.assertEquals(300, resultingDataPerZone.get(zone).getDouble("Employee Tertiary Sector Rest"), MatsimTestUtils.EPSILON); } } diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java index 43fa34e8a5d..62127e7e2f5 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/RunGenerateSmallScaleCommercialTrafficTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.smallScaleCommercialTrafficGeneration; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -102,19 +102,19 @@ void testMainRunAndResults() { assert population != null; for (Person person : population.getPersons().values()) { - Assert.assertNotNull(person.getSelectedPlan()); - Assert.assertTrue(person.getAttributes().getAsMap().containsKey("tourStartArea")); - Assert.assertTrue(person.getAttributes().getAsMap().containsKey("vehicles")); - Assert.assertTrue(person.getAttributes().getAsMap().containsKey("subpopulation")); - Assert.assertTrue(person.getAttributes().getAsMap().containsKey("purpose")); + Assertions.assertNotNull(person.getSelectedPlan()); + Assertions.assertTrue(person.getAttributes().getAsMap().containsKey("tourStartArea")); + Assertions.assertTrue(person.getAttributes().getAsMap().containsKey("vehicles")); + Assertions.assertTrue(person.getAttributes().getAsMap().containsKey("subpopulation")); + Assertions.assertTrue(person.getAttributes().getAsMap().containsKey("purpose")); } - Assert.assertEquals(CarriersUtils.addOrGetCarriers(scenarioWSolution).getCarriers().size(), + Assertions.assertEquals(CarriersUtils.addOrGetCarriers(scenarioWSolution).getCarriers().size(), CarriersUtils.addOrGetCarriers(scenarioWOSolution).getCarriers().size(), 0); int countedTours = 0; for (Carrier carrier_withSolution : CarriersUtils.addOrGetCarriers(scenarioWSolution).getCarriers().values()) { countedTours += carrier_withSolution.getSelectedPlan().getScheduledTours().size(); } - Assert.assertEquals(population.getPersons().size(), countedTours, 0); + Assertions.assertEquals(population.getPersons().size(), countedTours, 0); } } diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java index f73b0698099..0b89332ca30 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/SmallScaleCommercialTrafficUtilsTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.smallScaleCommercialTrafficGeneration; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -67,14 +67,14 @@ void findZoneOfLinksTest() throws IOException, URISyntaxException { .filterLinksForZones(scenario, shpZones, SmallScaleCommercialTrafficUtils.getIndexZones(shapeFileZonePath, config.global().getCoordinateSystem()), buildingsPerZone); - Assert.assertEquals(3, regionLinksMap.size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(60, regionLinksMap.get("testArea1_area1").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(41, regionLinksMap.get("testArea1_area2").size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(28, regionLinksMap.get("testArea2_area3").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, regionLinksMap.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(60, regionLinksMap.get("testArea1_area1").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(41, regionLinksMap.get("testArea1_area2").size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(28, regionLinksMap.get("testArea2_area3").size(), MatsimTestUtils.EPSILON); - Assert.assertNull(SmallScaleCommercialTrafficUtils.findZoneOfLink(Id.createLinkId("j(5,4)"), regionLinksMap)); - Assert.assertEquals("testArea1_area1", SmallScaleCommercialTrafficUtils.findZoneOfLink(Id.createLinkId("j(6,5)R"), regionLinksMap)); - Assert.assertEquals("testArea1_area2", SmallScaleCommercialTrafficUtils.findZoneOfLink(Id.createLinkId("j(2,7)R"), regionLinksMap)); - Assert.assertEquals("testArea2_area3", SmallScaleCommercialTrafficUtils.findZoneOfLink(Id.createLinkId("j(2,2)R"), regionLinksMap)); + Assertions.assertNull(SmallScaleCommercialTrafficUtils.findZoneOfLink(Id.createLinkId("j(5,4)"), regionLinksMap)); + Assertions.assertEquals("testArea1_area1", SmallScaleCommercialTrafficUtils.findZoneOfLink(Id.createLinkId("j(6,5)R"), regionLinksMap)); + Assertions.assertEquals("testArea1_area2", SmallScaleCommercialTrafficUtils.findZoneOfLink(Id.createLinkId("j(2,7)R"), regionLinksMap)); + Assertions.assertEquals("testArea2_area3", SmallScaleCommercialTrafficUtils.findZoneOfLink(Id.createLinkId("j(2,2)R"), regionLinksMap)); } } diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java index c2e7ff89bd0..c1d80ed77d6 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TrafficVolumeGenerationTest.java @@ -20,7 +20,7 @@ package org.matsim.smallScaleCommercialTrafficGeneration; import it.unimi.dsi.fastutil.objects.Object2DoubleMap; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -84,52 +84,52 @@ void testTrafficVolumeGenerationCommercialPersonTraffic() throws IOException { HashMap> trafficVolumePerTypeAndZone_stop = TrafficVolumeGeneration .createTrafficVolume_stop(resultingDataPerZone, output, sample, modesORvehTypes, usedTrafficType); - Assert.assertEquals(3, trafficVolumePerTypeAndZone_start.size()); - Assert.assertEquals(3, trafficVolumePerTypeAndZone_stop.size()); + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_start.size()); + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_stop.size()); for (String zone : resultingDataPerZone.keySet()) { TrafficVolumeKey trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey(zone, modesORvehTypes.get(0)); - Assert.assertTrue(trafficVolumePerTypeAndZone_start.containsKey(trafficVolumeKey)); - Assert.assertTrue(trafficVolumePerTypeAndZone_stop.containsKey(trafficVolumeKey)); + Assertions.assertTrue(trafficVolumePerTypeAndZone_start.containsKey(trafficVolumeKey)); + Assertions.assertTrue(trafficVolumePerTypeAndZone_stop.containsKey(trafficVolumeKey)); } TrafficVolumeKey trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey("testArea1_area1", modesORvehTypes.get(0)); - Assert.assertEquals(30, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(124, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(277, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(175, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(250, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - - Assert.assertEquals(10, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(105, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(426, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(121, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(65, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(30, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(124, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(277, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(175, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(250, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(10, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(105, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(426, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(121, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(65, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey("testArea1_area2", modesORvehTypes.get(0)); - Assert.assertEquals(30, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(211, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(514, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(441, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(630, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - - Assert.assertEquals(10, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(202, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(859, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(246, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(102, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(30, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(211, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(514, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(441, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(630, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(10, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(202, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(859, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(246, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(102, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey("testArea2_area3", modesORvehTypes.get(0)); - Assert.assertEquals(6, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(34, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(79, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(62, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(88, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(34, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(79, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(62, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(88, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(31, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(128, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(37, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(17, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(31, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(128, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(37, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(17, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); //test with different sample @@ -139,47 +139,47 @@ void testTrafficVolumeGenerationCommercialPersonTraffic() throws IOException { trafficVolumePerTypeAndZone_stop = TrafficVolumeGeneration .createTrafficVolume_stop(resultingDataPerZone, output, sample, modesORvehTypes, usedTrafficType); - Assert.assertEquals(3, trafficVolumePerTypeAndZone_start.size()); - Assert.assertEquals(3, trafficVolumePerTypeAndZone_stop.size()); + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_start.size()); + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_stop.size()); trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey("testArea1_area1", modesORvehTypes.get(0)); - Assert.assertEquals(7, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(31, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(69, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(44, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(63, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - - Assert.assertEquals(3, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(26, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(106, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(30, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(16, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(31, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(69, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(44, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(63, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(26, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(106, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(30, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(16, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey("testArea1_area2", modesORvehTypes.get(0)); - Assert.assertEquals(7, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(53, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(129, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(110, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(158, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - - Assert.assertEquals(3, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(50, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(215, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(61, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(25, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(53, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(129, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(110, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(158, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(50, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(215, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(61, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(25, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey("testArea2_area3", modesORvehTypes.get(0)); - Assert.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(8, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(20, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(15, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(22, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - - Assert.assertEquals(1, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(8, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(32, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(9, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(4, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(20, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(15, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(22, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(1, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(32, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); } @Test @@ -214,14 +214,14 @@ void testTrafficVolumeGenerationGoodsTraffic() throws IOException { HashMap> trafficVolumePerTypeAndZone_stop = TrafficVolumeGeneration .createTrafficVolume_stop(resultingDataPerZone, output, sample, modesORvehTypes, usedTrafficType); - Assert.assertEquals(15, trafficVolumePerTypeAndZone_start.size()); - Assert.assertEquals(15, trafficVolumePerTypeAndZone_stop.size()); + Assertions.assertEquals(15, trafficVolumePerTypeAndZone_start.size()); + Assertions.assertEquals(15, trafficVolumePerTypeAndZone_stop.size()); for (String zone : resultingDataPerZone.keySet()) { for (String modesORvehType : modesORvehTypes) { TrafficVolumeKey trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey(zone, modesORvehType); - Assert.assertTrue(trafficVolumePerTypeAndZone_start.containsKey(trafficVolumeKey)); - Assert.assertTrue(trafficVolumePerTypeAndZone_stop.containsKey(trafficVolumeKey)); + Assertions.assertTrue(trafficVolumePerTypeAndZone_start.containsKey(trafficVolumeKey)); + Assertions.assertTrue(trafficVolumePerTypeAndZone_stop.containsKey(trafficVolumeKey)); } } @@ -249,83 +249,83 @@ void testTrafficVolumeGenerationGoodsTraffic() throws IOException { sumStart += trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(i); sumStop += trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(i); if (modeORvehType.equals("vehTyp1")) { - Assert.assertEquals(5, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(16, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(101, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(36, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(33, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(0, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); - - Assert.assertEquals(5, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(17, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(73, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(54, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(10, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(0, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(16, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(101, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(36, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(33, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(5, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(17, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(73, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(54, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); } if (modeORvehType.equals("vehTyp2")) { - Assert.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(3, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(21, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(11, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(23, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(10, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); - - Assert.assertEquals(2, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(3, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(13, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(20, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(7, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(11, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(21, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(11, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(23, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(2, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(13, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(20, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(11, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); } if (modeORvehType.equals("vehTyp3")) { - Assert.assertEquals(3, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(6, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(44, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(42, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(28, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(23, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); - - Assert.assertEquals(4, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(8, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(28, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(73, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(6, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(15, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(44, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(42, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(28, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(23, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(4, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(28, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(73, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(15, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); } if (modeORvehType.equals("vehTyp4")) { - Assert.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(10, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(13, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(3, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); - - Assert.assertEquals(0, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(5, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(20, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(5, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(13, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(0, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(20, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); } if (modeORvehType.equals("vehTyp5")) { - Assert.assertEquals(2, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(4, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(29, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(72, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(31, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(0, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); - - Assert.assertEquals(4, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(6, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(20, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(133, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(8, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(0, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(29, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(72, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(31, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(4, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(20, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(133, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); } } - Assert.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); - Assert.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); } // test for "testArea1_area2" @@ -352,8 +352,8 @@ void testTrafficVolumeGenerationGoodsTraffic() throws IOException { sumStart += trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(i); sumStop += trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(i); } - Assert.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); - Assert.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); } // test for "testArea2_area3" @@ -380,8 +380,8 @@ void testTrafficVolumeGenerationGoodsTraffic() throws IOException { sumStart += trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(i); sumStop += trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(i); } - Assert.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); - Assert.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); } } @@ -406,49 +406,49 @@ void testAddingExistingScenarios() throws Exception { SmallScaleCommercialTrafficUtils.readExistingModels(scenario, sample, regionLinksMap); - Assert.assertEquals(3, CarriersUtils.getCarriers(scenario).getCarriers().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, CarriersUtils.getCarrierVehicleTypes(scenario).getVehicleTypes().size(), MatsimTestUtils.EPSILON); - Assert.assertTrue(CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("exampleServiceCarrier_carrier1", Carrier.class))); - Assert.assertTrue(CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("exampleServiceCarrier_carrier2", Carrier.class))); - Assert.assertTrue(CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("exampleShipmentCarrier_carrier1", Carrier.class))); + Assertions.assertEquals(3, CarriersUtils.getCarriers(scenario).getCarriers().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, CarriersUtils.getCarrierVehicleTypes(scenario).getVehicleTypes().size(), MatsimTestUtils.EPSILON); + Assertions.assertTrue(CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("exampleServiceCarrier_carrier1", Carrier.class))); + Assertions.assertTrue(CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("exampleServiceCarrier_carrier2", Carrier.class))); + Assertions.assertTrue(CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("exampleShipmentCarrier_carrier1", Carrier.class))); Carrier addedCarrier1 = CarriersUtils.getCarriers(scenario).getCarriers().get(Id.create("exampleServiceCarrier_carrier1", Carrier.class)); - Assert.assertNotNull(addedCarrier1.getSelectedPlan()); - Assert.assertEquals(0, CarriersUtils.getJspritIterations(addedCarrier1), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier1.getCarrierCapabilities().getCarrierVehicles().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier1.getCarrierCapabilities().getVehicleTypes().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(3, addedCarrier1.getSelectedPlan().getScheduledTours().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(30, addedCarrier1.getServices().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(6, addedCarrier1.getAttributes().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals("commercialPersonTraffic", addedCarrier1.getAttributes().getAttribute("subpopulation")); - Assert.assertEquals(2, (int) addedCarrier1.getAttributes().getAttribute("purpose")); - Assert.assertEquals("exampleServiceCarrier", addedCarrier1.getAttributes().getAttribute("existingModel")); - Assert.assertEquals("car", addedCarrier1.getAttributes().getAttribute("networkMode")); - Assert.assertNull(addedCarrier1.getAttributes().getAttribute("vehicleType")); - Assert.assertEquals("testArea2_area3", addedCarrier1.getAttributes().getAttribute("tourStartArea")); + Assertions.assertNotNull(addedCarrier1.getSelectedPlan()); + Assertions.assertEquals(0, CarriersUtils.getJspritIterations(addedCarrier1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier1.getCarrierCapabilities().getCarrierVehicles().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier1.getCarrierCapabilities().getVehicleTypes().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, addedCarrier1.getSelectedPlan().getScheduledTours().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(30, addedCarrier1.getServices().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, addedCarrier1.getAttributes().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals("commercialPersonTraffic", addedCarrier1.getAttributes().getAttribute("subpopulation")); + Assertions.assertEquals(2, (int) addedCarrier1.getAttributes().getAttribute("purpose")); + Assertions.assertEquals("exampleServiceCarrier", addedCarrier1.getAttributes().getAttribute("existingModel")); + Assertions.assertEquals("car", addedCarrier1.getAttributes().getAttribute("networkMode")); + Assertions.assertNull(addedCarrier1.getAttributes().getAttribute("vehicleType")); + Assertions.assertEquals("testArea2_area3", addedCarrier1.getAttributes().getAttribute("tourStartArea")); Carrier addedCarrier2 = CarriersUtils.getCarriers(scenario).getCarriers().get(Id.create("exampleServiceCarrier_carrier2", Carrier.class)); - Assert.assertNotNull(addedCarrier2.getSelectedPlan()); - Assert.assertEquals(0, CarriersUtils.getJspritIterations(addedCarrier2), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier2.getCarrierCapabilities().getCarrierVehicles().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier2.getCarrierCapabilities().getVehicleTypes().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, addedCarrier2.getSelectedPlan().getScheduledTours().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(20, addedCarrier2.getServices().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals("commercialPersonTraffic", addedCarrier2.getAttributes().getAttribute("subpopulation")); - Assert.assertEquals(2, (int) addedCarrier2.getAttributes().getAttribute("purpose")); - Assert.assertEquals("exampleServiceCarrier", addedCarrier2.getAttributes().getAttribute("existingModel")); - Assert.assertEquals("car", addedCarrier2.getAttributes().getAttribute("networkMode")); - Assert.assertNull(addedCarrier2.getAttributes().getAttribute("vehicleType")); - Assert.assertEquals("testArea2_area3", addedCarrier2.getAttributes().getAttribute("tourStartArea")); + Assertions.assertNotNull(addedCarrier2.getSelectedPlan()); + Assertions.assertEquals(0, CarriersUtils.getJspritIterations(addedCarrier2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier2.getCarrierCapabilities().getCarrierVehicles().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier2.getCarrierCapabilities().getVehicleTypes().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, addedCarrier2.getSelectedPlan().getScheduledTours().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(20, addedCarrier2.getServices().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals("commercialPersonTraffic", addedCarrier2.getAttributes().getAttribute("subpopulation")); + Assertions.assertEquals(2, (int) addedCarrier2.getAttributes().getAttribute("purpose")); + Assertions.assertEquals("exampleServiceCarrier", addedCarrier2.getAttributes().getAttribute("existingModel")); + Assertions.assertEquals("car", addedCarrier2.getAttributes().getAttribute("networkMode")); + Assertions.assertNull(addedCarrier2.getAttributes().getAttribute("vehicleType")); + Assertions.assertEquals("testArea2_area3", addedCarrier2.getAttributes().getAttribute("tourStartArea")); Carrier addedCarrier3 = CarriersUtils.getCarriers(scenario).getCarriers().get(Id.create("exampleShipmentCarrier_carrier1", Carrier.class)); - Assert.assertNull(addedCarrier3.getSelectedPlan()); - Assert.assertEquals(50, CarriersUtils.getJspritIterations(addedCarrier3), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier3.getCarrierCapabilities().getCarrierVehicles().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier3.getCarrierCapabilities().getVehicleTypes().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(FleetSize.INFINITE, addedCarrier3.getCarrierCapabilities().getFleetSize()); - Assert.assertEquals(0, addedCarrier3.getServices().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(5, addedCarrier3.getShipments().size(), MatsimTestUtils.EPSILON); + Assertions.assertNull(addedCarrier3.getSelectedPlan()); + Assertions.assertEquals(50, CarriersUtils.getJspritIterations(addedCarrier3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier3.getCarrierCapabilities().getCarrierVehicles().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier3.getCarrierCapabilities().getVehicleTypes().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(FleetSize.INFINITE, addedCarrier3.getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(0, addedCarrier3.getServices().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5, addedCarrier3.getShipments().size(), MatsimTestUtils.EPSILON); } @Test @@ -472,34 +472,34 @@ void testAddingExistingScenariosWithSample() throws Exception { SmallScaleCommercialTrafficUtils.readExistingModels(scenario, sample, regionLinksMap); - Assert.assertEquals(2, CarriersUtils.getCarriers(scenario).getCarriers().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, CarriersUtils.getCarrierVehicleTypes(scenario).getVehicleTypes().size(), MatsimTestUtils.EPSILON); - Assert.assertTrue(CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("exampleServiceCarrier_carrier1", Carrier.class))); - Assert.assertTrue(CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("exampleShipmentCarrier_carrier1", Carrier.class))); + Assertions.assertEquals(2, CarriersUtils.getCarriers(scenario).getCarriers().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, CarriersUtils.getCarrierVehicleTypes(scenario).getVehicleTypes().size(), MatsimTestUtils.EPSILON); + Assertions.assertTrue(CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("exampleServiceCarrier_carrier1", Carrier.class))); + Assertions.assertTrue(CarriersUtils.getCarriers(scenario).getCarriers().containsKey(Id.create("exampleShipmentCarrier_carrier1", Carrier.class))); Carrier addedCarrier1 = CarriersUtils.getCarriers(scenario).getCarriers().get(Id.create("exampleServiceCarrier_carrier1", Carrier.class)); - Assert.assertNotNull(addedCarrier1.getSelectedPlan()); - Assert.assertEquals(0, CarriersUtils.getJspritIterations(addedCarrier1), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier1.getCarrierCapabilities().getCarrierVehicles().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier1.getCarrierCapabilities().getVehicleTypes().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier1.getSelectedPlan().getScheduledTours().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(10, addedCarrier1.getServices().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(6, addedCarrier1.getAttributes().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals("commercialPersonTraffic", addedCarrier1.getAttributes().getAttribute("subpopulation")); - Assert.assertEquals(2, (int) addedCarrier1.getAttributes().getAttribute("purpose")); - Assert.assertEquals("exampleServiceCarrier", addedCarrier1.getAttributes().getAttribute("existingModel")); - Assert.assertEquals("car", addedCarrier1.getAttributes().getAttribute("networkMode")); - Assert.assertNull(addedCarrier1.getAttributes().getAttribute("vehicleType")); - Assert.assertEquals("testArea2_area3", addedCarrier1.getAttributes().getAttribute("tourStartArea")); + Assertions.assertNotNull(addedCarrier1.getSelectedPlan()); + Assertions.assertEquals(0, CarriersUtils.getJspritIterations(addedCarrier1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier1.getCarrierCapabilities().getCarrierVehicles().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier1.getCarrierCapabilities().getVehicleTypes().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier1.getSelectedPlan().getScheduledTours().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10, addedCarrier1.getServices().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, addedCarrier1.getAttributes().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals("commercialPersonTraffic", addedCarrier1.getAttributes().getAttribute("subpopulation")); + Assertions.assertEquals(2, (int) addedCarrier1.getAttributes().getAttribute("purpose")); + Assertions.assertEquals("exampleServiceCarrier", addedCarrier1.getAttributes().getAttribute("existingModel")); + Assertions.assertEquals("car", addedCarrier1.getAttributes().getAttribute("networkMode")); + Assertions.assertNull(addedCarrier1.getAttributes().getAttribute("vehicleType")); + Assertions.assertEquals("testArea2_area3", addedCarrier1.getAttributes().getAttribute("tourStartArea")); Carrier addedCarrier3 = CarriersUtils.getCarriers(scenario).getCarriers().get(Id.create("exampleShipmentCarrier_carrier1", Carrier.class)); - Assert.assertNull(addedCarrier3.getSelectedPlan()); - Assert.assertEquals(50, CarriersUtils.getJspritIterations(addedCarrier3), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier3.getCarrierCapabilities().getCarrierVehicles().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier3.getCarrierCapabilities().getVehicleTypes().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(FleetSize.INFINITE, addedCarrier3.getCarrierCapabilities().getFleetSize()); - Assert.assertEquals(0, addedCarrier3.getServices().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, addedCarrier3.getShipments().size(), MatsimTestUtils.EPSILON); + Assertions.assertNull(addedCarrier3.getSelectedPlan()); + Assertions.assertEquals(50, CarriersUtils.getJspritIterations(addedCarrier3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier3.getCarrierCapabilities().getCarrierVehicles().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier3.getCarrierCapabilities().getVehicleTypes().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(FleetSize.INFINITE, addedCarrier3.getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(0, addedCarrier3.getServices().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, addedCarrier3.getShipments().size(), MatsimTestUtils.EPSILON); } @Test @@ -571,23 +571,23 @@ void testReducingDemandAfterAddingExistingScenarios_goods() throws Exception { sumStart += trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(i); sumStop += trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(i); if (modeORvehType.equals("vehTyp3")) { - Assert.assertEquals(3, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(6, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(44, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(42, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(28, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(23, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); - - Assert.assertEquals(4, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(8, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(26, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(73, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(6, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(15, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(44, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(42, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(28, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(23, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(4, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(26, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(73, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(15, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); } } - Assert.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); - Assert.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); } // test for "testArea1_area2" @@ -614,8 +614,8 @@ void testReducingDemandAfterAddingExistingScenarios_goods() throws Exception { sumStart += trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(i); sumStop += trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(i); } - Assert.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); - Assert.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); } // test for "testArea2_area3" @@ -642,23 +642,23 @@ void testReducingDemandAfterAddingExistingScenarios_goods() throws Exception { sumStart += trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(i); sumStop += trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(i); if (modeORvehType.equals("vehTyp3")) { - Assert.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(7, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(17, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(11, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(5, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); - - Assert.assertEquals(1, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(6, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(14, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(3, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(17, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(11, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(1, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(14, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(6), MatsimTestUtils.EPSILON); } } - Assert.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); - Assert.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStart.get(i), sumStart, MatsimTestUtils.EPSILON); + Assertions.assertEquals(estimatesStop.get(i), sumStop, MatsimTestUtils.EPSILON); } } @@ -711,46 +711,46 @@ void testReducingDemandAfterAddingExistingScenarios_commercialPersonTraffic() th double sumOfStartOtherAreas = 0; TrafficVolumeKey trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey("testArea1_area1", modesORvehTypes.get(0)); - Assert.assertEquals(30, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(30, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); sumOfStartOtherAreas += trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2); - Assert.assertEquals(277, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(175, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(250, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(277, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(175, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(250, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(10, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(85, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(426, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(121, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(65, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(85, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(426, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(121, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(65, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey("testArea1_area2", modesORvehTypes.get(0)); - Assert.assertEquals(30, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(30, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); sumOfStartOtherAreas += trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2); - Assert.assertEquals(514, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(441, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(630, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(514, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(441, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(630, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(10, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(187, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(859, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(246, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(102, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(187, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(859, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(246, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(102, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); trafficVolumeKey = TrafficVolumeGeneration.makeTrafficVolumeKey("testArea2_area3", modesORvehTypes.get(0)); - Assert.assertEquals(6, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(0, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); sumOfStartOtherAreas += trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(2); - Assert.assertEquals(79, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(62, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(88, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(79, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(62, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(88, trafficVolumePerTypeAndZone_start.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); - Assert.assertEquals(27, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); - Assert.assertEquals(128, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); - Assert.assertEquals(37, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); - Assert.assertEquals(17, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(27, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(128, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(37, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(4), MatsimTestUtils.EPSILON); + Assertions.assertEquals(17, trafficVolumePerTypeAndZone_stop.get(trafficVolumeKey).getDouble(5), MatsimTestUtils.EPSILON); - Assert.assertEquals(330, sumOfStartOtherAreas, MatsimTestUtils.EPSILON); + Assertions.assertEquals(330, sumOfStartOtherAreas, MatsimTestUtils.EPSILON); } @@ -761,7 +761,7 @@ void testTrafficVolumeKeyGeneration() { TrafficVolumeKey newKey = TrafficVolumeGeneration.makeTrafficVolumeKey(zone, mode); - Assert.assertEquals(newKey.getZone(), zone); - Assert.assertEquals(newKey.getModeORvehType(), mode); + Assertions.assertEquals(newKey.getZone(), zone); + Assertions.assertEquals(newKey.getModeORvehType(), mode); } } diff --git a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java index 5d439e96bc9..0c8f2522a37 100644 --- a/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java +++ b/contribs/application/src/test/java/org/matsim/smallScaleCommercialTrafficGeneration/TripDistributionMatrixTest.java @@ -20,7 +20,7 @@ package org.matsim.smallScaleCommercialTrafficGeneration; import it.unimi.dsi.fastutil.objects.Object2DoubleMap; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -104,16 +104,16 @@ void testTripDistributionCommercialPersonTrafficTraffic() throws IOException { odMatrix.clearRoundingError(); //tests - Assert.assertEquals(3, odMatrix.getListOfZones().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, odMatrix.getListOfZones().size(), MatsimTestUtils.EPSILON); for (String zone : resultingDataPerZone.keySet()) { - Assert.assertTrue(odMatrix.getListOfZones().contains(zone)); + Assertions.assertTrue(odMatrix.getListOfZones().contains(zone)); } - Assert.assertEquals(1, odMatrix.getListOfModesOrVehTypes().size(), MatsimTestUtils.EPSILON); - Assert.assertTrue(odMatrix.getListOfModesOrVehTypes().contains("total")); + Assertions.assertEquals(1, odMatrix.getListOfModesOrVehTypes().size(), MatsimTestUtils.EPSILON); + Assertions.assertTrue(odMatrix.getListOfModesOrVehTypes().contains("total")); - Assert.assertEquals(5, odMatrix.getListOfPurposes().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5, odMatrix.getListOfPurposes().size(), MatsimTestUtils.EPSILON); for (int i = 1; i <= 5; i++) { - Assert.assertTrue(odMatrix.getListOfPurposes().contains(i)); + Assertions.assertTrue(odMatrix.getListOfPurposes().contains(i)); } double sumStartServices = 0; double sumStopServices = 0; @@ -129,11 +129,11 @@ void testTripDistributionCommercialPersonTrafficTraffic() throws IOException { sumStartServices += odMatrix.getSumOfServicesForStartZone(zone, modeORvehType, purpose, usedTrafficType); double planedVolume = trafficVolumePerTypeAndZone_stop.get(key).getDouble(purpose); - Assert.assertEquals(planedVolume, generatedVolume, MatsimTestUtils.EPSILON); + Assertions.assertEquals(planedVolume, generatedVolume, MatsimTestUtils.EPSILON); } } } - Assert.assertEquals(sumStartServices, sumStopServices, MatsimTestUtils.EPSILON); + Assertions.assertEquals(sumStartServices, sumStopServices, MatsimTestUtils.EPSILON); } @Test @@ -194,18 +194,18 @@ void testTripDistributionGoodsTraffic() throws IOException { odMatrix.clearRoundingError(); //tests - Assert.assertEquals(3, odMatrix.getListOfZones().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, odMatrix.getListOfZones().size(), MatsimTestUtils.EPSILON); for (String zone : resultingDataPerZone.keySet()) { - Assert.assertTrue(odMatrix.getListOfZones().contains(zone)); + Assertions.assertTrue(odMatrix.getListOfZones().contains(zone)); } - Assert.assertEquals(5, odMatrix.getListOfModesOrVehTypes().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5, odMatrix.getListOfModesOrVehTypes().size(), MatsimTestUtils.EPSILON); for (String modeORvehType : modesORvehTypes) { - Assert.assertTrue(odMatrix.getListOfModesOrVehTypes().contains(modeORvehType)); + Assertions.assertTrue(odMatrix.getListOfModesOrVehTypes().contains(modeORvehType)); } - Assert.assertEquals(6, odMatrix.getListOfPurposes().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, odMatrix.getListOfPurposes().size(), MatsimTestUtils.EPSILON); for (int i = 1; i <= 6; i++) { - Assert.assertTrue(odMatrix.getListOfPurposes().contains(i)); + Assertions.assertTrue(odMatrix.getListOfPurposes().contains(i)); } double sumStartServices = 0; double sumStopServices = 0; @@ -221,10 +221,10 @@ void testTripDistributionGoodsTraffic() throws IOException { sumStartServices += odMatrix.getSumOfServicesForStartZone(zone, modeORvehType, purpose, usedTrafficType); double planedVolume = trafficVolumePerTypeAndZone_stop.get(key).getDouble(purpose); - Assert.assertEquals(planedVolume, generatedVolume, MatsimTestUtils.EPSILON); + Assertions.assertEquals(planedVolume, generatedVolume, MatsimTestUtils.EPSILON); } } } - Assert.assertEquals(sumStartServices, sumStopServices, MatsimTestUtils.EPSILON); + Assertions.assertEquals(sumStartServices, sumStopServices, MatsimTestUtils.EPSILON); } } diff --git a/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java b/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java index 2fe06af31f4..8a486ca716e 100644 --- a/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java +++ b/contribs/av/src/test/java/org/matsim/contrib/av/flow/TestAvFlowFactor.java @@ -26,7 +26,7 @@ import java.net.MalformedURLException; import java.net.URL; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -70,8 +70,8 @@ void testAvFlowFactor() throws MalformedURLException { controler.getEvents().addHandler(vehicleTimeCounter); controler.run(); - Assert.assertEquals(vehicleTimeCounter.lastAVEnterTime, 32598, 0.1); - Assert.assertEquals(vehicleTimeCounter.lastNonAVEnterTime, 36179, 0.1); + Assertions.assertEquals(vehicleTimeCounter.lastAVEnterTime, 32598, 0.1); + Assertions.assertEquals(vehicleTimeCounter.lastNonAVEnterTime, 36179, 0.1); } diff --git a/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java b/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java index 5d7aae5a4e5..2721030096d 100644 --- a/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java +++ b/contribs/av/src/test/java/org/matsim/contrib/av/intermodal/RunTaxiPTIntermodalExampleIT.java @@ -29,7 +29,7 @@ import java.util.List; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -83,7 +83,7 @@ void testIntermodalExample() throws MalformedURLException { } } - Assert.assertTrue("no pt agent has any intermodal route (=taxi for access or egress to pt)", - intermodalTripCounter > 0); + Assertions.assertTrue(intermodalTripCounter > 0, + "no pt agent has any intermodal route (=taxi for access or egress to pt)"); } } diff --git a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java index 9bba0878b85..bb131f1005a 100644 --- a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java +++ b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java @@ -30,8 +30,8 @@ import java.util.UUID; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; public class BicycleLinkSpeedCalculatorTest { @RegisterExtension diff --git a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleUtilityUtilsTest.java b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleUtilityUtilsTest.java index 5e8ebb2f5d9..3d9d4ff5c90 100644 --- a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleUtilityUtilsTest.java +++ b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleUtilityUtilsTest.java @@ -6,7 +6,7 @@ import org.matsim.api.core.v01.network.Link; import org.matsim.core.network.NetworkUtils; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class BicycleUtilityUtilsTest { diff --git a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java index e14c9e48b76..961e43f0182 100644 --- a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java +++ b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/run/BicycleTest.java @@ -20,7 +20,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -63,8 +63,8 @@ import java.util.List; import java.util.Map; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import static org.matsim.utils.eventsfilecomparison.EventsFileComparator.Result.FILES_ARE_EQUAL; /** @@ -97,8 +97,9 @@ void testNormal() { LOG.info("Checking MATSim events file ..."); final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); + assertEquals(FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), + "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -107,9 +108,9 @@ void testNormal() { for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); - Assert.assertEquals("Scores of persons " + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of persons " + personId + " are different"); } - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test @@ -134,14 +135,15 @@ void testCobblestone() { Scenario scenarioCurrent = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); new PopulationReader( scenarioReference ).readFile( utils.getInputDirectory() + "output_plans.xml.gz" ); new PopulationReader( scenarioCurrent ).readFile( utils.getOutputDirectory() + "output_plans.xml.gz" ); - assertTrue( "Populations are different", PopulationUtils.equalPopulation( scenarioReference.getPopulation(), scenarioCurrent.getPopulation() ) ); + assertTrue( PopulationUtils.equalPopulation( scenarioReference.getPopulation(), scenarioCurrent.getPopulation() ), "Populations are different" ); } { LOG.info( "Checking MATSim events file ..." ); final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals( "Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew )); + assertEquals( FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew ), + "Different event files."); } } @@ -164,14 +166,15 @@ void testPedestrian() { LOG.info("Checking MATSim events file ..."); final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); + assertEquals(FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), + "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test @@ -193,14 +196,15 @@ void testLane() { LOG.info("Checking MATSim events file ..."); final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); + assertEquals(FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), + "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test @@ -222,14 +226,15 @@ void testGradient() { LOG.info("Checking MATSim events file ..."); final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew)); + assertEquals(FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( eventsFilenameReference, eventsFilenameNew), + "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test @@ -252,14 +257,15 @@ void testGradientLane() { LOG.info("Checking MATSim events file ..."); final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); + assertEquals(FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew), + "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test @@ -284,14 +290,15 @@ void testNormal10It() { LOG.info("Checking MATSim events file ..."); final String eventsFilenameReference = utils.getInputDirectory() + "output_events.xml.gz"; final String eventsFilenameNew = utils.getOutputDirectory() + "output_events.xml.gz"; - assertEquals("Different event files.", FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew)); + assertEquals(FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison(eventsFilenameReference, eventsFilenameNew), + "Different event files."); Scenario scenarioReference = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario scenarioCurrent = ScenarioUtils.createScenario(ConfigUtils.createConfig()); new PopulationReader(scenarioReference).readFile(utils.getInputDirectory() + "output_plans.xml.gz"); new PopulationReader(scenarioCurrent).readFile(utils.getOutputDirectory() + "output_plans.xml.gz"); - assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); + assertTrue(PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation()), "Populations are different"); } @Test @@ -322,7 +329,7 @@ void testLinkBasedScoring() { for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); - Assert.assertEquals("Scores of persons " + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of persons " + personId + " are different"); } // assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } @@ -410,7 +417,7 @@ void testLinkVsLegMotorizedScoring() { for (Id personId : scenarioReference.getPopulation().getPersons().keySet()) { double scoreReference = scenarioReference.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = scenarioCurrent.getPopulation().getPersons().get(personId).getSelectedPlan().getScore(); - Assert.assertEquals("Scores of person=" + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of person=" + personId + " are different"); } // assertTrue("Populations are different", PopulationUtils.equalPopulation(scenarioReference.getPopulation(), scenarioCurrent.getPopulation())); } @@ -528,14 +535,14 @@ public void install() { controler.run(); - Assert.assertEquals("All bicycle users should use the longest but fastest route where the bicycle infrastructur speed factor is set to 1.0", 3, linkHandler.getLinkId2demand().get(Id.createLinkId("2")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Only the car user should use the shortest route", 1, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, linkHandler.getLinkId2demand().get(Id.createLinkId("2")), MatsimTestUtils.EPSILON, "All bicycle users should use the longest but fastest route where the bicycle infrastructur speed factor is set to 1.0"); + Assertions.assertEquals(1, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON, "Only the car user should use the shortest route"); - Assert.assertEquals("Wrong travel time (bicycle user)", 1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (bicycle user)", 1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(1), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (bicycle user)", 1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(0), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); + Assertions.assertEquals(1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(1), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); + Assertions.assertEquals(1.0 + Math.ceil( 13000 / (25.0 /3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("2")).get(2), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); - Assert.assertEquals("Wrong travel time (car user)", Math.ceil( 10000 / (13.88) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Math.ceil( 10000 / (13.88) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON, "Wrong travel time (car user)"); } @@ -615,11 +622,11 @@ void testInfrastructureSpeedFactorDistanceMoreRelevantThanTravelTime() { controler.run(); - Assert.assertEquals("All bicycle users should use the shortest route even though the bicycle infrastructur speed factor is set to 0.1", 4, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (car user)", Math.ceil(10000 / 13.88 ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (bicycle user)", Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(1), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (bicycle user)", Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(2), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time (bicycle user)", Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(3), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, linkHandler.getLinkId2demand().get(Id.createLinkId("6")), MatsimTestUtils.EPSILON, "All bicycle users should use the shortest route even though the bicycle infrastructur speed factor is set to 0.1"); + Assertions.assertEquals(Math.ceil(10000 / 13.88 ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(0), MatsimTestUtils.EPSILON, "Wrong travel time (car user)"); + Assertions.assertEquals(Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(1), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); + Assertions.assertEquals(Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(2), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); + Assertions.assertEquals(Math.ceil( 10000 / (25. * 0.1 / 3.6) ), linkHandler.getLinkId2travelTimes().get(Id.createLinkId("6")).get(3), MatsimTestUtils.EPSILON, "Wrong travel time (bicycle user)"); } private Config createConfig( int lastIteration ){ diff --git a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java index 85c1d6f6e88..848b371c711 100644 --- a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java +++ b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarIT.java @@ -23,7 +23,7 @@ import cadyts.measurements.SingleLinkMeasurement; import cadyts.utilities.io.tabularFileParser.TabularFileParser; import cadyts.utilities.misc.DynamicData; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -141,14 +141,14 @@ public PlanStrategy get() { CadytsContext context = injector.getInstance(CadytsContext.class); //test calibration settings - Assert.assertEquals(true, context.getCalibrator().getBruteForce()); - Assert.assertEquals(false, context.getCalibrator().getCenterRegression()); - Assert.assertEquals(Integer.MAX_VALUE, context.getCalibrator().getFreezeIteration()); - Assert.assertEquals(8.0, context.getCalibrator().getMinStddev(SingleLinkMeasurement.TYPE.FLOW_VEH_H), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, context.getCalibrator().getPreparatoryIterations()); - Assert.assertEquals(0.95, context.getCalibrator().getRegressionInertia(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1.0, context.getCalibrator().getVarianceScale(), MatsimTestUtils.EPSILON); - Assert.assertEquals(3600.0, context.getCalibrator().getTimeBinSize_s(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(true, context.getCalibrator().getBruteForce()); + Assertions.assertEquals(false, context.getCalibrator().getCenterRegression()); + Assertions.assertEquals(Integer.MAX_VALUE, context.getCalibrator().getFreezeIteration()); + Assertions.assertEquals(8.0, context.getCalibrator().getMinStddev(SingleLinkMeasurement.TYPE.FLOW_VEH_H), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, context.getCalibrator().getPreparatoryIterations()); + Assertions.assertEquals(0.95, context.getCalibrator().getRegressionInertia(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.0, context.getCalibrator().getVarianceScale(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3600.0, context.getCalibrator().getTimeBinSize_s(), MatsimTestUtils.EPSILON); } @@ -212,26 +212,26 @@ public ScoringFunction createNewScoringFunction(Person person) { //scenario data test Scenario scenario = injector.getInstance(Scenario.class); - Assert.assertEquals("Different number of links in network.", scenario.getNetwork().getLinks().size() , 23 ); - Assert.assertEquals("Different number of nodes in network.", scenario.getNetwork().getNodes().size() , 15 ); + Assertions.assertEquals(scenario.getNetwork().getLinks().size() , 23, "Different number of links in network." ); + Assertions.assertEquals(scenario.getNetwork().getNodes().size() , 15, "Different number of nodes in network." ); - Assert.assertNotNull("Population is null.", scenario.getPopulation()); + Assertions.assertNotNull(scenario.getPopulation(), "Population is null."); - Assert.assertEquals("Num. of persons in population is wrong.", scenario.getPopulation().getPersons().size(), 5); - Assert.assertEquals("Scale factor is wrong.", scenario.getConfig().counts().getCountsScaleFactor(), 1.0, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scenario.getPopulation().getPersons().size(), 5, "Num. of persons in population is wrong."); + Assertions.assertEquals(scenario.getConfig().counts().getCountsScaleFactor(), 1.0, MatsimTestUtils.EPSILON, "Scale factor is wrong."); //counts - Assert.assertEquals("Count file is wrong.", scenario.getConfig().counts().getCountsFileName(), inputDir + "counts5.xml"); + Assertions.assertEquals(scenario.getConfig().counts().getCountsFileName(), inputDir + "counts5.xml", "Count file is wrong."); Counts occupCounts = new Counts<>(); new MatsimCountsReader(occupCounts).readFile(scenario.getConfig().counts().getCountsFileName()); Count count = occupCounts.getCount(Id.create(19, Link.class)); - Assert.assertEquals("Occupancy counts description is wrong", occupCounts.getDescription(), "counts values for equil net"); - Assert.assertEquals("CsId is wrong.", count.getCsLabel() , "link_19"); - Assert.assertEquals("Volume of hour 6 is wrong", count.getVolume(7).getValue(), 5.0 , MatsimTestUtils.EPSILON); - Assert.assertEquals("Max count volume is wrong.", count.getMaxVolume().getValue(), 5.0 , MatsimTestUtils.EPSILON); + Assertions.assertEquals(occupCounts.getDescription(), "counts values for equil net", "Occupancy counts description is wrong"); + Assertions.assertEquals(count.getCsLabel() , "link_19", "CsId is wrong."); + Assertions.assertEquals(count.getVolume(7).getValue(), 5.0 , MatsimTestUtils.EPSILON, "Volume of hour 6 is wrong"); + Assertions.assertEquals(count.getMaxVolume().getValue(), 5.0 , MatsimTestUtils.EPSILON, "Max count volume is wrong."); String outCounts = outputDir + "ITERS/it." + lastIteration + "/" + lastIteration + ".countscompare.txt"; AdHocCountsReaderCar reader = new AdHocCountsReaderCar(outCounts); @@ -240,29 +240,29 @@ public ScoringFunction createNewScoringFunction(Person person) { { double[] simValues = reader.getSimulatedValues( locId11 ); double[] realValues = reader.getRealValues( locId11 ); - Assert.assertEquals( "Volume of hour 6 is wrong", 0.0, simValues[6], MatsimTestUtils.EPSILON ); - Assert.assertEquals( "Volume of hour 6 is wrong", 0.0, realValues[6], MatsimTestUtils.EPSILON ); + Assertions.assertEquals( 0.0, simValues[6], MatsimTestUtils.EPSILON, "Volume of hour 6 is wrong" ); + Assertions.assertEquals( 0.0, realValues[6], MatsimTestUtils.EPSILON, "Volume of hour 6 is wrong" ); } { Id locId12 = Id.create( "12", Link.class ); double[] simValues = reader.getSimulatedValues( locId12 ); double[] realValues = reader.getRealValues( locId12 ); - Assert.assertEquals( "Volume of hour 6 is wrong", 0.0, simValues[6], MatsimTestUtils.EPSILON ); - Assert.assertEquals( "Volume of hour 6 is wrong", 0.0, realValues[6], MatsimTestUtils.EPSILON ); + Assertions.assertEquals( 0.0, simValues[6], MatsimTestUtils.EPSILON, "Volume of hour 6 is wrong" ); + Assertions.assertEquals( 0.0, realValues[6], MatsimTestUtils.EPSILON, "Volume of hour 6 is wrong" ); } Id locId19 = Id.create( "19", Link.class ); { double[] simValues = reader.getSimulatedValues( locId19 ); double[] realValues = reader.getRealValues( locId19 ); - Assert.assertEquals( "Volume of hour 6 is wrong", 5.0, simValues[6], MatsimTestUtils.EPSILON ); - Assert.assertEquals( "Volume of hour 6 is wrong", 5.0, realValues[6], MatsimTestUtils.EPSILON ); + Assertions.assertEquals( 5.0, simValues[6], MatsimTestUtils.EPSILON, "Volume of hour 6 is wrong" ); + Assertions.assertEquals( 5.0, realValues[6], MatsimTestUtils.EPSILON, "Volume of hour 6 is wrong" ); } { Id locId21 = Id.create( "21", Link.class ); double[] simValues = reader.getSimulatedValues( locId21 ); double[] realValues = reader.getRealValues( locId21 ); - Assert.assertEquals( "Volume of hour 6 is wrong", 5.0, simValues[6], MatsimTestUtils.EPSILON ); - Assert.assertEquals( "Volume of hour 6 is wrong", 5.0, realValues[6], MatsimTestUtils.EPSILON ); + Assertions.assertEquals( 5.0, simValues[6], MatsimTestUtils.EPSILON, "Volume of hour 6 is wrong" ); + Assertions.assertEquals( 5.0, realValues[6], MatsimTestUtils.EPSILON, "Volume of hour 6 is wrong" ); } // test calibration statistics String testCalibStatPath = outputDir + "calibration-stats.txt"; @@ -273,7 +273,7 @@ public ScoringFunction createNewScoringFunction(Person person) { // Assert.assertEquals("different Count_ll", "-0.046875", outStatData.getCount_ll() ); // Assert.assertEquals("different Count_ll_pred_err", "0.01836234363152515" , outStatData.getCount_ll_pred_err() ); // Assert.assertEquals("different Link_lambda_avg", "-2.2604922388914356E-10", outStatData.getLink_lambda_avg() ); - Assert.assertEquals("different Link_lambda_avg", "3.2261421242498865E-5", outStatData.getLink_lambda_avg() ); + Assertions.assertEquals("3.2261421242498865E-5", outStatData.getLink_lambda_avg(), "different Link_lambda_avg" ); // Assert.assertEquals("different Link_lambda_max", "0.0" , outStatData.getLink_lambda_max() ); // Assert.assertEquals("different Link_lambda_min", "-7.233575164452593E-9", outStatData.getLink_lambda_min() ); // Assert.assertEquals("different Link_lambda_stddev", "1.261054219517188E-9", outStatData.getLink_lambda_stddev()); @@ -283,7 +283,7 @@ public ScoringFunction createNewScoringFunction(Person person) { // Assert.assertEquals("different Plan_lambda_min", "-7.233575164452593E-9" , outStatData.getPlan_lambda_min() ); // Assert.assertEquals("different Plan_lambda_stddev", "0.0" , outStatData.getPlan_lambda_stddev()); // Assert.assertEquals("different Total_ll", "-0.046875", outStatData.getTotal_ll() ); - Assert.assertEquals("different Total_ll", "0.0", outStatData.getTotal_ll() ); + Assertions.assertEquals("0.0", outStatData.getTotal_ll(), "different Total_ll" ); //test link offsets final Network network = scenario.getNetwork(); @@ -304,10 +304,10 @@ public ScoringFunction createNewScoringFunction(Person person) { isZero = (Math.abs(linkOffsets.getBinValue(link19 , binIndex) - 0.0) < MatsimTestUtils.EPSILON); }while (isZero && binIndex<86400); - Assert.assertEquals("Wrong bin index for first link offset", 6, binIndex); + Assertions.assertEquals(6, binIndex, "Wrong bin index for first link offset"); - Assert.assertEquals("Wrong link offset of link 11", 0.0, linkOffsets.getBinValue(link11 , binIndex), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong link offset of link 19", 0.0014707121641471912, linkOffsets.getBinValue(link19 , binIndex), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, linkOffsets.getBinValue(link11 , binIndex), MatsimTestUtils.EPSILON, "Wrong link offset of link 11"); + Assertions.assertEquals(0.0014707121641471912, linkOffsets.getBinValue(link19 , binIndex), MatsimTestUtils.EPSILON, "Wrong link offset of link 19"); } diff --git a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java index 08ccf453ef9..9ab184be6b4 100644 --- a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java +++ b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java @@ -1,10 +1,10 @@ package org.matsim.contrib.cadyts.car; -import static org.junit.Assert.assertTrue; - import java.util.concurrent.atomic.AtomicInteger; import org.junit.Ignore; + +import static org.junit.jupiter.api.Assertions.assertTrue; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -44,8 +44,8 @@ void testCadytsWithPtVehicles() { } }); controler.run(); - assertTrue("There's at least one bus on the test link", bussesSeenOnLink.get() > 0); - assertTrue("This test runs to the end, meaning cadyts doesn't throw an exception with pt", true); + assertTrue(bussesSeenOnLink.get() > 0, "There's at least one bus on the test link"); + assertTrue(true, "This test runs to the end, meaning cadyts doesn't throw an exception with pt"); } } diff --git a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java index 1da4d65881a..98cc6caaebe 100644 --- a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java +++ b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/utils/CalibrationStatReaderTest.java @@ -20,8 +20,7 @@ package org.matsim.contrib.cadyts.utils; import java.io.IOException; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -40,17 +39,17 @@ void testReader() throws IOException { CalibrationStatReader calibrationStatReader = new CalibrationStatReader(); tabularFileParser.parse(calibStatFile, calibrationStatReader); CalibrationStatReader.StatisticsData statData6= calibrationStatReader.getCalStatMap().get(Integer.valueOf(6)); - Assert.assertEquals("different Count_ll", "-1.546875", statData6.getCount_ll() ); - Assert.assertEquals("different Count_ll_pred_err", "9.917082938182276E-8" , statData6.getCount_ll_pred_err() ); - Assert.assertEquals("different Link_lambda_avg", "0.0013507168476099964", statData6.getLink_lambda_avg() ); - Assert.assertEquals("different Link_lambda_max", "0.031434867572002166" , statData6.getLink_lambda_max() ); - Assert.assertEquals("different Link_lambda_min", "0.0", statData6.getLink_lambda_min() ); - Assert.assertEquals("different Link_lambda_stddev", "0.0058320747961925256" , statData6.getLink_lambda_stddev()); - Assert.assertEquals("different P2p_ll", "--" , statData6.getP2p_ll()); - Assert.assertEquals("different Plan_lambda_avg", "0.04322293912351989", statData6.getPlan_lambda_avg() ); - Assert.assertEquals("different Plan_lambda_max", "0.04715229919344063" , statData6.getPlan_lambda_max() ); - Assert.assertEquals("different Plan_lambda_min", "0.03929357905359915" , statData6.getPlan_lambda_min() ); - Assert.assertEquals("different Plan_lambda_stddev", "0.004200662608832472" , statData6.getPlan_lambda_stddev()); - Assert.assertEquals("different Total_ll", "-1.546875", statData6.getTotal_ll() ); + Assertions.assertEquals("-1.546875", statData6.getCount_ll(), "different Count_ll" ); + Assertions.assertEquals("9.917082938182276E-8" , statData6.getCount_ll_pred_err(), "different Count_ll_pred_err" ); + Assertions.assertEquals("0.0013507168476099964", statData6.getLink_lambda_avg(), "different Link_lambda_avg" ); + Assertions.assertEquals("0.031434867572002166" , statData6.getLink_lambda_max(), "different Link_lambda_max" ); + Assertions.assertEquals("0.0", statData6.getLink_lambda_min(), "different Link_lambda_min" ); + Assertions.assertEquals("0.0058320747961925256" , statData6.getLink_lambda_stddev(), "different Link_lambda_stddev"); + Assertions.assertEquals("--" , statData6.getP2p_ll(), "different P2p_ll"); + Assertions.assertEquals("0.04322293912351989", statData6.getPlan_lambda_avg(), "different Plan_lambda_avg" ); + Assertions.assertEquals("0.04715229919344063" , statData6.getPlan_lambda_max(), "different Plan_lambda_max" ); + Assertions.assertEquals("0.03929357905359915" , statData6.getPlan_lambda_min(), "different Plan_lambda_min" ); + Assertions.assertEquals("0.004200662608832472" , statData6.getPlan_lambda_stddev(), "different Plan_lambda_stddev"); + Assertions.assertEquals("-1.546875", statData6.getTotal_ll(), "different Total_ll" ); } } diff --git a/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java b/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java index 4f862921469..045303dc9c2 100644 --- a/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java +++ b/contribs/carsharing/src/test/java/org/matsim/contrib/carsharing/runExample/RunCarsharingIT.java @@ -25,7 +25,7 @@ import com.google.inject.Inject; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.analysis.LegHistogram; @@ -162,63 +162,63 @@ void testOutput(int iteration) { if (TransportMode.walk.equals(legMode)) { // walk is used for access+egress to car // -> number of walk legs for access+egress equals twice the number of car legs = 44 - Assert.assertEquals(44, nOfModeLegs); + Assertions.assertEquals(44, nOfModeLegs); } else if ("oneway_vehicle".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } else if (TransportMode.car.equals(legMode)) { - Assert.assertEquals(22, nOfModeLegs); + Assertions.assertEquals(22, nOfModeLegs); } else if ("egress_walk_ow".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } else if ("access_walk_ow".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } } else if (iteration == 10) { if (TransportMode.walk.equals(legMode)) { - Assert.assertEquals(2, nOfModeLegs); + Assertions.assertEquals(2, nOfModeLegs); } else if ("bike".equals(legMode)) { - Assert.assertEquals(2, nOfModeLegs); + Assertions.assertEquals(2, nOfModeLegs); } else if (TransportMode.car.equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } else if ("twoway_vehicle".equals(legMode)) { - Assert.assertEquals(6, nOfModeLegs); + Assertions.assertEquals(6, nOfModeLegs); } else if ("oneway_vehicle".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } else if ("egress_walk_ow".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } else if ("access_walk_ow".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } else if ("egress_walk_tw".equals(legMode)) { - Assert.assertEquals(3, nOfModeLegs); + Assertions.assertEquals(3, nOfModeLegs); } else if ("access_walk_tw".equals(legMode)) { - Assert.assertEquals(3, nOfModeLegs); + Assertions.assertEquals(3, nOfModeLegs); } else if ("egress_walk_ff".equals(legMode)) { - Assert.assertEquals(2, nOfModeLegs); + Assertions.assertEquals(2, nOfModeLegs); } else if ("access_walk_ff".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } } else if (iteration == 20) { if (TransportMode.walk.equals(legMode)) { - Assert.assertEquals(5, nOfModeLegs); + Assertions.assertEquals(5, nOfModeLegs); } else if ("bike".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } else if ("twoway_vehicle".equals(legMode)) { - Assert.assertEquals(6, nOfModeLegs); + Assertions.assertEquals(6, nOfModeLegs); } else if ("freefloating_vehicle".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } else if ("egress_walk_tw".equals(legMode)) { - Assert.assertEquals(3, nOfModeLegs); + Assertions.assertEquals(3, nOfModeLegs); } else if ("access_walk_tw".equals(legMode)) { - Assert.assertEquals(3, nOfModeLegs); + Assertions.assertEquals(3, nOfModeLegs); } else if ("access_walk_ff".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } else if ("egress_walk_ff".equals(legMode)) { - Assert.assertEquals(0, nOfModeLegs); + Assertions.assertEquals(0, nOfModeLegs); } } diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/ChangeCommercialJobOperatorTest.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/ChangeCommercialJobOperatorTest.java index 6fb30f6b0b7..5dad7e11991 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/ChangeCommercialJobOperatorTest.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/ChangeCommercialJobOperatorTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.commercialTrafficApplications.jointDemand; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -31,18 +31,18 @@ void getPlanAlgoInstance() { Activity work = (Activity) testPlan.getPlanElements().get(2); Id carrierId = JointDemandUtils.getCurrentlySelectedCarrierForJob(work, 1); - Assert.assertEquals("the person should expect a pizza", "pizza", JointDemandUtils.getCarrierMarket(carriers.getCarriers().get(carrierId))); - Assert.assertTrue("the person should expect a pizza from the italian place", carrierId.toString().contains("italian")); + Assertions.assertEquals("pizza", JointDemandUtils.getCarrierMarket(carriers.getCarriers().get(carrierId)), "the person should expect a pizza"); + Assertions.assertTrue(carrierId.toString().contains("italian"), "the person should expect a pizza from the italian place"); changeCommercialJobOperator.getPlanAlgoInstance().run(testPlan); carrierId = JointDemandUtils.getCurrentlySelectedCarrierForJob(work, 1); - Assert.assertTrue("the person should expect a pizza from the american place", carrierId.toString().contains("american")); + Assertions.assertTrue(carrierId.toString().contains("american"), "the person should expect a pizza from the american place"); changeCommercialJobOperator.getPlanAlgoInstance().run(testPlan); carrierId = JointDemandUtils.getCurrentlySelectedCarrierForJob(work, 1); - Assert.assertTrue("the person should expect a pizza from the italian place", carrierId.toString().contains("italian")); + Assertions.assertTrue(carrierId.toString().contains("italian"), "the person should expect a pizza from the italian place"); } diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/DefaultCommercialServiceScoreTest.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/DefaultCommercialServiceScoreTest.java index 051e97829e9..d2ce82e986d 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/DefaultCommercialServiceScoreTest.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/DefaultCommercialServiceScoreTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.commercialTrafficApplications.jointDemand; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.contrib.commercialTrafficApplications.jointDemand.DefaultCommercialServiceScore; @@ -10,10 +10,10 @@ public class DefaultCommercialServiceScoreTest { void calcScore() { DefaultCommercialServiceScore serviceScore = new DefaultCommercialServiceScore(6, -6, 1800); - Assert.assertEquals(serviceScore.calcScore(0), 6., 0.001); - Assert.assertEquals(serviceScore.calcScore(1800), 0, 0.001); - Assert.assertEquals(serviceScore.calcScore(3600), -6., 0.001); - Assert.assertEquals(serviceScore.calcScore(7200), -6., 0.001); + Assertions.assertEquals(serviceScore.calcScore(0), 6., 0.001); + Assertions.assertEquals(serviceScore.calcScore(1800), 0, 0.001); + Assertions.assertEquals(serviceScore.calcScore(3600), -6., 0.001); + Assertions.assertEquals(serviceScore.calcScore(7200), -6., 0.001); } } \ No newline at end of file diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java index f71e9a3a3ed..8e083962c5d 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java @@ -18,8 +18,8 @@ package org.matsim.contrib.commercialTrafficApplications.jointDemand; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -113,14 +113,14 @@ void testIfTheRightPersonIsScoredForReceivingAJob() { .map(carrierService -> carrierService.getId()) .findFirst().orElseThrow(() -> new RuntimeException("no service activity found in scheduledTours")); - Assert.assertEquals("the person that is delivered pizza should be customerOrderingForParty", partyPizzaPlan.getPerson().getId().toString(), serviceActivity.toString().split("_")[0]); + Assertions.assertEquals(partyPizzaPlan.getPerson().getId().toString(), serviceActivity.toString().split("_")[0], "the person that is delivered pizza should be customerOrderingForParty"); //compare scores - Assert.assertTrue("the plan of the customer receiving a job should get a higher score than the plan of the non customer ", partyPizzaPlan.getScore() > nonCustomerPlan.getScore()); - Assert.assertTrue("the plan of the customer receiving a job should get a higher score than the plan of the customer not receiving one ", partyPizzaPlan.getScore() > lonelyPizzaPlan.getScore()); - Assert.assertTrue("the difference of receiving a job in time and not receiving it at all should be the maxJobScore=" + MAX_JOB_SCORE + " as job is performed in time", partyPizzaPlan.getScore() - lonelyPizzaPlan.getScore() == MAX_JOB_SCORE); - Assert.assertEquals("not receiving a job at all should be scored with zero", lonelyPizzaPlan.getScore(), 0.0, MatsimTestUtils.EPSILON); - Assert.assertTrue(lonelyPizzaPlan.getScore() - nonCustomerPlan.getScore() == 0); + Assertions.assertTrue(partyPizzaPlan.getScore() > nonCustomerPlan.getScore(), "the plan of the customer receiving a job should get a higher score than the plan of the non customer "); + Assertions.assertTrue(partyPizzaPlan.getScore() > lonelyPizzaPlan.getScore(), "the plan of the customer receiving a job should get a higher score than the plan of the customer not receiving one "); + Assertions.assertTrue(partyPizzaPlan.getScore() - lonelyPizzaPlan.getScore() == MAX_JOB_SCORE, "the difference of receiving a job in time and not receiving it at all should be the maxJobScore=" + MAX_JOB_SCORE + " as job is performed in time"); + Assertions.assertEquals(lonelyPizzaPlan.getScore(), 0.0, MatsimTestUtils.EPSILON, "not receiving a job at all should be scored with zero"); + Assertions.assertTrue(lonelyPizzaPlan.getScore() - nonCustomerPlan.getScore() == 0); } diff --git a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java index 09772d843d3..e6a0711851a 100644 --- a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java +++ b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest66IT.java @@ -20,14 +20,14 @@ package org.matsim.integration.always; -import static org.junit.Assert.assertEquals; - import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; import java.util.HashSet; import jakarta.inject.Inject; + +import static org.junit.jupiter.api.Assertions.assertEquals; import jakarta.inject.Provider; import org.apache.logging.log4j.LogManager; diff --git a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java index da2037aa8cd..49ec89733a1 100644 --- a/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java +++ b/contribs/common/src/test/java/org/matsim/integration/always/BetaTravelTest6IT.java @@ -20,14 +20,14 @@ package org.matsim.integration.always; -import static org.junit.Assert.assertEquals; - import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; import java.util.HashSet; import jakarta.inject.Inject; + +import static org.junit.jupiter.api.Assertions.assertEquals; import jakarta.inject.Provider; import org.apache.logging.log4j.LogManager; diff --git a/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java b/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java index 7ff2403f49b..2562177bd77 100644 --- a/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java +++ b/contribs/decongestion/src/test/java/org/matsim/contrib/decongestion/DecongestionPricingTestIT.java @@ -22,7 +22,7 @@ */ package org.matsim.contrib.decongestion; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.analysis.ScoreStatsControlerListener.ScoreItem; @@ -130,19 +130,19 @@ public void install() { double tt1 = controler.getLinkTravelTimes().getLinkTravelTime(scenario.getNetwork().getLinks().get(Id.createLinkId("link12")), 7 * 3600 + 63, null, null); double tt2 = controler.getLinkTravelTimes().getLinkTravelTime(scenario.getNetwork().getLinks().get(Id.createLinkId("link12")), 7 * 3600 + 15. * 60, null, null); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 100.0, tt0, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 150.5, tt1, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 100.0, tt2, MatsimTestUtils.EPSILON); + Assertions.assertEquals(100.0, tt0, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); + Assertions.assertEquals(150.5, tt1, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); + Assertions.assertEquals(100.0, tt2, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); final int index = config.controller().getLastIteration() - config.controller().getFirstIteration(); double avgScore = controler.getScoreStats().getScoreHistory().get( ScoreItem.executed ).get(index); - Assert.assertEquals("Wrong average executed score. The tolls seem to have changed.", -33.940316666666666, avgScore, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-33.940316666666666, avgScore, MatsimTestUtils.EPSILON, "Wrong average executed score. The tolls seem to have changed."); System.out.println(info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().toString()); System.out.println(info.getlinkInfos().get(Id.createLinkId("link12")).getTime2avgDelay().toString()); - Assert.assertEquals("Wrong average delay (capacity is set in a way that one of the two agents has to wait 101 sec. Thus the average is 50.5", 50.5, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2avgDelay().get(84), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong toll.", 50.5 * 0.0123, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(84), MatsimTestUtils.EPSILON); + Assertions.assertEquals(50.5, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2avgDelay().get(84), MatsimTestUtils.EPSILON, "Wrong average delay (capacity is set in a way that one of the two agents has to wait 101 sec. Thus the average is 50.5"); + Assertions.assertEquals(50.5 * 0.0123, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(84), MatsimTestUtils.EPSILON, "Wrong toll."); } @@ -197,13 +197,13 @@ public void install() { double tt1 = controler.getLinkTravelTimes().getLinkTravelTime(scenario.getNetwork().getLinks().get(Id.createLinkId("link12")), 7 * 3600 + 63, null, null); double tt2 = controler.getLinkTravelTimes().getLinkTravelTime(scenario.getNetwork().getLinks().get(Id.createLinkId("link12")), 7 * 3600 + 15. * 60, null, null); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 100.0, tt0, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 150.5, tt1, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 100.0, tt2, MatsimTestUtils.EPSILON); + Assertions.assertEquals(100.0, tt0, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); + Assertions.assertEquals(150.5, tt1, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); + Assertions.assertEquals(100.0, tt2, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); final int index = config.controller().getLastIteration() - config.controller().getFirstIteration(); double avgScore = controler.getScoreStats().getScoreHistory().get( ScoreItem.executed ).get(index); - Assert.assertEquals("Wrong average executed score. The tolls seem to have changed.", -33.940316666666666, avgScore, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-33.940316666666666, avgScore, MatsimTestUtils.EPSILON, "Wrong average executed score. The tolls seem to have changed."); } /** @@ -279,19 +279,19 @@ public void install() { double tt1 = controler.getLinkTravelTimes().getLinkTravelTime(scenario.getNetwork().getLinks().get(Id.createLinkId("link12")), 7 * 3600 + 63, null, null); double tt2 = controler.getLinkTravelTimes().getLinkTravelTime(scenario.getNetwork().getLinks().get(Id.createLinkId("link12")), 7 * 3600 + 15. * 60, null, null); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 100.0, tt0, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 150.5, tt1, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 100.0, tt2, MatsimTestUtils.EPSILON); + Assertions.assertEquals(100.0, tt0, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); + Assertions.assertEquals(150.5, tt1, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); + Assertions.assertEquals(100.0, tt2, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); final int index = config.controller().getLastIteration() - config.controller().getFirstIteration(); double avgScore = controler.getScoreStats().getScoreHistory().get( ScoreItem.executed ).get(index); - Assert.assertEquals("Wrong average executed score. The tolls seem to have changed.", -134.31916666666666, avgScore, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-134.31916666666666, avgScore, MatsimTestUtils.EPSILON, "Wrong average executed score. The tolls seem to have changed."); System.out.println(info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().toString()); System.out.println(info.getlinkInfos().get(Id.createLinkId("link12")).getTime2avgDelay().toString()); - Assert.assertEquals("Wrong average delay (capacity is set in a way that one of the two agents has to wait 101 sec. Thus the average is 50.5", 50.5, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2avgDelay().get(84), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong toll.", 50.5 * 2, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(84), MatsimTestUtils.EPSILON); + Assertions.assertEquals(50.5, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2avgDelay().get(84), MatsimTestUtils.EPSILON, "Wrong average delay (capacity is set in a way that one of the two agents has to wait 101 sec. Thus the average is 50.5"); + Assertions.assertEquals(50.5 * 2, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(84), MatsimTestUtils.EPSILON, "Wrong toll."); } /** @@ -345,13 +345,13 @@ public void install() { double tt1 = controler.getLinkTravelTimes().getLinkTravelTime(scenario.getNetwork().getLinks().get(Id.createLinkId("link12")), 7 * 3600 + 63, null, null); double tt2 = controler.getLinkTravelTimes().getLinkTravelTime(scenario.getNetwork().getLinks().get(Id.createLinkId("link12")), 7 * 3600 + 15. * 60, null, null); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 100.0, tt0, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 150.5, tt1, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 100.0, tt2, MatsimTestUtils.EPSILON); + Assertions.assertEquals(100.0, tt0, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); + Assertions.assertEquals(150.5, tt1, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); + Assertions.assertEquals(100.0, tt2, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); final int index = config.controller().getLastIteration() - config.controller().getFirstIteration(); double avgScore = controler.getScoreStats().getScoreHistory().get( ScoreItem.executed ).get(index); - Assert.assertEquals("Wrong average executed score. The tolls seem to have changed.", -134.31916666666666, avgScore, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-134.31916666666666, avgScore, MatsimTestUtils.EPSILON, "Wrong average executed score. The tolls seem to have changed."); } /** @@ -419,19 +419,19 @@ public void install() { double tt1 = controler.getLinkTravelTimes().getLinkTravelTime(scenario.getNetwork().getLinks().get(Id.createLinkId("link12")), 7 * 3600 + 63, null, null); double tt2 = controler.getLinkTravelTimes().getLinkTravelTime(scenario.getNetwork().getLinks().get(Id.createLinkId("link12")), 7 * 3600 + 15. * 60, null, null); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 100.0, tt0, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 150.5, tt1, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong travel time. The run output seems to have changed.", 100.0, tt2, MatsimTestUtils.EPSILON); + Assertions.assertEquals(100.0, tt0, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); + Assertions.assertEquals(150.5, tt1, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); + Assertions.assertEquals(100.0, tt2, MatsimTestUtils.EPSILON, "Wrong travel time. The run output seems to have changed."); final int index = config.controller().getLastIteration() - config.controller().getFirstIteration(); double avgScore = controler.getScoreStats().getScoreHistory().get( ScoreItem.executed ).get(index); - Assert.assertEquals("Wrong average executed score. The tolls seem to have changed.", -33.31916666666666, avgScore, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-33.31916666666666, avgScore, MatsimTestUtils.EPSILON, "Wrong average executed score. The tolls seem to have changed."); System.out.println(info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().toString()); System.out.println(info.getlinkInfos().get(Id.createLinkId("link12")).getTime2avgDelay().toString()); - Assert.assertEquals("Wrong average delay (capacity is set in a way that one of the two agents has to wait 101 sec. Thus the average is 50.5", 50.5, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2avgDelay().get(84), MatsimTestUtils.EPSILON); - Assert.assertNull("Wrong toll.", info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(84)); + Assertions.assertEquals(50.5, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2avgDelay().get(84), MatsimTestUtils.EPSILON, "Wrong average delay (capacity is set in a way that one of the two agents has to wait 101 sec. Thus the average is 50.5"); + Assertions.assertNull(info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(84), "Wrong toll."); } @@ -489,11 +489,11 @@ public void install() { final int index = config.controller().getLastIteration() - config.controller().getFirstIteration(); double avgScore = controler.getScoreStats().getScoreHistory().get( ScoreItem.executed ).get(index) ; - Assert.assertEquals("Wrong average executed score. The run output seems to have changed.", -12036.177448472225, avgScore, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-12036.177448472225, avgScore, MatsimTestUtils.EPSILON, "Wrong average executed score. The run output seems to have changed."); System.out.println(info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().toString()); - Assert.assertEquals("Wrong toll in time bin 61.", 9.197000000000003, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(61), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong toll in time bin 73.", 12.963999999999984, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(73), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9.197000000000003, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(61), MatsimTestUtils.EPSILON, "Wrong toll in time bin 61."); + Assertions.assertEquals(12.963999999999984, info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(73), MatsimTestUtils.EPSILON, "Wrong toll in time bin 73."); } /** @@ -551,11 +551,11 @@ public void install() { final int index = config.controller().getLastIteration() - config.controller().getFirstIteration(); double avgScore = controler.getScoreStats().getScoreHistory().get( ScoreItem.executed ).get( index ) ; - Assert.assertEquals("Wrong average executed score. The run output seems to have changed.", -55.215645833333184, avgScore, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-55.215645833333184, avgScore, MatsimTestUtils.EPSILON, "Wrong average executed score. The run output seems to have changed."); System.out.println(info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().toString()); - Assert.assertEquals("Wrong toll in time bin 61.", 13., info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(61), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong toll in time bin 73.", 13., info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(73), MatsimTestUtils.EPSILON); + Assertions.assertEquals(13., info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(61), MatsimTestUtils.EPSILON, "Wrong toll in time bin 61."); + Assertions.assertEquals(13., info.getlinkInfos().get(Id.createLinkId("link12")).getTime2toll().get(73), MatsimTestUtils.EPSILON, "Wrong toll in time bin 73."); } } diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/SubtourModeChoiceReplacementTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/SubtourModeChoiceReplacementTest.java index b9cab362620..416162e725e 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/SubtourModeChoiceReplacementTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/SubtourModeChoiceReplacementTest.java @@ -1,7 +1,5 @@ package org.matsim.contrib.discrete_mode_choice; -import static org.junit.Assert.assertEquals; - import java.util.Arrays; import java.util.Collections; import java.util.HashSet; @@ -10,6 +8,8 @@ import java.util.Set; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.population.Plan; import org.matsim.contrib.discrete_mode_choice.test_utils.PlanBuilder; import org.matsim.contrib.discrete_mode_choice.test_utils.PlanTester; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/constraints/VehicleTourConstraintTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/constraints/VehicleTourConstraintTest.java index a95458ffdf4..f5c0fd7ce92 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/constraints/VehicleTourConstraintTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/constraints/VehicleTourConstraintTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.discrete_mode_choice.components.constraints; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertFalse; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.Arrays; import java.util.Collection; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/readers/ApolloTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/readers/ApolloTest.java index 3e396542e5f..c588e1864cf 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/readers/ApolloTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/readers/ApolloTest.java @@ -1,11 +1,11 @@ package org.matsim.contrib.discrete_mode_choice.components.readers; -import static org.junit.Assert.assertEquals; - import java.io.IOException; import java.net.URL; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.contribs.discrete_mode_choice.components.readers.ApolloParameterReader; import org.matsim.contribs.discrete_mode_choice.components.readers.ApolloParameters; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/tour_finder/ActivityTourFinderTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/tour_finder/ActivityTourFinderTest.java index 8fd14c7f09a..483cfa96dfb 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/tour_finder/ActivityTourFinderTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/tour_finder/ActivityTourFinderTest.java @@ -1,12 +1,12 @@ package org.matsim.contrib.discrete_mode_choice.components.tour_finder; -import static org.junit.Assert.assertEquals; - import java.util.Arrays; import java.util.LinkedList; import java.util.List; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.population.Plan; import org.matsim.contribs.discrete_mode_choice.components.tour_finder.ActivityTourFinder; import org.matsim.contribs.discrete_mode_choice.model.DiscreteModeChoiceTrip; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/utils/ScheduleWaitingTimeEstimatorTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/utils/ScheduleWaitingTimeEstimatorTest.java index 2e69210fff1..f9c951bb195 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/utils/ScheduleWaitingTimeEstimatorTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/components/utils/ScheduleWaitingTimeEstimatorTest.java @@ -1,5 +1,7 @@ package org.matsim.contrib.discrete_mode_choice.components.utils; +import static org.junit.jupiter.api.Assertions.assertEquals; + import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -25,8 +27,6 @@ import java.util.LinkedList; import java.util.List; -import static org.junit.Assert.assertEquals; - public class ScheduleWaitingTimeEstimatorTest { @Test void testValidSingleCase() throws IOException { diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/examples/TestSiouxFalls.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/examples/TestSiouxFalls.java index 5a1edb6623e..299d69644dd 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/examples/TestSiouxFalls.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/examples/TestSiouxFalls.java @@ -1,12 +1,12 @@ package org.matsim.contrib.discrete_mode_choice.examples; -import static org.junit.Assert.assertEquals; - import java.net.URL; import java.util.HashMap; import java.util.Map; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.PersonArrivalEvent; import org.matsim.api.core.v01.events.handler.PersonArrivalEventHandler; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MaximumUtilityTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MaximumUtilityTest.java index 31bff842634..b186857b40b 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MaximumUtilityTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MaximumUtilityTest.java @@ -1,13 +1,13 @@ package org.matsim.contrib.discrete_mode_choice.models; -import static org.junit.Assert.assertEquals; - import java.util.Arrays; import java.util.Collections; import java.util.List; import java.util.Random; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.population.Activity; import org.matsim.contribs.discrete_mode_choice.model.DiscreteModeChoiceModel.FallbackBehaviour; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MultinomialLogitTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MultinomialLogitTest.java index dbe32f1e8a3..fcee4f218af 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MultinomialLogitTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/MultinomialLogitTest.java @@ -1,7 +1,5 @@ package org.matsim.contrib.discrete_mode_choice.models; -import static org.junit.Assert.assertEquals; - import java.util.Arrays; import java.util.Collections; import java.util.HashMap; @@ -10,6 +8,8 @@ import java.util.Random; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.population.Activity; import org.matsim.contribs.discrete_mode_choice.model.DiscreteModeChoiceModel.FallbackBehaviour; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/NestedLogitTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/NestedLogitTest.java index 38e7b54df7d..b25de2aeb32 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/NestedLogitTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/NestedLogitTest.java @@ -1,7 +1,5 @@ package org.matsim.contrib.discrete_mode_choice.models; -import static org.junit.Assert.assertEquals; - import java.util.Arrays; import java.util.Collections; import java.util.HashMap; @@ -10,6 +8,8 @@ import java.util.Random; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.population.Activity; import org.matsim.contribs.discrete_mode_choice.model.DiscreteModeChoiceModel.FallbackBehaviour; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/RandomUtilityTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/RandomUtilityTest.java index e69eae5ee23..8df0f2cf4ae 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/RandomUtilityTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/RandomUtilityTest.java @@ -1,7 +1,5 @@ package org.matsim.contrib.discrete_mode_choice.models; -import static org.junit.Assert.assertEquals; - import java.util.Arrays; import java.util.Collections; import java.util.HashMap; @@ -10,6 +8,8 @@ import java.util.Random; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.population.Activity; import org.matsim.contribs.discrete_mode_choice.components.estimators.UniformTripEstimator; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/nested/NestCalculatorTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/nested/NestCalculatorTest.java index 5c344aabd51..d65e211943b 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/nested/NestCalculatorTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/models/nested/NestCalculatorTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.discrete_mode_choice.models.nested; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.matsim.contribs.discrete_mode_choice.model.DiscreteModeChoiceModel.NoFeasibleChoiceException; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java index 4090739bcd5..a516cf31ec3 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/modules/config/ConfigTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.discrete_mode_choice.modules.config; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.io.BufferedReader; import java.io.File; diff --git a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/replanning/TestDepartureTimes.java b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/replanning/TestDepartureTimes.java index c3e744e0880..69f766da8d4 100644 --- a/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/replanning/TestDepartureTimes.java +++ b/contribs/discrete_mode_choice/src/test/java/org/matsim/contrib/discrete_mode_choice/replanning/TestDepartureTimes.java @@ -1,7 +1,5 @@ package org.matsim.contrib.discrete_mode_choice.replanning; -import static org.junit.Assert.assertEquals; - import java.util.Arrays; import java.util.Collections; import java.util.LinkedList; @@ -9,6 +7,8 @@ import java.util.Random; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.population.Leg; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java index 8ca27490ae3..10b53461d07 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java @@ -24,7 +24,7 @@ import java.nio.file.Path; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; @@ -85,10 +85,10 @@ void loadConfigGroupTest() throws IOException { Config config = ConfigUtils.createConfig(); ConfigUtils.loadConfig(config, configFile.toString()); DrtWithExtensionsConfigGroup loadedCfg = ConfigUtils.addOrGetModule(config, DrtWithExtensionsConfigGroup.class); - Assert.assertTrue(loadedCfg.getDrtCompanionParams().isPresent()); - Assert.assertTrue(loadedCfg.getDrtCompanionParams().get().getDrtCompanionSamplingWeights().get(0).equals(WEIGHT_1)); - Assert.assertTrue(loadedCfg.getDrtCompanionParams().get().getDrtCompanionSamplingWeights().get(1).equals(WEIGHT_2)); - Assert.assertTrue(loadedCfg.getDrtCompanionParams().get().getDrtCompanionSamplingWeights().get(2).equals(WEIGHT_3)); + Assertions.assertTrue(loadedCfg.getDrtCompanionParams().isPresent()); + Assertions.assertTrue(loadedCfg.getDrtCompanionParams().get().getDrtCompanionSamplingWeights().get(0).equals(WEIGHT_1)); + Assertions.assertTrue(loadedCfg.getDrtCompanionParams().get().getDrtCompanionSamplingWeights().get(1).equals(WEIGHT_2)); + Assertions.assertTrue(loadedCfg.getDrtCompanionParams().get().getDrtCompanionSamplingWeights().get(2).equals(WEIGHT_3)); } } diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/edrt/run/RunEDrtScenarioIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/edrt/run/RunEDrtScenarioIT.java index 370304d1bdb..051867cb5f8 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/edrt/run/RunEDrtScenarioIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/edrt/run/RunEDrtScenarioIT.java @@ -18,11 +18,11 @@ package org.matsim.contrib.drt.extension.edrt.run; -import static org.junit.Assert.assertEquals; - import java.net.URL; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.contrib.drt.prebooking.PrebookingParams; import org.matsim.contrib.drt.prebooking.logic.ProbabilityBasedPrebookingLogic; import org.matsim.contrib.drt.run.DrtConfigGroup; diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/fiss/RunFissDrtScenarioIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/fiss/RunFissDrtScenarioIT.java index 52da0c3199a..6034419d22e 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/fiss/RunFissDrtScenarioIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/fiss/RunFissDrtScenarioIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.drt.extension.fiss; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.LinkLeaveEvent; @@ -173,7 +173,7 @@ public void install() { } run.run(); - Assert.assertEquals(23817, linkCounter.getLinkLeaveCount()); + Assertions.assertEquals(23817, linkCounter.getLinkLeaveCount()); } static class LinkCounter implements LinkLeaveEventHandler { diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java index 91d5699623d..69febd3aab0 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/insertion/DrtInsertionExtensionIT.java @@ -1,7 +1,7 @@ package org.matsim.contrib.drt.extension.insertion; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.net.URL; import java.util.ArrayList; diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java index 427416b3b4b..06bcd185b89 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/operationFacilities/OperationFacilitiesIOTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.drt.extension.operations.operationFacilities; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -58,12 +58,12 @@ void test() { Id charger = Id.create(i, Charger.class); Id charger2 = Id.create(i+"_2", Charger.class); final OperationFacilitySpecification facility = copy.getOperationFacilitySpecifications().get(id); - Assert.assertEquals(linkId.toString(), facility.getLinkId().toString()); - Assert.assertEquals(coord.getX(), facility.getCoord().getX(), 0); - Assert.assertEquals(coord.getY(), facility.getCoord().getY(), 0); - Assert.assertEquals(capacity, facility.getCapacity()); - Assert.assertEquals(charger.toString(), facility.getChargers().get(0).toString()); - Assert.assertEquals(charger2.toString(), facility.getChargers().get(1).toString()); + Assertions.assertEquals(linkId.toString(), facility.getLinkId().toString()); + Assertions.assertEquals(coord.getX(), facility.getCoord().getX(), 0); + Assertions.assertEquals(coord.getY(), facility.getCoord().getY(), 0); + Assertions.assertEquals(capacity, facility.getCapacity()); + Assertions.assertEquals(charger.toString(), facility.getChargers().get(0).toString()); + Assertions.assertEquals(charger2.toString(), facility.getChargers().get(1).toString()); } for (int i = 10; i < 20; i++) { @@ -73,11 +73,11 @@ void test() { int capacity = i; Id charger = Id.create(i, Charger.class); final OperationFacilitySpecification facility = copy.getOperationFacilitySpecifications().get(id); - Assert.assertEquals(linkId.toString(), facility.getLinkId().toString()); - Assert.assertEquals(coord.getX(), facility.getCoord().getX(), 0); - Assert.assertEquals(coord.getY(), facility.getCoord().getY(), 0); - Assert.assertEquals(capacity, facility.getCapacity()); - Assert.assertEquals(charger.toString(), facility.getChargers().get(0).toString()); + Assertions.assertEquals(linkId.toString(), facility.getLinkId().toString()); + Assertions.assertEquals(coord.getX(), facility.getCoord().getX(), 0); + Assertions.assertEquals(coord.getY(), facility.getCoord().getY(), 0); + Assertions.assertEquals(capacity, facility.getCapacity()); + Assertions.assertEquals(charger.toString(), facility.getChargers().get(0).toString()); } } } diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java index d2f4c3e27f2..ff5eb57ecdc 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/ShiftsIOTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.drt.extension.operations.shifts; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.File; import java.util.Optional; diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyTest.java index d3b4dfb001c..b3e8db5e38d 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/operations/shifts/analysis/efficiency/ShiftEfficiencyTest.java @@ -9,7 +9,7 @@ package org.matsim.contrib.drt.extension.operations.shifts.analysis.efficiency; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonMoneyEvent; @@ -53,7 +53,7 @@ void testDrtShiftEfficiency() { events.processEvent(new DrtShiftStartedEvent(10 * 3600, shift1, vehicle1, link1) ); // should throw because vehicle is already registered with another shift - Assert.assertThrows(RuntimeException.class, () -> { + Assertions.assertThrows(RuntimeException.class, () -> { events.processEvent(new DrtShiftStartedEvent(10 * 3600, shift1, vehicle1, link1)); }); @@ -62,14 +62,14 @@ void testDrtShiftEfficiency() { events.processEvent(new PassengerDroppedOffEvent(11 * 3600, "drt", request1, person1, vehicle1)); - Assert.assertTrue(shiftEfficiencyTracker.getCurrentRecord().getRequestsByShift().get(shift1).contains(request1)); + Assertions.assertTrue(shiftEfficiencyTracker.getCurrentRecord().getRequestsByShift().get(shift1).contains(request1)); events.processEvent(new PersonMoneyEvent(11 * 3600, person1, -FARE, DrtFareHandler.PERSON_MONEY_EVENT_PURPOSE_DRT_FARE, "drt", request1.toString())); - Assert.assertEquals(FARE, shiftEfficiencyTracker.getCurrentRecord().getRevenueByShift().get(shift1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(FARE, shiftEfficiencyTracker.getCurrentRecord().getRevenueByShift().get(shift1), MatsimTestUtils.EPSILON); - Assert.assertFalse(shiftEfficiencyTracker.getCurrentRecord().getFinishedShifts().containsKey(shift1)); + Assertions.assertFalse(shiftEfficiencyTracker.getCurrentRecord().getFinishedShifts().containsKey(shift1)); events.processEvent(new DrtShiftEndedEvent(20 * 3600, shift1, vehicle1, link1, operationFacility1)); - Assert.assertTrue(shiftEfficiencyTracker.getCurrentRecord().getFinishedShifts().containsKey(shift1)); + Assertions.assertTrue(shiftEfficiencyTracker.getCurrentRecord().getFinishedShifts().containsKey(shift1)); } } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtZonalSystemTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtZonalSystemTest.java index 6e58adfdbe5..a49cc10a3d0 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtZonalSystemTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/analysis/zonal/DrtZonalSystemTest.java @@ -21,7 +21,7 @@ package org.matsim.contrib.drt.analysis.zonal; import static org.assertj.core.api.Assertions.assertThat; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import static org.matsim.contrib.drt.analysis.zonal.DrtGridUtilsTest.createNetwork; import static org.matsim.contrib.drt.analysis.zonal.DrtZonalSystem.createFromPreparedGeometries; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java index 791902fbf14..003b183046c 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/config/ConfigBehaviorTest.java @@ -2,7 +2,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.drt.run.DrtConfigGroup; @@ -46,13 +46,13 @@ final void testMaterializeAfterReadParameterSets() { MultiModeDrtConfigGroup multiModeDrtConfigGroup = ConfigUtils.addOrGetModule( config, MultiModeDrtConfigGroup.class ); // this should have two config groups here, but does not: - Assert.assertEquals( 2, multiModeDrtConfigGroup.getModalElements().size() ); + Assertions.assertEquals( 2, multiModeDrtConfigGroup.getModalElements().size() ); // check if you are getting back the values from the config file: for( DrtConfigGroup drtConfigGroup : multiModeDrtConfigGroup.getModalElements() ){ log.info( drtConfigGroup.getMode() ); if ( ! ( drtConfigGroup.getMode().equals( "drt20" ) || drtConfigGroup.getMode().equals( "drt20000" ) ) ) { - Assert.fail(); + Assertions.fail(); } } @@ -79,8 +79,8 @@ final void testMaterializeAfterReadStandardParams() { DvrpConfigGroup dvrpConfig = ConfigUtils.addOrGetModule( config, DvrpConfigGroup.class ); // check if you are getting back the values from the config file: - Assert.assertEquals( 1.23, dvrpConfig.travelTimeEstimationAlpha, Double.MIN_VALUE ); - Assert.assertEquals( 4.56, dvrpConfig.travelTimeEstimationBeta, Double.MIN_VALUE ); + Assertions.assertEquals( 1.23, dvrpConfig.travelTimeEstimationAlpha, Double.MIN_VALUE ); + Assertions.assertEquals( 4.56, dvrpConfig.travelTimeEstimationBeta, Double.MIN_VALUE ); } } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/fare/DrtFareHandlerTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/fare/DrtFareHandlerTest.java index fc3c85c6c57..35e41f5d018 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/fare/DrtFareHandlerTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/fare/DrtFareHandlerTest.java @@ -21,7 +21,7 @@ package org.matsim.contrib.drt.fare; import org.apache.commons.lang3.mutable.MutableDouble; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonMoneyEvent; @@ -77,7 +77,7 @@ public void reset(int iteration) { events.flush(); //fare: 1 (daily fee) + 1 (distance()+ 1 basefare + 1 (time) - Assert.assertEquals(-4.0, fare.getValue(), 0); + Assertions.assertEquals(-4.0, fare.getValue(), 0); } { // test minFarePerTrip @@ -91,7 +91,7 @@ public void reset(int iteration) { * fare new trip: 0 (daily fee already paid) + 0.1 (distance)+ 1 basefare + 0.1 (time) = 1.2 < minFarePerTrip = 1.5 * --> new total fare: 4 (previous trip) + 1.5 (minFarePerTrip for new trip) = 5.5 */ - Assert.assertEquals(-5.5, fare.getValue(), 0); + Assertions.assertEquals(-5.5, fare.getValue(), 0); } } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java index 6b01f318098..76b6f176cde 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/DrtPoolingParameterTest.java @@ -3,7 +3,7 @@ import java.net.URL; import java.util.*; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -66,7 +66,7 @@ public class DrtPoolingParameterTest { @Test void testMaxWaitTimeNoVehicles() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(50, 10.0, 10000.); - Assert.assertEquals("There should be no vehicle used", 0, handler.getVehRequestCount().size()); + Assertions.assertEquals(0, handler.getVehRequestCount().size(), "There should be no vehicle used"); } @@ -79,17 +79,17 @@ void testMaxWaitTimeNoVehicles() { void testMaxWaitTimeTwoVehiclesForTwoAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(121, 10.0, 10000.); - Assert.assertEquals("There should two vehicle used", 2, handler.getVehRequestCount().size()); + Assertions.assertEquals(2, handler.getVehRequestCount().size(), "There should two vehicle used"); Id drt_veh_1_1 = Id.create("drt_veh_1_1", DvrpVehicle.class); Id drt_veh_1_2 = Id.create("drt_veh_1_2", DvrpVehicle.class); - Assert.assertTrue("drt_veh_1_1 should be requested in general", - handler.getVehRequestCount().containsKey(drt_veh_1_1)); - Assert.assertEquals("drt_veh_1_1 should be requested exactly once", 1, - handler.getVehRequestCount().get(drt_veh_1_1), 0); - Assert.assertTrue("drt_veh_1_2 should be requested in general", - handler.getVehRequestCount().containsKey(drt_veh_1_2)); - Assert.assertEquals("drt_veh_1_2 should be requested exactly once", 1, - handler.getVehRequestCount().get(drt_veh_1_2), 0); + Assertions.assertTrue(handler.getVehRequestCount().containsKey(drt_veh_1_1), + "drt_veh_1_1 should be requested in general"); + Assertions.assertEquals(1, + handler.getVehRequestCount().get(drt_veh_1_1), 0, "drt_veh_1_1 should be requested exactly once"); + Assertions.assertTrue(handler.getVehRequestCount().containsKey(drt_veh_1_2), + "drt_veh_1_2 should be requested in general"); + Assertions.assertEquals(1, + handler.getVehRequestCount().get(drt_veh_1_2), 0, "drt_veh_1_2 should be requested exactly once"); } @@ -100,17 +100,17 @@ void testMaxWaitTimeTwoVehiclesForTwoAgents() { void testMaxWaitTimeTwoVehiclesForFourAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(250, 10.0, 10000.); - Assert.assertEquals("There should two vehicle used", 2, handler.getVehRequestCount().size()); + Assertions.assertEquals(2, handler.getVehRequestCount().size(), "There should two vehicle used"); Id drt_veh_1_1 = Id.create("drt_veh_1_1", DvrpVehicle.class); Id drt_veh_1_2 = Id.create("drt_veh_1_2", DvrpVehicle.class); - Assert.assertTrue("drt_veh_1_1 should be requested in general", - handler.getVehRequestCount().containsKey(drt_veh_1_1)); - Assert.assertEquals("drt_veh_1_1 should be requested exactly twice", 2, - handler.getVehRequestCount().get(drt_veh_1_1), 0); - Assert.assertTrue("drt_veh_1_2 should be requested in general", - handler.getVehRequestCount().containsKey(drt_veh_1_2)); - Assert.assertEquals("drt_veh_1_2 should be requested exactly twice", 2, - handler.getVehRequestCount().get(drt_veh_1_2), 0); + Assertions.assertTrue(handler.getVehRequestCount().containsKey(drt_veh_1_1), + "drt_veh_1_1 should be requested in general"); + Assertions.assertEquals(2, + handler.getVehRequestCount().get(drt_veh_1_1), 0, "drt_veh_1_1 should be requested exactly twice"); + Assertions.assertTrue(handler.getVehRequestCount().containsKey(drt_veh_1_2), + "drt_veh_1_2 should be requested in general"); + Assertions.assertEquals(2, + handler.getVehRequestCount().get(drt_veh_1_2), 0, "drt_veh_1_2 should be requested exactly twice"); } @@ -122,12 +122,12 @@ void testMaxWaitTimeOneVehicleForFourAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(500, 10.0, 10000.); System.out.println(handler.getVehRequestCount()); - Assert.assertEquals("There should only be one vehicle used", 1, handler.getVehRequestCount().size()); + Assertions.assertEquals(1, handler.getVehRequestCount().size(), "There should only be one vehicle used"); Id drt_veh_1_1 = Id.create("drt_veh_1_1", DvrpVehicle.class); - Assert.assertTrue("drt_veh_1_1 should be requested in general", - handler.getVehRequestCount().containsKey(drt_veh_1_1)); - Assert.assertEquals("drt_veh_1_1 should be requested exactly four times", 4, - handler.getVehRequestCount().get(drt_veh_1_1), 0); + Assertions.assertTrue(handler.getVehRequestCount().containsKey(drt_veh_1_1), + "drt_veh_1_1 should be requested in general"); + Assertions.assertEquals(4, + handler.getVehRequestCount().get(drt_veh_1_1), 0, "drt_veh_1_1 should be requested exactly four times"); } @@ -143,7 +143,7 @@ void testMaxWaitTimeOneVehicleForFourAgents() { void testBetaNoVehicles() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(5000, 1.0, 0.); - Assert.assertEquals("There should only be zero vehicles used", 0, handler.getVehRequestCount().size()); + Assertions.assertEquals(0, handler.getVehRequestCount().size(), "There should only be zero vehicles used"); } @@ -155,17 +155,17 @@ void testBetaNoVehicles() { void testBetaTwoVehiclesForTwoAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(5000, 1.0, 150); - Assert.assertEquals("There should two vehicle used", 2, handler.getVehRequestCount().size()); + Assertions.assertEquals(2, handler.getVehRequestCount().size(), "There should two vehicle used"); Id drt_veh_1_1 = Id.create("drt_veh_1_1", DvrpVehicle.class); Id drt_veh_1_2 = Id.create("drt_veh_1_2", DvrpVehicle.class); - Assert.assertTrue("drt_veh_1_1 should be requested in general", - handler.getVehRequestCount().containsKey(drt_veh_1_1)); - Assert.assertEquals("drt_veh_1_1 should be requested exactly once", 1, - handler.getVehRequestCount().get(drt_veh_1_1), 0); - Assert.assertTrue("drt_veh_1_2 should be requested in general", - handler.getVehRequestCount().containsKey(drt_veh_1_2)); - Assert.assertEquals("drt_veh_1_2 should be requested exactly once", 1, - handler.getVehRequestCount().get(drt_veh_1_2), 0); + Assertions.assertTrue(handler.getVehRequestCount().containsKey(drt_veh_1_1), + "drt_veh_1_1 should be requested in general"); + Assertions.assertEquals(1, + handler.getVehRequestCount().get(drt_veh_1_1), 0, "drt_veh_1_1 should be requested exactly once"); + Assertions.assertTrue(handler.getVehRequestCount().containsKey(drt_veh_1_2), + "drt_veh_1_2 should be requested in general"); + Assertions.assertEquals(1, + handler.getVehRequestCount().get(drt_veh_1_2), 0, "drt_veh_1_2 should be requested exactly once"); } @@ -176,17 +176,17 @@ void testBetaTwoVehiclesForTwoAgents() { void testBetaTwoVehiclesForFourAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(5000, 1.0, 250); - Assert.assertEquals("There should two vehicle used", 2, handler.getVehRequestCount().size()); + Assertions.assertEquals(2, handler.getVehRequestCount().size(), "There should two vehicle used"); Id drt_veh_1_1 = Id.create("drt_veh_1_1", DvrpVehicle.class); Id drt_veh_1_2 = Id.create("drt_veh_1_2", DvrpVehicle.class); - Assert.assertTrue("drt_veh_1_1 should be requested in general", - handler.getVehRequestCount().containsKey(drt_veh_1_1)); - Assert.assertEquals("drt_veh_1_1 should be requested exactly twice", 2, - handler.getVehRequestCount().get(drt_veh_1_1), 0); - Assert.assertTrue("drt_veh_1_2 should be requested in general", - handler.getVehRequestCount().containsKey(drt_veh_1_2)); - Assert.assertEquals("drt_veh_1_2 should be requested exactly twice", 2, - handler.getVehRequestCount().get(drt_veh_1_2), 0); + Assertions.assertTrue(handler.getVehRequestCount().containsKey(drt_veh_1_1), + "drt_veh_1_1 should be requested in general"); + Assertions.assertEquals(2, + handler.getVehRequestCount().get(drt_veh_1_1), 0, "drt_veh_1_1 should be requested exactly twice"); + Assertions.assertTrue(handler.getVehRequestCount().containsKey(drt_veh_1_2), + "drt_veh_1_2 should be requested in general"); + Assertions.assertEquals(2, + handler.getVehRequestCount().get(drt_veh_1_2), 0, "drt_veh_1_2 should be requested exactly twice"); } /** @@ -196,12 +196,12 @@ void testBetaTwoVehiclesForFourAgents() { void testBetaOneVehicleForFourAgents() { PersonEnterDrtVehicleEventHandler handler = setupAndRunScenario(5000, 1.0, 400); - Assert.assertEquals("There should only be one vehicle used", 1, handler.getVehRequestCount().size()); + Assertions.assertEquals(1, handler.getVehRequestCount().size(), "There should only be one vehicle used"); Id drt_veh_1_1 = Id.create("drt_veh_1_1", DvrpVehicle.class); - Assert.assertTrue("drt_veh_1_1 should be requested in general", - handler.getVehRequestCount().containsKey(drt_veh_1_1)); - Assert.assertEquals("drt_veh_1_1 should be requested exactly four times", 4, - handler.getVehRequestCount().get(drt_veh_1_1), 0); + Assertions.assertTrue(handler.getVehRequestCount().containsKey(drt_veh_1_1), + "drt_veh_1_1 should be requested in general"); + Assertions.assertEquals(4, + handler.getVehRequestCount().get(drt_veh_1_1), 0, "drt_veh_1_1 should be requested exactly four times"); } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java index 692657020d8..61241d7c293 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/AbandonAndCancelTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.drt.prebooking; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/ComplexUnschedulerTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/ComplexUnschedulerTest.java index f6155aceec8..93a59a769bd 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/ComplexUnschedulerTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/ComplexUnschedulerTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.drt.prebooking; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.Arrays; import java.util.Collections; @@ -541,16 +541,16 @@ private static void assertTasks(Schedule schedule, List reference Task task = schedule.getTasks().get(i); ReferenceTask reference = references.get(i); - assertEquals("wrong type in task " + i, reference.taskType, task.getClass()); - assertEquals("wrong begin time in task " + i, reference.startTime, task.getBeginTime(), 1e-3); - assertEquals("wrong end time in task " + i, reference.endTime, task.getEndTime(), 1e-3); + assertEquals(reference.taskType, task.getClass(), "wrong type in task " + i); + assertEquals(reference.startTime, task.getBeginTime(), 1e-3, "wrong begin time in task " + i); + assertEquals(reference.endTime, task.getEndTime(), 1e-3, "wrong end time in task " + i); if (i > 0) { - assertEquals("wrong transition from " + (i - 1) + " to " + i, schedule.getTasks().get(i).getBeginTime(), - schedule.getTasks().get(i - 1).getEndTime(), 1e-3); + assertEquals(schedule.getTasks().get(i).getBeginTime(), + schedule.getTasks().get(i - 1).getEndTime(), 1e-3, "wrong transition from " + (i - 1) + " to " + i); } - assertTrue("invalid task " + i, task.getEndTime() >= task.getBeginTime()); + assertTrue(task.getEndTime() >= task.getBeginTime(), "invalid task " + i); } } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java index 35605aac125..4245cd4b4ca 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PersonStuckPrebookingTest.java @@ -1,12 +1,12 @@ package org.matsim.contrib.drt.prebooking; -import static org.junit.Assert.assertEquals; - import java.util.Arrays; import java.util.Collections; import java.util.Set; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java index 05f5eeb2eb8..cb149fc1f3b 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/prebooking/PrebookingTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.drt.prebooking; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java index 71dc3a222b8..e4d242dabcf 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/DrtRoutingModuleTest.java @@ -22,7 +22,7 @@ import java.util.Arrays; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -111,7 +111,7 @@ void testCottbusClosestAccessEgressStopFinder() { List routedList = dvrpRoutingModule.calcRoute( DefaultRoutingRequest.withoutAttributes(hf, wf, 8 * 3600, p1)); - Assert.assertEquals(5, routedList.size()); + Assertions.assertEquals(5, routedList.size()); Leg accessLegP1 = (Leg)routedList.get(0); GenericRouteImpl accessLegP1Route = (GenericRouteImpl)accessLegP1.getRoute(); @@ -129,32 +129,32 @@ void testCottbusClosestAccessEgressStopFinder() { // drt boarding should be at link id 2183 or 2184, not totally clear which one of these (from and to nodes inverted) // drt alighting should be at link id 5866 or 5867, not totally clear which one of these (from and to nodes inverted) - Assert.assertEquals(TransportMode.walk, accessLegP1.getMode()); - Assert.assertEquals(Id.createLinkId(3699), accessLegP1Route.getStartLinkId()); - Assert.assertEquals(Id.createLinkId(2184), accessLegP1Route.getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, accessLegP1.getMode()); + Assertions.assertEquals(Id.createLinkId(3699), accessLegP1Route.getStartLinkId()); + Assertions.assertEquals(Id.createLinkId(2184), accessLegP1Route.getEndLinkId()); - Assert.assertEquals(drtMode + " interaction", stageActivityAccessP1.getType()); - Assert.assertEquals(Id.createLinkId(2184), stageActivityAccessP1.getLinkId()); + Assertions.assertEquals(drtMode + " interaction", stageActivityAccessP1.getType()); + Assertions.assertEquals(Id.createLinkId(2184), stageActivityAccessP1.getLinkId()); - Assert.assertEquals(drtMode, realDrtLegP1.getMode()); - Assert.assertEquals(Id.createLinkId(2184), realDrtLegP1Route.getStartLinkId()); + Assertions.assertEquals(drtMode, realDrtLegP1.getMode()); + Assertions.assertEquals(Id.createLinkId(2184), realDrtLegP1Route.getStartLinkId()); /* * links 5866 and 5867 are located between the same nodes, so their drt stops should be at the same place place, * too. Therefore it is not clear which one of these is the right one, as ClosestAccessEgressStopFinder should * find the nearest drt stop, but both have the same distance from the destination facility. */ - Assert.assertTrue( + Assertions.assertTrue( realDrtLegP1Route.getEndLinkId().equals(Id.createLinkId(5866)) || realDrtLegP1Route.getEndLinkId() .equals(Id.createLinkId(5867))); Id endLink = realDrtLegP1Route.getEndLinkId(); // Check of other, more drt-specific attributes of the DrtRoute is missing, maybe these should be tested in DrtRoutingModule instead - Assert.assertEquals(drtMode + " interaction", stageActivityEgressP1.getType()); - Assert.assertEquals(endLink, stageActivityEgressP1.getLinkId()); + Assertions.assertEquals(drtMode + " interaction", stageActivityEgressP1.getType()); + Assertions.assertEquals(endLink, stageActivityEgressP1.getLinkId()); - Assert.assertEquals(TransportMode.walk, egressLegP1.getMode()); - Assert.assertEquals(endLink, egressLegP1Route.getStartLinkId()); - Assert.assertEquals(Id.createLinkId(7871), egressLegP1Route.getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, egressLegP1.getMode()); + Assertions.assertEquals(endLink, egressLegP1Route.getStartLinkId()); + Assertions.assertEquals(Id.createLinkId(7871), egressLegP1Route.getEndLinkId()); // case 2: origin and destination outside max walking distance from next stop (>2000m vs. max 200m) Person p2 = scenario.getPopulation().getPersons().get(Id.createPersonId(2)); @@ -167,7 +167,7 @@ void testCottbusClosestAccessEgressStopFinder() { List routedList2 = dvrpRoutingModule.calcRoute( DefaultRoutingRequest.withoutAttributes(hf2, wf2, 8 * 3600, p2)); - Assert.assertNull(routedList2); + Assertions.assertNull(routedList2); // case 3: origin and destination at the same coordinate, > 2000 m walking distance from next stop Person p3 = scenario.getPopulation().getPersons().get(Id.createPersonId(3)); @@ -180,7 +180,7 @@ void testCottbusClosestAccessEgressStopFinder() { List routedList3 = dvrpRoutingModule.calcRoute( DefaultRoutingRequest.withoutAttributes(hf3, wf3, 8 * 3600, p3)); - Assert.assertNull(routedList3); + Assertions.assertNull(routedList3); // case 4: origin and destination at the same coordinate, in 200 m walking distance from next stop Person p4 = scenario.getPopulation().getPersons().get(Id.createPersonId(4)); @@ -193,7 +193,7 @@ void testCottbusClosestAccessEgressStopFinder() { List routedList4 = dvrpRoutingModule.calcRoute( DefaultRoutingRequest.withoutAttributes(hf4, wf4, 8 * 3600, p4)); - Assert.assertNull(routedList4); + Assertions.assertNull(routedList4); // case 5: origin within 200 m walking distance from next stop, but destination outside walking distance Person p5 = scenario.getPopulation().getPersons().get(Id.createPersonId(5)); @@ -207,7 +207,7 @@ void testCottbusClosestAccessEgressStopFinder() { DefaultRoutingRequest.withoutAttributes(hf5, wf5, 8 * 3600, p5)); // TODO: Asserts are prepared for interpreting maxWalkingDistance as a real maximum, but routing still works wrongly - Assert.assertNull(routedList5); + Assertions.assertNull(routedList5); // case 6: destination within 200 m walking distance from next stop, but origin outside walking distance Person p6 = scenario.getPopulation().getPersons().get(Id.createPersonId(6)); @@ -221,7 +221,7 @@ void testCottbusClosestAccessEgressStopFinder() { DefaultRoutingRequest.withoutAttributes(hf6, wf6, 8 * 3600, p6)); // TODO: Asserts are prepared for interpreting maxWalkingDistance as a real maximum, but routing still works wrongly - Assert.assertNull(routedList6); + Assertions.assertNull(routedList6); } @@ -243,13 +243,13 @@ void testRouteDescriptionHandling() { DrtRoute drtRoute = new DrtRoute(h.getLinkId(), w.getLinkId()); drtRoute.setRouteDescription(oldRouteFormat); - Assert.assertTrue(drtRoute.getMaxWaitTime() == 600.); - Assert.assertTrue(drtRoute.getDirectRideTime() == 400); + Assertions.assertTrue(drtRoute.getMaxWaitTime() == 600.); + Assertions.assertTrue(drtRoute.getDirectRideTime() == 400); drtRoute.setRouteDescription(newRouteFormat); - Assert.assertTrue(drtRoute.getMaxWaitTime() == 600.); - Assert.assertTrue(drtRoute.getDirectRideTime() == 400); - Assert.assertTrue(drtRoute.getUnsharedPath().equals(Arrays.asList("a", "b", "c"))); + Assertions.assertTrue(drtRoute.getMaxWaitTime() == 600.); + Assertions.assertTrue(drtRoute.getDirectRideTime() == 400); + Assertions.assertTrue(drtRoute.getUnsharedPath().equals(Arrays.asList("a", "b", "c"))); } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/MultiModeDrtMainModeIdentifierTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/MultiModeDrtMainModeIdentifierTest.java index 517321d1305..cfdc3002eee 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/MultiModeDrtMainModeIdentifierTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/routing/MultiModeDrtMainModeIdentifierTest.java @@ -3,7 +3,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.TransportMode; @@ -34,13 +34,13 @@ void test() { List testElements = new ArrayList<>(); Leg l1 = PopulationUtils.createLeg(TransportMode.car); testElements.add(l1); - Assert.assertEquals(TransportMode.car, mmi.identifyMainMode(testElements)); + Assertions.assertEquals(TransportMode.car, mmi.identifyMainMode(testElements)); } { List testElements = new ArrayList<>(); Leg l1 = PopulationUtils.createLeg(drtMode); testElements.add(l1); - Assert.assertEquals(drtMode, mmi.identifyMainMode(testElements)); + Assertions.assertEquals(drtMode, mmi.identifyMainMode(testElements)); } { String drtStageActivityType = ScoringConfigGroup.createStageActivityType(drtMode); @@ -58,7 +58,7 @@ void test() { testElements.add(l2); testElements.add(a3); testElements.add(l3); - Assert.assertEquals(drtMode, mmi.identifyMainMode(testElements)); + Assertions.assertEquals(drtMode, mmi.identifyMainMode(testElements)); } } } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java index 04bd15fa5c8..e3ac88d4985 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/run/examples/RunDrtExampleIT.java @@ -20,7 +20,7 @@ package org.matsim.contrib.drt.run.examples; import static org.assertj.core.api.Assertions.assertThat; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import java.io.IOException; import java.net.URL; diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/DiversionTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/DiversionTest.java index 822f23b36c9..2aa72304e53 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/DiversionTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/router/DiversionTest.java @@ -4,8 +4,7 @@ import java.util.List; import java.util.Objects; import java.util.Set; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -221,18 +220,18 @@ protected void configureQSim() { // Took the fixed value from the simulation, to make sure this stays consistent // over refactorings - Assert.assertEquals(testTracker.eventBasedArrivalTime, 657.0, 0); + Assertions.assertEquals(testTracker.eventBasedArrivalTime, 657.0, 0); // Initially calculated arrival time should predict correctly the final arrival // time - Assert.assertEquals(testTracker.initialArrivalTime, 657.0, 0); + Assertions.assertEquals(testTracker.initialArrivalTime, 657.0, 0); // Along the route, when diverting to the same destination, arrival time should // stay constant - testTracker.diversionArrivalTimes.forEach(t -> Assert.assertEquals(t, 657.0, 0)); + testTracker.diversionArrivalTimes.forEach(t -> Assertions.assertEquals(t, 657.0, 0)); // Also ,the task end time should be consistent with the path - testTracker.taskEndTimes.forEach(t -> Assert.assertEquals(t, 657.0, 0)); + testTracker.taskEndTimes.forEach(t -> Assertions.assertEquals(t, 657.0, 0)); } static private class TestModeModule extends AbstractDvrpModeModule { @@ -549,15 +548,15 @@ protected void configureQSim() { // Took the fixed value from the simulation, to make sure this stays consistent // over refactorings - same as previous unit test - Assert.assertEquals(testTracker.eventBasedArrivalTime, 657.0, 0); + Assertions.assertEquals(testTracker.eventBasedArrivalTime, 657.0, 0); // Initially calculated arrival time should predict correctly the final arrival // time - as in the first unit test as we route to L8 - Assert.assertEquals(testTracker.initialArrivalTime, 657.0, 0); + Assertions.assertEquals(testTracker.initialArrivalTime, 657.0, 0); // Along the route, when diverting to the same destination, arrival time should // stay constant - testTracker.diversionArrivalTimes.forEach(t -> Assert.assertEquals(t, 739.0, 0)); + testTracker.diversionArrivalTimes.forEach(t -> Assertions.assertEquals(t, 739.0, 0)); // Without fix in OnlineDriveTaskTrackerImpl, the last test will lead to a // difference of one second for the samples at late times diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java index ea2bb982d8e..c7cde9b6eb1 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/EmissionModuleTest.java @@ -15,8 +15,8 @@ import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; -import static org.junit.Assert.*; import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.fail; /** * Most of the other test implicitly test the EmissionModule as well. Still, I guess it makes sense to have this here diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/OsmHbefaMappingTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/OsmHbefaMappingTest.java index af88ae935a2..195fc6e6fcb 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/OsmHbefaMappingTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/OsmHbefaMappingTest.java @@ -6,8 +6,7 @@ import org.matsim.api.core.v01.network.Link; import org.matsim.core.network.NetworkUtils; -import static org.junit.Assert.*; -import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.*; public class OsmHbefaMappingTest { diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java index 5f39db1437a..18bf6881844 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java @@ -20,8 +20,8 @@ package org.matsim.contrib.emissions; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -128,7 +128,7 @@ void calculateColdEmissionsAndThrowEventTest_Exceptions() { } catch (Exception e) { excep = true; } - Assert.assertTrue(message, excep); + Assertions.assertTrue(excep, message); excep = false; } @@ -154,7 +154,7 @@ void calculateColdEmissionsAndThrowEventTest_minimalVehicleInformation() { String message = "The expected emissions for an emissions event with vehicle information string '" + vehInfo11 + "' are " + numberOfColdEmissions * averageAverageFactor + " but were " + sumOfEmissions; - Assert.assertEquals( message, numberOfColdEmissions * averageAverageFactor, sumOfEmissions, MatsimTestUtils.EPSILON ); + Assertions.assertEquals( numberOfColdEmissions * averageAverageFactor, sumOfEmissions, MatsimTestUtils.EPSILON, message ); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase1.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase1.java index a5785997e66..690ee4ed802 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase1.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase1.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -119,7 +119,7 @@ void calculateColdEmissionsAndThrowEventTest_completeData() { double sumOfEmissions = calculatedPollutants.values().stream().mapToDouble(Double::doubleValue).sum(); String message = "The expected emissions for " + testCase1.toString() + " are " + pollutants.size() * (Double) testCase1.get(4) + " but were " + sumOfEmissions; - Assert.assertEquals(message, pollutants.size() * (Double) testCase1.get(4), sumOfEmissions, MatsimTestUtils.EPSILON); + Assertions.assertEquals(pollutants.size() * (Double) testCase1.get(4), sumOfEmissions, MatsimTestUtils.EPSILON, message); } private static ColdEmissionAnalysisModule setUp() { diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase2.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase2.java index d975c75f447..c97de7d7ecd 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase2.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase2.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -112,7 +112,7 @@ void calculateColdEmissionsAndThrowEventTest_completeData() { double sumOfEmissions = calculatedPollutants.values().stream().mapToDouble(Double::doubleValue).sum(); String message = "The expected emissions for " + testCase2.toString() + " are " + pollutants.size() * (Double) testCase2.get( 4 ) + " but were " + sumOfEmissions; - Assert.assertEquals( message, pollutants.size() * (Double) testCase2.get( 4 ), sumOfEmissions, MatsimTestUtils.EPSILON ); + Assertions.assertEquals( pollutants.size() * (Double) testCase2.get( 4 ), sumOfEmissions, MatsimTestUtils.EPSILON, message ); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase3.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase3.java index e925e1df1d6..3da0de0f540 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase3.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase3.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -116,7 +116,7 @@ void calculateColdEmissionsAndThrowEventTest_completeData() { double sumOfEmissions = calculatedPollutants.values().stream().mapToDouble(Double::doubleValue).sum(); String message = "The expected emissions for " + testCase3.toString() + " are " + pollutants.size() * (Double) testCase3.get( 4 ) + " but were " + sumOfEmissions; - Assert.assertEquals( message, pollutants.size() * (Double) testCase3.get( 4 ), sumOfEmissions, MatsimTestUtils.EPSILON ); + Assertions.assertEquals( pollutants.size() * (Double) testCase3.get( 4 ), sumOfEmissions, MatsimTestUtils.EPSILON, message ); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase4.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase4.java index 06a4298fb58..726297486d3 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase4.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase4.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -126,7 +126,7 @@ void calculateColdEmissionsAndThrowEventTest_completeData() { double sumOfEmissions = calculatedPollutants.values().stream().mapToDouble(Double::doubleValue).sum(); String message = "The expected emissions for " + testCase4.toString() + " are " + pollutants.size() * (Double) testCase4.get( 4 ) + " but were " + sumOfEmissions; - Assert.assertEquals( message, pollutants.size() * (Double) testCase4.get( 4 ), sumOfEmissions, MatsimTestUtils.EPSILON ); + Assertions.assertEquals( pollutants.size() * (Double) testCase4.get( 4 ), sumOfEmissions, MatsimTestUtils.EPSILON, message ); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase6.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase6.java index 735adde0f16..97abfd77803 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase6.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModuleCase6.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -121,7 +121,7 @@ void calculateColdEmissionsAndThrowEventTest_completeData() { double sumOfEmissions = calculatedPollutants.values().stream().mapToDouble(Double::doubleValue).sum(); String message = "The expected emissions for " + testCase6.toString() + " are " + pollutants.size() * (Double) testCase6.get( 4 ) + " but were " + sumOfEmissions; - Assert.assertEquals( message, pollutants.size() * (Double) testCase6.get( 4 ), sumOfEmissions, MatsimTestUtils.EPSILON ); + Assertions.assertEquals( pollutants.size() * (Double) testCase6.get( 4 ), sumOfEmissions, MatsimTestUtils.EPSILON, message ); } private ColdEmissionAnalysisModule setUp() { diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionsFallbackBehaviour.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionsFallbackBehaviour.java index 6c81637cc12..cef4618571e 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionsFallbackBehaviour.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionsFallbackBehaviour.java @@ -23,7 +23,7 @@ import static org.junit.jupiter.api.Assertions.assertThrows; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -89,7 +89,7 @@ void testColdDetailedValueOnlyDetailed() { .checkVehicleInfoAndCalculateWColdEmissions(vehicleFull.getType(), vehicleFull.getId(), link.getId(), startTime, parkingDuration, distance); - Assert.assertEquals(emissionsFactorInGrammPerKilometer_Detailed, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(emissionsFactorInGrammPerKilometer_Detailed, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } @@ -147,7 +147,7 @@ void testCold_DetailedThenTechnologyAverageElseAbort_FallbackNotNeeded() { .checkVehicleInfoAndCalculateWColdEmissions(vehicleFull.getType(), vehicleFull.getId(), link.getId(), startTime, parkingDuration, distance); - Assert.assertEquals(emissionsFactorInGrammPerKilometer_Detailed, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(emissionsFactorInGrammPerKilometer_Detailed, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } @@ -167,7 +167,7 @@ void testCold_DetailedThenTechnologyAverageElseAbort_FallbackToTechnologyAverage vehicleFallbackToTechnologyAverage.getId(), link.getId(), startTime, parkingDuration, distance); - Assert.assertEquals(emissionsFactorInGrammPerKilometer_TechnologyAverage, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(emissionsFactorInGrammPerKilometer_TechnologyAverage, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } /** @@ -205,7 +205,7 @@ void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackNotNeeded() .checkVehicleInfoAndCalculateWColdEmissions(vehicleFull.getType(), vehicleFull.getId(), link.getId(), startTime, parkingDuration, distance); - Assert.assertEquals(emissionsFactorInGrammPerKilometer_Detailed, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(emissionsFactorInGrammPerKilometer_Detailed, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } @@ -224,7 +224,7 @@ void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackToTechnology .checkVehicleInfoAndCalculateWColdEmissions(vehicleFallbackToTechnologyAverage.getType(), vehicleFallbackToTechnologyAverage.getId(), link.getId(), startTime, parkingDuration, distance); - Assert.assertEquals(emissionsFactorInGrammPerKilometer_TechnologyAverage, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(emissionsFactorInGrammPerKilometer_TechnologyAverage, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } /** @@ -244,7 +244,7 @@ void testCold_DetailedThenTechnologyAverageThenAverageTable_FallbackToAverageTab .checkVehicleInfoAndCalculateWColdEmissions(vehicleFallbackToAverageTable.getType(), vehicleFallbackToAverageTable.getId(), link.getId(), startTime, parkingDuration, distance); - Assert.assertEquals(emissionsFactorInGrammPerKilometer_AverageTable, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(emissionsFactorInGrammPerKilometer_AverageTable, coldEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaColdEmissionFactorKey.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaColdEmissionFactorKey.java index e3bbaecef8f..13efc7bf890 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaColdEmissionFactorKey.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaColdEmissionFactorKey.java @@ -20,10 +20,10 @@ package org.matsim.contrib.emissions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import static org.matsim.contrib.emissions.Pollutant.CO; import static org.matsim.contrib.emissions.Pollutant.FC; @@ -83,8 +83,8 @@ final void testEqualsForCompleteKeys() { compare.setVehicleCategory(hbefaVehCategory); String message = "these two objects should be the same but are not: " + normal.toString() + " and " + compare.toString(); - Assert.assertEquals(message, normal, compare); - Assert.assertEquals(message, compare, normal); + Assertions.assertEquals(normal, compare, message); + Assertions.assertEquals(compare, normal, message); } { @@ -101,8 +101,8 @@ final void testEqualsForCompleteKeys() { different.setVehicleCategory(HbefaVehicleCategory.HEAVY_GOODS_VEHICLE); String message = "these two objects should not be the same: " + normal.toString() + " and " + different.toString(); - assertNotEquals(message, normal, different); - assertNotEquals(message, different, normal); + assertNotEquals(normal, different, message); + assertNotEquals(different, normal, message); } } @@ -128,7 +128,7 @@ final void testEqualsForIncompleteKeys_vehicleCategory(){ noVehCat.setVehicleAttributes(hbefaVehicleAttributes); String message = "these two HbefaColdEmissionFactorKeys should not be the same: " + normal.toString() + " and " + noVehCat.toString(); - assertFalse(message, noVehCat.equals(normal)); + assertFalse(noVehCat.equals(normal), message); } @Test @@ -147,7 +147,7 @@ final void testEqualsForIncompleteKeys_pollutant(){ noColdPollutant.setVehicleAttributes(hbefaVehicleAttributes); String message = "these two HbefaColdEmissionFactorKeys should not be the same: " + normal.toString() + " and " + noColdPollutant.toString(); - assertFalse(message, noColdPollutant.equals(normal)); + assertFalse(noColdPollutant.equals(normal), message); } @Test @@ -166,7 +166,7 @@ final void testEqualsForIncompleteKeys_parkingTime() { noParkingTime.setVehicleAttributes(hbefaVehicleAttributes); String message = "these two HbefaColdEmissionFactorKeys should not be the same: " + normal.toString() + " and " + noParkingTime.toString(); - assertFalse(message, noParkingTime.equals(normal)); + assertFalse(noParkingTime.equals(normal), message); } @Test @@ -185,7 +185,7 @@ final void testEqualsForIncompleteKeys_distance() { noDistance.setVehicleAttributes(hbefaVehicleAttributes); String message = "these two HbefaColdEmissionFactorKeys should not be the same: " + normal.toString() + " and " + noDistance.toString(); - assertFalse(message, noDistance.equals(normal)); + assertFalse(noDistance.equals(normal), message); } @Test @@ -200,7 +200,7 @@ final void testEqualsForIncompleteKeys_emptyKey() { HbefaColdEmissionFactorKey emptyKey = new HbefaColdEmissionFactorKey(); String message = "these two HbefaColdEmissionFactorKeys should not be the same: " + normal.toString() + " and " + emptyKey.toString(); - assertFalse(message, emptyKey.equals(normal)); + assertFalse(emptyKey.equals(normal), message); } @Test @@ -227,7 +227,7 @@ final void testEqualsForIncompleteKeys_VehicleAttributes(){ noVehAtt.setVehicleCategory(hbefaVehCategory); String message = "these two HbefaColdEmissionFactorKeys should not be the same: " + normal.toString() + " and " + noVehAtt.toString(); - assertFalse(message, noVehAtt.equals(normal)); + assertFalse(noVehAtt.equals(normal), message); //set the vehicle attributes of the normal hbefaColdWmissionFactorKey to 'average' @@ -239,7 +239,7 @@ final void testEqualsForIncompleteKeys_VehicleAttributes(){ hbefaVehicleAttributesAverage.setHbefaTechnology("average"); normal.setVehicleAttributes(hbefaVehicleAttributesAverage); - Assert.assertTrue(message, noVehAtt.equals(normal)); + Assertions.assertTrue(noVehAtt.equals(normal), message); } } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaVehicleAttributes.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaVehicleAttributes.java index 49a3e04e8cd..bb8743783d9 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaVehicleAttributes.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaVehicleAttributes.java @@ -20,7 +20,7 @@ package org.matsim.contrib.emissions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; @@ -54,8 +54,8 @@ final void testEqualsForCompleteAttributes(){ String assertErrorMessage = "These hbefa vehicle attribute objects should have been the same: "; assertErrorMessage += normal.toString() + " and " + compare.toString(); - Assert.assertEquals(assertErrorMessage, normal, compare); - Assert.assertEquals(assertErrorMessage, compare, normal); + Assertions.assertEquals(normal, compare, assertErrorMessage); + Assertions.assertEquals(compare, normal, assertErrorMessage); } @@ -74,8 +74,8 @@ final void testEqualsForCompleteAttributes_emConcept(){ differentValues.setHbefaTechnology(technology); assertErrorMessage = "These hbefa vehicle attribute objects should not have been the same: "; assertErrorMessage += normal.toString() + " and " + differentValues.toString(); - Assert.assertNotEquals(assertErrorMessage, normal, differentValues); - Assert.assertNotEquals(assertErrorMessage, differentValues, normal); + Assertions.assertNotEquals(normal, differentValues, assertErrorMessage); + Assertions.assertNotEquals(differentValues, normal, assertErrorMessage); } @Test @@ -92,8 +92,8 @@ final void testEqualsForCompleteAttributes_sizeClass(){ differentValues.setHbefaTechnology(technology); assertErrorMessage = "These hbefa vehicle attribute objects should not have been the same: "; assertErrorMessage += normal.toString() + " and " + differentValues.toString(); - Assert.assertNotEquals(assertErrorMessage, normal, differentValues); - Assert.assertNotEquals(assertErrorMessage, differentValues, normal); + Assertions.assertNotEquals(normal, differentValues, assertErrorMessage); + Assertions.assertNotEquals(differentValues, normal, assertErrorMessage); } @@ -111,8 +111,8 @@ final void testEqualsForCompleteAttributes_technologies(){ differentValues.setHbefaTechnology("other technology"); assertErrorMessage = "These hbefa vehicle attribute objects should not have been the same: "; assertErrorMessage += normal.toString() + " and " + differentValues.toString(); - Assert.assertNotEquals(assertErrorMessage, normal, differentValues); - Assert.assertNotEquals(assertErrorMessage, differentValues, normal); + Assertions.assertNotEquals(normal, differentValues, assertErrorMessage); + Assertions.assertNotEquals(differentValues, normal, assertErrorMessage); } @@ -131,13 +131,13 @@ final void testEqualsForIncompleteAttributes_emConcept(){ noEmConcept.setHbefaSizeClass(sizeClass); noEmConcept.setHbefaTechnology(technology); message = "no em concept was set, therefore " + normal.getHbefaEmConcept() + " should not equal " + noEmConcept.getHbefaEmConcept(); - Assert.assertNotEquals(message, noEmConcept, normal); - Assert.assertNotEquals(message, normal, noEmConcept); + Assertions.assertNotEquals(noEmConcept, normal, message); + Assertions.assertNotEquals(normal, noEmConcept, message); normal.setHbefaEmConcept("average"); message = "no em concept was set, therefore " + noEmConcept.getHbefaEmConcept() + "should be set to 'average'"; - Assert.assertEquals(message, noEmConcept, normal); - Assert.assertEquals(message, normal, noEmConcept); + Assertions.assertEquals(noEmConcept, normal, message); + Assertions.assertEquals(normal, noEmConcept, message); } @@ -153,15 +153,15 @@ final void testEqualsForIncompleteAttributes_technology() { noTechnology.setHbefaEmConcept(concept); noTechnology.setHbefaSizeClass(sizeClass); message = "no technology was set, therefore " + normal.getHbefaTechnology() + " should not equal " + noTechnology.getHbefaTechnology(); - Assert.assertNotEquals(message, noTechnology, normal); - Assert.assertNotEquals(message, normal, noTechnology); + Assertions.assertNotEquals(noTechnology, normal, message); + Assertions.assertNotEquals(normal, noTechnology, message); //set the hbefa technology of the normal vehicle attributes to 'average' //then noTechnology is equal to normal normal.setHbefaTechnology("average"); message = "no em concept was set, therefore " + noTechnology.getHbefaEmConcept() + "should be set to 'average'"; - Assert.assertEquals(message, noTechnology, normal); - Assert.assertEquals(message, normal, noTechnology); + Assertions.assertEquals(noTechnology, normal, message); + Assertions.assertEquals(normal, noTechnology, message); } @@ -178,13 +178,13 @@ final void testEqualsForIncompleteAttributes_sizeClass(){ noSize.setHbefaEmConcept(concept); noSize.setHbefaTechnology(technology); message = "no size class was set, therefore " + normal.getHbefaSizeClass() + " should not equal " + noSize.getHbefaSizeClass(); - Assert.assertNotEquals(message, noSize, normal); - Assert.assertNotEquals(message, normal, noSize); + Assertions.assertNotEquals(noSize, normal, message); + Assertions.assertNotEquals(normal, noSize, message); normal.setHbefaSizeClass("average"); message = "no size class was set, therefore " + noSize.getHbefaEmConcept() + "should be set to 'average'"; - Assert.assertEquals(message, noSize, normal); - Assert.assertEquals(message, normal, noSize); + Assertions.assertEquals(noSize, normal, message); + Assertions.assertEquals(normal, noSize, message); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaWarmEmissionFactorKey.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaWarmEmissionFactorKey.java index c8c60aeaee3..2ff96fb02bd 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaWarmEmissionFactorKey.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestHbefaWarmEmissionFactorKey.java @@ -22,10 +22,10 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import static org.junit.Assert.assertFalse; +import static org.junit.jupiter.api.Assertions.assertFalse; import static org.matsim.contrib.emissions.Pollutant.CO; import static org.matsim.contrib.emissions.Pollutant.FC; @@ -80,8 +80,8 @@ final void testEqualsForCompleteKeys(){ compare.setVehicleCategory(hbefaVehicleCategory); String message = "these two objects should be the same but are not: " + normal.toString() + " and " + compare.toString(); - Assert.assertTrue(message, normal.equals(compare)); - Assert.assertTrue(message, compare.equals(normal)); + Assertions.assertTrue(normal.equals(compare), message); + Assertions.assertTrue(compare.equals(normal), message); //two unequal but complete objects HbefaWarmEmissionFactorKey different = new HbefaWarmEmissionFactorKey(); @@ -97,8 +97,8 @@ final void testEqualsForCompleteKeys(){ message = "these two objects should not be the same: " + normal.toString() + " and " + different.toString(); - assertFalse(message, different.equals(normal)); - assertFalse(message, normal.equals(different)); + assertFalse(different.equals(normal), message); + assertFalse(normal.equals(different), message); } // the following tests each compare a incomplete key to a complete key @@ -169,8 +169,8 @@ final void testEqualsForIncompleteKeys_roadCategory() { String message = "these two HbefaWarmEmissionFactorKeys should not be the same: " + normal.toString() + " and " + noRoadCat.toString(); String message2 = "this key should not be comparable since no road category is set"; - Assert.assertTrue(message2, equalErr); - assertFalse(message, normal.equals(noRoadCat)); + Assertions.assertTrue(equalErr, message2); + assertFalse(normal.equals(noRoadCat), message); } @Test @@ -233,11 +233,11 @@ final void testEqualsForIncompleteKeys_vehicleAttributes(){ } String message = "these two HbefaWarmEmissionFactorKeys should not be the same: " + normal.toString() + " and " + noVehAtt.toString(); - assertFalse(message, noVehAtt.equals(normal)); + assertFalse(noVehAtt.equals(normal), message); assertFalse(equalErr); // veh attributes are allowed to be not initiated // therefore this should not throw a nullpointer but return false - assertFalse(message, normal.equals(noVehAtt)); + assertFalse(normal.equals(noVehAtt), message); //set the vehicle attributes of the normal hbefacoldemissionfactorkey to 'average' //then noVehAtt is equal to normal @@ -248,8 +248,8 @@ final void testEqualsForIncompleteKeys_vehicleAttributes(){ normal.setVehicleAttributes(hbefaVehicleAttributesAverage); message = "these two HbefaWarmEmissionFactorKeys should be the same: " + normal.toString() + " and " + noVehAtt.toString(); - Assert.assertTrue(message, normal.equals(noVehAtt)); - Assert.assertTrue(message, noVehAtt.equals(normal)); + Assertions.assertTrue(normal.equals(noVehAtt), message); + Assertions.assertTrue(noVehAtt.equals(normal), message); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java index 03d6e88cbbf..b54c7c286c5 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestPositionEmissionModule.java @@ -43,13 +43,13 @@ import org.matsim.vis.snapshotwriters.PositionEvent; import jakarta.inject.Singleton; + +import static org.junit.jupiter.api.Assertions.assertEquals; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Set; -import static org.junit.Assert.assertEquals; - public class TestPositionEmissionModule { private static final String configFile = IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "emissions-sampleScenario/testv2_Vehv2" ), "config_detailed.xml" ).toString(); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java index fd437883c91..92440ecfd30 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java @@ -20,7 +20,7 @@ package org.matsim.contrib.emissions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -149,18 +149,18 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent6() catch(RuntimeException re){ exceptionThrown = true; } - Assert.assertTrue("An average speed higher than the free flow speed should throw a runtime exception",exceptionThrown); + Assertions.assertTrue(exceptionThrown,"An average speed higher than the free flow speed should throw a runtime exception"); { //avg=ff=sg -> use ff factors Map warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(sgffVehicle, sgflink, sgffLinklength / AVG_PASSENGER_CAR_SPEED_FF_KMH * 3.6); - Assert.assertEquals(DETAILED_SGFF_FACTOR_FF * sgffLinklength / 1000., warmEmissions.get(NO2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(DETAILED_SGFF_FACTOR_FF * sgffLinklength / 1000., warmEmissions.get(NO2), MatsimTestUtils.EPSILON); } { //avg use sg factors Map warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(sgffVehicle, sgflink, 2*sgffLinklength/ AVG_PASSENGER_CAR_SPEED_FF_KMH *3.6 ); - Assert.assertEquals( DETAILED_SGFF_FACTOR_SG *sgffLinklength/1000., warmEmissions.get(NO2 ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( DETAILED_SGFF_FACTOR_SG *sgffLinklength/1000., warmEmissions.get(NO2 ), MatsimTestUtils.EPSILON ); } } @@ -191,7 +191,7 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Ex }catch(Exception e){ excep = true; } - Assert.assertFalse(excep); + Assertions.assertFalse(excep); excep=false; } @@ -218,7 +218,7 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Ex }catch(Exception e){ excep = true; } - Assert.assertTrue(excep); excep=false; + Assertions.assertTrue(excep); excep=false; } @Test @@ -242,7 +242,7 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Ex }catch(Exception e){ excep = true; } - Assert.assertTrue(excep); excep=false; + Assertions.assertTrue(excep); excep=false; } @Test @@ -264,7 +264,7 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Ex }catch(Exception e){ excep = true; } - Assert.assertTrue(excep); excep=false; + Assertions.assertTrue(excep); excep=false; } @@ -285,25 +285,25 @@ void testCounters7(){ // ff < avg < ff+1 - handled like free flow double travelTime = tableLinkLength/(AVG_PASSENGER_CAR_SPEED_FF_KMH +0.5)*3.6; emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(tableVehicle, tableLink, travelTime ); - Assert.assertEquals(0, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(tableLinkLength/1000., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(tableLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0., emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(tableLinkLength/1000., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(tableLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0., emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); emissionsModule.reset(); // ff < sg < avg - handled like free flow as well - no additional test needed // avg < ff < sg - handled like stop go emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(tableVehicle, tableLink, 2* tableLinkLength/(AVG_PASSENGER_CAR_SPEED_FF_KMH)*3.6 ); - Assert.assertEquals(0, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(tableLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(tableLinkLength/1000, emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(1, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(tableLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(tableLinkLength/1000, emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(1, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); emissionsModule.reset(); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java index ed4a1e7322a..48734493dce 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java @@ -20,7 +20,7 @@ package org.matsim.contrib.emissions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -150,12 +150,12 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent1() Vehicle vehicle = vehFac.createVehicle(vehicleId, vehFac.createVehicleType(vehicleTypeId)); Map warmEmissions = warmEmissionAnalysisModule.checkVehicleInfoAndCalculateWarmEmissions( vehicle, mockLink, linkLength / PETROL_SPEED_FF * 3.6 ); - Assert.assertEquals(DETAILED_PETROL_FACTOR_FF *linkLength/1000., warmEmissions.get( CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(DETAILED_PETROL_FACTOR_FF *linkLength/1000., warmEmissions.get( CO2_TOTAL ), MatsimTestUtils.EPSILON ); emissionEventManager.reset(); warmEmissionAnalysisModule.throwWarmEmissionEvent(leaveTime, mockLink.getId(), vehicleId, warmEmissions ); - Assert.assertEquals( pollutants.size() * DETAILED_PETROL_FACTOR_FF *linkLength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( pollutants.size() * DETAILED_PETROL_FACTOR_FF *linkLength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); emissionEventManager.reset(); warmEmissions.clear(); @@ -186,24 +186,24 @@ void testCounters1(){ // s&g speed, ff speed @@ -249,7 +249,7 @@ void testCounters1(){ }catch(RuntimeException re){ exceptionThrown = true; } - Assert.assertTrue("An average speed higher than the free flow speed should throw a runtime exception", exceptionThrown); + Assertions.assertTrue(exceptionThrown, "An average speed higher than the free flow speed should throw a runtime exception"); warmEmissionAnalysisModule.reset(); } @@ -282,26 +282,26 @@ void testCounters5(){ switch( emissionsComputationMethod ) { case StopAndGoFraction: - Assert.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); break; case AverageSpeed: - Assert.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); break; default: throw new IllegalStateException( "Unexpected value: " + emissionsComputationMethod ); } - Assert.assertEquals(inconff/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(inconff/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); emissionsModule.reset(); // average speed equals wrong free flow speed emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(inconffVehicle, inconLink, inconff / inconffavgSpeed * 3.6); - Assert.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(inconff/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(inconff/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); //@KMT is there the need for adding a test here? emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(inconffVehicle, inconLink, 2 * inconff / (PETROL_SPEED_FF + PETROL_SPEED_SG) * 3.6); @@ -331,50 +331,50 @@ void testCounters1fractional(){ // s&g speed, ff speed @@ -384,7 +384,7 @@ void testCounters1fractional(){ }catch(RuntimeException re){ exceptionThrown = true; } - Assert.assertTrue("An average speed higher than the free flow speed should throw a runtime exception", exceptionThrown); + Assertions.assertTrue(exceptionThrown, "An average speed higher than the free flow speed should throw a runtime exception"); emissionsModule.reset(); emissionsModule.getEcg().setEmissionsComputationMethod(AverageSpeed ); @@ -413,20 +413,20 @@ void testCounters6(){ // average speed equals free flow speed from table emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(inconffVehicle, inconLink, inconff / PETROL_SPEED_FF * 3.6); - Assert.assertEquals(1, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(inconff/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(1, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(inconff/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); emissionsModule.reset(); // average speed equals wrong free flow speed emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(inconffVehicle, inconLink, inconff / inconffavgSpeed * 3.6); - Assert.assertEquals(0, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(inconff/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(inconff/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(inconffVehicle, inconLink, 2 * inconff / (PETROL_SPEED_FF + PETROL_SPEED_SG) * 3.6); } @@ -448,13 +448,13 @@ void testCounters8(){ Link pcLink = createMockLink("link table", linkLength, PETROL_SPEED_FF / 3.6 ); emissionsModule.reset(); - Assert.assertEquals(0, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), 1e-7 ); - Assert.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(0., emissionsModule.getKmCounter(), 1e-7 ); - Assert.assertEquals(0., emissionsModule.getStopGoKmCounter(), 1e-7 ); - Assert.assertEquals(0, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(0, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), 1e-7 ); + Assertions.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(0., emissionsModule.getKmCounter(), 1e-7 ); + Assertions.assertEquals(0., emissionsModule.getStopGoKmCounter(), 1e-7 ); + Assertions.assertEquals(0, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(0, emissionsModule.getWarmEmissionEventCounter() ); // < s&g speed emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(vehicle, pcLink, travelTime * 3.6); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase2.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase2.java index b79d61d4bd2..4549248da51 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase2.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase2.java @@ -20,7 +20,7 @@ package org.matsim.contrib.emissions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -158,11 +158,11 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent2() // After discussion with Kai N. we decided to let it as it is for the time being. I will add a log.info in the consistency checker. KMT Jul'20 //results should be equal here, because in both cases only the freeflow value is relevant (100% freeflow, 0% stop&go). - Assert.assertEquals( 0.1, warmEmissions.get( NMHC ), MatsimTestUtils.EPSILON ); //(*#) + Assertions.assertEquals( 0.1, warmEmissions.get( NMHC ), MatsimTestUtils.EPSILON ); //(*#) // throw and test corresponding event: emissionsModule.throwWarmEmissionEvent( leaveTime, pclink.getId(), pcVehicleId, warmEmissions ); - Assert.assertEquals( 2.3, emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); //seems to be (0.1 (g/km -- see expected values a few lines above(*#) * number of entries in enum Pollutant) + Assertions.assertEquals( 2.3, emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); //seems to be (0.1 (g/km -- see expected values a few lines above(*#) * number of entries in enum Pollutant) emissionEventManager.reset(); warmEmissions.clear(); @@ -171,10 +171,10 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent2() // sub case avg speed = stop go speed { warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions( pcVehicle, pclink, pclinkLength / PCSG_VELOCITY_KMH * 3.6 ); - Assert.assertEquals( AVG_PC_FACTOR_SG * pclinkLength / 1000., warmEmissions.get( NMHC ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( AVG_PC_FACTOR_SG * pclinkLength / 1000., warmEmissions.get( NMHC ), MatsimTestUtils.EPSILON ); emissionsModule.throwWarmEmissionEvent( leaveTime, pclink.getId(), pcVehicleId, warmEmissions ); - Assert.assertEquals(pollutants.size() * AVG_PC_FACTOR_SG * pclinkLength / 1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(pollutants.size() * AVG_PC_FACTOR_SG * pclinkLength / 1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); emissionsModule.reset(); warmEmissions.clear(); } @@ -200,24 +200,24 @@ void testCounters3(){ // sub case: current speed equals free flow speed warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(pcVehicle,pclink, pclinkLength/ PC_FREE_VELOCITY_KMH *3.6 ); - Assert.assertEquals(0, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(pclinkLength/1000, emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(pclinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0., emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(pclinkLength/1000, emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(pclinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0., emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); emissionsModule.reset(); // sub case: current speed equals stop go speed warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(pcVehicle, pclink, pclinkLength/ PCSG_VELOCITY_KMH *3.6 ); - Assert.assertEquals(0, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(pclinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(pclinkLength/1000, emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(1, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(pclinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(pclinkLength/1000, emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(1, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase3.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase3.java index 70c8e007f2b..b0c11c1f770 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase3.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase3.java @@ -20,7 +20,7 @@ package org.matsim.contrib.emissions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -133,19 +133,19 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent3() // sub case avg speed = free flow speed warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(dieselVehicle, diesellink, dieselLinkLength/ TestWarmEmissionAnalysisModule.AVG_PASSENGER_CAR_SPEED_FF_KMH *3.6 ); - Assert.assertEquals( AVG_PC_FACTOR_FF *dieselLinkLength/1000., warmEmissions.get(PM ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( AVG_PC_FACTOR_FF *dieselLinkLength/1000., warmEmissions.get(PM ), MatsimTestUtils.EPSILON ); emissionEventManager.reset(); emissionsModule.throwWarmEmissionEvent(leaveTime, diesellink.getId(), dieselVehicleId, warmEmissions ); - Assert.assertEquals( pollutants.size() * AVG_PC_FACTOR_FF *dieselLinkLength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( pollutants.size() * AVG_PC_FACTOR_FF *dieselLinkLength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); emissionEventManager.reset(); warmEmissions.clear(); // sub case avg speed = stop go speed warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(dieselVehicle, diesellink, dieselLinkLength/ TestWarmEmissionAnalysisModule.AVG_PASSENGER_CAR_SPEED_SG_KMH *3.6 ); - Assert.assertEquals( AVG_PC_FACTOR_SG *dieselLinkLength/1000., warmEmissions.get(PM ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( AVG_PC_FACTOR_SG *dieselLinkLength/1000., warmEmissions.get(PM ), MatsimTestUtils.EPSILON ); emissionEventManager.reset(); emissionsModule.throwWarmEmissionEvent(leaveTime, diesellink.getId(), dieselVehicleId, warmEmissions ); - Assert.assertEquals( pollutants.size() * AVG_PC_FACTOR_SG *dieselLinkLength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( pollutants.size() * AVG_PC_FACTOR_SG *dieselLinkLength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); emissionEventManager.reset(); warmEmissions.clear(); } @@ -170,24 +170,24 @@ void testCounters4(){ // sub case: current speed equals free flow speed warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(dieselVehicle, diesellink, dieselLinkLength/ TestWarmEmissionAnalysisModule.AVG_PASSENGER_CAR_SPEED_FF_KMH *3.6 ); - Assert.assertEquals(0, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(dieselLinkLength/1000., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(dieselLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0., emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(dieselLinkLength/1000., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(dieselLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0., emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); emissionsModule.reset(); // sub case: current speed equals stop go speed warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(dieselVehicle, diesellink, dieselLinkLength/ TestWarmEmissionAnalysisModule.AVG_PASSENGER_CAR_SPEED_SG_KMH *3.6 ); - Assert.assertEquals(0, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(dieselLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(dieselLinkLength/1000., emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(1, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(dieselLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(dieselLinkLength/1000., emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(1, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); emissionsModule.reset(); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase4.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase4.java index 8202a25ca35..6ceab142803 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase4.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase4.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -139,19 +139,19 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent4() // sub case avg speed = stop go speed warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(lpgVehicle, lpglink, lpgLinkLength/ SPEED_SG *3.6 ); - Assert.assertEquals( AVG_PC_FACTOR_SG *lpgLinkLength/1000., warmEmissions.get(PM), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( AVG_PC_FACTOR_SG *lpgLinkLength/1000., warmEmissions.get(PM), MatsimTestUtils.EPSILON ); emissionEventManager.reset(); emissionsModule.throwWarmEmissionEvent(leaveTime, lpglink.getId(), lpgVehicleId, warmEmissions ); - Assert.assertEquals( pollutants.size() * AVG_PC_FACTOR_SG *lpgLinkLength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( pollutants.size() * AVG_PC_FACTOR_SG *lpgLinkLength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); emissionEventManager.reset(); warmEmissions.clear(); // sub case avg speed = free flow speed warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(lpgVehicle, lpglink, lpgLinkLength/ SPEED_FF *3.6 ); - Assert.assertEquals( AVG_PC_FACTOR_FF *lpgLinkLength/1000., warmEmissions.get(PM ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( AVG_PC_FACTOR_FF *lpgLinkLength/1000., warmEmissions.get(PM ), MatsimTestUtils.EPSILON ); emissionEventManager.reset(); emissionsModule.throwWarmEmissionEvent(leaveTime, lpglink.getId(), lpgVehicleId, warmEmissions ); - Assert.assertEquals( pollutants.size() * AVG_PC_FACTOR_FF *lpgLinkLength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( pollutants.size() * AVG_PC_FACTOR_FF *lpgLinkLength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); warmEmissions.clear(); } @@ -176,24 +176,24 @@ void testCounters2(){ // sub case: current speed equals free flow speed warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(vehicle, lpgLink, lpgLinkLength/ SPEED_FF *3.6 ); - Assert.assertEquals(0, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(lpgLinkLength/1000, emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(lpgLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(.0, emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(lpgLinkLength/1000, emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(1, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(lpgLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(.0, emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); emissionsModule.reset(); // sub case: current speed equals free flow speed warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(vehicle, lpgLink, lpgLinkLength/ SPEED_SG *3.6 ); - Assert.assertEquals(0, emissionsModule.getFractionOccurences() ); - Assert.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); - Assert.assertEquals(lpgLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(lpgLinkLength/1000, emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); - Assert.assertEquals(1, emissionsModule.getStopGoOccurences() ); - Assert.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); + Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); + Assertions.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0, emissionsModule.getFreeFlowOccurences() ); + Assertions.assertEquals(lpgLinkLength/1000, emissionsModule.getKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(lpgLinkLength/1000, emissionsModule.getStopGoKmCounter(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(1, emissionsModule.getStopGoOccurences() ); + Assertions.assertEquals(1, emissionsModule.getWarmEmissionEventCounter() ); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase5.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase5.java index 3fd040f0950..86a2dbc4792 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase5.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase5.java @@ -20,7 +20,7 @@ package org.matsim.contrib.emissions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -137,10 +137,10 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent5() Vehicle zeroVehicle = vehFac.createVehicle(zeroVehicleId, vehFac.createVehicleType(zeroVehicleTypeId)); Map warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(zeroVehicle, zerolink, 2 * zeroLinklength / (zeroFreeVelocity + zeroSgVelocity) * 3.6); - Assert.assertEquals( DETAILED_ZERO_FACTOR_FF *zeroLinklength/1000., warmEmissions.get(PM ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( DETAILED_ZERO_FACTOR_FF *zeroLinklength/1000., warmEmissions.get(PM ), MatsimTestUtils.EPSILON ); emissionsModule.throwWarmEmissionEvent(22., lpgLinkId, zeroVehicleId, warmEmissions); - Assert.assertEquals( pollutants.size() * DETAILED_ZERO_FACTOR_FF *zeroLinklength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( pollutants.size() * DETAILED_ZERO_FACTOR_FF *zeroLinklength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); warmEmissions.clear(); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionsFallbackBehaviour.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionsFallbackBehaviour.java index ee7ccc6eeee..4d7d500299e 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionsFallbackBehaviour.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionsFallbackBehaviour.java @@ -23,7 +23,7 @@ import static org.junit.jupiter.api.Assertions.assertThrows; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -76,7 +76,7 @@ void testWarmDetailedValueOnlyDetailed() { Map warmEmissions = emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFull, link, travelTimeOnLink); double expectedValue = 30.34984742; // = 200m * 151.7492371 g/km - Assert.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } @@ -132,7 +132,7 @@ void testWarm_DetailedThenTechnologyAverageElseAbort_FallbackNotNeeded() { Map warmEmissions = emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFull, link, travelTimeOnLink); double expectedValue = 30.34984742; // = 200m * 151.7492371 g/km - Assert.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } @@ -151,7 +151,7 @@ void testWarm_DetailedThenTechnologyAverageElseAbort_FallbackToTechnologyAverage Map warmEmissions = emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFallbackToTechnologyAverage, link, travelTimeOnLink); double expectedValue = 31.53711548; // = 200m * 157.6855774 g/km - Assert.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } /** @@ -188,7 +188,7 @@ void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackNotNeeded() Map warmEmissions = emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFull, link, travelTimeOnLink); double expectedValue = 30.34984742; // = 200m * 151.7492371 g/km - Assert.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } @@ -207,7 +207,7 @@ void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackToTechnology Map warmEmissions = emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFallbackToTechnologyAverage, link, travelTimeOnLink); double expectedValue = 31.53711548; // = 200m * 157.6855774 g/km - Assert.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } /** @@ -227,7 +227,7 @@ void testWarm_DetailedThenTechnologyAverageThenAverageTable_FallbackToAverageTab Map warmEmissions = emissionModule.getWarmEmissionAnalysisModule().checkVehicleInfoAndCalculateWarmEmissions(vehicleFallbackToAverageTable, link, travelTimeOnLink); double expectedValue = 31.1947174; // = 200m * 155.973587 g/km - Assert.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( expectedValue, warmEmissions.get(Pollutant.CO2_TOTAL ), MatsimTestUtils.EPSILON ); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/VspHbefaRoadTypeMappingTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/VspHbefaRoadTypeMappingTest.java index 7caf57a3bc9..f0164d11e86 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/VspHbefaRoadTypeMappingTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/VspHbefaRoadTypeMappingTest.java @@ -6,7 +6,7 @@ import org.matsim.api.core.v01.network.Link; import org.matsim.core.network.NetworkUtils; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class VspHbefaRoadTypeMappingTest { diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java index df4bd3474a3..d9614bd3dea 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionGridAnalyzerTest.java @@ -32,8 +32,7 @@ import java.util.Map; import java.util.UUID; -import static org.junit.Assert.*; -import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.*; import static org.matsim.contrib.emissions.Pollutant.*; public class EmissionGridAnalyzerTest { diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsByPollutantTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsByPollutantTest.java index 2575ebf4470..635affd8832 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsByPollutantTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsByPollutantTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.emissions.analysis; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import static org.matsim.contrib.emissions.Pollutant.CO; import static org.matsim.contrib.emissions.Pollutant.NO2; diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsOnLinkEventHandlerTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsOnLinkEventHandlerTest.java index cc7b9df638c..fe8c91a53ab 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsOnLinkEventHandlerTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/EmissionsOnLinkEventHandlerTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.emissions.analysis; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import static org.matsim.contrib.emissions.Pollutant.HC; import java.util.ArrayList; diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java index 0ea0f7b3f9b..423131e4f6f 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/FastEmissionGridAnalyzerTest.java @@ -15,8 +15,8 @@ import java.nio.file.Paths; import java.util.Map; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; public class FastEmissionGridAnalyzerTest { diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RasterTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RasterTest.java index 2bcc4d639db..7e6b360020d 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RasterTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RasterTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.emissions.analysis; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.fail; import org.junit.jupiter.api.Test; diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java index 307667309b6..4592d26ec17 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/analysis/RawEmissionEventsReaderTest.java @@ -12,7 +12,7 @@ import java.nio.file.Paths; import java.util.concurrent.atomic.AtomicInteger; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class RawEmissionEventsReaderTest { diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestColdEmissionEventImpl.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestColdEmissionEventImpl.java index c4dff777494..022265df9f0 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestColdEmissionEventImpl.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestColdEmissionEventImpl.java @@ -21,7 +21,7 @@ package org.matsim.contrib.emissions.events; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -64,20 +64,13 @@ final void testGetAttributesForCompleteEmissionMaps(){ ColdEmissionEvent ce = new ColdEmissionEvent(0.0, linkId, vehicleId, coldEmissionsMap); Map ceg = ce.getAttributes(); - Assert.assertEquals("the CO value of this cold emission event was "+ Double.parseDouble(ceg.get(CO.name()))+ "but should have been "+ co, - Double.parseDouble(ceg.get(CO.name())), co, MatsimTestUtils.EPSILON); - Assert.assertEquals("the FC value of this cold emission event was "+ Double.parseDouble(ceg.get(FC.name()))+ "but should have been "+ fc, - Double.parseDouble(ceg.get(FC.name())), fc, MatsimTestUtils.EPSILON); - Assert.assertEquals("the HC value of this cold emission event was "+ Double.parseDouble(ceg.get(HC.name()))+ "but should have been "+ hc, - Double.parseDouble(ceg.get(HC.name())), hc, MatsimTestUtils.EPSILON); - Assert.assertEquals("the NMHC value of this cold emission event was "+ Double.parseDouble(ceg.get(NMHC.name()))+ "but should have been "+ nm, - Double.parseDouble(ceg.get(NMHC.name())), nm, MatsimTestUtils.EPSILON); - Assert.assertEquals("the NO2 value of this cold emission event was "+ Double.parseDouble(ceg.get(NO2.name()))+ "but should have been "+ n2, - Double.parseDouble(ceg.get(NO2.name())), n2, MatsimTestUtils.EPSILON); - Assert.assertEquals("the NOx value of this cold emission event was "+ Double.parseDouble(ceg.get(NOx.name()))+ "but should have been "+ nx, - Double.parseDouble(ceg.get(NOx.name())), nx, MatsimTestUtils.EPSILON); - Assert.assertEquals("the PM value of this cold emission event was "+ Double.parseDouble(ceg.get(PM.name()))+ "but should have been "+ pm, - Double.parseDouble(ceg.get(PM.name())), pm, MatsimTestUtils.EPSILON); + Assertions.assertEquals(Double.parseDouble(ceg.get(CO.name())), co, MatsimTestUtils.EPSILON, "the CO value of this cold emission event was "+ Double.parseDouble(ceg.get(CO.name()))+ "but should have been "+ co); + Assertions.assertEquals(Double.parseDouble(ceg.get(FC.name())), fc, MatsimTestUtils.EPSILON, "the FC value of this cold emission event was "+ Double.parseDouble(ceg.get(FC.name()))+ "but should have been "+ fc); + Assertions.assertEquals(Double.parseDouble(ceg.get(HC.name())), hc, MatsimTestUtils.EPSILON, "the HC value of this cold emission event was "+ Double.parseDouble(ceg.get(HC.name()))+ "but should have been "+ hc); + Assertions.assertEquals(Double.parseDouble(ceg.get(NMHC.name())), nm, MatsimTestUtils.EPSILON, "the NMHC value of this cold emission event was "+ Double.parseDouble(ceg.get(NMHC.name()))+ "but should have been "+ nm); + Assertions.assertEquals(Double.parseDouble(ceg.get(NO2.name())), n2, MatsimTestUtils.EPSILON, "the NO2 value of this cold emission event was "+ Double.parseDouble(ceg.get(NO2.name()))+ "but should have been "+ n2); + Assertions.assertEquals(Double.parseDouble(ceg.get(NOx.name())), nx, MatsimTestUtils.EPSILON, "the NOx value of this cold emission event was "+ Double.parseDouble(ceg.get(NOx.name()))+ "but should have been "+ nx); + Assertions.assertEquals(Double.parseDouble(ceg.get(PM.name())), pm, MatsimTestUtils.EPSILON, "the PM value of this cold emission event was "+ Double.parseDouble(ceg.get(PM.name()))+ "but should have been "+ pm); } @@ -124,7 +117,7 @@ final void testGetAttributesForIncompleteMaps(){ for(Pollutant cp : coldPollutants){ //empty map - Assert.assertNull(emptyMapEvent.getAttributes().get(cp)); + Assertions.assertNull(emptyMapEvent.getAttributes().get(cp)); //values not set try{ @@ -142,8 +135,8 @@ final void testGetAttributesForIncompleteMaps(){ noMapNullPointers++; } } - Assert.assertEquals(numberOfColdPollutants, valNullPointers); - Assert.assertEquals(numberOfColdPollutants, noMapNullPointers); + Assertions.assertEquals(numberOfColdPollutants, valNullPointers); + Assertions.assertEquals(numberOfColdPollutants, noMapNullPointers); } } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestWarmEmissionEventImpl.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestWarmEmissionEventImpl.java index b10f7129d27..62691c3670f 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestWarmEmissionEventImpl.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/TestWarmEmissionEventImpl.java @@ -28,7 +28,7 @@ * 3 test the number of attributes returned */ -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -82,24 +82,15 @@ final void testGetAttributesForCompleteEmissionMaps(){ WarmEmissionEvent we = new WarmEmissionEvent(0.0, linkId, vehicleId, map); Map weg = we.getAttributes(); - Assert.assertEquals("the CO value of this warm emission event was "+ Double.parseDouble(weg.get(CO.name()))+ "but should have been "+ co, - Double.parseDouble(weg.get(CO.name())), co, MatsimTestUtils.EPSILON); - Assert.assertEquals("the CO2 value of this warm emission event was "+ Double.parseDouble(weg.get(CO2_TOTAL.name()))+ "but should have been "+ c2, - Double.parseDouble(weg.get(CO2_TOTAL.name())), c2, MatsimTestUtils.EPSILON); - Assert.assertEquals("the FC value of this warm emission event was "+ Double.parseDouble(weg.get(FC.name()))+ "but should have been "+ fc, - Double.parseDouble(weg.get(FC.name())), fc, MatsimTestUtils.EPSILON); - Assert.assertEquals("the HC value of this warm emission event was "+ Double.parseDouble(weg.get(HC.name()))+ "but should have been "+ hc, - Double.parseDouble(weg.get(HC.name())), hc, MatsimTestUtils.EPSILON); - Assert.assertEquals("the NMHC value of this warm emission event was "+ Double.parseDouble(weg.get(NMHC.name()))+ "but should have been "+ nm, - Double.parseDouble(weg.get(NMHC.name())), nm, MatsimTestUtils.EPSILON); - Assert.assertEquals("the NO2 value of this warm emission event was "+ Double.parseDouble(weg.get(NO2.name()))+ "but should have been "+ n2, - Double.parseDouble(weg.get(NO2.name())), n2, MatsimTestUtils.EPSILON); - Assert.assertEquals("the NOx value of this warm emission event was "+ Double.parseDouble(weg.get(NOx.name()))+ "but should have been "+ nx, - Double.parseDouble(weg.get(NOx.name())), nx, MatsimTestUtils.EPSILON); - Assert.assertEquals("the PM value of this warm emission event was "+ Double.parseDouble(weg.get(PM.name()))+ "but should have been "+ pm, - Double.parseDouble(weg.get(PM.name())), pm, MatsimTestUtils.EPSILON); - Assert.assertEquals("the SO2 value of this warm emission event was "+ Double.parseDouble(weg.get(SO2.name()))+ "but should have been "+ so, - Double.parseDouble(weg.get(SO2.name())), so, MatsimTestUtils.EPSILON); + Assertions.assertEquals(Double.parseDouble(weg.get(CO.name())), co, MatsimTestUtils.EPSILON, "the CO value of this warm emission event was "+ Double.parseDouble(weg.get(CO.name()))+ "but should have been "+ co); + Assertions.assertEquals(Double.parseDouble(weg.get(CO2_TOTAL.name())), c2, MatsimTestUtils.EPSILON, "the CO2 value of this warm emission event was "+ Double.parseDouble(weg.get(CO2_TOTAL.name()))+ "but should have been "+ c2); + Assertions.assertEquals(Double.parseDouble(weg.get(FC.name())), fc, MatsimTestUtils.EPSILON, "the FC value of this warm emission event was "+ Double.parseDouble(weg.get(FC.name()))+ "but should have been "+ fc); + Assertions.assertEquals(Double.parseDouble(weg.get(HC.name())), hc, MatsimTestUtils.EPSILON, "the HC value of this warm emission event was "+ Double.parseDouble(weg.get(HC.name()))+ "but should have been "+ hc); + Assertions.assertEquals(Double.parseDouble(weg.get(NMHC.name())), nm, MatsimTestUtils.EPSILON, "the NMHC value of this warm emission event was "+ Double.parseDouble(weg.get(NMHC.name()))+ "but should have been "+ nm); + Assertions.assertEquals(Double.parseDouble(weg.get(NO2.name())), n2, MatsimTestUtils.EPSILON, "the NO2 value of this warm emission event was "+ Double.parseDouble(weg.get(NO2.name()))+ "but should have been "+ n2); + Assertions.assertEquals(Double.parseDouble(weg.get(NOx.name())), nx, MatsimTestUtils.EPSILON, "the NOx value of this warm emission event was "+ Double.parseDouble(weg.get(NOx.name()))+ "but should have been "+ nx); + Assertions.assertEquals(Double.parseDouble(weg.get(PM.name())), pm, MatsimTestUtils.EPSILON, "the PM value of this warm emission event was "+ Double.parseDouble(weg.get(PM.name()))+ "but should have been "+ pm); + Assertions.assertEquals(Double.parseDouble(weg.get(SO2.name())), so, MatsimTestUtils.EPSILON, "the SO2 value of this warm emission event was "+ Double.parseDouble(weg.get(SO2.name()))+ "but should have been "+ so); } @Test @@ -140,7 +131,7 @@ final void testGetAttributesForIncompleteMaps(){ String wp=wpEnum.name(); //empty map - Assert.assertNull(emptyMapEvent.getAttributes().get(wp)); + Assertions.assertNull(emptyMapEvent.getAttributes().get(wp)); //values not set try{ @@ -158,8 +149,8 @@ final void testGetAttributesForIncompleteMaps(){ noMapNullPointers++; } } - Assert.assertEquals(numberOfWarmPollutants, valuesNotSetNullPointers); - Assert.assertEquals(numberOfWarmPollutants, noMapNullPointers); + Assertions.assertEquals(numberOfWarmPollutants, valuesNotSetNullPointers); + Assertions.assertEquals(numberOfWarmPollutants, noMapNullPointers); } } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java index 28c1b9ab2a6..2858e572d58 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/events/VehicleLeavesTrafficEventTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.emissions.events; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -82,7 +82,7 @@ public void install(){ } final String expected = utils.getClassInputDirectory() + emissionEventsFileName; EventsFileComparator.Result result = EventsUtils.compareEventsFiles(expected, resultingEvents); - Assert.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result); + Assertions.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result); } } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java index ede97411a51..951ed2fb237 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunAverageEmissionToolOfflineExampleIT.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.emissions.EmissionUtils; @@ -59,7 +59,7 @@ final void testAverage_vehTypeV1() { String expected = utils.getInputDirectory() + RunAverageEmissionToolOfflineExample.emissionEventsFilename; String actual = utils.getOutputDirectory() + RunAverageEmissionToolOfflineExample.emissionEventsFilename; Result result = EventsUtils.compareEventsFiles( expected, actual ); - Assert.assertEquals( Result.FILES_ARE_EQUAL, result); + Assertions.assertEquals( Result.FILES_ARE_EQUAL, result); } @Test @@ -81,7 +81,7 @@ final void testAverage_vehTypeV2() { String expected = utils.getInputDirectory() + RunAverageEmissionToolOfflineExample.emissionEventsFilename; String actual = utils.getOutputDirectory() + RunAverageEmissionToolOfflineExample.emissionEventsFilename; Result result = EventsUtils.compareEventsFiles( expected, actual ); - Assert.assertEquals( Result.FILES_ARE_EQUAL, result); + Assertions.assertEquals( Result.FILES_ARE_EQUAL, result); } /** @@ -107,7 +107,7 @@ final void testAverage_vehTypeV2b() { String expected = utils.getInputDirectory() + RunAverageEmissionToolOfflineExample.emissionEventsFilename; String actual = utils.getOutputDirectory() + RunAverageEmissionToolOfflineExample.emissionEventsFilename; Result result = EventsUtils.compareEventsFiles( expected, actual ); - Assert.assertEquals( Result.FILES_ARE_EQUAL, result); + Assertions.assertEquals( Result.FILES_ARE_EQUAL, result); } @@ -131,6 +131,6 @@ final void testAverage_vehTypeV2_HBEFA4() { String expected = utils.getInputDirectory() + RunAverageEmissionToolOfflineExample.emissionEventsFilename; String actual = utils.getOutputDirectory() + RunAverageEmissionToolOfflineExample.emissionEventsFilename; Result result = EventsUtils.compareEventsFiles( expected, actual ); - Assert.assertEquals( Result.FILES_ARE_EQUAL, result); + Assertions.assertEquals( Result.FILES_ARE_EQUAL, result); } } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java index 26a96f651e4..e2ed6c54bba 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOfflineExampleIT.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -64,7 +64,7 @@ final void testDetailed_vehTypeV1() { } catch (Exception ee ) { gotAnException = true ; } - Assert.assertTrue( gotAnException ); + Assertions.assertTrue( gotAnException ); } // Expecting RuntimeException, because requested values are only in average file. Without fallback it has to fail! @@ -88,7 +88,7 @@ final void testDetailed_vehTypeV2() { } catch (Exception ee ) { gotAnException = true ; } - Assert.assertTrue( gotAnException ); + Assertions.assertTrue( gotAnException ); } // Expecting RuntimeException, because requested values are only in average file. Without fallback it has to fail! @@ -114,7 +114,7 @@ final void testDetailed_vehTypeV2_HBEFA4() { } catch (Exception ee ) { gotAnException = true ; } - Assert.assertTrue( gotAnException ); + Assertions.assertTrue( gotAnException ); } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java index ad7e875891a..b73afd4d36f 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1.java @@ -18,8 +18,8 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -28,8 +28,6 @@ import org.matsim.core.config.ConfigUtils; import org.matsim.testcases.MatsimTestUtils; -import static org.junit.Assert.fail; - /** * @author nagel * @@ -65,7 +63,7 @@ final void testDetailed_vehTypeV1() { } catch (Exception ee ) { gotAnException = true ; } - Assert.assertTrue( gotAnException ); + Assertions.assertTrue( gotAnException ); } } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java index 2ba07507548..8715b4525ed 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV1FallbackToAverage.java @@ -18,6 +18,8 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; +import static org.junit.jupiter.api.Assertions.fail; + import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -28,8 +30,6 @@ import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; -import static org.junit.Assert.fail; - /** * @author nagel * diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java index 8ebcee11237..62e8af5a78e 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java @@ -18,8 +18,8 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -28,8 +28,6 @@ import org.matsim.core.config.ConfigUtils; import org.matsim.testcases.MatsimTestUtils; -import static org.junit.Assert.fail; - /** * @author nagel * @@ -58,7 +56,7 @@ final void testDetailed_vehTypeV2() { } catch (Exception ee ) { gotAnException = true ; } - Assert.assertTrue( gotAnException ); + Assertions.assertTrue( gotAnException ); } } diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java index 346f29f433c..ef667425698 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2FallbackToAverage.java @@ -18,6 +18,8 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; +import static org.junit.jupiter.api.Assertions.fail; + import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -29,8 +31,6 @@ import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; -import static org.junit.Assert.fail; - /** * @author nagel * diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/utils/EmissionUtilsTest.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/utils/EmissionUtilsTest.java index 6fdf91cdb46..4f20dfbf78f 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/utils/EmissionUtilsTest.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/utils/EmissionUtilsTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.emissions.utils; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -124,15 +124,15 @@ final void testSumUpEmissions() { Double pmv = sum.get( PM ); Double sov = sum.get(SO2); - Assert.assertEquals("Value of CO should be " + (wcov + ccov), cov, wcov + ccov, MatsimTestUtils.EPSILON); - Assert.assertEquals("Value of CO2_TOTAL should be " + wc2v, c2v, wc2v, MatsimTestUtils.EPSILON); - Assert.assertEquals("Value of FC should be " + (wfcv + cfcv), fcv, wfcv + cfcv, MatsimTestUtils.EPSILON); - Assert.assertEquals("Value of HC should be " + (whcv + chcv), hcv, whcv + chcv, MatsimTestUtils.EPSILON); - Assert.assertEquals("Value of NMHC should be " + (wnmv + cnmv), nmv, wnmv + cnmv, MatsimTestUtils.EPSILON); - Assert.assertEquals("Value of NO2 should be " + (wn2v + cn2v), n2v, wn2v + cn2v, MatsimTestUtils.EPSILON); - Assert.assertEquals("Value of NOx should be " + (wnxv + cnxv), nxv, wnxv + cnxv, MatsimTestUtils.EPSILON); - Assert.assertEquals("Value of PM should be ." + (wpmv + cpmv), pmv, wpmv + cpmv, MatsimTestUtils.EPSILON); - Assert.assertEquals("Value of SO2 should be " + wsov, sov, wsov, MatsimTestUtils.EPSILON); + Assertions.assertEquals(cov, wcov + ccov, MatsimTestUtils.EPSILON, "Value of CO should be " + (wcov + ccov)); + Assertions.assertEquals(c2v, wc2v, MatsimTestUtils.EPSILON, "Value of CO2_TOTAL should be " + wc2v); + Assertions.assertEquals(fcv, wfcv + cfcv, MatsimTestUtils.EPSILON, "Value of FC should be " + (wfcv + cfcv)); + Assertions.assertEquals(hcv, whcv + chcv, MatsimTestUtils.EPSILON, "Value of HC should be " + (whcv + chcv)); + Assertions.assertEquals(nmv, wnmv + cnmv, MatsimTestUtils.EPSILON, "Value of NMHC should be " + (wnmv + cnmv)); + Assertions.assertEquals(n2v, wn2v + cn2v, MatsimTestUtils.EPSILON, "Value of NO2 should be " + (wn2v + cn2v)); + Assertions.assertEquals(nxv, wnxv + cnxv, MatsimTestUtils.EPSILON, "Value of NOx should be " + (wnxv + cnxv)); + Assertions.assertEquals(pmv, wpmv + cpmv, MatsimTestUtils.EPSILON, "Value of PM should be ." + (wpmv + cpmv)); + Assertions.assertEquals(sov, wsov, MatsimTestUtils.EPSILON, "Value of SO2 should be " + wsov); } @Test @@ -235,25 +235,25 @@ final void testSumUpEmissionsPerId() { double a2so = sums.get(Id.create("id2", Person.class)).get(SO2); //assures simultaneously that persons/ids are distinguished correctly - Assert.assertEquals("CO value of person 1 should be" +e1co +"but is ", e1co, a1co, MatsimTestUtils.EPSILON); - Assert.assertEquals("CO2 value of person 1 should be" + e1c2 + "but is ", e1c2, a1c2, MatsimTestUtils.EPSILON); - Assert.assertEquals("FC value of person 1 should be" + e1fc + "but is ", e1fc, a1fc, MatsimTestUtils.EPSILON); - Assert.assertEquals("HC value of person 1 should be" + e1hc + "but is ", e1hc, a1hc, MatsimTestUtils.EPSILON); - Assert.assertEquals("NMHC value of person 1 should be" + e1nm + "but is ", e1nm, a1nm, MatsimTestUtils.EPSILON); - Assert.assertEquals("NO2 value of person 1 should be" + e1n2 + "but is ", e1n2, a1n2, MatsimTestUtils.EPSILON); - Assert.assertEquals("NOx value of person 1 should be" + e1nx + "but is ", e1nx, a1nx, MatsimTestUtils.EPSILON); - Assert.assertEquals("PM value of person 1 should be" + e1pm + "but is ", e1pm, a1pm, MatsimTestUtils.EPSILON); - Assert.assertEquals("SO value of person 1 should be" + e1so + "but is ", e1so, a1so, MatsimTestUtils.EPSILON); - - Assert.assertEquals("CO value of person 2 should be" + e2co + "but is ", e2co, a2co, MatsimTestUtils.EPSILON); - Assert.assertEquals("CO2 value of person 2 should be" + e2c2 + "but is ", e2c2, a2c2, MatsimTestUtils.EPSILON); - Assert.assertEquals("FC value of person 2 should be" + e2fc + "but is ", e2fc, a2fc, MatsimTestUtils.EPSILON); - Assert.assertEquals("HC value of person 2 should be" + e2hc + "but is ", e2hc, a2hc, MatsimTestUtils.EPSILON); - Assert.assertEquals("NMHC value of person 2 should be" + e2nm + "but is ", e2nm, a2nm, MatsimTestUtils.EPSILON); - Assert.assertEquals("NO2 value of person 2 should be" + e2n2 + "but is ", e2n2, a2n2, MatsimTestUtils.EPSILON); - Assert.assertEquals("NOx value of person 2 should be" + e2nx + "but is ", e2nx, a2nx, MatsimTestUtils.EPSILON); - Assert.assertEquals("PM value of person 2 should be" + e2pm + "but is ", e2pm, a2pm, MatsimTestUtils.EPSILON); - Assert.assertEquals("SO value of person 2 should be" + e2so + "but is ", e2so, a2so, MatsimTestUtils.EPSILON); + Assertions.assertEquals(e1co, a1co, MatsimTestUtils.EPSILON, "CO value of person 1 should be" +e1co +"but is "); + Assertions.assertEquals(e1c2, a1c2, MatsimTestUtils.EPSILON, "CO2 value of person 1 should be" + e1c2 + "but is "); + Assertions.assertEquals(e1fc, a1fc, MatsimTestUtils.EPSILON, "FC value of person 1 should be" + e1fc + "but is "); + Assertions.assertEquals(e1hc, a1hc, MatsimTestUtils.EPSILON, "HC value of person 1 should be" + e1hc + "but is "); + Assertions.assertEquals(e1nm, a1nm, MatsimTestUtils.EPSILON, "NMHC value of person 1 should be" + e1nm + "but is "); + Assertions.assertEquals(e1n2, a1n2, MatsimTestUtils.EPSILON, "NO2 value of person 1 should be" + e1n2 + "but is "); + Assertions.assertEquals(e1nx, a1nx, MatsimTestUtils.EPSILON, "NOx value of person 1 should be" + e1nx + "but is "); + Assertions.assertEquals(e1pm, a1pm, MatsimTestUtils.EPSILON, "PM value of person 1 should be" + e1pm + "but is "); + Assertions.assertEquals(e1so, a1so, MatsimTestUtils.EPSILON, "SO value of person 1 should be" + e1so + "but is "); + + Assertions.assertEquals(e2co, a2co, MatsimTestUtils.EPSILON, "CO value of person 2 should be" + e2co + "but is "); + Assertions.assertEquals(e2c2, a2c2, MatsimTestUtils.EPSILON, "CO2 value of person 2 should be" + e2c2 + "but is "); + Assertions.assertEquals(e2fc, a2fc, MatsimTestUtils.EPSILON, "FC value of person 2 should be" + e2fc + "but is "); + Assertions.assertEquals(e2hc, a2hc, MatsimTestUtils.EPSILON, "HC value of person 2 should be" + e2hc + "but is "); + Assertions.assertEquals(e2nm, a2nm, MatsimTestUtils.EPSILON, "NMHC value of person 2 should be" + e2nm + "but is "); + Assertions.assertEquals(e2n2, a2n2, MatsimTestUtils.EPSILON, "NO2 value of person 2 should be" + e2n2 + "but is "); + Assertions.assertEquals(e2nx, a2nx, MatsimTestUtils.EPSILON, "NOx value of person 2 should be" + e2nx + "but is "); + Assertions.assertEquals(e2pm, a2pm, MatsimTestUtils.EPSILON, "PM value of person 2 should be" + e2pm + "but is "); + Assertions.assertEquals(e2so, a2so, MatsimTestUtils.EPSILON, "SO value of person 2 should be" + e2so + "but is "); } @@ -263,7 +263,7 @@ final void testGetTotalEmissions_nullInput() { @SuppressWarnings("ConstantConditions") SortedMap totalEmissions = EmissionUtils.getTotalEmissions(null); - Assert.fail("Expected NullPointerException, got none."); + Assertions.fail("Expected NullPointerException, got none."); }); @@ -278,7 +278,7 @@ final void testGetTotalEmissions_emptyList() { //test empty list as input totalEmissions = EmissionUtils.getTotalEmissions(persons2emissions); - Assert.assertEquals("this map should be empty", 0, totalEmissions.size()); + Assertions.assertEquals(0, totalEmissions.size(), "this map should be empty"); } @Test @@ -342,22 +342,22 @@ final void testGetTotalEmissions_completeData() { persons2emissions.put(p3Id, allEmissionsp3); totalEmissions = EmissionUtils.getTotalEmissions(persons2emissions); - Assert.assertEquals(CO + " values are not correct", p1co + p2co + p3co, totalEmissions.get(CO), MatsimTestUtils.EPSILON); - Assert.assertEquals(CO2_TOTAL + " values are not correct", p1c2 + p2c2 + p3c2, totalEmissions.get(CO2_TOTAL), MatsimTestUtils.EPSILON); - Assert.assertEquals(FC + " values are not correct", p1fc + p2fc + p3fc, totalEmissions.get(FC), MatsimTestUtils.EPSILON); - Assert.assertEquals(HC + " values are not correct", p1hc + p2hc + p3hc, totalEmissions.get(HC), MatsimTestUtils.EPSILON); - Assert.assertEquals(NMHC + " values are not correct", p1nm + p2nm + p3nm, totalEmissions.get(NMHC), MatsimTestUtils.EPSILON); - Assert.assertEquals(NO2 + " values are not correct", p1n2 + p2n2 + p3n2, totalEmissions.get(NO2), MatsimTestUtils.EPSILON); - Assert.assertEquals(NOx + " values are not correct", p1nx + p2nx + p3nx, totalEmissions.get(NOx), MatsimTestUtils.EPSILON); - Assert.assertEquals(PM + " values are not correct", p1pm + p2pm + p3pm, totalEmissions.get(PM), MatsimTestUtils.EPSILON); - Assert.assertEquals(SO2 + " values are not correct", p1so + p2so + p3so, totalEmissions.get(SO2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(p1co + p2co + p3co, totalEmissions.get(CO), MatsimTestUtils.EPSILON, CO + " values are not correct"); + Assertions.assertEquals(p1c2 + p2c2 + p3c2, totalEmissions.get(CO2_TOTAL), MatsimTestUtils.EPSILON, CO2_TOTAL + " values are not correct"); + Assertions.assertEquals(p1fc + p2fc + p3fc, totalEmissions.get(FC), MatsimTestUtils.EPSILON, FC + " values are not correct"); + Assertions.assertEquals(p1hc + p2hc + p3hc, totalEmissions.get(HC), MatsimTestUtils.EPSILON, HC + " values are not correct"); + Assertions.assertEquals(p1nm + p2nm + p3nm, totalEmissions.get(NMHC), MatsimTestUtils.EPSILON, NMHC + " values are not correct"); + Assertions.assertEquals(p1n2 + p2n2 + p3n2, totalEmissions.get(NO2), MatsimTestUtils.EPSILON, NO2 + " values are not correct"); + Assertions.assertEquals(p1nx + p2nx + p3nx, totalEmissions.get(NOx), MatsimTestUtils.EPSILON, NOx + " values are not correct"); + Assertions.assertEquals(p1pm + p2pm + p3pm, totalEmissions.get(PM), MatsimTestUtils.EPSILON, PM + " values are not correct"); + Assertions.assertEquals(p1so + p2so + p3so, totalEmissions.get(SO2), MatsimTestUtils.EPSILON, SO2 + " values are not correct"); // assume that all maps are complete for (Pollutant emission : pollsFromEU) { - Assert.assertTrue(totalEmissions.containsKey(emission)); + Assertions.assertTrue(totalEmissions.containsKey(emission)); } // nothing else in the list - Assert.assertEquals("this list should be as long as number of pollutants", totalEmissions.keySet().size(), pollsFromEU.size()); + Assertions.assertEquals(totalEmissions.keySet().size(), pollsFromEU.size(), "this list should be as long as number of pollutants"); } @@ -421,52 +421,51 @@ final void testSetNonCalculatedEmissionsForPopulation_completeData(){ Map, SortedMap> finalMap = EmissionUtils.setNonCalculatedEmissionsForPopulation(pop, totalEmissions, pollsFromEU); //check: all persons added to the population are contained in the finalMap - Assert.assertTrue("the calculated map should contain person 1", finalMap.containsKey(idp1)); - Assert.assertTrue("the calculated map should contain person 2", finalMap.containsKey(idp2)); + Assertions.assertTrue(finalMap.containsKey(idp1), "the calculated map should contain person 1"); + Assertions.assertTrue(finalMap.containsKey(idp2), "the calculated map should contain person 2"); //nothing else in the finalMap - Assert.assertEquals("the calculated map should contain two persons but contains "+ - finalMap.size() + "persons." ,pop.getPersons().keySet().size(), finalMap.size()); + Assertions.assertEquals(pop.getPersons().keySet().size(), finalMap.size(), "the calculated map should contain two persons but contains "+ + finalMap.size() + "persons."); //check: all values for person 1 and 2 are not null or zero // and of type double for(Object id : finalMap.keySet()) { - Assert.assertTrue(id instanceof Id); + Assertions.assertTrue(id instanceof Id); for (Object pollutant : finalMap.get(id).values()) { - Assert.assertSame(pollutant.getClass(), Double.class); - Assert.assertNotSame(0.0, pollutant); - Assert.assertNotNull(pollutant); + Assertions.assertSame(pollutant.getClass(), Double.class); + Assertions.assertNotSame(0.0, pollutant); + Assertions.assertNotNull(pollutant); } //check: all emission types appear for (Pollutant emission : pollsFromEU) { - Assert.assertTrue(finalMap.get(id).containsKey(emission)); + Assertions.assertTrue(finalMap.get(id).containsKey(emission)); } //nothing else in the list int numOfPolls = pollsFromEU.size(); - Assert.assertEquals("the number of pullutants is " + finalMap.get(id).keySet().size() + " but should be" + numOfPolls, - numOfPolls, finalMap.get(id).keySet().size()); + Assertions.assertEquals(numOfPolls, finalMap.get(id).keySet().size(), "the number of pullutants is " + finalMap.get(id).keySet().size() + " but should be" + numOfPolls); } //check: values for all emissions are correct -person 1 - Assert.assertEquals("CO value for person 1 is not correct", cov1, finalMap.get(idp1).get( CO ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("CO2 value for person 1 is not correct", c2v1, finalMap.get(idp1).get( CO2_TOTAL ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("FC value for person 1 is not correct", fcv1, finalMap.get(idp1).get( FC ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("HC value for person 1 is not correct", hcv1, finalMap.get(idp1).get( HC ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("NMHC value for person 1 is not correct", nmv1, finalMap.get(idp1).get( NMHC ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("NO2 value for person 1 is not correct", n2v1, finalMap.get(idp1).get( NO2 ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("NOx value for person 1 is not correct", nxv1, finalMap.get(idp1).get( NOx ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("PM value for person 1 is not correct", pmv1, finalMap.get(idp1).get( PM ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("SO value for person 1 is not correct", sov1, finalMap.get(idp1).get( SO2 ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(cov1, finalMap.get(idp1).get( CO ), MatsimTestUtils.EPSILON, "CO value for person 1 is not correct" ); + Assertions.assertEquals(c2v1, finalMap.get(idp1).get( CO2_TOTAL ), MatsimTestUtils.EPSILON, "CO2 value for person 1 is not correct" ); + Assertions.assertEquals(fcv1, finalMap.get(idp1).get( FC ), MatsimTestUtils.EPSILON, "FC value for person 1 is not correct" ); + Assertions.assertEquals(hcv1, finalMap.get(idp1).get( HC ), MatsimTestUtils.EPSILON, "HC value for person 1 is not correct" ); + Assertions.assertEquals(nmv1, finalMap.get(idp1).get( NMHC ), MatsimTestUtils.EPSILON, "NMHC value for person 1 is not correct" ); + Assertions.assertEquals(n2v1, finalMap.get(idp1).get( NO2 ), MatsimTestUtils.EPSILON, "NO2 value for person 1 is not correct" ); + Assertions.assertEquals(nxv1, finalMap.get(idp1).get( NOx ), MatsimTestUtils.EPSILON, "NOx value for person 1 is not correct" ); + Assertions.assertEquals(pmv1, finalMap.get(idp1).get( PM ), MatsimTestUtils.EPSILON, "PM value for person 1 is not correct" ); + Assertions.assertEquals(sov1, finalMap.get(idp1).get( SO2 ), MatsimTestUtils.EPSILON, "SO value for person 1 is not correct" ); //check: values for all emissions are correct -person 2 - Assert.assertEquals("CO value for person 2 is not correct", cov2, finalMap.get(idp2).get( CO ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("CO2 value for person 2 is not correct", c2v2, finalMap.get(idp2).get( CO2_TOTAL ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("FC value for person 2 is not correct", fcv2, finalMap.get(idp2).get( FC ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("HC value for person 2 is not correct", hcv2, finalMap.get(idp2).get( HC ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("NMHC value for person 2 is not correct", nmv2, finalMap.get(idp2).get( NMHC ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("NO2 value for person 2 is not correct", n2v2, finalMap.get(idp2).get( NO2 ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("NOx value for person 2 is not correct", nxv2, finalMap.get(idp2).get( NOx ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("PM value for person 2 is not correct", pmv2, finalMap.get(idp2).get( PM ), MatsimTestUtils.EPSILON ); - Assert.assertEquals("SO value for person 2 is not correct", sov2, finalMap.get(idp2).get( SO2 ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(cov2, finalMap.get(idp2).get( CO ), MatsimTestUtils.EPSILON, "CO value for person 2 is not correct" ); + Assertions.assertEquals(c2v2, finalMap.get(idp2).get( CO2_TOTAL ), MatsimTestUtils.EPSILON, "CO2 value for person 2 is not correct" ); + Assertions.assertEquals(fcv2, finalMap.get(idp2).get( FC ), MatsimTestUtils.EPSILON, "FC value for person 2 is not correct" ); + Assertions.assertEquals(hcv2, finalMap.get(idp2).get( HC ), MatsimTestUtils.EPSILON, "HC value for person 2 is not correct" ); + Assertions.assertEquals(nmv2, finalMap.get(idp2).get( NMHC ), MatsimTestUtils.EPSILON, "NMHC value for person 2 is not correct" ); + Assertions.assertEquals(n2v2, finalMap.get(idp2).get( NO2 ), MatsimTestUtils.EPSILON, "NO2 value for person 2 is not correct" ); + Assertions.assertEquals(nxv2, finalMap.get(idp2).get( NOx ), MatsimTestUtils.EPSILON, "NOx value for person 2 is not correct" ); + Assertions.assertEquals(pmv2, finalMap.get(idp2).get( PM ), MatsimTestUtils.EPSILON, "PM value for person 2 is not correct" ); + Assertions.assertEquals(sov2, finalMap.get(idp2).get( SO2 ), MatsimTestUtils.EPSILON, "SO value for person 2 is not correct" ); } @@ -482,25 +481,25 @@ final void testSetNonCalculatedEmissionsForPopulation_missingMap() { Map, SortedMap> finalMap = EmissionUtils.setNonCalculatedEmissionsForPopulation(pop, totalEmissions, pollsFromEU); //check: person 3 is contained in the finalMap - Assert.assertTrue("the calculated map should contain person 3", finalMap.containsKey(idp3)); + Assertions.assertTrue(finalMap.containsKey(idp3), "the calculated map should contain person 3"); //nothing else in the finalMap message = "the calculated map should contain " + pop.getPersons().size() + " person(s) but contains " + finalMap.keySet().size() + "person(s)."; - Assert.assertEquals(message, pop.getPersons().keySet().size(), finalMap.keySet().size()); + Assertions.assertEquals(pop.getPersons().keySet().size(), finalMap.keySet().size(), message); //check: all values for the this person are zero and of type double for (Object pollutant : finalMap.get(idp3).values()) { - Assert.assertSame(pollutant.getClass(), Double.class); - Assert.assertEquals(0.0, (Double) pollutant, MatsimTestUtils.EPSILON); - Assert.assertNotNull(pollutant); + Assertions.assertSame(pollutant.getClass(), Double.class); + Assertions.assertEquals(0.0, (Double) pollutant, MatsimTestUtils.EPSILON); + Assertions.assertNotNull(pollutant); } //check: all types of emissions appear for (Pollutant emission : pollsFromEU) { - Assert.assertTrue(finalMap.get(idp3).containsKey(emission)); + Assertions.assertTrue(finalMap.get(idp3).containsKey(emission)); } //nothing else in the list int numOfPolls = pollsFromEU.size(); message = "the number of pullutants is " + finalMap.get(idp3).keySet().size() + " but should be" + numOfPolls; - Assert.assertEquals(message, numOfPolls, finalMap.get(idp3).keySet().size()); + Assertions.assertEquals(numOfPolls, finalMap.get(idp3).keySet().size(), message); } @@ -542,10 +541,10 @@ final void testSetNonCalculatedEmissionsForPopulation_missingPerson() { Map, SortedMap> finalMap = EmissionUtils.setNonCalculatedEmissionsForPopulation(pop, totalEmissions, pollsFromEU); //check: all persons added to the population are contained in the finalMap - Assert.assertFalse("the calculated map should not contain person 4", finalMap.containsKey(idp4)); + Assertions.assertFalse(finalMap.containsKey(idp4), "the calculated map should not contain person 4"); //nothing else in the finalMap message = "the calculated map should contain " + pop.getPersons().size() + " person(s) but contains " + finalMap.keySet().size() + "person(s)."; - Assert.assertEquals(message, pop.getPersons().keySet().size(), finalMap.keySet().size()); + Assertions.assertEquals(pop.getPersons().keySet().size(), finalMap.keySet().size(), message); } @@ -568,7 +567,7 @@ final void testSetNonCalculatedEmissionsForPopulation_nullEmissions(){ } catch (NullPointerException e) { nullPointerEx = true; } - Assert.assertTrue(nullPointerEx); + Assertions.assertTrue(nullPointerEx); } @Test @@ -598,7 +597,7 @@ final void testSetNonCalculatedEmissionsForPopulation_emptyPopulation(){ //nothing in the finalMap message = "the calculated map should contain " + pop.getPersons().size() + " person(s) but contains " + finalMap.keySet().size() + "person(s)."; - Assert.assertEquals(message, pop.getPersons().keySet().size(), finalMap.keySet().size()); + Assertions.assertEquals(pop.getPersons().keySet().size(), finalMap.keySet().size(), message); } @@ -618,28 +617,26 @@ final void testSetNonCalculatedEmissionsForPopulation_emptyEmissionMap() { Map, SortedMap> finalMap = EmissionUtils.setNonCalculatedEmissionsForPopulation(pop, totalEmissions, pollsFromEU); //check: all persons added to the population are contained in the finalMap - Assert.assertTrue("the calculated map should contain person 5", finalMap.containsKey(idp5)); - Assert.assertTrue("the calculated map should contain person 6", finalMap.containsKey(idp6)); + Assertions.assertTrue(finalMap.containsKey(idp5), "the calculated map should contain person 5"); + Assertions.assertTrue(finalMap.containsKey(idp6), "the calculated map should contain person 6"); //nothing else in the finalMap message = "the calculated map should contain " + pop.getPersons().size() + " person(s) but contains " + finalMap.keySet().size() + "person(s)."; - Assert.assertEquals(message, pop.getPersons().keySet().size(), finalMap.keySet().size()); + Assertions.assertEquals(pop.getPersons().keySet().size(), finalMap.keySet().size(), message); //check: all values for all persons are zero and of type double for (Id id : finalMap.keySet()) { for (Object pollutant : finalMap.get(id).values()) { - Assert.assertSame(pollutant.getClass(), Double.class); - Assert.assertEquals("map of pollutants was missing. Therefore all values should be set to zero.", - 0.0, (Double) pollutant, MatsimTestUtils.EPSILON); - Assert.assertNotNull(pollutant); + Assertions.assertSame(pollutant.getClass(), Double.class); + Assertions.assertEquals(0.0, (Double) pollutant, MatsimTestUtils.EPSILON, "map of pollutants was missing. Therefore all values should be set to zero."); + Assertions.assertNotNull(pollutant); } //check: alle types of emissions appear for (Pollutant emission : pollsFromEU) { - Assert.assertTrue(finalMap.get(id).containsKey(emission)); + Assertions.assertTrue(finalMap.get(id).containsKey(emission)); } //nothing else in the list int numOfPolls = pollsFromEU.size(); - Assert.assertEquals("the number of pullutants is " + finalMap.get(id).keySet().size() + " but should be" + numOfPolls, - numOfPolls, finalMap.get(id).keySet().size()); + Assertions.assertEquals(numOfPolls, finalMap.get(id).keySet().size(), "the number of pullutants is " + finalMap.get(id).keySet().size() + " but should be" + numOfPolls); } @@ -732,64 +729,64 @@ final void testSetNonCalculatedEmissionsForNetwork() { Id linkId = link.getId(); - Assert.assertTrue(totalEmissionsFilled.containsKey(linkId)); + Assertions.assertTrue(totalEmissionsFilled.containsKey(linkId)); SortedMap emissionMapForLink = totalEmissionsFilled.get(linkId); for (Pollutant pollutant : pollsFromEU) { System.out.println("pollutant: " + pollutant + "; linkId: " + linkId); - Assert.assertTrue(pollutant + "not found for link " + linkId.toString(), - emissionMapForLink.containsKey(pollutant)); - Assert.assertEquals(Double.class, emissionMapForLink.get(pollutant).getClass()); + Assertions.assertTrue(emissionMapForLink.containsKey(pollutant), + pollutant + "not found for link " + linkId.toString()); + Assertions.assertEquals(Double.class, emissionMapForLink.get(pollutant).getClass()); } } //check values //link 12 and 13 - Assert.assertEquals(totalEmissionsFilled.get(link12id).get( CO2_TOTAL ), c2link12v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link12id).get( CO ), colink12v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link12id).get( FC ), fclink12v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link12id).get( HC ), hclink12v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link12id).get( NMHC ), nmlink12v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link12id).get( NO2 ), n2link12v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link12id).get( NOx ), nxlink12v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link12id).get( PM ), pmlink12v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link12id).get( SO2 ), solink12v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link13id).get( CO2_TOTAL ), c2link13v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link13id).get( CO ), colink13v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link13id).get( FC ), fclink13v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link13id).get( HC ), hclink13v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link13id).get( NMHC ), nmlink13v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link13id).get( NO2 ), n2link13v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link13id).get( NOx ), nxlink13v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link13id).get( PM ), pmlink13v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link13id).get( SO2 ), solink13v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link12id).get( CO2_TOTAL ), c2link12v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link12id).get( CO ), colink12v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link12id).get( FC ), fclink12v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link12id).get( HC ), hclink12v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link12id).get( NMHC ), nmlink12v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link12id).get( NO2 ), n2link12v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link12id).get( NOx ), nxlink12v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link12id).get( PM ), pmlink12v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link12id).get( SO2 ), solink12v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link13id).get( CO2_TOTAL ), c2link13v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link13id).get( CO ), colink13v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link13id).get( FC ), fclink13v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link13id).get( HC ), hclink13v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link13id).get( NMHC ), nmlink13v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link13id).get( NO2 ), n2link13v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link13id).get( NOx ), nxlink13v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link13id).get( PM ), pmlink13v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link13id).get( SO2 ), solink13v, MatsimTestUtils.EPSILON ); //link 14 and 34 for(Pollutant pollutant: pollsFromEU){ - Assert.assertEquals(totalEmissionsFilled.get(link14id).get(pollutant), .0, MatsimTestUtils.EPSILON); - Assert.assertEquals(totalEmissionsFilled.get(link34id).get(pollutant), .0, MatsimTestUtils.EPSILON); + Assertions.assertEquals(totalEmissionsFilled.get(link14id).get(pollutant), .0, MatsimTestUtils.EPSILON); + Assertions.assertEquals(totalEmissionsFilled.get(link34id).get(pollutant), .0, MatsimTestUtils.EPSILON); } //link 23 - partial - Assert.assertEquals(totalEmissionsFilled.get(link23id).get( CO2_TOTAL ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link23id).get( CO ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link23id).get( FC ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link23id).get( HC ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link23id).get( NMHC ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link23id).get( NO2 ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link23id).get( NOx ), nxlink23v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link23id).get( PM ), pmlink23v, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link23id).get( SO2 ), solink23v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link23id).get( CO2_TOTAL ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link23id).get( CO ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link23id).get( FC ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link23id).get( HC ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link23id).get( NMHC ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link23id).get( NO2 ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link23id).get( NOx ), nxlink23v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link23id).get( PM ), pmlink23v, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link23id).get( SO2 ), solink23v, MatsimTestUtils.EPSILON ); //link 24 - empty - Assert.assertEquals(totalEmissionsFilled.get(link24id).get( CO2_TOTAL ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link24id).get( CO ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link24id).get( FC ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link24id).get( HC ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link24id).get( NMHC ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link24id).get( NO2 ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link24id).get( NOx ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link24id).get( PM ), .0, MatsimTestUtils.EPSILON ); - Assert.assertEquals(totalEmissionsFilled.get(link24id).get( SO2 ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link24id).get( CO2_TOTAL ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link24id).get( CO ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link24id).get( FC ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link24id).get( HC ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link24id).get( NMHC ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link24id).get( NO2 ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link24id).get( NOx ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link24id).get( PM ), .0, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(totalEmissionsFilled.get(link24id).get( SO2 ), .0, MatsimTestUtils.EPSILON ); } public static Map createEmissions() { diff --git a/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java b/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java index 0fe8353c9d8..ffc5f81e296 100644 --- a/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java +++ b/contribs/ev/src/test/java/org/matsim/contrib/ev/example/RunEvExampleWithLTHConsumptionModelTest.java @@ -2,7 +2,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.population.Population; @@ -38,20 +38,20 @@ void runTest(){ PopulationUtils.readPopulation( actual, utils.getOutputDirectory() + "/output_plans.xml.gz" ); boolean result = PopulationUtils.comparePopulations( expected, actual ); - Assert.assertTrue( result ); + Assertions.assertTrue( result ); } { String expected = utils.getInputDirectory() + "/output_events.xml.gz" ; String actual = utils.getOutputDirectory() + "/output_events.xml.gz" ; EventsFileComparator.Result result = EventsUtils.compareEventsFiles( expected, actual ); - Assert.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result ); + Assertions.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result ); } } catch ( Exception ee ) { log.fatal("there was an exception: \n" + ee ) ; // if one catches an exception, then one needs to explicitly fail the test: - Assert.fail(); + Assertions.fail(); } } diff --git a/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java b/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java index dbd13c7a8b6..f686d7d95d4 100644 --- a/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java +++ b/contribs/ev/src/test/java/org/matsim/contrib/ev/temperature/TemperatureChangeModuleIntegrationTest.java @@ -20,8 +20,7 @@ package org.matsim.contrib.ev.temperature; import jakarta.inject.Inject; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -71,10 +70,10 @@ static class TemperatureTestEventHandler implements PersonDepartureEventHandler @Override public void handleEvent(PersonDepartureEvent event) { if (event.getLinkId().equals(Id.createLinkId("link1"))) { - Assert.assertEquals(temperatureService.getCurrentTemperature(event.getLinkId()), -10.0, 0.001); + Assertions.assertEquals(temperatureService.getCurrentTemperature(event.getLinkId()), -10.0, 0.001); } if (event.getLinkId().equals(Id.createLinkId("link2"))) { - Assert.assertEquals(temperatureService.getCurrentTemperature(event.getLinkId()), 30.0, 0.001); + Assertions.assertEquals(temperatureService.getCurrentTemperature(event.getLinkId()), 30.0, 0.001); } } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java index 89a1108290d..bf1cb7be9a6 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierEventsReadersTest.java @@ -20,7 +20,7 @@ package org.matsim.freight.carriers; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -96,7 +96,7 @@ void testWriteReadServiceBasedEvents() { .readStream(new ByteArrayInputStream(outputStream.toByteArray()), ControllerConfigGroup.EventsFileFormat.xml); eventsManager2.finishProcessing(); - Assert.assertEquals(collector1.getEvents(), collector2.getEvents()); + Assertions.assertEquals(collector1.getEvents(), collector2.getEvents()); } @@ -114,8 +114,8 @@ void testReadServiceBasedEvents() { .readFile(utils.getClassInputDirectory() + "serviceBasedEvents.xml"); eventsManager.finishProcessing(); - Assert.assertEquals("Number of tour related carrier events is not correct", 4 , eventHandlerTours.handledEvents.size()); - Assert.assertEquals("Number of service related carrier events is not correct", 14 , eventHandlerServices.handledEvents.size()); + Assertions.assertEquals(4 , eventHandlerTours.handledEvents.size(), "Number of tour related carrier events is not correct"); + Assertions.assertEquals(14 , eventHandlerServices.handledEvents.size(), "Number of service related carrier events is not correct"); } @Test @@ -142,7 +142,7 @@ void testWriteReadShipmentBasedEvents() { .readStream(new ByteArrayInputStream(outputStream.toByteArray()), ControllerConfigGroup.EventsFileFormat.xml); eventsManager2.finishProcessing(); - Assert.assertEquals(collector1.getEvents(), collector2.getEvents()); + Assertions.assertEquals(collector1.getEvents(), collector2.getEvents()); } @Test @@ -159,8 +159,8 @@ void testReadShipmentBasedEvents() { .readFile(utils.getClassInputDirectory() + "shipmentBasedEvents.xml"); eventsManager.finishProcessing(); - Assert.assertEquals("Number of tour related carrier events is not correct", 2 , eventHandlerTours.handledEvents.size()); - Assert.assertEquals("Number of shipments related carrier events is not correct", 20 , testEventHandlerShipments.handledEvents.size()); + Assertions.assertEquals(2 , eventHandlerTours.handledEvents.size(), "Number of tour related carrier events is not correct"); + Assertions.assertEquals(20 , testEventHandlerShipments.handledEvents.size(), "Number of shipments related carrier events is not correct"); } @@ -196,7 +196,7 @@ void testReader() { handledEvents.addAll(eventHandlerShipments.handledEvents); //Please note: This test is sensitive to the order of events as they are added in carrierEvents (input) and the resukts of the handler... - Assert.assertArrayEquals(carrierEvents.toArray(), handledEvents.toArray()); + Assertions.assertArrayEquals(carrierEvents.toArray(), handledEvents.toArray()); } private static class TestEventHandlerTours diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java index 9a8bfba14f9..1be22630df2 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanReaderV1Test.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -52,7 +52,7 @@ void testCarrierPlanReaderDoesSomething() { Carriers carriers = new Carriers(); CarrierPlanReaderV1 carrierPlanReaderV1 = new CarrierPlanReaderV1(carriers, carrierVehicleTypes ); carrierPlanReaderV1.readFile(utils.getClassInputDirectory() + "carrierPlansEquils.xml"); - Assert.assertEquals(1, carriers.getCarriers().size()); + Assertions.assertEquals(1, carriers.getCarriers().size()); } @Test @@ -66,18 +66,18 @@ void testReaderReadsCorrectly() { Carriers carriers = new Carriers(); CarrierPlanReaderV1 carrierPlanReaderV1 = new CarrierPlanReaderV1(carriers, carrierVehicleTypes ); carrierPlanReaderV1.readFile(utils.getClassInputDirectory() + "carrierPlansEquils.xml"); - Assert.assertEquals(1, carriers.getCarriers().size()); + Assertions.assertEquals(1, carriers.getCarriers().size()); Carrier carrier = carriers.getCarriers().values().iterator().next(); - Assert.assertEquals(1, carrier.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(1, carrier.getSelectedPlan().getScheduledTours().size()); Leg leg = (Leg) carrier.getSelectedPlan().getScheduledTours() .iterator().next().getTour().getTourElements().get(0); NetworkRoute route = (NetworkRoute) leg.getRoute(); - Assert.assertEquals(3, route.getLinkIds().size()); - Assert.assertEquals("23", route.getStartLinkId().toString()); - Assert.assertEquals("2", route.getLinkIds().get(0).toString()); - Assert.assertEquals("3", route.getLinkIds().get(1).toString()); - Assert.assertEquals("4", route.getLinkIds().get(2).toString()); - Assert.assertEquals("15", route.getEndLinkId().toString()); + Assertions.assertEquals(3, route.getLinkIds().size()); + Assertions.assertEquals("23", route.getStartLinkId().toString()); + Assertions.assertEquals("2", route.getLinkIds().get(0).toString()); + Assertions.assertEquals("3", route.getLinkIds().get(1).toString()); + Assertions.assertEquals("4", route.getLinkIds().get(2).toString()); + Assertions.assertEquals("15", route.getEndLinkId().toString()); } @Test @@ -92,9 +92,9 @@ void testReaderReadsScoreAndSelectedPlanCorrectly() { CarrierPlanReaderV1 carrierPlanReaderV1 = new CarrierPlanReaderV1(carriers, carrierVehicleTypes ); carrierPlanReaderV1.readFile(utils.getClassInputDirectory() + "carrierPlansEquils.xml"); Carrier carrier = carriers.getCarriers().values().iterator().next(); - Assert.assertNotNull(carrier.getSelectedPlan()); - Assert.assertEquals(-100.0, carrier.getSelectedPlan().getScore(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2,carrier.getPlans().size()); + Assertions.assertNotNull(carrier.getSelectedPlan()); + Assertions.assertEquals(-100.0, carrier.getSelectedPlan().getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2,carrier.getPlans().size()); } @Test @@ -109,8 +109,8 @@ void testReaderReadsUnScoredAndUnselectedPlanCorrectly() { CarrierPlanReaderV1 carrierPlanReaderV1 = new CarrierPlanReaderV1(carriers, carrierVehicleTypes ); carrierPlanReaderV1.readFile(utils.getClassInputDirectory() + "carrierPlansEquils_unscored_unselected.xml"); Carrier carrier = carriers.getCarriers().values().iterator().next(); - Assert.assertNull(carrier.getSelectedPlan()); - Assert.assertEquals(2,carrier.getPlans().size()); + Assertions.assertNull(carrier.getSelectedPlan()); + Assertions.assertEquals(2,carrier.getPlans().size()); } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java index 8d2c910226d..0c918cf4616 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2Test.java @@ -21,8 +21,8 @@ package org.matsim.freight.carriers; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -62,7 +62,7 @@ public void setUp() throws Exception{ @Test void test_whenReadingServices_nuOfServicesIsCorrect(){ - Assert.assertEquals(3,testCarrier.getServices().size()); + Assertions.assertEquals(3,testCarrier.getServices().size()); } @Test @@ -70,43 +70,43 @@ void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ CarrierVehicle light = CarriersUtils.getCarrierVehicle(testCarrier, Id.createVehicleId("lightVehicle")); Gbl.assertNotNull(light); - Assert.assertEquals("light",light.getVehicleTypeId().toString()); + Assertions.assertEquals("light",light.getVehicleTypeId().toString()); CarrierVehicle medium = CarriersUtils.getCarrierVehicle(testCarrier, Id.createVehicleId("mediumVehicle")); Gbl.assertNotNull(medium); - Assert.assertEquals("medium",medium.getVehicleTypeId().toString()); + Assertions.assertEquals("medium",medium.getVehicleTypeId().toString()); CarrierVehicle heavy = CarriersUtils.getCarrierVehicle(testCarrier, Id.createVehicleId("heavyVehicle")); Gbl.assertNotNull(heavy); - Assert.assertEquals("heavy",heavy.getVehicleTypeId().toString()); + Assertions.assertEquals("heavy",heavy.getVehicleTypeId().toString()); } @Test void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ Map, CarrierVehicle> carrierVehicles = testCarrier.getCarrierCapabilities().getCarrierVehicles(); - Assert.assertEquals(3,carrierVehicles.size()); - Assert.assertTrue(exactlyTheseVehiclesAreInVehicleCollection(Arrays.asList(Id.create("lightVehicle", Vehicle.class), + Assertions.assertEquals(3,carrierVehicles.size()); + Assertions.assertTrue(exactlyTheseVehiclesAreInVehicleCollection(Arrays.asList(Id.create("lightVehicle", Vehicle.class), Id.create("mediumVehicle", Vehicle.class),Id.create("heavyVehicle", Vehicle.class)),carrierVehicles.values())); } @Test void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ - Assert.assertEquals(FleetSize.INFINITE, testCarrier.getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(FleetSize.INFINITE, testCarrier.getCarrierCapabilities().getFleetSize()); } @Test void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ - Assert.assertEquals(2, testCarrier.getShipments().size()); + Assertions.assertEquals(2, testCarrier.getShipments().size()); } @Test void test_whenReadingCarrier_itReadsPlansCorrectly(){ - Assert.assertEquals(3, testCarrier.getPlans().size()); + Assertions.assertEquals(3, testCarrier.getPlans().size()); } @Test void test_whenReadingCarrier_itSelectsPlansCorrectly(){ - Assert.assertNotNull(testCarrier.getSelectedPlan()); + Assertions.assertNotNull(testCarrier.getSelectedPlan()); } @Test @@ -118,15 +118,15 @@ void test_whenReadingCarrierWithFiniteFleet_itSetsFleetSizeCorrectly(){ Carriers carriers = new Carriers(); String classInputDirectory = utils.getClassInputDirectory(); new CarrierPlanXmlReader(carriers, carrierVehicleTypes ).readFile(classInputDirectory + "carrierPlansEquilsFiniteFleet.xml" ); - Assert.assertEquals(FleetSize.FINITE, carriers.getCarriers().get(Id.create("testCarrier", Carrier.class)).getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(FleetSize.FINITE, carriers.getCarriers().get(Id.create("testCarrier", Carrier.class)).getCarrierCapabilities().getFleetSize()); } @Test void test_whenReadingPlans_nuOfToursIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); - Assert.assertEquals(1, plans.get(0).getScheduledTours().size()); - Assert.assertEquals(1, plans.get(1).getScheduledTours().size()); - Assert.assertEquals(1, plans.get(2).getScheduledTours().size()); + Assertions.assertEquals(1, plans.get(0).getScheduledTours().size()); + Assertions.assertEquals(1, plans.get(1).getScheduledTours().size()); + Assertions.assertEquals(1, plans.get(2).getScheduledTours().size()); } @Test @@ -134,7 +134,7 @@ void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan1 = plans.get(0); ScheduledTour tour1 = plan1.getScheduledTours().iterator().next(); - Assert.assertEquals(5,tour1.getTour().getTourElements().size()); + Assertions.assertEquals(5,tour1.getTour().getTourElements().size()); } @Test @@ -142,7 +142,7 @@ void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan2 = plans.get(1); ScheduledTour tour1 = plan2.getScheduledTours().iterator().next(); - Assert.assertEquals(9,tour1.getTour().getTourElements().size()); + Assertions.assertEquals(9,tour1.getTour().getTourElements().size()); } @Test @@ -150,7 +150,7 @@ void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan3 = plans.get(2); ScheduledTour tour1 = plan3.getScheduledTours().iterator().next(); - Assert.assertEquals(9,tour1.getTour().getTourElements().size()); + Assertions.assertEquals(9,tour1.getTour().getTourElements().size()); } @@ -163,18 +163,18 @@ private boolean exactlyTheseVehiclesAreInVehicleCollection(List> asL @Test void test_CarrierHasAttributes(){ - Assert.assertEquals((TransportMode.drt), CarriersUtils.getCarrierMode(testCarrier)); - Assert.assertEquals(50, CarriersUtils.getJspritIterations(testCarrier)); + Assertions.assertEquals((TransportMode.drt), CarriersUtils.getCarrierMode(testCarrier)); + Assertions.assertEquals(50, CarriersUtils.getJspritIterations(testCarrier)); } @Test void test_ServicesAndShipmentsHaveAttributes(){ Object serviceCustomerAtt = testCarrier.getServices().get(Id.create("serv1", CarrierService.class)).getAttributes().getAttribute("customer"); - Assert.assertNotNull(serviceCustomerAtt); - Assert.assertEquals("someRandomCustomer", serviceCustomerAtt); + Assertions.assertNotNull(serviceCustomerAtt); + Assertions.assertEquals("someRandomCustomer", serviceCustomerAtt); Object shipmentCustomerAtt = testCarrier.getShipments().get(Id.create("s1",CarrierShipment.class)).getAttributes().getAttribute("customer"); - Assert.assertNotNull(shipmentCustomerAtt); - Assert.assertEquals("someRandomCustomer", shipmentCustomerAtt); + Assertions.assertNotNull(shipmentCustomerAtt); + Assertions.assertEquals("someRandomCustomer", shipmentCustomerAtt); } @Test @@ -210,7 +210,7 @@ void test_readStream() { new CarrierPlanXmlReader(carriers, carrierVehicleTypes ).readStream(is ); - Assert.assertEquals(1, carriers.getCarriers().size()); + Assertions.assertEquals(1, carriers.getCarriers().size()); } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java index 32b3dd45307..0532c455bd7 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java @@ -21,9 +21,9 @@ package org.matsim.freight.carriers; -import org.junit.Assert; import org.junit.Before; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -57,7 +57,7 @@ public void setUp() throws Exception{ @Test @Ignore void test_whenReadingServices_nuOfServicesIsCorrect(){ - Assert.assertEquals(3,testCarrier.getServices().size()); + Assertions.assertEquals(3,testCarrier.getServices().size()); } @Test @@ -65,48 +65,48 @@ void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ CarrierVehicle light = CarriersUtils.getCarrierVehicle(testCarrier, Id.createVehicleId("lightVehicle")); Gbl.assertNotNull(light); - Assert.assertEquals("light",light.getVehicleTypeId().toString()); + Assertions.assertEquals("light",light.getVehicleTypeId().toString()); CarrierVehicle medium = CarriersUtils.getCarrierVehicle(testCarrier, Id.createVehicleId("mediumVehicle")); Gbl.assertNotNull(medium); - Assert.assertEquals("medium",medium.getVehicleTypeId().toString()); + Assertions.assertEquals("medium",medium.getVehicleTypeId().toString()); CarrierVehicle heavy = CarriersUtils.getCarrierVehicle(testCarrier, Id.createVehicleId("heavyVehicle")); Gbl.assertNotNull(heavy); - Assert.assertEquals("heavy",heavy.getVehicleTypeId().toString()); + Assertions.assertEquals("heavy",heavy.getVehicleTypeId().toString()); } @Test @Ignore void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ Map, CarrierVehicle> carrierVehicles = testCarrier.getCarrierCapabilities().getCarrierVehicles(); - Assert.assertEquals(3,carrierVehicles.size()); - Assert.assertTrue(exactlyTheseVehiclesAreInVehicleCollection(Arrays.asList(Id.create("lightVehicle", Vehicle.class), + Assertions.assertEquals(3,carrierVehicles.size()); + Assertions.assertTrue(exactlyTheseVehiclesAreInVehicleCollection(Arrays.asList(Id.create("lightVehicle", Vehicle.class), Id.create("mediumVehicle", Vehicle.class),Id.create("heavyVehicle", Vehicle.class)),carrierVehicles.values())); } @Test @Ignore void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ - Assert.assertEquals(FleetSize.INFINITE, testCarrier.getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(FleetSize.INFINITE, testCarrier.getCarrierCapabilities().getFleetSize()); } @Test @Ignore void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ - Assert.assertEquals(2, testCarrier.getShipments().size()); + Assertions.assertEquals(2, testCarrier.getShipments().size()); } @Test @Ignore void test_whenReadingCarrier_itReadsPlansCorrectly(){ - Assert.assertEquals(3, testCarrier.getPlans().size()); + Assertions.assertEquals(3, testCarrier.getPlans().size()); } @Test @Ignore void test_whenReadingCarrier_itSelectsPlansCorrectly(){ - Assert.assertNotNull(testCarrier.getSelectedPlan()); + Assertions.assertNotNull(testCarrier.getSelectedPlan()); } @Test @@ -118,16 +118,16 @@ void test_whenReadingCarrierWithFiniteFleet_itSetsFleetSizeCorrectly(){ Carriers carriers = new Carriers(); String classInputDirectory = utils.getClassInputDirectory(); new CarrierPlanXmlReader(carriers, carrierVehicleTypes ).readFile(classInputDirectory + "carrierPlansEquilsFiniteFleetWithDtd.xml" ); - Assert.assertEquals(FleetSize.FINITE, carriers.getCarriers().get(Id.create("testCarrier", Carrier.class)).getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(FleetSize.FINITE, carriers.getCarriers().get(Id.create("testCarrier", Carrier.class)).getCarrierCapabilities().getFleetSize()); } @Test @Ignore void test_whenReadingPlans_nuOfToursIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); - Assert.assertEquals(1, plans.get(0).getScheduledTours().size()); - Assert.assertEquals(1, plans.get(1).getScheduledTours().size()); - Assert.assertEquals(1, plans.get(2).getScheduledTours().size()); + Assertions.assertEquals(1, plans.get(0).getScheduledTours().size()); + Assertions.assertEquals(1, plans.get(1).getScheduledTours().size()); + Assertions.assertEquals(1, plans.get(2).getScheduledTours().size()); } @Test @@ -136,7 +136,7 @@ void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan1 = plans.get(0); ScheduledTour tour1 = plan1.getScheduledTours().iterator().next(); - Assert.assertEquals(5,tour1.getTour().getTourElements().size()); + Assertions.assertEquals(5,tour1.getTour().getTourElements().size()); } @Test @@ -144,7 +144,7 @@ void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan2 = plans.get(1); ScheduledTour tour1 = plan2.getScheduledTours().iterator().next(); - Assert.assertEquals(9,tour1.getTour().getTourElements().size()); + Assertions.assertEquals(9,tour1.getTour().getTourElements().size()); } @Test @@ -153,7 +153,7 @@ void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan3 = plans.get(2); ScheduledTour tour1 = plan3.getScheduledTours().iterator().next(); - Assert.assertEquals(9,tour1.getTour().getTourElements().size()); + Assertions.assertEquals(9,tour1.getTour().getTourElements().size()); } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java index c6a5c2f42b1..a5617f9a1d2 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2Test.java @@ -33,7 +33,7 @@ import java.util.*; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class CarrierPlanXmlWriterV2Test { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java index 315570c91a2..9f2d701bf0a 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlWriterV2_1Test.java @@ -33,7 +33,7 @@ import java.util.*; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class CarrierPlanXmlWriterV2_1Test { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java index 6f6a002f19c..7efefd4ce40 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeLoaderTest.java @@ -21,8 +21,8 @@ package org.matsim.freight.carriers; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -54,16 +54,16 @@ void test_whenLoadingTypes_allAssignmentsInLightVehicleAreCorrectly(){ CarrierVehicle v = CarriersUtils.getCarrierVehicle(testCarrier,Id.createVehicleId("lightVehicle")); VehicleType vehicleTypeLoaded = v.getType(); - Assert.assertNotNull(vehicleTypeLoaded); + Assertions.assertNotNull(vehicleTypeLoaded); - Assert.assertEquals("light", vehicleTypeLoaded.getId().toString()); - Assert.assertEquals(15, vehicleTypeLoaded.getCapacity().getOther(), MatsimTestUtils.EPSILON); - Assert.assertEquals(20, vehicleTypeLoaded.getCostInformation().getFixedCosts(), MatsimTestUtils.EPSILON); - Assert.assertEquals(0.35, vehicleTypeLoaded.getCostInformation().getCostsPerMeter(), MatsimTestUtils.EPSILON); - Assert.assertEquals(30, vehicleTypeLoaded.getCostInformation().getCostsPerSecond(), MatsimTestUtils.EPSILON); + Assertions.assertEquals("light", vehicleTypeLoaded.getId().toString()); + Assertions.assertEquals(15, vehicleTypeLoaded.getCapacity().getOther(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(20, vehicleTypeLoaded.getCostInformation().getFixedCosts(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.35, vehicleTypeLoaded.getCostInformation().getCostsPerMeter(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(30, vehicleTypeLoaded.getCostInformation().getCostsPerSecond(), MatsimTestUtils.EPSILON); - Assert.assertEquals("gasoline", vehicleTypeLoaded.getEngineInformation().getFuelType().toString()); - Assert.assertEquals(0.02, VehicleUtils.getFuelConsumption(vehicleTypeLoaded), MatsimTestUtils.EPSILON); + Assertions.assertEquals("gasoline", vehicleTypeLoaded.getEngineInformation().getFuelType().toString()); + Assertions.assertEquals(0.02, VehicleUtils.getFuelConsumption(vehicleTypeLoaded), MatsimTestUtils.EPSILON); } @Test @@ -73,16 +73,16 @@ void test_whenLoadingTypes_allAssignmentsInMediumVehicleAreCorrectly(){ CarrierVehicle v = CarriersUtils.getCarrierVehicle(testCarrier,Id.createVehicleId("mediumVehicle")); VehicleType vehicleTypeLoaded = v.getType(); - Assert.assertNotNull(vehicleTypeLoaded); + Assertions.assertNotNull(vehicleTypeLoaded); - Assert.assertEquals("medium", vehicleTypeLoaded.getId().toString()); - Assert.assertEquals(30, vehicleTypeLoaded.getCapacity().getOther(), MatsimTestUtils.EPSILON); - Assert.assertEquals(50, vehicleTypeLoaded.getCostInformation().getFixedCosts(), MatsimTestUtils.EPSILON); - Assert.assertEquals(0.4, vehicleTypeLoaded.getCostInformation().getCostsPerMeter(), MatsimTestUtils.EPSILON); - Assert.assertEquals(30, vehicleTypeLoaded.getCostInformation().getCostsPerSecond(), MatsimTestUtils.EPSILON); + Assertions.assertEquals("medium", vehicleTypeLoaded.getId().toString()); + Assertions.assertEquals(30, vehicleTypeLoaded.getCapacity().getOther(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(50, vehicleTypeLoaded.getCostInformation().getFixedCosts(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.4, vehicleTypeLoaded.getCostInformation().getCostsPerMeter(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(30, vehicleTypeLoaded.getCostInformation().getCostsPerSecond(), MatsimTestUtils.EPSILON); - Assert.assertEquals("gasoline", vehicleTypeLoaded.getEngineInformation().getFuelType().toString()); - Assert.assertEquals(0.02, VehicleUtils.getFuelConsumption(vehicleTypeLoaded), MatsimTestUtils.EPSILON); + Assertions.assertEquals("gasoline", vehicleTypeLoaded.getEngineInformation().getFuelType().toString()); + Assertions.assertEquals(0.02, VehicleUtils.getFuelConsumption(vehicleTypeLoaded), MatsimTestUtils.EPSILON); } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java index 5801d07e523..c7a740a1a31 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeReaderTest.java @@ -30,8 +30,8 @@ import org.matsim.testcases.MatsimTestUtils; import org.matsim.vehicles.VehicleType; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; public class CarrierVehicleTypeReaderTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java index 080ea93de26..74152387942 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierVehicleTypeTest.java @@ -21,8 +21,8 @@ package org.matsim.freight.carriers; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -86,102 +86,102 @@ public void setUp() throws Exception{ @Test void test_whenCreatingTypeMedium_itCreatesDescriptionCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals("Medium Vehicle", medium.getDescription()); + Assertions.assertEquals("Medium Vehicle", medium.getDescription()); } @Test void test_whenCreatingTypeMedium_itCreatesCapacityCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(30., medium.getCapacity().getWeightInTons(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(30., medium.getCapacity().getWeightInTons(), MatsimTestUtils.EPSILON ); } @Test void test_whenCreatingTypeMedium_itCreatesCostInfoCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(50.0, medium.getCostInformation().getFixedCosts(),0.01 ); - Assert.assertEquals(1.0, medium.getCostInformation().getCostsPerMeter(),0.01 ); - Assert.assertEquals(0.5, medium.getCostInformation().getCostsPerSecond(),0.01 ); + Assertions.assertEquals(50.0, medium.getCostInformation().getFixedCosts(),0.01 ); + Assertions.assertEquals(1.0, medium.getCostInformation().getCostsPerMeter(),0.01 ); + Assertions.assertEquals(0.5, medium.getCostInformation().getCostsPerSecond(),0.01 ); } @Test void test_whenCreatingTypeMedium_itCreatesEngineInfoCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(0.02, medium.getEngineInformation().getFuelConsumption(),0.001); - Assert.assertEquals(FuelType.diesel, medium.getEngineInformation().getFuelType()); + Assertions.assertEquals(0.02, medium.getEngineInformation().getFuelConsumption(),0.001); + Assertions.assertEquals(FuelType.diesel, medium.getEngineInformation().getFuelType()); } @Test void test_whenCreatingTypeMedium_itCreatesMaxVelocityCorrectly(){ VehicleType medium = types.getVehicleTypes().get(Id.create("medium", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(13.89, medium.getMaximumVelocity(), 0.01); + Assertions.assertEquals(13.89, medium.getMaximumVelocity(), 0.01); } //Now testing the copy @Test void test_whenCopyingTypeMedium_itCopiesDescriptionCorrectly(){ VehicleType medium2 = types.getVehicleTypes().get(Id.create("medium2", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals("Medium Vehicle", medium2.getDescription()); + Assertions.assertEquals("Medium Vehicle", medium2.getDescription()); } @Test void test_whenCopyingTypeMedium_itCopiesCapacityCorrectly(){ VehicleType medium2 = types.getVehicleTypes().get(Id.create("medium2", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(30., medium2.getCapacity().getWeightInTons(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(30., medium2.getCapacity().getWeightInTons(), MatsimTestUtils.EPSILON ); } @Test void test_whenCopyingTypeMedium_itCopiesCostInfoCorrectly(){ VehicleType medium2 = types.getVehicleTypes().get(Id.create("medium2", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(50.0, medium2.getCostInformation().getFixedCosts(),0.01 ); - Assert.assertEquals(1.0, medium2.getCostInformation().getCostsPerMeter(),0.01 ); - Assert.assertEquals(0.5, medium2.getCostInformation().getCostsPerSecond(),0.01 ); + Assertions.assertEquals(50.0, medium2.getCostInformation().getFixedCosts(),0.01 ); + Assertions.assertEquals(1.0, medium2.getCostInformation().getCostsPerMeter(),0.01 ); + Assertions.assertEquals(0.5, medium2.getCostInformation().getCostsPerSecond(),0.01 ); } @Test void test_whenCopyingTypeMedium_itCopiesEngineInfoCorrectly(){ VehicleType medium2 = types.getVehicleTypes().get(Id.create("medium2", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(0.02, medium2.getEngineInformation().getFuelConsumption(),0.001); - Assert.assertEquals(FuelType.diesel, medium2.getEngineInformation().getFuelType()); + Assertions.assertEquals(0.02, medium2.getEngineInformation().getFuelConsumption(),0.001); + Assertions.assertEquals(FuelType.diesel, medium2.getEngineInformation().getFuelType()); } @Test void test_whenCopyingTypeMedium_itCopiesMaxVelocityCorrectly(){ VehicleType medium2 = types.getVehicleTypes().get(Id.create("medium2", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(13.89, medium2.getMaximumVelocity(), 0.01); + Assertions.assertEquals(13.89, medium2.getMaximumVelocity(), 0.01); } //Now testing the modified type. @Test void test_whenModifyingTypeSmall_itModifiesDescriptionCorrectly(){ VehicleType small = types.getVehicleTypes().get(Id.create("small", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals("Small Vehicle", small.getDescription()); + Assertions.assertEquals("Small Vehicle", small.getDescription()); } @Test void test_whenModifyingTypeSmall_itModifiesCapacityCorrectly(){ VehicleType small = types.getVehicleTypes().get(Id.create("small", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(16., small.getCapacity().getWeightInTons(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(16., small.getCapacity().getWeightInTons(), MatsimTestUtils.EPSILON ); } @Test void test_whenModifyingTypeSmall_itModifiesCostInfoCorrectly(){ VehicleType small = types.getVehicleTypes().get(Id.create("small", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(25.0, small.getCostInformation().getFixedCosts(),0.01 ); - Assert.assertEquals(0.75, small.getCostInformation().getCostsPerMeter(),0.01 ); - Assert.assertEquals(0.25, small.getCostInformation().getCostsPerSecond(),0.01 ); + Assertions.assertEquals(25.0, small.getCostInformation().getFixedCosts(),0.01 ); + Assertions.assertEquals(0.75, small.getCostInformation().getCostsPerMeter(),0.01 ); + Assertions.assertEquals(0.25, small.getCostInformation().getCostsPerSecond(),0.01 ); } @Test void test_whenModifyingTypeSmall_itModifiesEngineInfoCorrectly(){ VehicleType small = types.getVehicleTypes().get(Id.create("small", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(0.015, small.getEngineInformation().getFuelConsumption(),0.001); - Assert.assertEquals(FuelType.gasoline, small.getEngineInformation().getFuelType()); + Assertions.assertEquals(0.015, small.getEngineInformation().getFuelConsumption(),0.001); + Assertions.assertEquals(FuelType.gasoline, small.getEngineInformation().getFuelType()); } @Test void test_whenModifyingTypeSmall_itModifiesMaxVelocityCorrectly(){ VehicleType small = types.getVehicleTypes().get(Id.create("small", org.matsim.vehicles.VehicleType.class ) ); - Assert.assertEquals(10.0, small.getMaximumVelocity(), 0.01); + Assertions.assertEquals(10.0, small.getMaximumVelocity(), 0.01); } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java index a70e13239eb..b57f9d7b884 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarriersUtilsTest.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -48,16 +48,16 @@ void testAddAndGetVehicleToCarrier() { //add Vehicle CarriersUtils.addCarrierVehicle(carrier, carrierVehicle); - Assert.assertEquals(1, carrier.getCarrierCapabilities().getCarrierVehicles().size()); + Assertions.assertEquals(1, carrier.getCarrierCapabilities().getCarrierVehicles().size()); CarrierVehicle cv = (CarrierVehicle) carrier.getCarrierCapabilities().getCarrierVehicles().values().toArray()[0]; - Assert.assertEquals(VehicleUtils.getDefaultVehicleType(), cv.getType()); - Assert.assertEquals(Id.createLinkId("link0"), cv.getLinkId() ); + Assertions.assertEquals(VehicleUtils.getDefaultVehicleType(), cv.getType()); + Assertions.assertEquals(Id.createLinkId("link0"), cv.getLinkId() ); //get Vehicle CarrierVehicle carrierVehicle1 = CarriersUtils.getCarrierVehicle(carrier, testVehicleId ); - Assert.assertEquals(testVehicleId, carrierVehicle1.getId()); - Assert.assertEquals(VehicleUtils.getDefaultVehicleType(), carrierVehicle1.getType()); - Assert.assertEquals(Id.createLinkId("link0"), carrierVehicle1.getLinkId() ); + Assertions.assertEquals(testVehicleId, carrierVehicle1.getId()); + Assertions.assertEquals(VehicleUtils.getDefaultVehicleType(), carrierVehicle1.getType()); + Assertions.assertEquals(Id.createLinkId("link0"), carrierVehicle1.getLinkId() ); } @Test @@ -69,17 +69,17 @@ void testAddAndGetServiceToCarrier() { //add Service CarriersUtils.addService(carrier, service1); - Assert.assertEquals(1, carrier.getServices().size()); + Assertions.assertEquals(1, carrier.getServices().size()); CarrierService cs1a = (CarrierService) carrier.getServices().values().toArray()[0]; - Assert.assertEquals(service1, cs1a); - Assert.assertEquals(Id.createLinkId("link0"), cs1a.getLocationLinkId()); + Assertions.assertEquals(service1, cs1a); + Assertions.assertEquals(Id.createLinkId("link0"), cs1a.getLocationLinkId()); //get Service CarrierService cs1b = CarriersUtils.getService(carrier, serviceId ); - Assert.assertEquals(serviceId, cs1b.getId()); - Assert.assertEquals(service1.getId(), cs1b.getId()); - Assert.assertEquals(Id.createLinkId("link0"), cs1b.getLocationLinkId()); - Assert.assertEquals(30, cs1b.getServiceDuration(), EPSILON); + Assertions.assertEquals(serviceId, cs1b.getId()); + Assertions.assertEquals(service1.getId(), cs1b.getId()); + Assertions.assertEquals(Id.createLinkId("link0"), cs1b.getLocationLinkId()); + Assertions.assertEquals(30, cs1b.getServiceDuration(), EPSILON); } @Test @@ -90,27 +90,27 @@ void testAddAndGetShipmentToCarrier() { //add Shipment CarriersUtils.addShipment(carrier, service1); - Assert.assertEquals(1, carrier.getShipments().size()); + Assertions.assertEquals(1, carrier.getShipments().size()); CarrierShipment carrierShipment1a = (CarrierShipment) carrier.getShipments().values().toArray()[0]; - Assert.assertEquals(service1, carrierShipment1a); - Assert.assertEquals(Id.createLinkId("link0"), carrierShipment1a.getFrom()); + Assertions.assertEquals(service1, carrierShipment1a); + Assertions.assertEquals(Id.createLinkId("link0"), carrierShipment1a.getFrom()); //get Shipment CarrierShipment carrierShipment1b = CarriersUtils.getShipment(carrier, shipmentId ); - Assert.assertEquals(shipmentId, carrierShipment1b.getId()); - Assert.assertEquals(service1.getId(), carrierShipment1b.getId()); - Assert.assertEquals(Id.createLinkId("link0"), carrierShipment1b.getFrom()); - Assert.assertEquals(20, carrierShipment1b.getSize(), EPSILON); + Assertions.assertEquals(shipmentId, carrierShipment1b.getId()); + Assertions.assertEquals(service1.getId(), carrierShipment1b.getId()); + Assertions.assertEquals(Id.createLinkId("link0"), carrierShipment1b.getFrom()); + Assertions.assertEquals(20, carrierShipment1b.getSize(), EPSILON); } @Test void testGetSetJspritIteration(){ Carrier carrier = new CarrierImpl(Id.create("carrier", Carrier.class)); //jspirtIterations is not set. should return Integer.Min_Value (null is not possible because returning (int) - Assert.assertEquals(Integer.MIN_VALUE, CarriersUtils.getJspritIterations(carrier) ); + Assertions.assertEquals(Integer.MIN_VALUE, CarriersUtils.getJspritIterations(carrier) ); CarriersUtils.setJspritIterations(carrier, 125); - Assert.assertEquals(125, CarriersUtils.getJspritIterations(carrier) ); + Assertions.assertEquals(125, CarriersUtils.getJspritIterations(carrier) ); } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/FreightCarriersConfigGroupTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/FreightCarriersConfigGroupTest.java index a56f1fce3aa..6113348707b 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/FreightCarriersConfigGroupTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/FreightCarriersConfigGroupTest.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigReader; @@ -43,11 +43,11 @@ void test_allParametersAreWrittenToXml() { FreightCarriersConfigGroup freight = new FreightCarriersConfigGroup(); Map params = freight.getParams(); - Assert.assertTrue(params.containsKey(FreightCarriersConfigGroup.CARRIERS_FILE)); - Assert.assertTrue(params.containsKey(FreightCarriersConfigGroup.CARRIERS_VEHICLE_TYPE)); - Assert.assertTrue(params.containsKey(FreightCarriersConfigGroup.VEHICLE_ROUTING_ALGORITHM)); - Assert.assertTrue(params.containsKey(FreightCarriersConfigGroup.TRAVEL_TIME_SLICE_WIDTH)); - Assert.assertTrue(params.containsKey(FreightCarriersConfigGroup.USE_DISTANCE_CONSTRAINT)); + Assertions.assertTrue(params.containsKey(FreightCarriersConfigGroup.CARRIERS_FILE)); + Assertions.assertTrue(params.containsKey(FreightCarriersConfigGroup.CARRIERS_VEHICLE_TYPE)); + Assertions.assertTrue(params.containsKey(FreightCarriersConfigGroup.VEHICLE_ROUTING_ALGORITHM)); + Assertions.assertTrue(params.containsKey(FreightCarriersConfigGroup.TRAVEL_TIME_SLICE_WIDTH)); + Assertions.assertTrue(params.containsKey(FreightCarriersConfigGroup.USE_DISTANCE_CONSTRAINT)); } @Test @@ -71,11 +71,11 @@ void test_configXmlCanBeParsed() { new ConfigReader(config).parse(is); - Assert.assertEquals("/path/to/carriers.xml", freight.getCarriersFile()); - Assert.assertEquals("/path/to/carriersVehicleTypes.xml", freight.getCarriersVehicleTypesFile()); - Assert.assertEquals("/path/to/carriersRoutingAlgorithm.xml", freight.getVehicleRoutingAlgorithmFile()); - Assert.assertEquals(3600.0, freight.getTravelTimeSliceWidth(), 1e-8); - Assert.assertEquals(UseDistanceConstraintForTourPlanning.basedOnEnergyConsumption, freight.getUseDistanceConstraintForTourPlanning()); + Assertions.assertEquals("/path/to/carriers.xml", freight.getCarriersFile()); + Assertions.assertEquals("/path/to/carriersVehicleTypes.xml", freight.getCarriersVehicleTypesFile()); + Assertions.assertEquals("/path/to/carriersRoutingAlgorithm.xml", freight.getVehicleRoutingAlgorithmFile()); + Assertions.assertEquals(3600.0, freight.getTravelTimeSliceWidth(), 1e-8); + Assertions.assertEquals(UseDistanceConstraintForTourPlanning.basedOnEnergyConsumption, freight.getUseDistanceConstraintForTourPlanning()); } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java index c073356e1f0..507326c6e2b 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java @@ -21,8 +21,8 @@ package org.matsim.freight.carriers.controler; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -98,10 +98,10 @@ public void install() { controler.run(); Carrier carrier1 = controler.getInjector().getInstance(Carriers.class).getCarriers().get(Id.create("carrier1", Carrier.class)); - Assert.assertEquals(-170000.0, carrier1.getSelectedPlan().getScore(), 0.0 ); + Assertions.assertEquals(-170000.0, carrier1.getSelectedPlan().getScore(), 0.0 ); Carrier carrier2 = controler.getInjector().getInstance(Carriers.class).getCarriers().get(Id.create("carrier2", Carrier.class)); - Assert.assertEquals(-85000.0, carrier2.getSelectedPlan().getScore(), 0.0 ); + Assertions.assertEquals(-85000.0, carrier2.getSelectedPlan().getScore(), 0.0 ); } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java index e82e956b9da..83f1dd9e021 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithoutPersonsIT.java @@ -23,7 +23,7 @@ import static org.junit.jupiter.api.Assertions.assertThrows; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -115,10 +115,10 @@ public void install() { controler.run(); Carrier carrier1 = CarriersUtils.getCarriers(controler.getScenario()).getCarriers().get(Id.create("carrier1", Carrier.class)); - Assert.assertEquals(-170000.0, carrier1.getSelectedPlan().getScore(), 0.0 ); + Assertions.assertEquals(-170000.0, carrier1.getSelectedPlan().getScore(), 0.0 ); Carrier carrier2 = CarriersUtils.getCarriers(controler.getScenario()).getCarriers().get(Id.create("carrier2", Carrier.class)); - Assert.assertEquals(-85000.0, carrier2.getSelectedPlan().getScore(), 0.0 ); + Assertions.assertEquals(-85000.0, carrier2.getSelectedPlan().getScore(), 0.0 ); } @Test @@ -141,10 +141,10 @@ public void install() { controler.run(); Carrier carrier1 = CarriersUtils.getCarriers(controler.getScenario()).getCarriers().get(Id.create("carrier1", Carrier.class)); - Assert.assertEquals(-240.0, carrier1.getSelectedPlan().getScore(), 2.0); + Assertions.assertEquals(-240.0, carrier1.getSelectedPlan().getScore(), 2.0); Carrier carrier2 = CarriersUtils.getCarriers(controler.getScenario()).getCarriers().get(Id.create("carrier2", Carrier.class)); - Assert.assertEquals(0.0, carrier2.getSelectedPlan().getScore(), 0.0 ); + Assertions.assertEquals(0.0, carrier2.getSelectedPlan().getScore(), 0.0 ); } @@ -169,10 +169,10 @@ public void install() { controler.run(); Carrier carrier1 = CarriersUtils.getCarriers(controler.getScenario()).getCarriers().get(Id.create("carrier1", Carrier.class)); - Assert.assertEquals(-4873.0, carrier1.getSelectedPlan().getScore(), 2.0); + Assertions.assertEquals(-4873.0, carrier1.getSelectedPlan().getScore(), 2.0); Carrier carrier2 = CarriersUtils.getCarriers(controler.getScenario()).getCarriers().get(Id.create("carrier2", Carrier.class)); - Assert.assertEquals(0.0, carrier2.getSelectedPlan().getScore(), 0.0 ); + Assertions.assertEquals(0.0, carrier2.getSelectedPlan().getScore(), 0.0 ); } @@ -197,7 +197,7 @@ public void install() { controler.run(); Carrier carrier1 = CarriersUtils.getCarriers(controler.getScenario()).getCarriers().get(Id.create("carrier1", Carrier.class)); - Assert.assertEquals(-4871.0, carrier1.getSelectedPlan().getScore(), 2.0); + Assertions.assertEquals(-4871.0, carrier1.getSelectedPlan().getScore(), 2.0); } @Test diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java index 7879f26e03d..d7329adc924 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintFromVehiclesFileTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -111,23 +111,26 @@ final void CarrierSmallBatteryTest_Version1() throws ExecutionException, Interru CarriersUtils.runJsprit(scenario); - Assert.assertEquals("Not the correct amout of scheduled tours", 1, - carrierV1.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(1, + carrierV1.getSelectedPlan().getScheduledTours().size(), + "Not the correct amout of scheduled tours"); VehicleType vehicleType_SmallV1 = vehicleTypes.getVehicleTypes().get(Id.create("SmallBattery_V1", VehicleType.class)); VehicleType vehicleType_LargeV1 = vehicleTypes.getVehicleTypes().get(Id.create("LargeBattery_V1", VehicleType.class)); - Assert.assertEquals(vehicleType_SmallV1.getId(), ((Vehicle) carrierV1.getSelectedPlan().getScheduledTours().iterator().next() + Assertions.assertEquals(vehicleType_SmallV1.getId(), ((Vehicle) carrierV1.getSelectedPlan().getScheduledTours().iterator().next() .getVehicle()).getType().getId()); double maxDistance_vehicleType_LargeV1 = VehicleUtils.getEnergyCapacity(vehicleType_LargeV1.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_LargeV1.getEngineInformation()); double maxDistance_vehicleType_SmallV1 = VehicleUtils.getEnergyCapacity(vehicleType_SmallV1.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_SmallV1.getEngineInformation()); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_LargeV1, - MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_SmallV1, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_LargeV1, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); + Assertions.assertEquals(30000, maxDistance_vehicleType_SmallV1, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); double distanceTour = 0.0; List elements = carrierV1.getSelectedPlan().getScheduledTours().iterator().next().getTour() @@ -140,8 +143,9 @@ final void CarrierSmallBatteryTest_Version1() throws ExecutionException, Interru scenario.getNetwork()); } } - Assert.assertEquals("The schedulded tour has a non expected distance", 24000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(24000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); } /** @@ -185,23 +189,26 @@ final void CarrierLargeBatteryTest_Version2() throws ExecutionException, Interru CarriersUtils.runJsprit(scenario); - Assert.assertEquals("Not the correct amout of scheduled tours", 1, - carrierV2.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(1, + carrierV2.getSelectedPlan().getScheduledTours().size(), + "Not the correct amout of scheduled tours"); VehicleType vehicleType_SmallV2 = vehicleTypes.getVehicleTypes().get(Id.create("SmallBattery_V2", VehicleType.class)); VehicleType vehicleType_LargeV2 = vehicleTypes.getVehicleTypes().get(Id.create("LargeBattery_V2", VehicleType.class)); - Assert.assertEquals(vehicleType_LargeV2.getId(), carrierV2.getSelectedPlan().getScheduledTours().iterator().next() + Assertions.assertEquals(vehicleType_LargeV2.getId(), carrierV2.getSelectedPlan().getScheduledTours().iterator().next() .getVehicle().getType().getId()); double maxDistance_vehicleType_LargeV2 = VehicleUtils.getEnergyCapacity(vehicleType_LargeV2.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_LargeV2.getEngineInformation()); double maxDistance_vehicleType_SmallV2 = VehicleUtils.getEnergyCapacity(vehicleType_SmallV2.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_SmallV2.getEngineInformation()); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_LargeV2, - MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 15000, maxDistance_vehicleType_SmallV2, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_LargeV2, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); + Assertions.assertEquals(15000, maxDistance_vehicleType_SmallV2, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); double distanceTour = 0.0; List elements = carrierV2.getSelectedPlan().getScheduledTours().iterator().next().getTour() @@ -214,8 +221,9 @@ final void CarrierLargeBatteryTest_Version2() throws ExecutionException, Interru scenario.getNetwork()); } } - Assert.assertEquals("The schedulded tour has a non expected distance", 24000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(24000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); } @@ -259,8 +267,9 @@ final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, Interr CarriersUtils.runJsprit(scenario); - Assert.assertEquals("Not the correct amout of scheduled tours", 2, - carrierV3.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(2, + carrierV3.getSelectedPlan().getScheduledTours().size(), + "Not the correct amout of scheduled tours"); VehicleType vehicleType_SmallV3 = vehicleTypes.getVehicleTypes().get(Id.create("SmallBattery_V3", VehicleType.class)); VehicleType vehicleType_LargeV3 = vehicleTypes.getVehicleTypes().get(Id.create("LargeBattery_V3", VehicleType.class)); @@ -270,11 +279,13 @@ final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, Interr double maxDistance_vehicleType_SmallV3 = VehicleUtils.getEnergyCapacity(vehicleType_SmallV3.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_SmallV3.getEngineInformation()); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_LargeV3, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_LargeV3, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_SmallV3, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_SmallV3, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); for (ScheduledTour scheduledTour : carrierV3.getSelectedPlan().getScheduledTours()) { @@ -289,13 +300,15 @@ final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, Interr 0, scenario.getNetwork()); } } - Assert.assertEquals(vehicleType_SmallV3.getId(), scheduledTour.getVehicle().getType().getId()); + Assertions.assertEquals(vehicleType_SmallV3.getId(), scheduledTour.getVehicle().getType().getId()); if (distanceTour == 12000) - Assert.assertEquals("The schedulded tour has a non expected distance", 12000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(12000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); else - Assert.assertEquals("The schedulded tour has a non expected distance", 20000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(20000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); } } @@ -341,8 +354,9 @@ final void CarrierWithAdditionalDieselVehicleTest_Version4() throws ExecutionExc CarriersUtils.runJsprit(scenario); - Assert.assertEquals("Not the correct amount of scheduled tours", 2, - carrierV4.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(2, + carrierV4.getSelectedPlan().getScheduledTours().size(), + "Not the correct amount of scheduled tours"); VehicleType vehicleType_SmallV4 = vehicleTypes.getVehicleTypes().get(Id.create("SmallBattery_V4", VehicleType.class)); VehicleType vehicleType_LargeV4 = vehicleTypes.getVehicleTypes().get(Id.create("LargeBattery_V4", VehicleType.class)); @@ -352,11 +366,13 @@ final void CarrierWithAdditionalDieselVehicleTest_Version4() throws ExecutionExc double maxDistance_vehicleType_SmallV4 = VehicleUtils.getEnergyCapacity(vehicleType_SmallV4.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_SmallV4.getEngineInformation()); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_Large4, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_Large4, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_SmallV4, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_SmallV4, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); for (ScheduledTour scheduledTour : carrierV4.getSelectedPlan().getScheduledTours()) { @@ -372,13 +388,15 @@ final void CarrierWithAdditionalDieselVehicleTest_Version4() throws ExecutionExc } } if (thisTypeId.equals("SmallBattery_V4")) - Assert.assertEquals("The schedulded tour has a non expected distance", 24000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(24000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); else if (thisTypeId.equals("DieselVehicle")) - Assert.assertEquals("The schedulded tour has a non expected distance", 36000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(36000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); else - Assert.fail("Wrong vehicleType used"); + Assertions.fail("Wrong vehicleType used"); } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java index f84e547bb14..16c42c7286c 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/DistanceConstraintTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -121,20 +121,23 @@ final void CarrierSmallBatteryTest_Version1() throws ExecutionException, Interru CarriersUtils.runJsprit(scenario); - Assert.assertEquals("Not the correct amout of scheduled tours", 1, - carrierV1.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(1, + carrierV1.getSelectedPlan().getScheduledTours().size(), + "Not the correct amout of scheduled tours"); - Assert.assertEquals(vehicleType_SmallV1.getId(), ((Vehicle) carrierV1.getSelectedPlan().getScheduledTours().iterator().next() + Assertions.assertEquals(vehicleType_SmallV1.getId(), ((Vehicle) carrierV1.getSelectedPlan().getScheduledTours().iterator().next() .getVehicle()).getType().getId()); double maxDistance_vehicleType_LargeV1 = VehicleUtils.getEnergyCapacity(vehicleType_LargeV1.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_LargeV1.getEngineInformation()); double maxDistance_vehicleType_SmallV1 = VehicleUtils.getEnergyCapacity(vehicleType_SmallV1.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_SmallV1.getEngineInformation()); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_LargeV1, - MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_SmallV1, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_LargeV1, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); + Assertions.assertEquals(30000, maxDistance_vehicleType_SmallV1, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); double distanceTour = 0.0; List elements = carrierV1.getSelectedPlan().getScheduledTours().iterator().next().getTour() @@ -147,8 +150,9 @@ final void CarrierSmallBatteryTest_Version1() throws ExecutionException, Interru scenario.getNetwork()); } } - Assert.assertEquals("The schedulded tour has a non expected distance", 24000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(24000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); } /** @@ -201,20 +205,23 @@ final void CarrierLargeBatteryTest_Version2() throws ExecutionException, Interru CarriersUtils.runJsprit(scenario); - Assert.assertEquals("Not the correct amout of scheduled tours", 1, - carrierV2.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(1, + carrierV2.getSelectedPlan().getScheduledTours().size(), + "Not the correct amout of scheduled tours"); - Assert.assertEquals(vehicleType_LargeV2.getId(), carrierV2.getSelectedPlan().getScheduledTours().iterator().next() + Assertions.assertEquals(vehicleType_LargeV2.getId(), carrierV2.getSelectedPlan().getScheduledTours().iterator().next() .getVehicle().getType().getId()); double maxDistance_vehicleType_LargeV2 = VehicleUtils.getEnergyCapacity(vehicleType_LargeV2.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_LargeV2.getEngineInformation()); double maxDistance_vehicleType_SmallV2 = VehicleUtils.getEnergyCapacity(vehicleType_SmallV2.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_SmallV2.getEngineInformation()); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_LargeV2, - MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 15000, maxDistance_vehicleType_SmallV2, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_LargeV2, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); + Assertions.assertEquals(15000, maxDistance_vehicleType_SmallV2, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); double distanceTour = 0.0; List elements = carrierV2.getSelectedPlan().getScheduledTours().iterator().next().getTour() @@ -227,8 +234,9 @@ final void CarrierLargeBatteryTest_Version2() throws ExecutionException, Interru scenario.getNetwork()); } } - Assert.assertEquals("The schedulded tour has a non expected distance", 24000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(24000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); } @@ -284,19 +292,22 @@ final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, Interr CarriersUtils.runJsprit(scenario); - Assert.assertEquals("Not the correct amout of scheduled tours", 2, - carrierV3.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(2, + carrierV3.getSelectedPlan().getScheduledTours().size(), + "Not the correct amout of scheduled tours"); double maxDistance_vehicleType_LargeV3 = VehicleUtils.getEnergyCapacity(vehicleType_LargeV3.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_LargeV3.getEngineInformation()); double maxDistance_vehicleType_SmallV3 = VehicleUtils.getEnergyCapacity(vehicleType_SmallV3.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_SmallV3.getEngineInformation()); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_LargeV3, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_LargeV3, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_SmallV3, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_SmallV3, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); for (ScheduledTour scheduledTour : carrierV3.getSelectedPlan().getScheduledTours()) { @@ -311,13 +322,15 @@ final void Carrier2SmallBatteryTest_Version3() throws ExecutionException, Interr 0, scenario.getNetwork()); } } - Assert.assertEquals(vehicleType_SmallV3.getId(), scheduledTour.getVehicle().getType().getId()); + Assertions.assertEquals(vehicleType_SmallV3.getId(), scheduledTour.getVehicle().getType().getId()); if (distanceTour == 12000) - Assert.assertEquals("The schedulded tour has a non expected distance", 12000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(12000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); else - Assert.assertEquals("The schedulded tour has a non expected distance", 20000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(20000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); } } @@ -379,19 +392,22 @@ final void CarrierWithAdditionalDieselVehicleTest_Version4() throws ExecutionExc CarriersUtils.runJsprit(scenario); - Assert.assertEquals("Not the correct amout of scheduled tours", 2, - carrierV4.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(2, + carrierV4.getSelectedPlan().getScheduledTours().size(), + "Not the correct amout of scheduled tours"); double maxDistance_vehicleType_Large4 = VehicleUtils.getEnergyCapacity(vehicleType_LargeV4.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_LargeV4.getEngineInformation()); double maxDistance_vehicleType_SmallV4 = VehicleUtils.getEnergyCapacity(vehicleType_SmallV4.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_SmallV4.getEngineInformation()); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_Large4, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_Large4, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_SmallV4, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_SmallV4, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); for (ScheduledTour scheduledTour : carrierV4.getSelectedPlan().getScheduledTours()) { @@ -407,13 +423,15 @@ final void CarrierWithAdditionalDieselVehicleTest_Version4() throws ExecutionExc } } if (thisTypeId.equals("SmallBattery_V4")) - Assert.assertEquals("The schedulded tour has a non expected distance", 24000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(24000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); else if (thisTypeId.equals("DieselVehicle")) - Assert.assertEquals("The schedulded tour has a non expected distance", 36000, distanceTour, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(36000, distanceTour, + MatsimTestUtils.EPSILON, + "The schedulded tour has a non expected distance"); else - Assert.fail("Wrong vehicleType used"); + Assertions.fail("Wrong vehicleType used"); } } @@ -463,16 +481,18 @@ final void CarrierWithShipmentsMidSizeBatteryTest_Version5() throws ExecutionExc CarriersUtils.runJsprit(scenario); //We need two tours, due to reloading both shipments must be transported one after the other - Assert.assertEquals("Not the correct amout of scheduled tours", 2, - carrierV5.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(2, + carrierV5.getSelectedPlan().getScheduledTours().size(), + "Not the correct amout of scheduled tours"); - Assert.assertEquals(vehicleType_MidSizeV5.getId(), carrierV5.getSelectedPlan().getScheduledTours().iterator().next() + Assertions.assertEquals(vehicleType_MidSizeV5.getId(), carrierV5.getSelectedPlan().getScheduledTours().iterator().next() .getVehicle().getType().getId()); double maxDistance_vehicleType_LargeV5 = VehicleUtils.getEnergyCapacity(vehicleType_MidSizeV5.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_MidSizeV5.getEngineInformation()); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 20000, maxDistance_vehicleType_LargeV5, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(20000, maxDistance_vehicleType_LargeV5, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); ArrayList distancesOfTours = new ArrayList(); for (ScheduledTour scheduledTour: carrierV5.getSelectedPlan().getScheduledTours()) { @@ -489,11 +509,11 @@ final void CarrierWithShipmentsMidSizeBatteryTest_Version5() throws ExecutionExc distancesOfTours.add(distanceTour); } - Assert.assertEquals("There must be two entry for tour distances", 2, distancesOfTours.size()); + Assertions.assertEquals(2, distancesOfTours.size(), "There must be two entry for tour distances"); //One tour has distance of 12000m - Assert.assertTrue("The schedulded tour has a non expected distance", distancesOfTours.contains(12000.0)); + Assertions.assertTrue(distancesOfTours.contains(12000.0), "The schedulded tour has a non expected distance"); //The other tour has distance of 20000m - Assert.assertTrue("The schedulded tour has a non expected distance", distancesOfTours.contains(20000.0)); + Assertions.assertTrue(distancesOfTours.contains(20000.0), "The schedulded tour has a non expected distance"); } /** @@ -543,16 +563,18 @@ final void CarrierWithShipmentsLargeBatteryTest_Version6() throws ExecutionExcep //We need two tours, due to reloading both shipments must be transported one after the other - Assert.assertEquals("Not the correct amout of scheduled tours", 1, - carrierV5.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(1, + carrierV5.getSelectedPlan().getScheduledTours().size(), + "Not the correct amout of scheduled tours"); - Assert.assertEquals(vehicleType_LargeV5.getId(), carrierV5.getSelectedPlan().getScheduledTours().iterator().next() + Assertions.assertEquals(vehicleType_LargeV5.getId(), carrierV5.getSelectedPlan().getScheduledTours().iterator().next() .getVehicle().getType().getId()); double maxDistance_vehicleType_LargeV5 = VehicleUtils.getEnergyCapacity(vehicleType_LargeV5.getEngineInformation()) / VehicleUtils.getEnergyConsumptionKWhPerMeter(vehicleType_LargeV5.getEngineInformation()); - Assert.assertEquals("Wrong maximum distance of the tour of this vehicleType", 30000, maxDistance_vehicleType_LargeV5, - MatsimTestUtils.EPSILON); + Assertions.assertEquals(30000, maxDistance_vehicleType_LargeV5, + MatsimTestUtils.EPSILON, + "Wrong maximum distance of the tour of this vehicleType"); ArrayList distancesOfTours = new ArrayList(); for (ScheduledTour scheduledTour: carrierV5.getSelectedPlan().getScheduledTours()) { @@ -569,9 +591,9 @@ final void CarrierWithShipmentsLargeBatteryTest_Version6() throws ExecutionExcep distancesOfTours.add(distanceTour); } - Assert.assertEquals("There must be one entry for tour distances", 1, distancesOfTours.size()); + Assertions.assertEquals(1, distancesOfTours.size(), "There must be one entry for tour distances"); //This tour has distance of 24000m - Assert.assertTrue("The schedulded tour has a non expected distance", distancesOfTours.contains(24000.0)); + Assertions.assertTrue(distancesOfTours.contains(24000.0), "The schedulded tour has a non expected distance"); } /** diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java index a0001daba4b..d9aeaf17ef7 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java @@ -29,8 +29,8 @@ import com.graphhopper.jsprit.core.util.Solutions; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -188,7 +188,7 @@ public void setUp() throws Exception { @Test final void test_carrier1CostsAreCorrectly() { - Assert.assertEquals(-44, carriersPlannedAndRouted.getCarriers().get(Id.create("carrier1", Carrier.class)).getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-44, carriersPlannedAndRouted.getCarriers().get(Id.create("carrier1", Carrier.class)).getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); } /* @@ -196,7 +196,7 @@ final void test_carrier1CostsAreCorrectly() { */ @Test final void test_carrier2CostsAreCorrectly() { - Assert.assertEquals(-20.44, carriersPlannedAndRouted.getCarriers().get(Id.create("carrier2", Carrier.class)).getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-20.44, carriersPlannedAndRouted.getCarriers().get(Id.create("carrier2", Carrier.class)).getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); } /* @@ -205,7 +205,7 @@ final void test_carrier2CostsAreCorrectly() { */ @Test final void test_carrier3CostsAreCorrectly() { - Assert.assertEquals(-18.36, carriersPlannedAndRouted.getCarriers().get(Id.create("carrier3", Carrier.class)).getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-18.36, carriersPlannedAndRouted.getCarriers().get(Id.create("carrier3", Carrier.class)).getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); } private static CarrierService createMatsimService(String id, String to, int size) { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java index 5131d83904d..9aa5504cdf7 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/IntegrationIT.java @@ -27,7 +27,7 @@ import com.graphhopper.jsprit.core.problem.solution.VehicleRoutingProblemSolution; import com.graphhopper.jsprit.core.reporting.SolutionPrinter; import com.graphhopper.jsprit.core.util.Solutions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -77,7 +77,7 @@ void testJsprit() throws ExecutionException, InterruptedException { scoreWithRunJsprit = scoreWithRunJsprit + carrier.getSelectedPlan().getJspritScore(); } double scoreRunWithOldStructure = generateCarrierPlans(scenario.getNetwork(), CarriersUtils.getCarriers(scenario), CarriersUtils.getCarrierVehicleTypes(scenario)); - Assert.assertEquals("The score of both runs are not the same", scoreWithRunJsprit, scoreRunWithOldStructure, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scoreWithRunJsprit, scoreRunWithOldStructure, MatsimTestUtils.EPSILON, "The score of both runs are not the same"); } private static double generateCarrierPlans(Network network, Carriers carriers, CarrierVehicleTypes vehicleTypes) { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java index ec82034c573..a3e187a4fe2 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java @@ -50,7 +50,7 @@ import static org.hamcrest.CoreMatchers.is; import static org.hamcrest.CoreMatchers.not; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class MatsimTransformerTest { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java index b1c1e3a83f5..ccdb7095162 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/NetworkBasedTransportCostsTest.java @@ -24,7 +24,7 @@ import com.graphhopper.jsprit.core.problem.Location; import com.graphhopper.jsprit.core.problem.driver.Driver; import com.graphhopper.jsprit.core.problem.vehicle.Vehicle; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -78,10 +78,10 @@ void test_whenAddingTwoDifferentVehicleTypes_itMustAccountForThem(){ when(vehicle2.getType()).thenReturn(type2); when(vehicle2.getId()).thenReturn("vehicle2"); - Assert.assertEquals(20000.0, c.getTransportCost(Location.newInstance("20"), Location.newInstance("21"), 0.0, mock(Driver.class), vehicle1), 0.01); - Assert.assertEquals(40000.0, c.getTransportCost(Location.newInstance("20"), Location.newInstance("21"), 0.0, mock(Driver.class), vehicle2), 0.01); - Assert.assertEquals(20000.0, c.getDistance(Location.newInstance("6"), Location.newInstance("21"), 0.0, vehicle1), 0.01); - Assert.assertEquals(20000.0, c.getDistance(Location.newInstance("6"), Location.newInstance("21"), 0.0, vehicle2), 0.01); + Assertions.assertEquals(20000.0, c.getTransportCost(Location.newInstance("20"), Location.newInstance("21"), 0.0, mock(Driver.class), vehicle1), 0.01); + Assertions.assertEquals(40000.0, c.getTransportCost(Location.newInstance("20"), Location.newInstance("21"), 0.0, mock(Driver.class), vehicle2), 0.01); + Assertions.assertEquals(20000.0, c.getDistance(Location.newInstance("6"), Location.newInstance("21"), 0.0, vehicle1), 0.01); + Assertions.assertEquals(20000.0, c.getDistance(Location.newInstance("6"), Location.newInstance("21"), 0.0, vehicle2), 0.01); } @Test @@ -108,7 +108,7 @@ void test_whenVehicleTypeNotKnow_throwException(){ try{ c.getTransportCost(Location.newInstance("20"), Location.newInstance("21"), 0.0, mock(Driver.class), vehicle2); } - catch(IllegalStateException e){ Assert.assertTrue(true); } + catch(IllegalStateException e){ Assertions.assertTrue(true); } } @@ -153,10 +153,10 @@ void test_whenAddingTwoVehicleTypesViaConstructor_itMustAccountForThat(){ when(vehicle2.getType()).thenReturn(type2); when(vehicle2.getId()).thenReturn("vehicle2"); - Assert.assertEquals(20000.0, networkBasedTransportCosts.getTransportCost(Location.newInstance("20"), Location.newInstance("21"), 0.0, mock(Driver.class), vehicle1), 0.01); - Assert.assertEquals(40000.0, networkBasedTransportCosts.getTransportCost(Location.newInstance("20"), Location.newInstance("21"), 0.0, mock(Driver.class), vehicle2), 0.01); - Assert.assertEquals(20000.0, networkBasedTransportCosts.getDistance(Location.newInstance("6"), Location.newInstance("21"), 0.0, vehicle1), 0.01); - Assert.assertEquals(20000.0, networkBasedTransportCosts.getDistance(Location.newInstance("6"), Location.newInstance("21"), 0.0, vehicle2), 0.01); + Assertions.assertEquals(20000.0, networkBasedTransportCosts.getTransportCost(Location.newInstance("20"), Location.newInstance("21"), 0.0, mock(Driver.class), vehicle1), 0.01); + Assertions.assertEquals(40000.0, networkBasedTransportCosts.getTransportCost(Location.newInstance("20"), Location.newInstance("21"), 0.0, mock(Driver.class), vehicle2), 0.01); + Assertions.assertEquals(20000.0, networkBasedTransportCosts.getDistance(Location.newInstance("6"), Location.newInstance("21"), 0.0, vehicle1), 0.01); + Assertions.assertEquals(20000.0, networkBasedTransportCosts.getDistance(Location.newInstance("6"), Location.newInstance("21"), 0.0, vehicle2), 0.01); } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java index ed4ab348dd4..ad24848b155 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/SkillsIT.java @@ -26,7 +26,7 @@ import com.graphhopper.jsprit.core.problem.solution.VehicleRoutingProblemSolution; import com.graphhopper.jsprit.core.reporting.SolutionPrinter; import com.graphhopper.jsprit.core.util.Solutions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -55,10 +55,10 @@ void testJspritWithDifferentSkillsRequired() { solutionWithDifferentSkills = generateCarrierPlans(scenario); } catch (Exception e) { e.printStackTrace(); - Assert.fail("Should run integration test without exception."); + Assertions.fail("Should run integration test without exception."); } - Assert.assertEquals("Wrong number of vehicles.", 2L, solutionWithDifferentSkills.getRoutes().size()); - Assert.assertEquals("Wrong carrier score.", 2086.9971014492755, solutionWithDifferentSkills.getCost(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2L, solutionWithDifferentSkills.getRoutes().size(), "Wrong number of vehicles."); + Assertions.assertEquals(2086.9971014492755, solutionWithDifferentSkills.getCost(), MatsimTestUtils.EPSILON, "Wrong carrier score."); } @Test @@ -71,10 +71,10 @@ void testJspritWithSameSkillsRequired(){ solutionWithSameSkills = generateCarrierPlans(scenario); } catch (Exception e) { e.printStackTrace(); - Assert.fail("Should run integration test without exception."); + Assertions.fail("Should run integration test without exception."); } - Assert.assertEquals("Wrong number of vehicles.", 1L, solutionWithSameSkills.getRoutes().size()); - Assert.assertEquals("Wrong carrier score.", 1044.0985507246377, solutionWithSameSkills.getCost(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1L, solutionWithSameSkills.getRoutes().size(), "Wrong number of vehicles."); + Assertions.assertEquals(1044.0985507246377, solutionWithSameSkills.getCost(), MatsimTestUtils.EPSILON, "Wrong carrier score."); } private VehicleRoutingProblemSolution generateCarrierPlans(Scenario scenario) { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java index f93f457f58e..ced181d3172 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunChessboardIT.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers.usecases.chessboard; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.population.Population; @@ -55,17 +55,17 @@ void runChessboard() { PopulationUtils.readPopulation( actual, utils.getOutputDirectory() + "/output_plans.xml.gz" ); PopulationComparison.Result result = new PopulationComparison().compare(expected, actual); - Assert.assertSame(PopulationComparison.Result.equal, result); + Assertions.assertSame(PopulationComparison.Result.equal, result); } { String expected = utils.getInputDirectory() + "/output_events.xml.gz" ; String actual = utils.getOutputDirectory() + "/output_events.xml.gz" ; EventsFileComparator.Result result = EventsUtils.compareEventsFiles( expected, actual ); - Assert.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result ); + Assertions.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result ); } } catch (Exception ee ) { ee.printStackTrace(); - Assert.fail("something went wrong"); + Assertions.fail("something went wrong"); } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java index 82e0f4a99e6..bcb56fdaf35 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/usecases/chessboard/RunPassengerAlongWithCarriersIT.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers.usecases.chessboard; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.config.Config; @@ -44,7 +44,7 @@ void runChessboard() { abc.run(); } catch (Exception ee ) { ee.printStackTrace(); - Assert.fail("something went wrong: " + ee.getMessage()); + Assertions.fail("something went wrong: " + ee.getMessage()); } } diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java index 1c19c0cde0d..3cdf13513c1 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java @@ -26,8 +26,8 @@ import com.graphhopper.jsprit.core.problem.VehicleRoutingProblem; import com.graphhopper.jsprit.core.problem.solution.VehicleRoutingProblemSolution; import com.graphhopper.jsprit.core.util.Solutions; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -179,10 +179,10 @@ public void setUp() { @Test void numberOfToursIsCorrect() { - Assert.assertEquals(2, carrierWServices.getSelectedPlan().getScheduledTours().size()); - Assert.assertEquals(1, carrierWShipments.getSelectedPlan().getScheduledTours().size()); - Assert.assertEquals(1, carrierWShipmentsOnlyFromCarrierWServices.getSelectedPlan().getScheduledTours().size()); - Assert.assertEquals(1, carrierWShipmentsOnlyFromCarrierWShipments.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(2, carrierWServices.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(1, carrierWShipments.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(1, carrierWShipmentsOnlyFromCarrierWServices.getSelectedPlan().getScheduledTours().size()); + Assertions.assertEquals(1, carrierWShipmentsOnlyFromCarrierWShipments.getSelectedPlan().getScheduledTours().size()); } @@ -191,7 +191,7 @@ void numberOfToursIsCorrect() { */ @Test void toursInitialCarrierWServicesIsCorrect() { - Assert.assertEquals(-270.462, carrierWServices.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 + Assertions.assertEquals(-270.462, carrierWServices.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 // double tourDurationSum = 0; // for (ScheduledTour scheduledTour: carrierWServices.getSelectedPlan().getScheduledTours()){ // tourDurationSum += scheduledTour.getTour().getEnd().getExpectedArrival() - scheduledTour.getDeparture(); @@ -213,7 +213,7 @@ void toursInitialCarrierWServicesIsCorrect() { */ @Test void toursInitialCarrierWShipmentsIsCorrect() { - Assert.assertEquals(-136.87, carrierWShipments.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 + Assertions.assertEquals(-136.87, carrierWShipments.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 // double tourDurationSum = 0; // for (ScheduledTour scheduledTour: carrierWShipments.getSelectedPlan().getScheduledTours()){ @@ -237,7 +237,7 @@ void toursInitialCarrierWShipmentsIsCorrect() { */ @Test void toursCarrierWShipmentsOnlyFromCarrierWServicesIsCorrect() { - Assert.assertEquals(-140.462, carrierWShipmentsOnlyFromCarrierWServices.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 + Assertions.assertEquals(-140.462, carrierWShipmentsOnlyFromCarrierWServices.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 // double tourDurationSum = 0; // for (ScheduledTour scheduledTour: carrierWShipmentsOnlyFromCarrierWServices.getSelectedPlan().getScheduledTours()){ @@ -263,7 +263,7 @@ void toursCarrierWShipmentsOnlyFromCarrierWServicesIsCorrect() { */ @Test void toursCarrierWShipmentsOnlyFromCarrierWShipmentsIsCorrect() { - Assert.assertEquals(-136.87, carrierWShipmentsOnlyFromCarrierWShipments.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 + Assertions.assertEquals(-136.87, carrierWShipmentsOnlyFromCarrierWShipments.getSelectedPlan().getJspritScore(), MatsimTestUtils.EPSILON); //Note: In score waiting and serviceDurationTime are not includes by now -> May fail, when fixed. KMT Okt/18 // double tourDurationSum = 0; // for (ScheduledTour scheduledTour: carrierWShipmentsOnlyFromCarrierWShipments.getSelectedPlan().getScheduledTours()){ diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java index 7465db5d3d8..143a2a45a6b 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java @@ -30,7 +30,6 @@ import com.graphhopper.jsprit.core.util.Solutions; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Before; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -169,78 +168,78 @@ public void setUp() { //Should only have Services @Test void numberOfInitalServicesIsCorrect() { - Assert.assertEquals(2, carrierWServices.getServices().size()); + Assertions.assertEquals(2, carrierWServices.getServices().size()); int demandServices = 0; for (CarrierService carrierService : carrierWServices.getServices().values()) { demandServices += carrierService.getCapacityDemand(); } - Assert.assertEquals(4, demandServices); + Assertions.assertEquals(4, demandServices); - Assert.assertEquals(0, carrierWServices.getShipments().size()); + Assertions.assertEquals(0, carrierWServices.getShipments().size()); } //Should only have Shipments @Test void numberOfInitialShipmentsIsCorrect() { - Assert.assertEquals(0, carrierWShipments.getServices().size()); + Assertions.assertEquals(0, carrierWShipments.getServices().size()); - Assert.assertEquals(2, carrierWShipments.getShipments().size()); + Assertions.assertEquals(2, carrierWShipments.getShipments().size()); int demandShipments = 0; for (CarrierShipment carrierShipment : carrierWShipments.getShipments().values()) { demandShipments += carrierShipment.getSize(); } - Assert.assertEquals(3, demandShipments); + Assertions.assertEquals(3, demandShipments); } @Test void numberOfShipmentsFromCopiedShipmentsIsCorrect() { - Assert.assertEquals(0, carrierWShipmentsOnlyFromCarrierWShipments.getServices().size()); + Assertions.assertEquals(0, carrierWShipmentsOnlyFromCarrierWShipments.getServices().size()); - Assert.assertEquals(2, carrierWShipmentsOnlyFromCarrierWShipments.getShipments().size()); + Assertions.assertEquals(2, carrierWShipmentsOnlyFromCarrierWShipments.getShipments().size()); int demandShipments = 0; for (CarrierShipment carrierShipment : carrierWShipmentsOnlyFromCarrierWServices.getShipments().values()) { demandShipments += carrierShipment.getSize(); } - Assert.assertEquals(4, demandShipments); + Assertions.assertEquals(4, demandShipments); } @Test void numberOfShipmentsFromConvertedServicesIsCorrect() { - Assert.assertEquals(0, carrierWShipmentsOnlyFromCarrierWServices.getServices().size()); + Assertions.assertEquals(0, carrierWShipmentsOnlyFromCarrierWServices.getServices().size()); - Assert.assertEquals(2, carrierWShipmentsOnlyFromCarrierWServices.getShipments().size()); + Assertions.assertEquals(2, carrierWShipmentsOnlyFromCarrierWServices.getShipments().size()); int demandShipments = 0; for (CarrierShipment carrierShipment : carrierWShipmentsOnlyFromCarrierWServices.getShipments().values()) { demandShipments += carrierShipment.getSize(); } - Assert.assertEquals(4, demandShipments); + Assertions.assertEquals(4, demandShipments); } @Test void fleetAvailableAfterConvertingIsCorrect() { - Assert.assertEquals(FleetSize.INFINITE, carrierWShipmentsOnlyFromCarrierWServices.getCarrierCapabilities().getFleetSize()); - Assert.assertEquals(1, carrierWShipmentsOnlyFromCarrierWServices.getCarrierCapabilities().getVehicleTypes().size()); + Assertions.assertEquals(FleetSize.INFINITE, carrierWShipmentsOnlyFromCarrierWServices.getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(1, carrierWShipmentsOnlyFromCarrierWServices.getCarrierCapabilities().getVehicleTypes().size()); for ( VehicleType carrierVehicleType : carrierWShipmentsOnlyFromCarrierWServices.getCarrierCapabilities().getVehicleTypes()){ - Assert.assertEquals(3., carrierVehicleType.getCapacity().getOther(), Double.MIN_VALUE ); - Assert.assertEquals(130, carrierVehicleType.getCostInformation().getFixedCosts(), 0.0 ); - Assert.assertEquals(0.0001, carrierVehicleType.getCostInformation().getCostsPerMeter(), 0.0 ); - Assert.assertEquals(0.001, carrierVehicleType.getCostInformation().getCostsPerSecond(), 0.0 ); - Assert.assertEquals(10, carrierVehicleType.getMaximumVelocity(), 0.0); - Assert.assertEquals("diesel", VehicleUtils.getHbefaTechnology(carrierVehicleType.getEngineInformation())); - Assert.assertEquals(0.015, VehicleUtils.getFuelConsumption(carrierVehicleType), 0.0); + Assertions.assertEquals(3., carrierVehicleType.getCapacity().getOther(), Double.MIN_VALUE ); + Assertions.assertEquals(130, carrierVehicleType.getCostInformation().getFixedCosts(), 0.0 ); + Assertions.assertEquals(0.0001, carrierVehicleType.getCostInformation().getCostsPerMeter(), 0.0 ); + Assertions.assertEquals(0.001, carrierVehicleType.getCostInformation().getCostsPerSecond(), 0.0 ); + Assertions.assertEquals(10, carrierVehicleType.getMaximumVelocity(), 0.0); + Assertions.assertEquals("diesel", VehicleUtils.getHbefaTechnology(carrierVehicleType.getEngineInformation())); + Assertions.assertEquals(0.015, VehicleUtils.getFuelConsumption(carrierVehicleType), 0.0); } - Assert.assertEquals(FleetSize.INFINITE, carrierWShipmentsOnlyFromCarrierWShipments.getCarrierCapabilities().getFleetSize()); - Assert.assertEquals(1, carrierWShipmentsOnlyFromCarrierWShipments.getCarrierCapabilities().getVehicleTypes().size()); + Assertions.assertEquals(FleetSize.INFINITE, carrierWShipmentsOnlyFromCarrierWShipments.getCarrierCapabilities().getFleetSize()); + Assertions.assertEquals(1, carrierWShipmentsOnlyFromCarrierWShipments.getCarrierCapabilities().getVehicleTypes().size()); for ( VehicleType carrierVehicleType : carrierWShipmentsOnlyFromCarrierWShipments.getCarrierCapabilities().getVehicleTypes()){ - Assert.assertEquals(3., carrierVehicleType.getCapacity().getOther(), Double.MIN_VALUE ); - Assert.assertEquals(130, carrierVehicleType.getCostInformation().getFixedCosts(), 0.0 ); - Assert.assertEquals(0.0001, carrierVehicleType.getCostInformation().getCostsPerMeter(), 0.0 ); - Assert.assertEquals(0.001, carrierVehicleType.getCostInformation().getCostsPerSecond(), 0.0 ); - Assert.assertEquals(10, carrierVehicleType.getMaximumVelocity(), 0.0); - Assert.assertEquals("diesel", VehicleUtils.getHbefaTechnology(carrierVehicleType.getEngineInformation())); - Assert.assertEquals(0.015, VehicleUtils.getFuelConsumption(carrierVehicleType), 0.0); } + Assertions.assertEquals(3., carrierVehicleType.getCapacity().getOther(), Double.MIN_VALUE ); + Assertions.assertEquals(130, carrierVehicleType.getCostInformation().getFixedCosts(), 0.0 ); + Assertions.assertEquals(0.0001, carrierVehicleType.getCostInformation().getCostsPerMeter(), 0.0 ); + Assertions.assertEquals(0.001, carrierVehicleType.getCostInformation().getCostsPerSecond(), 0.0 ); + Assertions.assertEquals(10, carrierVehicleType.getMaximumVelocity(), 0.0); + Assertions.assertEquals("diesel", VehicleUtils.getHbefaTechnology(carrierVehicleType.getEngineInformation())); + Assertions.assertEquals(0.015, VehicleUtils.getFuelConsumption(carrierVehicleType), 0.0); } } @Test @@ -252,33 +251,33 @@ void copiingOfShipmentsIsDoneCorrectly() { if (carrierShipment1.getId() == Id.create("shipment1", CarrierShipment.class)) { System.out.println("Found Shipment1"); foundShipment1 = true; - Assert.assertEquals(Id.createLinkId("i(1,0)"), carrierShipment1.getFrom()); - Assert.assertEquals(Id.createLinkId("i(7,6)R"), carrierShipment1.getTo()); - Assert.assertEquals(1, carrierShipment1.getSize()); - Assert.assertEquals(30.0, carrierShipment1.getDeliveryServiceTime(), 0); - Assert.assertEquals(3600.0, carrierShipment1.getDeliveryTimeWindow().getStart(), 0); - Assert.assertEquals(36000.0, carrierShipment1.getDeliveryTimeWindow().getEnd(), 0); - Assert.assertEquals(5.0, carrierShipment1.getPickupServiceTime(), 0); - Assert.assertEquals(0.0, carrierShipment1.getPickupTimeWindow().getStart(), 0); - Assert.assertEquals(7200.0, carrierShipment1.getPickupTimeWindow().getEnd(), 0); + Assertions.assertEquals(Id.createLinkId("i(1,0)"), carrierShipment1.getFrom()); + Assertions.assertEquals(Id.createLinkId("i(7,6)R"), carrierShipment1.getTo()); + Assertions.assertEquals(1, carrierShipment1.getSize()); + Assertions.assertEquals(30.0, carrierShipment1.getDeliveryServiceTime(), 0); + Assertions.assertEquals(3600.0, carrierShipment1.getDeliveryTimeWindow().getStart(), 0); + Assertions.assertEquals(36000.0, carrierShipment1.getDeliveryTimeWindow().getEnd(), 0); + Assertions.assertEquals(5.0, carrierShipment1.getPickupServiceTime(), 0); + Assertions.assertEquals(0.0, carrierShipment1.getPickupTimeWindow().getStart(), 0); + Assertions.assertEquals(7200.0, carrierShipment1.getPickupTimeWindow().getEnd(), 0); } CarrierShipment carrierShipment2 = CarriersUtils.getShipment(carrierWShipmentsOnlyFromCarrierWShipments, Id.create("shipment2", CarrierShipment.class)); assert carrierShipment2 != null; if (carrierShipment2.getId() == Id.create("shipment2", CarrierShipment.class)) { System.out.println("Found Shipment2"); foundShipment2 = true; - Assert.assertEquals(Id.createLinkId("i(3,0)"), carrierShipment2.getFrom()); - Assert.assertEquals(Id.createLinkId("i(3,7)"), carrierShipment2.getTo()); - Assert.assertEquals(2, carrierShipment2.getSize()); - Assert.assertEquals(30.0, carrierShipment2.getDeliveryServiceTime(), 0); - Assert.assertEquals(3600.0, carrierShipment2.getDeliveryTimeWindow().getStart(), 0); - Assert.assertEquals(36000.0, carrierShipment2.getDeliveryTimeWindow().getEnd(), 0); - Assert.assertEquals(5.0, carrierShipment2.getPickupServiceTime(), 0); - Assert.assertEquals(0.0, carrierShipment2.getPickupTimeWindow().getStart(), 0); - Assert.assertEquals(7200.0, carrierShipment2.getPickupTimeWindow().getEnd(), 0); + Assertions.assertEquals(Id.createLinkId("i(3,0)"), carrierShipment2.getFrom()); + Assertions.assertEquals(Id.createLinkId("i(3,7)"), carrierShipment2.getTo()); + Assertions.assertEquals(2, carrierShipment2.getSize()); + Assertions.assertEquals(30.0, carrierShipment2.getDeliveryServiceTime(), 0); + Assertions.assertEquals(3600.0, carrierShipment2.getDeliveryTimeWindow().getStart(), 0); + Assertions.assertEquals(36000.0, carrierShipment2.getDeliveryTimeWindow().getEnd(), 0); + Assertions.assertEquals(5.0, carrierShipment2.getPickupServiceTime(), 0); + Assertions.assertEquals(0.0, carrierShipment2.getPickupTimeWindow().getStart(), 0); + Assertions.assertEquals(7200.0, carrierShipment2.getPickupTimeWindow().getEnd(), 0); } - Assert.assertTrue("Not found Shipment1 after copiing", foundShipment1); - Assert.assertTrue("Not found Shipment2 after copiing", foundShipment2); + Assertions.assertTrue(foundShipment1, "Not found Shipment1 after copiing"); + Assertions.assertTrue(foundShipment2, "Not found Shipment2 after copiing"); } @@ -290,32 +289,32 @@ void convertionOfServicesIsDoneCorrectly() { assert carrierShipment1 != null; if (carrierShipment1.getId() == Id.create("Service1", CarrierShipment.class)) { foundSercice1 = true; - Assert.assertEquals(Id.createLinkId("i(6,0)"), carrierShipment1.getFrom()); - Assert.assertEquals(Id.createLinkId("i(3,9)"), carrierShipment1.getTo()); - Assert.assertEquals(2, carrierShipment1.getSize()); - Assert.assertEquals(31.0, carrierShipment1.getDeliveryServiceTime(), 0); - Assert.assertEquals(3601.0, carrierShipment1.getDeliveryTimeWindow().getStart(), 0); - Assert.assertEquals(36001.0, carrierShipment1.getDeliveryTimeWindow().getEnd(), 0); - Assert.assertEquals(0.0, carrierShipment1.getPickupServiceTime(), 0); - Assert.assertEquals(0.0, carrierShipment1.getPickupTimeWindow().getStart(), 0); - Assert.assertEquals(36001.0, carrierShipment1.getPickupTimeWindow().getEnd(), 0); + Assertions.assertEquals(Id.createLinkId("i(6,0)"), carrierShipment1.getFrom()); + Assertions.assertEquals(Id.createLinkId("i(3,9)"), carrierShipment1.getTo()); + Assertions.assertEquals(2, carrierShipment1.getSize()); + Assertions.assertEquals(31.0, carrierShipment1.getDeliveryServiceTime(), 0); + Assertions.assertEquals(3601.0, carrierShipment1.getDeliveryTimeWindow().getStart(), 0); + Assertions.assertEquals(36001.0, carrierShipment1.getDeliveryTimeWindow().getEnd(), 0); + Assertions.assertEquals(0.0, carrierShipment1.getPickupServiceTime(), 0); + Assertions.assertEquals(0.0, carrierShipment1.getPickupTimeWindow().getStart(), 0); + Assertions.assertEquals(36001.0, carrierShipment1.getPickupTimeWindow().getEnd(), 0); } CarrierShipment carrierShipment2 = CarriersUtils.getShipment(carrierWShipmentsOnlyFromCarrierWServices, Id.create("Service2", CarrierShipment.class)); assert carrierShipment2 != null; if (carrierShipment2.getId() == Id.create("Service2", CarrierShipment.class)) { foundService2 = true; - Assert.assertEquals(Id.createLinkId("i(6,0)"), carrierShipment2.getFrom()); - Assert.assertEquals(Id.createLinkId("i(4,9)"), carrierShipment2.getTo()); - Assert.assertEquals(2, carrierShipment2.getSize()); - Assert.assertEquals(31.0, carrierShipment2.getDeliveryServiceTime(), 0); - Assert.assertEquals(3601.0, carrierShipment2.getDeliveryTimeWindow().getStart(), 0); - Assert.assertEquals(36001.0, carrierShipment2.getDeliveryTimeWindow().getEnd(), 0); - Assert.assertEquals(0.0, carrierShipment2.getPickupServiceTime(), 0); - Assert.assertEquals(0.0, carrierShipment2.getPickupTimeWindow().getStart(), 0); - Assert.assertEquals(36001.0, carrierShipment2.getPickupTimeWindow().getEnd(), 0); + Assertions.assertEquals(Id.createLinkId("i(6,0)"), carrierShipment2.getFrom()); + Assertions.assertEquals(Id.createLinkId("i(4,9)"), carrierShipment2.getTo()); + Assertions.assertEquals(2, carrierShipment2.getSize()); + Assertions.assertEquals(31.0, carrierShipment2.getDeliveryServiceTime(), 0); + Assertions.assertEquals(3601.0, carrierShipment2.getDeliveryTimeWindow().getStart(), 0); + Assertions.assertEquals(36001.0, carrierShipment2.getDeliveryTimeWindow().getEnd(), 0); + Assertions.assertEquals(0.0, carrierShipment2.getPickupServiceTime(), 0); + Assertions.assertEquals(0.0, carrierShipment2.getPickupTimeWindow().getStart(), 0); + Assertions.assertEquals(36001.0, carrierShipment2.getPickupTimeWindow().getEnd(), 0); } - Assert.assertTrue("Not found converted Service1 after converting", foundSercice1); - Assert.assertTrue("Not found converted Service2 after converting", foundService2); + Assertions.assertTrue(foundSercice1, "Not found converted Service1 after converting"); + Assertions.assertTrue(foundService2, "Not found converted Service2 after converting"); } /*Note: This test can be removed / modified when jsprit works properly with a combined Service and Shipment VRP. @@ -370,15 +369,15 @@ private static CarrierService createMatsimService(String id, String to, int size void testAddVehicleTypeSkill(){ VehiclesFactory factory = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getVehicles().getFactory(); VehicleType type = factory.createVehicleType(Id.create("test", VehicleType.class)); - Assert.assertFalse("Should not have skill.", CarriersUtils.hasSkill(type, "testSkill")); + Assertions.assertFalse(CarriersUtils.hasSkill(type, "testSkill"), "Should not have skill."); CarriersUtils.addSkill(type, "testSkillOne"); - Assert.assertTrue("Should have skill 'testSkillOne'.", CarriersUtils.hasSkill(type, "testSkillOne")); + Assertions.assertTrue(CarriersUtils.hasSkill(type, "testSkillOne"), "Should have skill 'testSkillOne'."); CarriersUtils.addSkill(type, "testSkillTwo"); - Assert.assertTrue("Should have skill 'testSkillOne'.", CarriersUtils.hasSkill(type, "testSkillOne")); - Assert.assertTrue("Should have skill 'testSkillTwo'.", CarriersUtils.hasSkill(type, "testSkillTwo")); + Assertions.assertTrue(CarriersUtils.hasSkill(type, "testSkillOne"), "Should have skill 'testSkillOne'."); + Assertions.assertTrue(CarriersUtils.hasSkill(type, "testSkillTwo"), "Should have skill 'testSkillTwo'."); } @Test @@ -386,15 +385,15 @@ void testAddShipmentSkill(){ CarrierShipment shipment = CarrierShipment.Builder.newInstance( Id.create("testShipment", CarrierShipment.class), Id.createLinkId("1"), Id.createLinkId("2"), 1) .build(); - Assert.assertFalse("Should not have skill.", CarriersUtils.hasSkill(shipment, "testSkill")); + Assertions.assertFalse(CarriersUtils.hasSkill(shipment, "testSkill"), "Should not have skill."); CarriersUtils.addSkill(shipment, "testSkillOne"); - Assert.assertTrue("Should have skill 'testSkillOne'.", CarriersUtils.hasSkill(shipment, "testSkillOne")); + Assertions.assertTrue(CarriersUtils.hasSkill(shipment, "testSkillOne"), "Should have skill 'testSkillOne'."); CarriersUtils.addSkill(shipment, "testSkillTwo"); - Assert.assertTrue("Should have skill 'testSkillOne'.", CarriersUtils.hasSkill(shipment, "testSkillOne")); - Assert.assertTrue("Should have skill 'testSkillTwo'.", CarriersUtils.hasSkill(shipment, "testSkillTwo")); + Assertions.assertTrue(CarriersUtils.hasSkill(shipment, "testSkillOne"), "Should have skill 'testSkillOne'."); + Assertions.assertTrue(CarriersUtils.hasSkill(shipment, "testSkillTwo"), "Should have skill 'testSkillTwo'."); } @Test @@ -402,15 +401,15 @@ void testAddServiceSkill(){ CarrierService service = CarrierService.Builder.newInstance( Id.create("testShipment", CarrierService.class), Id.createLinkId("2")) .build(); - Assert.assertFalse("Should not have skill.", CarriersUtils.hasSkill(service, "testSkill")); + Assertions.assertFalse(CarriersUtils.hasSkill(service, "testSkill"), "Should not have skill."); CarriersUtils.addSkill(service, "testSkillOne"); - Assert.assertTrue("Should have skill 'testSkillOne'.", CarriersUtils.hasSkill(service, "testSkillOne")); + Assertions.assertTrue(CarriersUtils.hasSkill(service, "testSkillOne"), "Should have skill 'testSkillOne'."); CarriersUtils.addSkill(service, "testSkillTwo"); - Assert.assertTrue("Should have skill 'testSkillOne'.", CarriersUtils.hasSkill(service, "testSkillOne")); - Assert.assertTrue("Should have skill 'testSkillTwo'.", CarriersUtils.hasSkill(service, "testSkillTwo")); + Assertions.assertTrue(CarriersUtils.hasSkill(service, "testSkillOne"), "Should have skill 'testSkillOne'."); + Assertions.assertTrue(CarriersUtils.hasSkill(service, "testSkillTwo"), "Should have skill 'testSkillTwo'."); } @Test @@ -433,10 +432,10 @@ void testRunJsprit_allInformationGiven(){ CarriersUtils.runJsprit(scenario); } catch (Exception e) { e.printStackTrace(); - Assert.fail(); + Assertions.fail(); } - Assert.assertEquals(vraFile, ConfigUtils.addOrGetModule( controler.getConfig(), FreightCarriersConfigGroup.class ).getVehicleRoutingAlgorithmFile()); + Assertions.assertEquals(vraFile, ConfigUtils.addOrGetModule( controler.getConfig(), FreightCarriersConfigGroup.class ).getVehicleRoutingAlgorithmFile()); } /** @@ -474,9 +473,9 @@ void testRunJsprit_NoAlgortihmFileGiven(){ try { CarriersUtils.runJsprit(scenario); } catch (Exception e) { - Assert.fail(); + Assertions.fail(); } - Assert.assertNull(ConfigUtils.addOrGetModule(scenario.getConfig(), FreightCarriersConfigGroup.class).getVehicleRoutingAlgorithmFile()); + Assertions.assertNull(ConfigUtils.addOrGetModule(scenario.getConfig(), FreightCarriersConfigGroup.class).getVehicleRoutingAlgorithmFile()); } private Config prepareConfig(){ diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverCostAllocationFixedTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverCostAllocationFixedTest.java index bdb2f256853..8faf02fd1c0 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverCostAllocationFixedTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverCostAllocationFixedTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.freightreceiver; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.testcases.MatsimTestUtils; @@ -8,6 +8,6 @@ public class ReceiverCostAllocationFixedTest { @Test void getScore() { - Assert.assertEquals("Wrong cost.", -20.0, new ReceiverCostAllocationFixed(20.0).getScore(null, null), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-20.0, new ReceiverCostAllocationFixed(20.0).getScore(null, null), MatsimTestUtils.EPSILON, "Wrong cost."); } } diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverPlanTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverPlanTest.java index 7c3a1691412..9933bda39d7 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverPlanTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiverPlanTest.java @@ -17,9 +17,9 @@ * *********************************************************************** */ package org.matsim.contrib.freightreceiver; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; -import org.junit.Assert; public class ReceiverPlanTest { @@ -30,8 +30,8 @@ void testBuilderTwo() { Receiver receiver = ReceiverUtils.newInstance( Id.create( "1", Receiver.class ) ); ReceiverPlan.Builder builder = ReceiverPlan.Builder.newInstance(receiver, true); ReceiverPlan plan = builder.build(); - Assert.assertEquals("Wrong receiver Id", Id.create("1", Receiver.class), plan.getReceiver().getId()); - Assert.assertNull("Score should be null", plan.getScore()); + Assertions.assertEquals(Id.create("1", Receiver.class), plan.getReceiver().getId(), "Wrong receiver Id"); + Assertions.assertNull(plan.getScore(), "Score should be null"); } /* TODO Add tests to check ReceiverOrders */ diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java index 70112f0895f..970641df24e 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversReaderTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.freightreceiver; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -47,15 +47,15 @@ void testBasicV2(){ new ReceiversReader(receivers).readFile(utils.getClassInputDirectory() + "receivers_v2_basic.xml"); } catch (Exception e) { e.printStackTrace(); - Assert.fail("Should read without exception."); + Assertions.fail("Should read without exception."); } /* Check one product type completely. */ ProductType p1 = receivers.getProductType(Id.create("P1", ProductType.class)); - Assert.assertNotNull("Product type should exists", p1); - Assert.assertEquals("Wrong origin link Id", Id.createLinkId("j(1,7)"), p1.getOriginLinkId()); - Assert.assertTrue("Wrong ProductType description", p1.getDescription().equalsIgnoreCase("Product 1")); - Assert.assertEquals("Wrong capacity.", 1.0, p1.getRequiredCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(p1, "Product type should exists"); + Assertions.assertEquals(Id.createLinkId("j(1,7)"), p1.getOriginLinkId(), "Wrong origin link Id"); + Assertions.assertTrue(p1.getDescription().equalsIgnoreCase("Product 1"), "Wrong ProductType description"); + Assertions.assertEquals(1.0, p1.getRequiredCapacity(), MatsimTestUtils.EPSILON, "Wrong capacity."); } @Test @@ -65,75 +65,75 @@ void testV2() { new ReceiversReader(receivers).readFile(utils.getClassInputDirectory() + "receivers_v2_full.xml"); } catch (Exception e) { e.printStackTrace(); - Assert.fail("Should read without exception."); + Assertions.fail("Should read without exception."); } /* Receivers */ - Assert.assertTrue("Wrong description.", "Chessboard".equalsIgnoreCase(receivers.getDescription())); + Assertions.assertTrue("Chessboard".equalsIgnoreCase(receivers.getDescription()), "Wrong description."); Object r = receivers.getAttributes().getAttribute("date"); - Assert.assertNotNull("No attribute", r); + Assertions.assertNotNull(r, "No attribute"); /* Product types */ - Assert.assertEquals("Wrong number of product types.", 2L, receivers.getAllProductTypes().size()); + Assertions.assertEquals(2L, receivers.getAllProductTypes().size(), "Wrong number of product types."); ProductType pt1 = receivers.getProductType(Id.create("P1", ProductType.class)); - Assert.assertNotNull("Could not find ProductType \"P1\"", pt1); - Assert.assertNotNull("Could not find ProductType \"P2\"", receivers.getProductType(Id.create("P2", ProductType.class))); + Assertions.assertNotNull(pt1, "Could not find ProductType \"P1\""); + Assertions.assertNotNull(receivers.getProductType(Id.create("P2", ProductType.class)), "Could not find ProductType \"P2\""); - Assert.assertTrue("Wrong ProductType description", pt1.getDescription().equalsIgnoreCase("Product 1")); - Assert.assertEquals("Wrong capacity.", 1.0, pt1.getRequiredCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertTrue(pt1.getDescription().equalsIgnoreCase("Product 1"), "Wrong ProductType description"); + Assertions.assertEquals(1.0, pt1.getRequiredCapacity(), MatsimTestUtils.EPSILON, "Wrong capacity."); /* Receiver */ - Assert.assertEquals("Wrong number of receivers.", 5, receivers.getReceivers().size()); + Assertions.assertEquals(5, receivers.getReceivers().size(), "Wrong number of receivers."); Receiver r1 = receivers.getReceivers().get(Id.create("1", Receiver.class)); - Assert.assertNotNull("Should find receiver '1'", r1); + Assertions.assertNotNull(r1, "Should find receiver '1'"); /* Receiver attributes. */ - Assert.assertFalse("Attributes should not be empty.", r1.getAttributes().isEmpty()); - Assert.assertNotNull("Should find attribute '" + CollaborationUtils.ATTR_GRANDCOALITION_MEMBER + "'", r1.getAttributes().getAttribute(CollaborationUtils.ATTR_GRANDCOALITION_MEMBER)); - Assert.assertNotNull("Should find attribute '" + CollaborationUtils.ATTR_COLLABORATION_STATUS + "'", r1.getAttributes().getAttribute(CollaborationUtils.ATTR_COLLABORATION_STATUS)); - Assert.assertNotNull("Should find attribute '" + ReceiverUtils.ATTR_RECEIVER_SCORE + "'", r1.getAttributes().getAttribute(ReceiverUtils.ATTR_RECEIVER_SCORE)); + Assertions.assertFalse(r1.getAttributes().isEmpty(), "Attributes should not be empty."); + Assertions.assertNotNull(r1.getAttributes().getAttribute(CollaborationUtils.ATTR_GRANDCOALITION_MEMBER), "Should find attribute '" + CollaborationUtils.ATTR_GRANDCOALITION_MEMBER + "'"); + Assertions.assertNotNull(r1.getAttributes().getAttribute(CollaborationUtils.ATTR_COLLABORATION_STATUS), "Should find attribute '" + CollaborationUtils.ATTR_COLLABORATION_STATUS + "'"); + Assertions.assertNotNull(r1.getAttributes().getAttribute(ReceiverUtils.ATTR_RECEIVER_SCORE), "Should find attribute '" + ReceiverUtils.ATTR_RECEIVER_SCORE + "'"); /* Time window */ - Assert.assertEquals("Wrong number of time windows.", 2, r1.getSelectedPlan().getTimeWindows().size()); + Assertions.assertEquals(2, r1.getSelectedPlan().getTimeWindows().size(), "Wrong number of time windows."); TimeWindow t1 = r1.getSelectedPlan().getTimeWindows().get(0); - Assert.assertEquals("Wrong time window start time.", Time.parseTime("06:00:00"), t1.getStart(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong time window end time.", Time.parseTime("10:00:00"), t1.getEnd(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Time.parseTime("06:00:00"), t1.getStart(), MatsimTestUtils.EPSILON, "Wrong time window start time."); + Assertions.assertEquals(Time.parseTime("10:00:00"), t1.getEnd(), MatsimTestUtils.EPSILON, "Wrong time window end time."); TimeWindow t2 = r1.getSelectedPlan().getTimeWindows().get(1); - Assert.assertEquals("Wrong time window start time.", Time.parseTime("15:00:00"), t2.getStart(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong time window end time.", Time.parseTime("18:00:00"), t2.getEnd(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Time.parseTime("15:00:00"), t2.getStart(), MatsimTestUtils.EPSILON, "Wrong time window start time."); + Assertions.assertEquals(Time.parseTime("18:00:00"), t2.getEnd(), MatsimTestUtils.EPSILON, "Wrong time window end time."); - Assert.assertEquals("Wrong number of products.", 2, r1.getProducts().size()); + Assertions.assertEquals(2, r1.getProducts().size(), "Wrong number of products."); /* Receiver product */ ReceiverProduct rp1 = r1.getProduct(Id.create("P1", ProductType.class)); - Assert.assertNotNull("Could not find receiver product \"P1\"", rp1); - Assert.assertEquals("Wrong stock on hand.", 0.0, rp1.getStockOnHand(), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(rp1, "Could not find receiver product \"P1\""); + Assertions.assertEquals(0.0, rp1.getStockOnHand(), MatsimTestUtils.EPSILON, "Wrong stock on hand."); /* Reorder policy */ ReorderPolicy policy = rp1.getReorderPolicy(); - Assert.assertNotNull("Could not find reorder policy.", policy); - Assert.assertTrue("Wrong policy type", policy instanceof SSReorderPolicy); - Assert.assertTrue("Wrong policy name.", policy.getPolicyName().equalsIgnoreCase("(s,S)")); - Assert.assertNotNull("Could not find attribute 's'", policy.getAttributes().getAttribute("s")); - Assert.assertNotNull("Could not find attribute 'S'", policy.getAttributes().getAttribute("S")); + Assertions.assertNotNull(policy, "Could not find reorder policy."); + Assertions.assertTrue(policy instanceof SSReorderPolicy, "Wrong policy type"); + Assertions.assertTrue(policy.getPolicyName().equalsIgnoreCase("(s,S)"), "Wrong policy name."); + Assertions.assertNotNull(policy.getAttributes().getAttribute("s"), "Could not find attribute 's'"); + Assertions.assertNotNull(policy.getAttributes().getAttribute("S"), "Could not find attribute 'S'"); /* (Receiver)Orders */ - Assert.assertEquals("Wrong number of orders/plans", 5, r1.getPlans().size()); + Assertions.assertEquals(5, r1.getPlans().size(), "Wrong number of orders/plans"); ReceiverPlan plan = r1.getSelectedPlan(); ReceiverOrder ro = plan.getReceiverOrder(Id.create("Carrier1", Carrier.class)); - Assert.assertNotNull("Should find ReceiverOrder.", ro); + Assertions.assertNotNull(ro, "Should find ReceiverOrder."); - Assert.assertEquals("Wrong carrier", ro.getCarrierId(), Id.create("Carrier1", Carrier.class)); - Assert.assertEquals("Wrong receiver", ro.getReceiverId(), Id.create("1", Receiver.class)); - Assert.assertNull("Should not have score now", ro.getScore()); + Assertions.assertEquals(ro.getCarrierId(), Id.create("Carrier1", Carrier.class), "Wrong carrier"); + Assertions.assertEquals(ro.getReceiverId(), Id.create("1", Receiver.class), "Wrong receiver"); + Assertions.assertNull(ro.getScore(), "Should not have score now"); /* Order (items) */ - Assert.assertEquals("Wrong number of order (items)", 2, ro.getReceiverProductOrders().size()); + Assertions.assertEquals(2, ro.getReceiverProductOrders().size(), "Wrong number of order (items)"); Order o = ro.getReceiverProductOrders().iterator().next(); - Assert.assertEquals("Wrong order id.", o.getId(), Id.create("Order11", Order.class)); - Assert.assertEquals("Wrong order quantity.", 5000, o.getOrderQuantity(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong product type.", o.getProduct().getProductType().getId(), Id.create("P1", ProductType.class)); - Assert.assertEquals("Wrong receiver.", o.getReceiver().getId(), Id.create("1", Receiver.class)); - Assert.assertEquals("Wrong service duration.", Time.parseTime("03:00:00"), o.getServiceDuration(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(o.getId(), Id.create("Order11", Order.class), "Wrong order id."); + Assertions.assertEquals(5000, o.getOrderQuantity(), MatsimTestUtils.EPSILON, "Wrong order quantity."); + Assertions.assertEquals(o.getProduct().getProductType().getId(), Id.create("P1", ProductType.class), "Wrong product type."); + Assertions.assertEquals(o.getReceiver().getId(), Id.create("1", Receiver.class), "Wrong receiver."); + Assertions.assertEquals(Time.parseTime("03:00:00"), o.getServiceDuration(), MatsimTestUtils.EPSILON, "Wrong service duration."); } } diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java index ca5a5f02009..35dbed33c31 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.freightreceiver; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -29,7 +29,7 @@ void testSetupReceivers() { Receivers receivers = setupReceivers(); } catch (Exception e) { e.printStackTrace(); - Assert.fail("Cannot set up test case"); + Assertions.fail("Cannot set up test case"); } } @@ -37,14 +37,14 @@ void testSetupReceivers() { void getReceivers() { Receivers receivers = setupReceivers(); Map, Receiver> map = receivers.getReceivers(); - Assert.assertNotNull("Map must exist.", map); - Assert.assertEquals("Wrong number of receivers.", 5, map.size()); + Assertions.assertNotNull(map, "Map must exist."); + Assertions.assertEquals(5, map.size(), "Wrong number of receivers."); /* Map must be unmodifiable. */ Receiver newReceiver = ReceiverUtils.newInstance(Id.create("dummy", Receiver.class)); try { map.put(newReceiver.getId(), newReceiver); - Assert.fail("Map must be unmodifiable."); + Assertions.fail("Map must be unmodifiable."); } catch (UnsupportedOperationException e) { e.printStackTrace(); } @@ -54,22 +54,22 @@ void getReceivers() { void getReceiver() { Receivers receivers = setupReceivers(); Receiver receiverExists = receivers.getReceiver(Id.create("1", Receiver.class)); - Assert.assertNotNull("Should find receiver.", receiverExists); + Assertions.assertNotNull(receiverExists, "Should find receiver."); Receiver receiverDoesNotExist = receivers.getReceiver(Id.create("dummy", Receiver.class)); - Assert.assertNull("Should not find receiver.", receiverDoesNotExist); + Assertions.assertNull(receiverDoesNotExist, "Should not find receiver."); } @Test void addReceiver() { Receivers receivers = setupReceivers(); - Assert.assertEquals("Wrong number of receivers.", 5, receivers.getReceivers().size()); + Assertions.assertEquals(5, receivers.getReceivers().size(), "Wrong number of receivers."); Receiver newReceiver = ReceiverUtils.newInstance(Id.create("dummy", Receiver.class)); receivers.addReceiver(newReceiver); - Assert.assertEquals("Receivers should increase.", 6, receivers.getReceivers().size()); + Assertions.assertEquals(6, receivers.getReceivers().size(), "Receivers should increase."); receivers.addReceiver(newReceiver); - Assert.assertEquals("Receivers should not increase.", 6, receivers.getReceivers().size()); + Assertions.assertEquals(6, receivers.getReceivers().size(), "Receivers should not increase."); /*TODO Should we maybe check if a receiver is NOT overwritten? */ } @@ -77,11 +77,11 @@ void addReceiver() { @Test void createAndAddProductType() { Receivers receivers = setupReceivers(); - Assert.assertEquals("Wrong number of product types.", 2, receivers.getAllProductTypes().size()); + Assertions.assertEquals(2, receivers.getAllProductTypes().size(), "Wrong number of product types."); ProductType test = ReceiverUtils.createAndGetProductType(receivers, Id.create("test", ProductType.class), Id.createLinkId("j(1,7)")); - Assert.assertEquals("Wrong number of product types.", 3, receivers.getAllProductTypes().size()); - Assert.assertTrue("Should contain new product types", receivers.getAllProductTypes().contains(test)); + Assertions.assertEquals(3, receivers.getAllProductTypes().size(), "Wrong number of product types."); + Assertions.assertTrue(receivers.getAllProductTypes().contains(test), "Should contain new product types"); } @Test @@ -89,15 +89,15 @@ void getProductType() { Receivers receivers = setupReceivers(); try { ProductType p1 = receivers.getProductType(Id.create("P1", ProductType.class)); - Assert.assertNotNull("Should find P1", p1); + Assertions.assertNotNull(p1, "Should find P1"); } catch (Exception e) { - Assert.fail("Should find P1"); + Assertions.fail("Should find P1"); } try { @SuppressWarnings("unused") ProductType dummy = receivers.getProductType(Id.create("dummy", ProductType.class)); - Assert.fail("Should crash when product type is not available."); + Assertions.fail("Should crash when product type is not available."); } catch (Exception e){ e.printStackTrace(); } @@ -107,45 +107,45 @@ void getProductType() { void getAllProductTypes() { Receivers receivers = setupReceivers(); Collection types = receivers.getAllProductTypes(); - Assert.assertNotNull("Must have product types.", types); - Assert.assertEquals("Wrong number of product types.", 2, types.size()); + Assertions.assertNotNull(types, "Must have product types."); + Assertions.assertEquals(2, types.size(), "Wrong number of product types."); List list = List.copyOf(types); ProductType p1 = list.get(0); - Assert.assertTrue("Should contain P1", p1.getId().toString().equalsIgnoreCase("P1")); - Assert.assertTrue("Wrong description", p1.getDescription().equalsIgnoreCase("Product 1")); - Assert.assertEquals("Wrong origin Id", Id.createLinkId("j(4,3)R"), p1.getOriginLinkId()); - Assert.assertEquals("Wrong capacity", 1.0, p1.getRequiredCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertTrue(p1.getId().toString().equalsIgnoreCase("P1"), "Should contain P1"); + Assertions.assertTrue(p1.getDescription().equalsIgnoreCase("Product 1"), "Wrong description"); + Assertions.assertEquals(Id.createLinkId("j(4,3)R"), p1.getOriginLinkId(), "Wrong origin Id"); + Assertions.assertEquals(1.0, p1.getRequiredCapacity(), MatsimTestUtils.EPSILON, "Wrong capacity"); ProductType p2 = list.get(1); - Assert.assertTrue("Should contain P2", p2.getId().toString().equalsIgnoreCase("P2")); - Assert.assertTrue("Wrong description", p2.getDescription().equalsIgnoreCase("Product 2")); - Assert.assertEquals("Wrong origin Id", Id.createLinkId("j(4,3)R"), p2.getOriginLinkId()); - Assert.assertEquals("Wrong capacity", 2.0, p2.getRequiredCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertTrue(p2.getId().toString().equalsIgnoreCase("P2"), "Should contain P2"); + Assertions.assertTrue(p2.getDescription().equalsIgnoreCase("Product 2"), "Wrong description"); + Assertions.assertEquals(Id.createLinkId("j(4,3)R"), p2.getOriginLinkId(), "Wrong origin Id"); + Assertions.assertEquals(2.0, p2.getRequiredCapacity(), MatsimTestUtils.EPSILON, "Wrong capacity"); } @Test void getAttributes() { Receivers receivers = setupReceivers(); - Assert.assertNotNull("Should find attributed.", receivers.getAttributes()); - Assert.assertEquals("Wrong number of attributes.", 0, receivers.getAttributes().size()); + Assertions.assertNotNull(receivers.getAttributes(), "Should find attributed."); + Assertions.assertEquals(0, receivers.getAttributes().size(), "Wrong number of attributes."); receivers.getAttributes().putAttribute("dummy", 123.4); - Assert.assertEquals("Wrong number of attributes.", 1, receivers.getAttributes().size()); + Assertions.assertEquals(1, receivers.getAttributes().size(), "Wrong number of attributes."); } @Test void setDescription() { Receivers receivers = setupReceivers(); - Assert.assertEquals("Wrong description.", "Chessboard", receivers.getDescription()); + Assertions.assertEquals("Chessboard", receivers.getDescription(), "Wrong description."); receivers.setDescription("Dummy"); - Assert.assertEquals("Wrong description.", "Dummy", receivers.getDescription()); + Assertions.assertEquals("Dummy", receivers.getDescription(), "Wrong description."); } @Test void getDescription() { Receivers receivers = setupReceivers(); - Assert.assertEquals("Wrong description.", "Chessboard", receivers.getDescription()); + Assertions.assertEquals("Chessboard", receivers.getDescription(), "Wrong description."); } private Receivers setupReceivers() { diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java index 972ebf6e200..34a66898d68 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/ReceiversWriterTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.freightreceiver; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -46,10 +46,10 @@ void testV1() { new ReceiversWriter( ReceiverUtils.getReceivers( sc ) ).writeV1(utils.getOutputDirectory() + "receivers_v1.xml"); } catch (Exception e) { e.printStackTrace(); - Assert.fail("Should write without exception."); + Assertions.fail("Should write without exception."); } - Assert.assertTrue("File should exist.", new File(utils.getOutputDirectory() + "receivers_v1.xml").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory() + "receivers_v1.xml").exists(), "File should exist."); } @Test @@ -63,10 +63,10 @@ void testV2() { new ReceiversWriter( ReceiverUtils.getReceivers( sc ) ).writeV2(utils.getOutputDirectory() + "receivers_v2.xml"); } catch (Exception e) { e.printStackTrace(); - Assert.fail("Should write without exception."); + Assertions.fail("Should write without exception."); } - Assert.assertTrue("File should exist.", new File(utils.getOutputDirectory() + "receivers_v2.xml").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory() + "receivers_v2.xml").exists(), "File should exist."); } } diff --git a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/SSReorderPolicyTest.java b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/SSReorderPolicyTest.java index 9f51534e124..1841ae963fc 100644 --- a/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/SSReorderPolicyTest.java +++ b/contribs/freightreceiver/src/test/java/org/matsim/contrib/freightreceiver/SSReorderPolicyTest.java @@ -21,7 +21,7 @@ package org.matsim.contrib.freightreceiver; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.testcases.MatsimTestUtils; @@ -30,9 +30,9 @@ public class SSReorderPolicyTest { @Test void testCalculateOrderQuantity() { ReorderPolicy policy = ReceiverUtils.createSSReorderPolicy(5.0, 10.0); - Assert.assertEquals("Wrong reorder quantity", 0.0, policy.calculateOrderQuantity(6.0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong reorder quantity", 5.0, policy.calculateOrderQuantity(5.0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong reorder quantity", 6.0, policy.calculateOrderQuantity(4.0), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, policy.calculateOrderQuantity(6.0), MatsimTestUtils.EPSILON, "Wrong reorder quantity"); + Assertions.assertEquals(5.0, policy.calculateOrderQuantity(5.0), MatsimTestUtils.EPSILON, "Wrong reorder quantity"); + Assertions.assertEquals(6.0, policy.calculateOrderQuantity(4.0), MatsimTestUtils.EPSILON, "Wrong reorder quantity"); } } diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java index 30153229e58..3be3bbb887a 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java @@ -14,7 +14,7 @@ import java.util.Arrays; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class RelaxedSubtourConstraintTest { diff --git a/contribs/integration/src/test/java/org/matsim/integration/daily/SomeDailyTest.java b/contribs/integration/src/test/java/org/matsim/integration/daily/SomeDailyTest.java index 2cf8b0c6d75..c19b95b9385 100644 --- a/contribs/integration/src/test/java/org/matsim/integration/daily/SomeDailyTest.java +++ b/contribs/integration/src/test/java/org/matsim/integration/daily/SomeDailyTest.java @@ -1,6 +1,6 @@ package org.matsim.integration.daily; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; public class SomeDailyTest { @@ -10,7 +10,7 @@ void doTest() { System.out.println("RUN TEST DAILY"); System.out.println("available ram: " + (Runtime.getRuntime().maxMemory() / 1024/1024)); - Assert.assertTrue(true); + Assertions.assertTrue(true); } } diff --git a/contribs/integration/src/test/java/org/matsim/integration/weekly/SomeWeeklyTest.java b/contribs/integration/src/test/java/org/matsim/integration/weekly/SomeWeeklyTest.java index 87c4be20dac..74db99859ba 100644 --- a/contribs/integration/src/test/java/org/matsim/integration/weekly/SomeWeeklyTest.java +++ b/contribs/integration/src/test/java/org/matsim/integration/weekly/SomeWeeklyTest.java @@ -1,6 +1,6 @@ package org.matsim.integration.weekly; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; public class SomeWeeklyTest { @@ -8,6 +8,6 @@ public class SomeWeeklyTest { void doTest() { System.out.println("RUN TEST WEEKLY"); System.out.println("available ram: " + (Runtime.getRuntime().maxMemory() / 1024/1024)); - Assert.assertTrue(true); + Assertions.assertTrue(true); } } diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java index 3ea1d36e21b..4f39e4a0b72 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/LocationChoiceIT.java @@ -20,7 +20,7 @@ package org.matsim.contrib.locationchoice; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import jakarta.inject.Provider; import org.junit.jupiter.api.Test; @@ -133,7 +133,7 @@ public PlanStrategy get() { // Secondly, I need to give it two facilities to choose from, because a choice set of size 1 is treated specially // (it is assumed that the one element is the one I'm already on, so nothing is done). // I tricked it. :-) michaz - assertEquals("number of plans in person.", 2, person.getPlans().size()); + assertEquals(2, person.getPlans().size(), "number of plans in person."); Plan newPlan = person.getSelectedPlan(); Activity newWork = (Activity) newPlan.getPlanElements().get(2); if (!config.routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FacilityPenaltyTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FacilityPenaltyTest.java index eac967476eb..4ae55db30cc 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FacilityPenaltyTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FacilityPenaltyTest.java @@ -3,7 +3,7 @@ import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.contrib.locationchoice.DestinationChoiceConfigGroup; import org.matsim.testcases.MatsimTestUtils; @@ -13,7 +13,7 @@ public class FacilityPenaltyTest { @Test void testGetPenalty() { FacilityPenalty facilitypenalty = new FacilityPenalty(0.0, new DestinationChoiceConfigGroup()); - Assert.assertEquals(facilitypenalty.getCapacityPenaltyFactor(0.0, 1.0), 0.0, MatsimTestUtils.EPSILON); + Assertions.assertEquals(facilitypenalty.getCapacityPenaltyFactor(0.0, 1.0), 0.0, MatsimTestUtils.EPSILON); } @Test @@ -26,6 +26,6 @@ void testcalculateCapPenaltyFactor() throws SecurityException, NoSuchMethodExcep method = facilitypenalty.getClass().getDeclaredMethod("calculateCapPenaltyFactor", new Class[]{int.class, int.class}); method.setAccessible(true); Double val = (Double)method.invoke(facilitypenalty, new Object[]{0, 1}); - Assert.assertTrue(Math.abs(val.doubleValue()) < 0.000000001); + Assertions.assertTrue(Math.abs(val.doubleValue()) < 0.000000001); } } diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java index dbbac69569f..bea0571d4e5 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/FrozenEpsilonLocaChoiceIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.locationchoice.frozenepsilons; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import static org.matsim.contrib.locationchoice.LocationChoiceIT.localCreatePopWOnePerson; import static org.matsim.contrib.locationchoice.frozenepsilons.FrozenTastesConfigGroup.Algotype; import static org.matsim.contrib.locationchoice.frozenepsilons.FrozenTastesConfigGroup.Algotype.bestResponse; @@ -14,7 +14,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -153,7 +153,7 @@ public void install() { // run: controler.run(); - assertEquals("number of plans in person.", 2, person.getPlans().size()); + assertEquals(2, person.getPlans().size(), "number of plans in person."); Plan newPlan = person.getSelectedPlan(); System.err.println( " newPlan: " + newPlan ) ; Activity newWork = (Activity) newPlan.getPlanElements().get(2 ); @@ -218,7 +218,7 @@ public void install() { controler.run(); - assertEquals("number of plans in person.", 2, person.getPlans().size()); + assertEquals(2, person.getPlans().size(), "number of plans in person."); Plan newPlan = person.getSelectedPlan(); System.err.println( " newPlan: " + newPlan ) ; Activity newWork = (Activity) newPlan.getPlanElements().get(2); @@ -429,7 +429,7 @@ int binFromVal( double val ) { } void check( double val, double actual ){ - Assert.assertEquals( val, actual, 2.*Math.max( 5, Math.sqrt( val ) ) ); + Assertions.assertEquals( val, actual, 2.*Math.max( 5, Math.sqrt( val ) ) ); } } ); diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java index 268466e0215..df26aac50ab 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java @@ -22,6 +22,8 @@ package org.matsim.contrib.locationchoice.frozenepsilons; +import static org.junit.jupiter.api.Assertions.assertTrue; + import org.junit.Before; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -34,8 +36,6 @@ import org.matsim.facilities.ActivityFacility; import org.matsim.testcases.MatsimTestUtils; -import static org.junit.Assert.assertTrue; - public class SamplerTest { @RegisterExtension diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/ScoringPenaltyTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/ScoringPenaltyTest.java index 5a4ce413fb9..7ee67877aff 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/ScoringPenaltyTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/ScoringPenaltyTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.locationchoice.frozenepsilons; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.contrib.locationchoice.DestinationChoiceConfigGroup; import org.matsim.testcases.MatsimTestUtils; @@ -11,6 +11,6 @@ public class ScoringPenaltyTest { void testGetPenalty() { FacilityPenalty facilityPenalty = new FacilityPenalty(0.0, new DestinationChoiceConfigGroup()); ScoringPenalty scoringpenalty = new ScoringPenalty(0.0, 1.0, facilityPenalty, 1.0); - Assert.assertEquals(scoringpenalty.getPenalty(), 0.0, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scoringpenalty.getPenalty(), 0.0, MatsimTestUtils.EPSILON); } } diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java index c17601dbc4b..6b6a02d29ee 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/LocationMutatorwChoiceSetTest.java @@ -19,12 +19,12 @@ package org.matsim.contrib.locationchoice.timegeography; -import static org.junit.Assert.assertEquals; - import java.util.List; import java.util.Random; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java index 1085935abf6..3dbbeac305a 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/ManageSubchainsTest.java @@ -19,7 +19,7 @@ package org.matsim.contrib.locationchoice.timegeography; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java index c13f5995a67..6284827abc7 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/timegeography/SubChainTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.locationchoice.timegeography; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertNotNull; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/contribs/locationchoice/src/test/java/org/matsim/core/router/BackwardFastMultiNodeTest.java b/contribs/locationchoice/src/test/java/org/matsim/core/router/BackwardFastMultiNodeTest.java index beb768be82e..11e7c5e4d92 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/core/router/BackwardFastMultiNodeTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/core/router/BackwardFastMultiNodeTest.java @@ -20,7 +20,7 @@ package org.matsim.core.router; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -75,38 +75,38 @@ private void runTestBackwardsFastMultiNodeDijkstra_OneToOne(boolean searchAllEnd */ Path path = dijkstra.calcLeastCostPath(fromNode, toNode, 3600.0, null, null); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation */ path = dijkstra.constructPath(fromNode, toNode, 3600.0); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); } /* @@ -142,64 +142,64 @@ void testBackwardsFastMultiNodeDijkstra_OneToMany() { */ Path path = dijkstra.calcLeastCostPath(fromNode, toNode, 3600.0, null, null); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode1 */ path = dijkstra.constructPath(fromNode, toNode1, 3600.0); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode2 */ path = dijkstra.constructPath(fromNode, toNode2, 3600.0); - Assert.assertEquals(1.333, path.travelCost, 0.001); - Assert.assertEquals(400.0, path.travelTime, 0.0); + Assertions.assertEquals(1.333, path.travelCost, 0.001); + Assertions.assertEquals(400.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n4", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n4", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l3", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l3", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode3 */ path = dijkstra.constructPath(fromNode, toNode3, 3600.0); - Assert.assertNull(null); + Assertions.assertNull(null); } @Test @@ -232,78 +232,78 @@ void testBackwardsFastMultiNodeDijkstra_OneToMany_SearchAllNodes() { */ Path path = dijkstra.calcLeastCostPath(fromNode, toNode, 3600.0, null, null); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode1 */ path = dijkstra.constructPath(fromNode, toNode1, 3600.0); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode2 */ path = dijkstra.constructPath(fromNode, toNode2, 3600.0); - Assert.assertEquals(1.333, path.travelCost, 0.001); - Assert.assertEquals(400.0, path.travelTime, 0.0); + Assertions.assertEquals(1.333, path.travelCost, 0.001); + Assertions.assertEquals(400.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n4", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n4", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l3", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l3", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode3 */ path = dijkstra.constructPath(fromNode, toNode3, 3600.0); - Assert.assertEquals(2.0, path.travelCost, 0.0); - Assert.assertEquals(600.0, path.travelTime, 0.0); - - Assert.assertEquals(5, path.nodes.size()); - Assert.assertEquals(Id.create("n5", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n4", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(4).getId()); - - Assert.assertEquals(4, path.links.size()); - Assert.assertEquals(Id.create("l4", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l3", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(2).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(3).getId()); + Assertions.assertEquals(2.0, path.travelCost, 0.0); + Assertions.assertEquals(600.0, path.travelTime, 0.0); + + Assertions.assertEquals(5, path.nodes.size()); + Assertions.assertEquals(Id.create("n5", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n4", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(4).getId()); + + Assertions.assertEquals(4, path.links.size()); + Assertions.assertEquals(Id.create("l4", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l3", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(3).getId()); } /* diff --git a/contribs/locationchoice/src/test/java/org/matsim/core/router/FastMultiNodeTest.java b/contribs/locationchoice/src/test/java/org/matsim/core/router/FastMultiNodeTest.java index 56c804c9cc9..05abc03159c 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/core/router/FastMultiNodeTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/core/router/FastMultiNodeTest.java @@ -20,7 +20,7 @@ package org.matsim.core.router; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -73,38 +73,38 @@ void testFastMultiNodeDijkstra_OneToOne() { */ Path path = dijkstra.calcLeastCostPath(fromNode, toNode, 3600.0, null, null); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation */ path = dijkstra.constructPath(fromNode, toNode, 3600.0); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); } @Test @@ -138,64 +138,64 @@ void testFastMultiNodeDijkstra_OneToMany() { */ Path path = dijkstra.calcLeastCostPath(fromNode, toNode, 3600.0, null, null); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode1 */ path = dijkstra.constructPath(fromNode, toNode1, 3600.0); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode2 */ path = dijkstra.constructPath(fromNode, toNode2, 3600.0); - Assert.assertEquals(1.333, path.travelCost, 0.001); - Assert.assertEquals(400.0, path.travelTime, 0.0); + Assertions.assertEquals(1.333, path.travelCost, 0.001); + Assertions.assertEquals(400.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n4", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n4", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l3", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l3", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode3 */ path = dijkstra.constructPath(fromNode, toNode3, 3600.0); - Assert.assertNull(path); + Assertions.assertNull(path); } @Test @@ -229,78 +229,78 @@ void testFastMultiNodeDijkstra_OneToMany_SearchAllNodes() { */ Path path = dijkstra.calcLeastCostPath(fromNode, toNode, 3600.0, null, null); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode1 */ path = dijkstra.constructPath(fromNode, toNode1, 3600.0); - Assert.assertEquals(1.0, path.travelCost, 0.0); - Assert.assertEquals(300.0, path.travelTime, 0.0); + Assertions.assertEquals(1.0, path.travelCost, 0.0); + Assertions.assertEquals(300.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n3", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l2", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode2 */ path = dijkstra.constructPath(fromNode, toNode2, 3600.0); - Assert.assertEquals(1.333, path.travelCost, 0.001); - Assert.assertEquals(400.0, path.travelTime, 0.0); + Assertions.assertEquals(1.333, path.travelCost, 0.001); + Assertions.assertEquals(400.0, path.travelTime, 0.0); - Assert.assertEquals(4, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n4", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(4, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n4", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(3, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l3", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(3, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l3", Link.class), path.links.get(2).getId()); /* * test constructPath method which uses data from the previous routing operation - toNode3 */ path = dijkstra.constructPath(fromNode, toNode3, 3600.0); - Assert.assertEquals(2.0, path.travelCost, 0.0); - Assert.assertEquals(600.0, path.travelTime, 0.0); - - Assert.assertEquals(5, path.nodes.size()); - Assert.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); - Assert.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); - Assert.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); - Assert.assertEquals(Id.create("n4", Node.class), path.nodes.get(3).getId()); - Assert.assertEquals(Id.create("n5", Node.class), path.nodes.get(4).getId()); - - Assert.assertEquals(4, path.links.size()); - Assert.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); - Assert.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); - Assert.assertEquals(Id.create("l3", Link.class), path.links.get(2).getId()); - Assert.assertEquals(Id.create("l4", Link.class), path.links.get(3).getId()); + Assertions.assertEquals(2.0, path.travelCost, 0.0); + Assertions.assertEquals(600.0, path.travelTime, 0.0); + + Assertions.assertEquals(5, path.nodes.size()); + Assertions.assertEquals(Id.create("n0", Node.class), path.nodes.get(0).getId()); + Assertions.assertEquals(Id.create("n1", Node.class), path.nodes.get(1).getId()); + Assertions.assertEquals(Id.create("n2", Node.class), path.nodes.get(2).getId()); + Assertions.assertEquals(Id.create("n4", Node.class), path.nodes.get(3).getId()); + Assertions.assertEquals(Id.create("n5", Node.class), path.nodes.get(4).getId()); + + Assertions.assertEquals(4, path.links.size()); + Assertions.assertEquals(Id.create("l0", Link.class), path.links.get(0).getId()); + Assertions.assertEquals(Id.create("l1", Link.class), path.links.get(1).getId()); + Assertions.assertEquals(Id.create("l3", Link.class), path.links.get(2).getId()); + Assertions.assertEquals(Id.create("l4", Link.class), path.links.get(3).getId()); } /* diff --git a/contribs/locationchoice/src/test/java/org/matsim/core/router/MultiNodeDijkstraTest.java b/contribs/locationchoice/src/test/java/org/matsim/core/router/MultiNodeDijkstraTest.java index 283b90b0218..fd40e25d1f1 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/core/router/MultiNodeDijkstraTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/core/router/MultiNodeDijkstraTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -88,31 +88,31 @@ public void testMultipleStarts(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("1", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("5", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("1", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("5", p.links.get(2).getId().toString()); // change costs tc.setData(Id.create(1, Link.class), 2.0, 5.0); p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("2", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("5", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("2", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("5", p.links.get(2).getId().toString()); // change costs again tc.setData(Id.create(1, Link.class), 2.0, 1.0); p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("1", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("5", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("1", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("5", p.links.get(2).getId().toString()); } @Test @@ -146,31 +146,31 @@ public void testMultipleEnds(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("2", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("5", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("2", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("5", p.links.get(2).getId().toString()); // change costs tc.setData(Id.create(4, Link.class), 3.0, 1.0); p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("2", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("4", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("2", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("4", p.links.get(2).getId().toString()); // change costs again tc.setData(Id.create(6, Link.class), 7.0, 3.0); p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("2", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("6", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("2", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("6", p.links.get(2).getId().toString()); } @Test @@ -205,33 +205,33 @@ public void testMultipleStartsAndEnds(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("2", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("5", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("2", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("5", p.links.get(2).getId().toString()); // change costs tc.setData(Id.create(3, Link.class), 3.0, 1.0); tc.setData(Id.create(4, Link.class), 3.0, 1.0); p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("3", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("4", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("3", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("4", p.links.get(2).getId().toString()); // change costs again tc.setData(Id.create(3, Link.class), 3.0, 4.0); tc.setData(Id.create(6, Link.class), 7.0, 3.0); p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("2", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("6", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("2", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("6", p.links.get(2).getId().toString()); } @Test @@ -270,11 +270,11 @@ public void testStartViaFaster(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("1", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("5", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("1", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("5", p.links.get(2).getId().toString()); } @Test @@ -315,11 +315,11 @@ public void testEndViaFaster(boolean fastRouter) { // toNodes.put(f.network.getNodes().get(Id.create(5)), new InitialNode(1.0, 1.0)); // // Path p = dijkstra.calcLeastCostPath(fromNodes, toNodes, null); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("2", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("5", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("2", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("5", p.links.get(2).getId().toString()); } @Test @@ -351,10 +351,10 @@ public void testOnlyFromToSameNode(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(0, p.links.size()); - Assert.assertEquals(1, p.nodes.size()); - Assert.assertEquals("2", p.nodes.get(0).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(0, p.links.size()); + Assertions.assertEquals(1, p.nodes.size()); + Assertions.assertEquals("2", p.nodes.get(0).getId().toString()); } @Test @@ -393,10 +393,10 @@ public void testSameNodeInFromToSetCheapest(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(0, p.links.size()); - Assert.assertEquals(1, p.nodes.size()); - Assert.assertEquals("4", p.nodes.get(0).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(0, p.links.size()); + Assertions.assertEquals(1, p.nodes.size()); + Assertions.assertEquals("4", p.nodes.get(0).getId().toString()); } @Test @@ -435,11 +435,11 @@ public void testSameNodeInFromToSetNotCheapest(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("2", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("6", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("2", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("6", p.links.get(2).getId().toString()); } @Test @@ -476,11 +476,11 @@ public void testSomeEndNodesNotReachable(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("2", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("5", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("2", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("5", p.links.get(2).getId().toString()); } @Test @@ -517,11 +517,11 @@ public void testSomeStartNodesNotUseable(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull("no path found!", p); - Assert.assertEquals(3, p.links.size()); - Assert.assertEquals("2", p.links.get(0).getId().toString()); - Assert.assertEquals("7", p.links.get(1).getId().toString()); - Assert.assertEquals("5", p.links.get(2).getId().toString()); + Assertions.assertNotNull(p, "no path found!"); + Assertions.assertEquals(3, p.links.size()); + Assertions.assertEquals("2", p.links.get(0).getId().toString()); + Assertions.assertEquals("7", p.links.get(1).getId().toString()); + Assertions.assertEquals("5", p.links.get(2).getId().toString()); } @Test @@ -553,7 +553,7 @@ public void testImpossibleRoute(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNull("wow, impossible path found!", p); + Assertions.assertNull(p, "wow, impossible path found!"); } /* @@ -589,9 +589,9 @@ public void testInitialValuesCorrection(boolean fastRouter) { Path p = createPath(dijkstra, fromNode, toNode); - Assert.assertNotNull(p); - Assert.assertEquals(300.0, p.travelTime, 0.0); - Assert.assertEquals(600.0, p.travelCost, 0.0); + Assertions.assertNotNull(p); + Assertions.assertEquals(300.0, p.travelTime, 0.0); + Assertions.assertEquals(600.0, p.travelCost, 0.0); } /*package*/ static Path createPath(Dijkstra dijsktra, Node fromNode, Node toNode) { diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java index 9f56650dc64..029bc07e9ed 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java @@ -25,7 +25,7 @@ import java.io.File; import java.io.IOException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; @@ -129,7 +129,7 @@ void testIntegration() throws IOException { double actualTtime = ((Leg)person.getSelectedPlan().getPlanElements().get(1)).getTravelTime().seconds(); //compare computed and actual travel time - Assert.assertEquals(ttime, actualTtime, 0); + Assertions.assertEquals(ttime, actualTtime, 0); } diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java index 39a0ba2fa6c..f1cfe36973c 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java @@ -26,11 +26,10 @@ import java.io.IOException; import java.util.List; -import org.junit.Assert; - import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; @@ -138,8 +137,8 @@ void testPtMatrixStops() throws IOException{ // the agents will walk 50 m to the nearest pt stop and 50 m back to their origin facility, so the total travel distance have to be 100 m. if(origin == destination){ - Assert.assertTrue(totalTravelTime == 100./defaultWalkSpeed); - Assert.assertTrue(totalTravelDistance == 100.); + Assertions.assertTrue(totalTravelTime == 100./defaultWalkSpeed); + Assertions.assertTrue(totalTravelDistance == 100.); } // test travel time and distance for neighboring origins and destinations @@ -147,13 +146,13 @@ else if( (origin + 1) % 4 == destination || (origin + 3) % 4 == destination){ // test total walk travel distance and time // in the test network the total walk distance always is 100 m, because the euclidean distance between a facility and its nearest pt stop always is 50 m - Assert.assertTrue(walkTravelDistance == 100.); - Assert.assertTrue(walkTravelTime == 100./defaultWalkSpeed); + Assertions.assertTrue(walkTravelDistance == 100.); + Assertions.assertTrue(walkTravelTime == 100./defaultWalkSpeed); // test pt travel distance and time // in the test network the euclidean distance between neighboring pt stops always is 180 m - Assert.assertTrue(ptTravelDistance == 180.*beelineDistanceFactor); - Assert.assertTrue(ptTravelTime == (180./defaultPtSpeed)*beelineDistanceFactor); + Assertions.assertTrue(ptTravelDistance == 180.*beelineDistanceFactor); + Assertions.assertTrue(ptTravelTime == (180./defaultPtSpeed)*beelineDistanceFactor); } // test travel times and distances for diagonal origin destination pairs @@ -166,16 +165,16 @@ else if( (origin + 1) % 4 == destination || (origin + 3) % 4 == destination){ // test total walk travel distance and time // in the test network the total walk distance always is 100 m, because the euclidean distance between a facility and its nearest pt stop always is 50 m - Assert.assertTrue(walkTravelDistance == 100.); - Assert.assertTrue(walkTravelTime == 100./defaultWalkSpeed); + Assertions.assertTrue(walkTravelDistance == 100.); + Assertions.assertTrue(walkTravelTime == 100./defaultWalkSpeed); // test upper bounds for pt travel distance and time (as described above) - Assert.assertTrue(ptTravelDistance <= euclideanDistance*beelineDistanceFactor); - Assert.assertTrue(ptTravelTime <= (euclideanDistance/defaultPtSpeed)*beelineDistanceFactor); + Assertions.assertTrue(ptTravelDistance <= euclideanDistance*beelineDistanceFactor); + Assertions.assertTrue(ptTravelTime <= (euclideanDistance/defaultPtSpeed)*beelineDistanceFactor); // test lower bounds for pt travel distance and time (as described above) - Assert.assertTrue(ptTravelDistance >= 180.*beelineDistanceFactor); - Assert.assertTrue(ptTravelTime >= (180./defaultPtSpeed)*beelineDistanceFactor); + Assertions.assertTrue(ptTravelDistance >= 180.*beelineDistanceFactor); + Assertions.assertTrue(ptTravelTime >= (180./defaultPtSpeed)*beelineDistanceFactor); } } } @@ -246,8 +245,8 @@ void testPtMatrixTimesAndDistances() throws IOException{ // the agents will walk 50 m to the nearest pt stop and 50 m back to their origin facility, so the total travel distance have to be 100 m. if(origin == destination){ - Assert.assertTrue(totalTravelDistance == 100.); - Assert.assertTrue(totalTravelTime == 100./defaultWalkSpeed); + Assertions.assertTrue(totalTravelDistance == 100.); + Assertions.assertTrue(totalTravelTime == 100./defaultWalkSpeed); } // test travel time and distance for different origins and destinations @@ -255,13 +254,13 @@ void testPtMatrixTimesAndDistances() throws IOException{ // test total walk travel distance and time // in the test network the total walk distance always is 100 m, because the euclidean distance between a facility and its nearest pt stop always is 50 m - Assert.assertTrue(walkTravelDistance == 100.); - Assert.assertTrue(walkTravelTime == 100./defaultWalkSpeed); + Assertions.assertTrue(walkTravelDistance == 100.); + Assertions.assertTrue(walkTravelTime == 100./defaultWalkSpeed); // test pt travel distance and time // in the csv-file the pt travel distance is given as 100 m; the pt travel time as 100 min - Assert.assertTrue(ptTravelDistance == 100.); - Assert.assertTrue(ptTravelTime == 100. * 60); // multiplied by 60 to convert minutes to seconds (csv-files are saved in minutes; matsim works with seconds) + Assertions.assertTrue(ptTravelDistance == 100.); + Assertions.assertTrue(ptTravelTime == 100. * 60); // multiplied by 60 to convert minutes to seconds (csv-files are saved in minutes; matsim works with seconds) } } } diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/TestQuadTree.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/TestQuadTree.java index fb284ae2911..22786b5a95c 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/TestQuadTree.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/TestQuadTree.java @@ -25,7 +25,7 @@ import java.util.Collection; import java.util.Iterator; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.collections.QuadTree; @@ -106,7 +106,7 @@ private void determineNearestPtStation(){ strb.append( ' ' ); } System.out.println( strb ); - Assert.assertEquals( "pt1a pt2a pt3a ", strb.toString() ); + Assertions.assertEquals( "pt1a pt2a pt3a ", strb.toString() ); } { Collection ptColWork = qTree.getDisk(work.getX(), work.getY(), distance); @@ -118,7 +118,7 @@ private void determineNearestPtStation(){ strb.append( ' ') ; } System.out.println( strb ); - Assert.assertEquals( "pt3b ", strb.toString() ); + Assertions.assertEquals( "pt3b ", strb.toString() ); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java index 9e13c9d134d..0809f0e6bf3 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java @@ -20,6 +20,7 @@ package org.matsim.contrib.minibus.genericUtils; import java.util.ArrayList; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.core.config.ConfigUtils; @@ -29,7 +30,6 @@ import org.matsim.pt.transitSchedule.api.TransitScheduleFactory; import org.matsim.pt.transitSchedule.api.TransitStopFacility; -import org.junit.Assert; import org.junit.Before; /** @@ -56,7 +56,7 @@ void testFindSecondTerminusStop() { stops.add(getOrCreateStopAtCoord(40, 0)); int indexSecondTerminusStop = TerminusStopFinder.findSecondTerminusStop(stops); - Assert.assertEquals(2, indexSecondTerminusStop); + Assertions.assertEquals(2, indexSecondTerminusStop); /* * rectangular line @@ -74,7 +74,7 @@ void testFindSecondTerminusStop() { stops.add(getOrCreateStopAtCoord(0, 10)); indexSecondTerminusStop = TerminusStopFinder.findSecondTerminusStop(stops); - Assert.assertEquals(2, indexSecondTerminusStop); + Assertions.assertEquals(2, indexSecondTerminusStop); /* * triangular line both candidate stops at same distance from first terminus @@ -91,7 +91,7 @@ void testFindSecondTerminusStop() { stops.add(getOrCreateStopAtCoord(0, 10)); indexSecondTerminusStop = TerminusStopFinder.findSecondTerminusStop(stops); - Assert.assertEquals(1, indexSecondTerminusStop); + Assertions.assertEquals(1, indexSecondTerminusStop); /* * triangular line many stops @@ -112,7 +112,7 @@ void testFindSecondTerminusStop() { stops.add(getOrCreateStopAtCoord(0, 20)); indexSecondTerminusStop = TerminusStopFinder.findSecondTerminusStop(stops); - Assert.assertEquals(5, indexSecondTerminusStop); + Assertions.assertEquals(5, indexSecondTerminusStop); /* * TODO: Currently failing, would require a more elaborate algorithm to determine the terminus stop diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java index 85b2ae5dc77..915d8919073 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/PControlerTestIT.java @@ -24,7 +24,7 @@ import java.util.LinkedList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -102,7 +102,7 @@ final void testPControler() { for (String filename : filesToCheckFor) { File f = new File(filename); - Assert.assertEquals(filename + " does not exist", true, f.exists() && !f.isDirectory()); + Assertions.assertEquals(true, f.exists() && !f.isDirectory(), filename + " does not exist"); } @@ -114,32 +114,32 @@ final void testPControler() { new TabularFileParser().parse(tabFileParserConfig, this); - Assert.assertEquals("There a less than the expected number of " + (numberOfIterations + 2) + " lines in " + filenameOfpStats, 12, this.pStatsResults.size()); + Assertions.assertEquals(12, this.pStatsResults.size(), "There a less than the expected number of " + (numberOfIterations + 2) + " lines in " + filenameOfpStats); // Check first iteration - Assert.assertEquals("Number of coops (first iteration)", "1", this.pStatsResults.get(1)[1]); - Assert.assertEquals("Number of routes (first iteration)", "1", this.pStatsResults.get(1)[3]); - Assert.assertEquals("Number of pax (first iteration)", "3092", this.pStatsResults.get(1)[5]); - Assert.assertEquals("Number of veh (first iteration)", "3", this.pStatsResults.get(1)[7]); - Assert.assertEquals("Number of budget (first iteration)", "-149.4493333333", this.pStatsResults.get(1)[9]); - - Assert.assertEquals("Number of +coops (first iteration)", "0", this.pStatsResults.get(1)[2]); - Assert.assertEquals("Number of +routes (first iteration)", "0", this.pStatsResults.get(1)[4]); - Assert.assertEquals("Number of +pax (first iteration)", "0", this.pStatsResults.get(1)[6]); - Assert.assertEquals("Number of +veh (first iteration)", "0", this.pStatsResults.get(1)[8]); - Assert.assertEquals("Number of +budget (first iteration)", "NaN", this.pStatsResults.get(1)[10]); - - Assert.assertEquals("Number of coops (last iteration)", "3", this.pStatsResults.get(11)[1]); - Assert.assertEquals("Number of routes (last iteration)", "3", this.pStatsResults.get(11)[3]); - Assert.assertEquals("Number of pax (last iteration)", "6728", this.pStatsResults.get(11)[5]); - Assert.assertEquals("Number of veh (last iteration)", "10", this.pStatsResults.get(11)[7]); - Assert.assertEquals("Number of budget (last iteration)", "68.7117037037", this.pStatsResults.get(11)[9]); - - Assert.assertEquals("Number of +coops (last iteration)", "2", this.pStatsResults.get(11)[2]); - Assert.assertEquals("Number of +routes (last iteration)", "2", this.pStatsResults.get(11)[4]); - Assert.assertEquals("Number of +pax (last iteration)", "6508", this.pStatsResults.get(11)[6]); - Assert.assertEquals("Number of +veh (last iteration)", "7", this.pStatsResults.get(11)[8]); - Assert.assertEquals("Number of +budget (last iteration)", "113.2005555555", this.pStatsResults.get(11)[10]); + Assertions.assertEquals("1", this.pStatsResults.get(1)[1], "Number of coops (first iteration)"); + Assertions.assertEquals("1", this.pStatsResults.get(1)[3], "Number of routes (first iteration)"); + Assertions.assertEquals("3092", this.pStatsResults.get(1)[5], "Number of pax (first iteration)"); + Assertions.assertEquals("3", this.pStatsResults.get(1)[7], "Number of veh (first iteration)"); + Assertions.assertEquals("-149.4493333333", this.pStatsResults.get(1)[9], "Number of budget (first iteration)"); + + Assertions.assertEquals("0", this.pStatsResults.get(1)[2], "Number of +coops (first iteration)"); + Assertions.assertEquals("0", this.pStatsResults.get(1)[4], "Number of +routes (first iteration)"); + Assertions.assertEquals("0", this.pStatsResults.get(1)[6], "Number of +pax (first iteration)"); + Assertions.assertEquals("0", this.pStatsResults.get(1)[8], "Number of +veh (first iteration)"); + Assertions.assertEquals("NaN", this.pStatsResults.get(1)[10], "Number of +budget (first iteration)"); + + Assertions.assertEquals("3", this.pStatsResults.get(11)[1], "Number of coops (last iteration)"); + Assertions.assertEquals("3", this.pStatsResults.get(11)[3], "Number of routes (last iteration)"); + Assertions.assertEquals("6728", this.pStatsResults.get(11)[5], "Number of pax (last iteration)"); + Assertions.assertEquals("10", this.pStatsResults.get(11)[7], "Number of veh (last iteration)"); + Assertions.assertEquals("68.7117037037", this.pStatsResults.get(11)[9], "Number of budget (last iteration)"); + + Assertions.assertEquals("2", this.pStatsResults.get(11)[2], "Number of +coops (last iteration)"); + Assertions.assertEquals("2", this.pStatsResults.get(11)[4], "Number of +routes (last iteration)"); + Assertions.assertEquals("6508", this.pStatsResults.get(11)[6], "Number of +pax (last iteration)"); + Assertions.assertEquals("7", this.pStatsResults.get(11)[8], "Number of +veh (last iteration)"); + Assertions.assertEquals("113.2005555555", this.pStatsResults.get(11)[10], "Number of +budget (last iteration)"); } @Override diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java index e83d57955aa..2050a1ad87c 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java @@ -24,8 +24,8 @@ import java.util.LinkedList; import java.util.List; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -91,7 +91,7 @@ final void testDefaultPControler() { for (String filename : filesToCheckFor) { File f = new File(filename); - Assert.assertEquals(filename + " does not exist", true, f.exists() && !f.isDirectory()); + Assertions.assertEquals(true, f.exists() && !f.isDirectory(), filename + " does not exist"); } // Check pStats @@ -103,16 +103,16 @@ final void testDefaultPControler() { new TabularFileParser().parse(tabFileParserConfig, this); // Check final iteration - Assert.assertEquals("Number of coops (final iteration)", "10", this.pStatsResults.get(31)[1]); - Assert.assertEquals("Number of routes (final iteration)", "13", this.pStatsResults.get(31)[3]); - Assert.assertEquals("Number of pax (final iteration)", "17163", this.pStatsResults.get(31)[5]); - Assert.assertEquals("Number of veh (final iteration)", "583", this.pStatsResults.get(31)[7]); - Assert.assertEquals("Number of budget (final iteration)", "-7123.2705000000", this.pStatsResults.get(31)[9]); - - Assert.assertEquals("Number of +coops (final iteration)", "4", this.pStatsResults.get(31)[2]); - Assert.assertEquals("Number of +routes (final iteration)", "6", this.pStatsResults.get(31)[4]); - Assert.assertEquals("Number of +pax (final iteration)", "3610", this.pStatsResults.get(31)[6]); - Assert.assertEquals("Number of +veh (final iteration)", "16", this.pStatsResults.get(31)[8]); + Assertions.assertEquals("10", this.pStatsResults.get(31)[1], "Number of coops (final iteration)"); + Assertions.assertEquals("13", this.pStatsResults.get(31)[3], "Number of routes (final iteration)"); + Assertions.assertEquals("17163", this.pStatsResults.get(31)[5], "Number of pax (final iteration)"); + Assertions.assertEquals("583", this.pStatsResults.get(31)[7], "Number of veh (final iteration)"); + Assertions.assertEquals("-7123.2705000000", this.pStatsResults.get(31)[9], "Number of budget (final iteration)"); + + Assertions.assertEquals("4", this.pStatsResults.get(31)[2], "Number of +coops (final iteration)"); + Assertions.assertEquals("6", this.pStatsResults.get(31)[4], "Number of +routes (final iteration)"); + Assertions.assertEquals("3610", this.pStatsResults.get(31)[6], "Number of +pax (final iteration)"); + Assertions.assertEquals("16", this.pStatsResults.get(31)[8], "Number of +veh (final iteration)"); } @Ignore @@ -153,7 +153,7 @@ final void testSubsidyPControler() { for (String filename : filesToCheckFor) { File f = new File(filename); - Assert.assertEquals(filename + " does not exist", true, f.exists() && !f.isDirectory()); + Assertions.assertEquals(true, f.exists() && !f.isDirectory(), filename + " does not exist"); } @@ -166,16 +166,16 @@ final void testSubsidyPControler() { new TabularFileParser().parse(tabFileParserConfig, this); // Check final iteration - Assert.assertEquals("Number of coops (final iteration)", "10", this.pStatsResults.get(31)[1]); - Assert.assertEquals("Number of routes (final iteration)", "62", this.pStatsResults.get(31)[3]); - Assert.assertEquals("Number of pax (final iteration)", "17210", this.pStatsResults.get(31)[5]); - Assert.assertEquals("Number of veh (final iteration)", "761", this.pStatsResults.get(31)[7]); - Assert.assertEquals("Number of budget (final iteration)", "-1876.5780555555", this.pStatsResults.get(31)[9]); - - Assert.assertEquals("Number of +coops (final iteration)", "4", this.pStatsResults.get(31)[2]); - Assert.assertEquals("Number of +routes (final iteration)", "51", this.pStatsResults.get(31)[4]); - Assert.assertEquals("Number of +pax (final iteration)", "9951", this.pStatsResults.get(31)[6]); - Assert.assertEquals("Number of +veh (final iteration)", "260", this.pStatsResults.get(31)[8]); + Assertions.assertEquals("10", this.pStatsResults.get(31)[1], "Number of coops (final iteration)"); + Assertions.assertEquals("62", this.pStatsResults.get(31)[3], "Number of routes (final iteration)"); + Assertions.assertEquals("17210", this.pStatsResults.get(31)[5], "Number of pax (final iteration)"); + Assertions.assertEquals("761", this.pStatsResults.get(31)[7], "Number of veh (final iteration)"); + Assertions.assertEquals("-1876.5780555555", this.pStatsResults.get(31)[9], "Number of budget (final iteration)"); + + Assertions.assertEquals("4", this.pStatsResults.get(31)[2], "Number of +coops (final iteration)"); + Assertions.assertEquals("51", this.pStatsResults.get(31)[4], "Number of +routes (final iteration)"); + Assertions.assertEquals("9951", this.pStatsResults.get(31)[6], "Number of +pax (final iteration)"); + Assertions.assertEquals("260", this.pStatsResults.get(31)[8], "Number of +veh (final iteration)"); } @Override diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java index 07e2e05c0e7..0b42a8231d0 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyTestIT.java @@ -24,7 +24,7 @@ import java.util.LinkedList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -91,7 +91,7 @@ final void testSubsidyPControler() { for (String filename : filesToCheckFor) { File f = new File(filename); - Assert.assertEquals(filename + " does not exist", true, f.exists() && !f.isDirectory()); + Assertions.assertEquals(true, f.exists() && !f.isDirectory(), filename + " does not exist"); } // Check pStats @@ -105,7 +105,7 @@ final void testSubsidyPControler() { // Check final iteration String actual = this.pStatsResults.get(2)[9]; // flaky (non-deterministic) test... allow multiple results - Assert.assertEquals("Number of budget (final iteration)", 174413625.6, Double.parseDouble(actual), 1); + Assertions.assertEquals(174413625.6, Double.parseDouble(actual), 1, "Number of budget (final iteration)"); } @Override diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java index f0d42a75dd7..1242c346766 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/EndRouteExtensionTest.java @@ -19,7 +19,7 @@ package org.matsim.contrib.minibus.replanning; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.minibus.PConstants; @@ -50,15 +50,15 @@ final void testRun() { PPlan testPlan = null; - Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start stop", "p_2111", coop.getBestPlan().getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2333", coop.getBestPlan().getStopsToBeServed().get(1).getId().toString()); - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertEquals(1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals("p_2111", coop.getBestPlan().getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2333", coop.getBestPlan().getStopsToBeServed().get(1).getId().toString(), "Compare end stop"); + Assertions.assertNull(testPlan, "Test plan should be null"); // buffer too small testPlan = strat.run(coop); - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertNull(testPlan, "Test plan should be null"); parameter = new ArrayList<>(); parameter.add("1000.0"); @@ -68,11 +68,11 @@ final void testRun() { testPlan = strat.run(coop); - Assert.assertNotNull("Test plan should not be null", testPlan); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); - Assert.assertEquals("Compare start stop", "p_2111", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2333", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3343", testPlan.getStopsToBeServed().get(2).getId().toString()); + Assertions.assertEquals("p_2111", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2333", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3343", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); parameter = new ArrayList<>(); @@ -83,17 +83,17 @@ final void testRun() { testPlan = strat.run(coop); - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2111", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2333", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3334", testPlan.getStopsToBeServed().get(2).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2111", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2333", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3334", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); coop.getBestPlan().setStopsToBeServed(testPlan.getStopsToBeServed()); testPlan = strat.run(coop); // remaining stops are covered now by the buffer of the otherwise wiggly route - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertNull(testPlan, "Test plan should be null"); } @@ -111,17 +111,17 @@ final void testRunVShapedRoute() { PPlan testPlan = null; - Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start stop", "p_2111", coop.getBestPlan().getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare middle stop", "p_3141", coop.getBestPlan().getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3222", coop.getBestPlan().getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare middle stop", "p_3141", coop.getBestPlan().getStopsToBeServed().get(3).getId().toString()); - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertEquals(1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals("p_2111", coop.getBestPlan().getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3141", coop.getBestPlan().getStopsToBeServed().get(1).getId().toString(), "Compare middle stop"); + Assertions.assertEquals("p_3222", coop.getBestPlan().getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_3141", coop.getBestPlan().getStopsToBeServed().get(3).getId().toString(), "Compare middle stop"); + Assertions.assertNull(testPlan, "Test plan should be null"); // buffer too small testPlan = strat.run(coop); - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertNull(testPlan, "Test plan should be null"); parameter = new ArrayList<>(); parameter.add("1000.0"); @@ -133,13 +133,13 @@ final void testRunVShapedRoute() { testPlan = strat.run(coop); - Assert.assertNotNull("Test plan should not be null", testPlan); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); - Assert.assertEquals("Compare start stop", "p_2111", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare former end stop", "p_3222", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare new end stop", "p_2223", testPlan.getStopsToBeServed().get(3).getId().toString()); - Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(4).getId().toString()); + Assertions.assertEquals("p_2111", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3141", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare most distant stop in between"); + Assertions.assertEquals("p_3222", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare former end stop"); + Assertions.assertEquals("p_2223", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare new end stop"); + Assertions.assertEquals("p_3141", testPlan.getStopsToBeServed().get(4).getId().toString(), "Compare most distant stop in between"); parameter = new ArrayList<>(); parameter.add("1000.0"); @@ -151,12 +151,12 @@ final void testRunVShapedRoute() { testPlan = strat.run(coop); - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2111", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare former end stop", "p_3222", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare new end stop", "p_1323", testPlan.getStopsToBeServed().get(3).getId().toString()); - Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(4).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2111", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3141", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare most distant stop in between"); + Assertions.assertEquals("p_3222", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare former end stop"); + Assertions.assertEquals("p_1323", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare new end stop"); + Assertions.assertEquals("p_3141", testPlan.getStopsToBeServed().get(4).getId().toString(), "Compare most distant stop in between"); parameter = new ArrayList<>(); parameter.add("1500.0"); @@ -168,12 +168,12 @@ final void testRunVShapedRoute() { testPlan = strat.run(coop); - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2111", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare former end stop", "p_3222", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare new end stop", "p_1413", testPlan.getStopsToBeServed().get(3).getId().toString()); - Assert.assertEquals("Compare most distant stop in between", "p_3141", testPlan.getStopsToBeServed().get(4).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2111", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3141", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare most distant stop in between"); + Assertions.assertEquals("p_3222", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare former end stop"); + Assertions.assertEquals("p_1413", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare new end stop"); + Assertions.assertEquals("p_3141", testPlan.getStopsToBeServed().get(4).getId().toString(), "Compare most distant stop in between"); coop.getBestPlan().setStopsToBeServed(testPlan.getStopsToBeServed()); coop.getBestPlan().setLine(testPlan.getLine()); @@ -181,13 +181,13 @@ final void testRunVShapedRoute() { testPlan = strat.run(coop); // Adds stop 2414 - Assert.assertEquals("Compare new end stop", "p_2414", testPlan.getStopsToBeServed().get(4).getId().toString()); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(4).getId().toString(), "Compare new end stop"); coop.getBestPlan().setStopsToBeServed(testPlan.getStopsToBeServed()); coop.getBestPlan().setLine(testPlan.getLine()); testPlan = strat.run(coop); // remaining stops are covered now by the buffer of the otherwise wiggly route - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertNull(testPlan, "Test plan should be null"); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java index dfae9e35570..15ac5a236ac 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomEndTimeAllocatorTest.java @@ -19,7 +19,7 @@ package org.matsim.contrib.minibus.replanning; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.minibus.hook.Operator; @@ -46,20 +46,20 @@ final void testRun() { coop.getBestPlan().setEndTime(40000.0); - Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare end time", 40000.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertEquals(1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(40000.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON, "Compare end time"); + Assertions.assertNull(testPlan, "Test plan should be null"); coop.getBestPlan().setNVehicles(2); // enough vehicles for testing, but mutation range 0 testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare end time", 40000.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare end time", 40000.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(40000.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON, "Compare end time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(40000.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON, "Compare end time"); param = new ArrayList<>(); param.add("900"); @@ -70,10 +70,10 @@ final void testRun() { // enough vehicles for testing testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 40000.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare end time", 40070.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(40000.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(40070.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON, "Compare end time"); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java index 0c51695020c..a32498bf0b3 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/MaxRandomStartTimeAllocatorTest.java @@ -19,7 +19,7 @@ package org.matsim.contrib.minibus.replanning; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.minibus.hook.Operator; @@ -47,20 +47,20 @@ final void testRun() { coop.getBestPlan().setStartTime(12000.0); coop.getBestPlan().setEndTime(36000.0); - Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 12000.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertEquals(1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(12000.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNull(testPlan, "Test plan should be null"); coop.getBestPlan().setNVehicles(2); // run strategy - time mutation is zero, thus no change testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 12000.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 12000.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(12000.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(12000.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); param = new ArrayList<>(); param.add("900"); @@ -71,10 +71,10 @@ final void testRun() { // enough vehicles for testing testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 12000.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 11920.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(12000.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(11920.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java index d9a58f4ce0b..93da904e378 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/SidewaysRouteExtensionTest.java @@ -19,7 +19,7 @@ package org.matsim.contrib.minibus.replanning; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.minibus.PConstants; @@ -62,15 +62,15 @@ final void testRun() { PPlan testPlan = null; - Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start stop", "p_2414", coop.getBestPlan().getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", coop.getBestPlan().getStopsToBeServed().get(1).getId().toString()); - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertEquals(1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals("p_2414", coop.getBestPlan().getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", coop.getBestPlan().getStopsToBeServed().get(1).getId().toString(), "Compare end stop"); + Assertions.assertNull(testPlan, "Test plan should be null"); // buffer too small testPlan = strat.run(coop); - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertNull(testPlan, "Test plan should be null"); parameter = new ArrayList<>(); parameter.add("100.0"); @@ -82,12 +82,12 @@ final void testRun() { testPlan = strat.run(coop); // enough buffer to add a stop located directly at the beeline - Assert.assertNotNull("Test plan should not be null", testPlan); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2324", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2324", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2324", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_2324", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); parameter = new ArrayList<>(); @@ -100,11 +100,11 @@ final void testRun() { testPlan = strat.run(coop); // enough buffer 0.5 * 3000m = 1500m - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2223", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare start stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2223", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2223", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2223", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); coop.getBestPlan().setStopsToBeServed(testPlan.getStopsToBeServed()); coop.getBestPlan().setLine(coop.getRouteProvider().createTransitLineFromOperatorPlan(coop.getId(), testPlan)); @@ -112,13 +112,13 @@ final void testRun() { testPlan = strat.run(coop); // and again stacking - therefore, enlarging the effective buffer - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2212", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2223", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(3).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2212", testPlan.getStopsToBeServed().get(4).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2223", testPlan.getStopsToBeServed().get(5).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2212", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2223", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_2212", testPlan.getStopsToBeServed().get(4).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2223", testPlan.getStopsToBeServed().get(5).getId().toString(), "Compare end stop"); parameter = new ArrayList<>(); parameter.add("4000.0"); @@ -131,74 +131,74 @@ final void testRun() { testPlan = strat.run(coop); // quite a lot buffer covering all nodes - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2324", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2324", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2324", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_2324", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); testPlan = strat.run(coop); // quite a lot buffer covering all nodes - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2223", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2223", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2223", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_2223", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); testPlan = strat.run(coop); // quite a lot buffer covering all nodes - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2223", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2223", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2223", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_2223", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); testPlan = strat.run(coop); // quite a lot buffer covering all nodes - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_3323", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3323", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3323", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_3323", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); testPlan = strat.run(coop); // quite a lot buffer covering all nodes - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_3433", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3433", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3433", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_3433", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); testPlan = strat.run(coop); // quite a lot buffer covering all nodes - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2423", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2423", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2423", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_2423", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); testPlan = strat.run(coop); // quite a lot buffer covering all nodes - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2322", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2322", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2322", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_2322", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); testPlan = strat.run(coop); // quite a lot buffer covering all nodes - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2221", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2221", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2221", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_2221", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); parameter = new ArrayList<>(); parameter.add("100.0"); @@ -211,20 +211,20 @@ final void testRun() { testPlan = strat.run(coop); // can now choose among stops at the outer edges - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_2324", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_2324", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_2324", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_2324", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); testPlan = strat.run(coop); // can now choose among stops at the outer edges - Assert.assertNotNull("Test plan should not be null", testPlan); - Assert.assertEquals("Compare start stop", "p_2414", testPlan.getStopsToBeServed().get(0).getId().toString()); - Assert.assertEquals("Compare start stop", "p_B", testPlan.getStopsToBeServed().get(1).getId().toString()); - Assert.assertEquals("Compare end stop", "p_3444", testPlan.getStopsToBeServed().get(2).getId().toString()); - Assert.assertEquals("Compare end stop", "p_B", testPlan.getStopsToBeServed().get(3).getId().toString()); + Assertions.assertNotNull(testPlan, "Test plan should not be null"); + Assertions.assertEquals("p_2414", testPlan.getStopsToBeServed().get(0).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_B", testPlan.getStopsToBeServed().get(1).getId().toString(), "Compare start stop"); + Assertions.assertEquals("p_3444", testPlan.getStopsToBeServed().get(2).getId().toString(), "Compare end stop"); + Assertions.assertEquals("p_B", testPlan.getStopsToBeServed().get(3).getId().toString(), "Compare end stop"); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java index d4cda9b24d9..279199989e0 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/TimeProviderTest.java @@ -21,7 +21,7 @@ import java.io.File; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -52,7 +52,7 @@ final void testGetRandomTimeInIntervalOneTimeSlot() { double startTime = 3600.0; double endTime = startTime; - Assert.assertEquals("New time (There is only one slot, thus time is zero)", 0.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON, "New time (There is only one slot, thus time is zero)"); } @Test @@ -69,7 +69,7 @@ final void testGetRandomTimeInIntervalOneSameStartEndTime() { double startTime = 3600.0; double endTime = startTime; - Assert.assertEquals("Same start and end time. Should return start time", 3600.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3600.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON, "Same start and end time. Should return start time"); } @Test @@ -86,8 +86,8 @@ final void testGetRandomTimeInIntervalDifferentStartEndTime() { double startTime = 7500.0; double endTime = 19400.0; - Assert.assertEquals("Check time", 7200.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); - Assert.assertEquals("Check time", 11700.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7200.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON, "Check time"); + Assertions.assertEquals(11700.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON, "Check time"); Id agentId = Id.create("id", Person.class); Id linkId = Id.create("id", Link.class); @@ -96,11 +96,11 @@ final void testGetRandomTimeInIntervalDifferentStartEndTime() { tP.handleEvent(new ActivityEndEvent(500.0 * i, agentId, linkId, facilityId, "type")); } - Assert.assertEquals("Check time", 9000.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); - Assert.assertEquals("Check time", 10800.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9000.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON, "Check time"); + Assertions.assertEquals(10800.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON, "Check time"); tP.reset(1); - Assert.assertEquals("Check time", 11700.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); - Assert.assertEquals("Check time", 9900.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON); + Assertions.assertEquals(11700.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON, "Check time"); + Assertions.assertEquals(9900.0, tP.getRandomTimeInInterval(startTime, endTime), MatsimTestUtils.EPSILON, "Check time"); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java index 9ece4bc8d4a..929d07a2dbd 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedEndTimeExtensionTest.java @@ -22,7 +22,7 @@ import java.io.File; import java.util.ArrayList; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -62,29 +62,29 @@ final void testRun() { coop.getBestPlan().setEndTime(19500.0); - Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertEquals(1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNull(testPlan, "Test plan should be null"); coop.getBestPlan().setNVehicles(2); // enough vehicles for testing testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 50400.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(50400.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON, "Compare start time"); // enough vehicles for testing testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 24300.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(24300.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON, "Compare start time"); // Now same with acts Id agentId = Id.create("id", Person.class); @@ -97,19 +97,19 @@ final void testRun() { testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 36000.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(36000.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON, "Compare start time"); tP.reset(1); testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 47700.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(19500.0, coop.getBestPlan().getEndTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(47700.0, testPlan.getEndTime(), MatsimTestUtils.EPSILON, "Compare start time"); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java index 38505c684cc..fe86892a6d6 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/replanning/WeightedStartTimeExtensionTest.java @@ -22,7 +22,7 @@ import java.io.File; import java.util.ArrayList; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -62,29 +62,29 @@ final void testRun() { coop.getBestPlan().setStartTime(19500.0); - Assert.assertEquals("Compare number of vehicles", 1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("Test plan should be null", testPlan); + Assertions.assertEquals(1.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNull(testPlan, "Test plan should be null"); coop.getBestPlan().setNVehicles(2); // enough vehicles for testing testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 9000.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(9000.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); // enough vehicles for testing testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 900.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(900.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); // Now same with acts Id agentId = Id.create("id", Person.class); @@ -97,19 +97,19 @@ final void testRun() { testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 9000.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(9000.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); tP.reset(1); testPlan = strat.run(coop); - Assert.assertEquals("Compare number of vehicles", 2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON); - Assert.assertNotNull("Test plan should be not null", testPlan); - Assert.assertEquals("There should be one vehicle bought", 1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Compare start time", 8100.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, coop.getBestPlan().getNVehicles(), MatsimTestUtils.EPSILON, "Compare number of vehicles"); + Assertions.assertEquals(19500.0, coop.getBestPlan().getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); + Assertions.assertNotNull(testPlan, "Test plan should be not null"); + Assertions.assertEquals(1.0, testPlan.getNVehicles(), MatsimTestUtils.EPSILON, "There should be one vehicle bought"); + Assertions.assertEquals(8100.0, testPlan.getStartTime(), MatsimTestUtils.EPSILON, "Compare start time"); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java index 173983379c2..b35559eeab5 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/ComplexCircleScheduleProviderTest.java @@ -21,7 +21,7 @@ import java.util.ArrayList; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -77,27 +77,27 @@ final void testCreateTransitLineLikeSimpleCircleScheduleProvider() { TransitLine line = prov.createTransitLineFromOperatorPlan(lineId, plan); - Assert.assertEquals("Transit line ids have to be the same", Id.create(lineId, TransitLine.class), line.getId()); + Assertions.assertEquals(Id.create(lineId, TransitLine.class), line.getId(), "Transit line ids have to be the same"); for (TransitRoute route : line.getRoutes().values()) { - Assert.assertEquals("Route id have to be the same", Id.create(lineId + "-" + routeId, TransitRoute.class), route.getId()); - Assert.assertEquals("Number of departures", 14.0, route.getDepartures().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Id.create(lineId + "-" + routeId, TransitRoute.class), route.getId(), "Route id have to be the same"); + Assertions.assertEquals(14.0, route.getDepartures().size(), MatsimTestUtils.EPSILON, "Number of departures"); // check links - Assert.assertEquals("Start link id has to be the same", refIds.get(0), route.getRoute().getStartLinkId()); + Assertions.assertEquals(refIds.get(0), route.getRoute().getStartLinkId(), "Start link id has to be the same"); int i = 1; for (Id linkId : route.getRoute().getLinkIds()) { - Assert.assertEquals("Route link ids have to be the same", refIds.get(i), linkId); + Assertions.assertEquals(refIds.get(i), linkId, "Route link ids have to be the same"); i++; } - Assert.assertEquals("End link id has to be the same", refIds.get(refIds.size() - 1), route.getRoute().getEndLinkId()); + Assertions.assertEquals(refIds.get(refIds.size() - 1), route.getRoute().getEndLinkId(), "End link id has to be the same"); // check stops i = 0; for (TransitRouteStop stop : route.getStops()) { - Assert.assertEquals("Route stop ids have to be the same", Id.create(pC.getPIdentifier() + refIds.get(i), TransitStopFacility.class), stop.getStopFacility().getId()); + Assertions.assertEquals(Id.create(pC.getPIdentifier() + refIds.get(i), TransitStopFacility.class), stop.getStopFacility().getId(), "Route stop ids have to be the same"); i++; } } @@ -144,30 +144,30 @@ final void testCreateTransitLineWithMoreStops() { TransitLine line = prov.createTransitLineFromOperatorPlan(lineId, plan); - Assert.assertEquals("Transit line ids have to be the same", Id.create(lineId, TransitLine.class), line.getId()); + Assertions.assertEquals(Id.create(lineId, TransitLine.class), line.getId(), "Transit line ids have to be the same"); for (TransitRoute route : line.getRoutes().values()) { - Assert.assertEquals("Route id have to be the same", Id.create(lineId + "-" + routeId, TransitRoute.class), route.getId()); + Assertions.assertEquals(Id.create(lineId + "-" + routeId, TransitRoute.class), route.getId(), "Route id have to be the same"); // check links - Assert.assertEquals("Start link id has to be the same", refIds.get(0), route.getRoute().getStartLinkId()); + Assertions.assertEquals(refIds.get(0), route.getRoute().getStartLinkId(), "Start link id has to be the same"); int i = 1; for (Id linkId : route.getRoute().getLinkIds()) { - Assert.assertEquals("Route link ids have to be the same", refIds.get(i), linkId); + Assertions.assertEquals(refIds.get(i), linkId, "Route link ids have to be the same"); i++; } - Assert.assertEquals("End link id has to be the same", refIds.get(refIds.size() - 1), route.getRoute().getEndLinkId()); + Assertions.assertEquals(refIds.get(refIds.size() - 1), route.getRoute().getEndLinkId(), "End link id has to be the same"); // check stops i = 0; for (TransitRouteStop stop : route.getStops()) { - Assert.assertEquals("Route stop ids have to be the same", Id.create(pC.getPIdentifier() + refIds.get(i), TransitStopFacility.class), stop.getStopFacility().getId()); + Assertions.assertEquals(Id.create(pC.getPIdentifier() + refIds.get(i), TransitStopFacility.class), stop.getStopFacility().getId(), "Route stop ids have to be the same"); i++; } - Assert.assertEquals("Number of departures", 11.0, route.getDepartures().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(11.0, route.getDepartures().size(), MatsimTestUtils.EPSILON, "Number of departures"); } } @@ -183,7 +183,7 @@ final void testGetRandomTransitStop() { for (int i = 0; i < 5; i++) { TransitStopFacility stop1 = prov.getRandomTransitStop(0); TransitStopFacility stop2 = prov.getRandomTransitStop(0); - Assert.assertNotSame("Stop should not be the same", stop1.getId(), stop2.getId()); + Assertions.assertNotSame(stop1.getId(), stop2.getId(), "Stop should not be the same"); } } @@ -198,6 +198,6 @@ final void testCreateEmptyLine() { SimpleCircleScheduleProvider prov = new SimpleCircleScheduleProvider(pC.getPIdentifier(), scenario.getTransitSchedule(), scenario.getNetwork(), null, pC.getVehicleMaximumVelocity(), pC.getDriverRestTime(), pC.getMode()); TransitLine line = prov.createEmptyLineFromOperator(lineId); - Assert.assertEquals("Transit line ids have to be the same", Id.create(lineId, TransitLine.class), line.getId()); + Assertions.assertEquals(Id.create(lineId, TransitLine.class), line.getId(), "Transit line ids have to be the same"); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java index 5d73e3a7e8d..b71c023add2 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/routeProvider/SimpleCircleScheduleProviderTest.java @@ -21,7 +21,7 @@ import java.util.ArrayList; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -77,29 +77,29 @@ final void testCreateTransitLine() { TransitLine line = prov.createTransitLineFromOperatorPlan(Id.create(lineId, Operator.class), plan); - Assert.assertEquals("Transit line ids have to be the same", Id.create(lineId, TransitLine.class), line.getId()); + Assertions.assertEquals(Id.create(lineId, TransitLine.class), line.getId(), "Transit line ids have to be the same"); for (TransitRoute route : line.getRoutes().values()) { - Assert.assertEquals("Route id have to be the same", Id.create(lineId + "-" + routeId, TransitRoute.class), route.getId()); - Assert.assertEquals("Number of departures", 14.0, route.getDepartures().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(Id.create(lineId + "-" + routeId, TransitRoute.class), route.getId(), "Route id have to be the same"); + Assertions.assertEquals(14.0, route.getDepartures().size(), MatsimTestUtils.EPSILON, "Number of departures"); // check stops int i = 0; for (TransitRouteStop stop : route.getStops()) { - Assert.assertEquals("Route stop ids have to be the same", Id.create(pC.getPIdentifier() + refIds.get(i), TransitStopFacility.class), stop.getStopFacility().getId()); + Assertions.assertEquals(Id.create(pC.getPIdentifier() + refIds.get(i), TransitStopFacility.class), stop.getStopFacility().getId(), "Route stop ids have to be the same"); i++; } // check links - Assert.assertEquals("Start link id has to be the same", refIds.get(0), route.getRoute().getStartLinkId()); + Assertions.assertEquals(refIds.get(0), route.getRoute().getStartLinkId(), "Start link id has to be the same"); i = 1; for (Id linkId : route.getRoute().getLinkIds()) { - Assert.assertEquals("Route link ids have to be the same", refIds.get(i), linkId); + Assertions.assertEquals(refIds.get(i), linkId, "Route link ids have to be the same"); i++; } - Assert.assertEquals("End link id has to be the same", refIds.get(refIds.size() - 1), route.getRoute().getEndLinkId()); + Assertions.assertEquals(refIds.get(refIds.size() - 1), route.getRoute().getEndLinkId(), "End link id has to be the same"); } } @@ -115,7 +115,7 @@ final void testGetRandomTransitStop() { for (int i = 0; i < 5; i++) { TransitStopFacility stop1 = prov.getRandomTransitStop(0); TransitStopFacility stop2 = prov.getRandomTransitStop(0); - Assert.assertNotSame("Stop should not be the same", stop1.getId(), stop2.getId()); + Assertions.assertNotSame(stop1.getId(), stop2.getId(), "Stop should not be the same"); } } @@ -130,6 +130,6 @@ final void testCreateEmptyLine() { SimpleCircleScheduleProvider prov = new SimpleCircleScheduleProvider(pC.getPIdentifier(), scenario.getTransitSchedule(), scenario.getNetwork(), null, pC.getVehicleMaximumVelocity(), pC.getDriverRestTime(), pC.getMode()); TransitLine line = prov.createEmptyLineFromOperator(lineId); - Assert.assertEquals("Transit line ids have to be the same", Id.create(lineId, TransitLine.class), line.getId()); + Assertions.assertEquals(Id.create(lineId, TransitLine.class), line.getId(), "Transit line ids have to be the same"); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java index 8c174734f6f..6cfd313655a 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreatePStopsOnJunctionApproachesAndBetweenJunctionsTest.java @@ -19,7 +19,7 @@ package org.matsim.contrib.minibus.schedule; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -69,12 +69,12 @@ final void testPScenarioHelperTestNetwork() { } /* 4 inner junctions with 4 approaches + 8 outer junctions with 3 approaches + 4 corners without junctions = 40 approach links */ - Assert.assertEquals("All 40 junction approach links got a paratransit stop", 40, numberOfParaStops, MatsimTestUtils.EPSILON); + Assertions.assertEquals(40, numberOfParaStops, MatsimTestUtils.EPSILON, "All 40 junction approach links got a paratransit stop"); /* Check whether these links are included as specified in the config */ - Assert.assertNotNull("Paratransit stop at link without real pt stop", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + realPtStopLink, TransitStopFacility.class))); - Assert.assertNotNull("Paratransit stop at link with small capacity", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooLowCapacityLink, TransitStopFacility.class))); - Assert.assertNotNull("Paratransit stop at link with high freespeed", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooHighFreespeedLink, TransitStopFacility.class))); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + realPtStopLink, TransitStopFacility.class)), "Paratransit stop at link without real pt stop"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooLowCapacityLink, TransitStopFacility.class)), "Paratransit stop at link with small capacity"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooHighFreespeedLink, TransitStopFacility.class)), "Paratransit stop at link with high freespeed"); TransitScheduleFactoryImpl tSF = new TransitScheduleFactoryImpl(); @@ -97,11 +97,11 @@ final void testPScenarioHelperTestNetwork() { } } - Assert.assertEquals("All car links minus one stop from formal transit got a paratransit stop", 40 - 3, numberOfParaStops, MatsimTestUtils.EPSILON); + Assertions.assertEquals(40 - 3, numberOfParaStops, MatsimTestUtils.EPSILON, "All car links minus one stop from formal transit got a paratransit stop"); - Assert.assertNull("No paratransit stop at link with real pt stop", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + realPtStopLink, TransitStopFacility.class))); - Assert.assertNull("No paratransit stop at link with too small capacity", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooLowCapacityLink, TransitStopFacility.class))); - Assert.assertNull("No paratransit stop at link with too high freespeed", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooHighFreespeedLink, TransitStopFacility.class))); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + realPtStopLink, TransitStopFacility.class)), "No paratransit stop at link with real pt stop"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooLowCapacityLink, TransitStopFacility.class)), "No paratransit stop at link with too small capacity"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + tooHighFreespeedLink, TransitStopFacility.class)), "No paratransit stop at link with too high freespeed"); } @@ -123,76 +123,76 @@ final void testComplexIntersection() { } } - Assert.assertEquals("Check number of paratransit stops", 16, numberOfParaStops, MatsimTestUtils.EPSILON); + Assertions.assertEquals(16, numberOfParaStops, MatsimTestUtils.EPSILON, "Check number of paratransit stops"); /* approaches to (unclustered) dead-ends */ - Assert.assertNotNull("Should find paratransit stop 'p_2_1'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "2_1", TransitStopFacility.class))); - Assert.assertNotNull("Should find paratransit stop 'p_4_3'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "4_3", TransitStopFacility.class))); - Assert.assertNotNull("Should find paratransit stop 'p_9_10'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "9_10", TransitStopFacility.class))); - Assert.assertNotNull("Should find paratransit stop 'p_30_31'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "30_31", TransitStopFacility.class))); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "2_1", TransitStopFacility.class)), "Should find paratransit stop 'p_2_1'"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "4_3", TransitStopFacility.class)), "Should find paratransit stop 'p_4_3'"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "9_10", TransitStopFacility.class)), "Should find paratransit stop 'p_9_10'"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "30_31", TransitStopFacility.class)), "Should find paratransit stop 'p_30_31'"); /* left junction: clustered nodes 5-6-7-8 */ - Assert.assertNotNull("Should find junction approach paratransit stop 'p_2_5'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "2_5", TransitStopFacility.class))); - Assert.assertNotNull("Should find junction approach paratransit stop 'p_4_6'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "4_6", TransitStopFacility.class))); - Assert.assertNotNull("Should find junction approach paratransit stop 'p_19_8'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "19_8", TransitStopFacility.class))); - Assert.assertNotNull("Should find junction approach paratransit stop 'p_9_7'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "9_7", TransitStopFacility.class))); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "2_5", TransitStopFacility.class)), "Should find junction approach paratransit stop 'p_2_5'"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "4_6", TransitStopFacility.class)), "Should find junction approach paratransit stop 'p_4_6'"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "19_8", TransitStopFacility.class)), "Should find junction approach paratransit stop 'p_19_8'"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "9_7", TransitStopFacility.class)), "Should find junction approach paratransit stop 'p_9_7'"); - Assert.assertNull("Should NOT find paratransit stop at link in junction '5_6'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "5_6", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '6_8'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "6_8", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '8_7'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "8_7", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '7_5'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "7_5", TransitStopFacility.class))); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "5_6", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '5_6'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "6_8", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '6_8'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "8_7", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '8_7'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "7_5", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '7_5'"); /* clustered nodes 11-12: dead-end, therefore only one stop approaching */ - Assert.assertNotNull("Should find junction approach paratransit stop 'p_13_12'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "13_12", TransitStopFacility.class))); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "13_12", TransitStopFacility.class)), "Should find junction approach paratransit stop 'p_13_12'"); /* right junction: clustered nodes 13-14-15-16-17-18-19-20-21-22-23-24 */ - Assert.assertNotNull("Should find junction approach paratransit stop 'p_6_15'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "6_15", TransitStopFacility.class))); - Assert.assertNotNull("Should find junction approach paratransit stop 'p_12_14'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "12_14", TransitStopFacility.class))); - Assert.assertNotNull("Should find junction approach paratransit stop 'p_27_22'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "27_22", TransitStopFacility.class))); - Assert.assertNotNull("Should find junction approach paratransit stop 'p_25_23'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "25_23", TransitStopFacility.class))); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "6_15", TransitStopFacility.class)), "Should find junction approach paratransit stop 'p_6_15'"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "12_14", TransitStopFacility.class)), "Should find junction approach paratransit stop 'p_12_14'"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "27_22", TransitStopFacility.class)), "Should find junction approach paratransit stop 'p_27_22'"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "25_23", TransitStopFacility.class)), "Should find junction approach paratransit stop 'p_25_23'"); // in-junction links // east-west, north-south - Assert.assertNull("Should NOT find paratransit stop at link in junction '15_16'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "15_16", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '16_17'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "16_17", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '17_18'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "17_18", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '14_17'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "14_17", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '17_21'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "17_21", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '21_24'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "21_24", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '22_21'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "22_21", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '21_20'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "21_20", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '20_19'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "20_19", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '23_20'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "23_20", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '20_16'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "20_16", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '16_13'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "16_13", TransitStopFacility.class))); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "15_16", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '15_16'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "16_17", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '16_17'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "17_18", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '17_18'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "14_17", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '14_17'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "17_21", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '17_21'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "21_24", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '21_24'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "22_21", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '22_21'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "21_20", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '21_20'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "20_19", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '20_19'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "23_20", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '23_20'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "20_16", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '20_16'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "16_13", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '16_13'"); // outer avoidance links - Assert.assertNull("Should NOT find paratransit stop at link in junction '15_13'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "15_13", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '14_18'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "14_18", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '22_24'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "22_24", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '23_19'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "23_19", TransitStopFacility.class))); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "15_13", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '15_13'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "14_18", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '14_18'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "22_24", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '22_24'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "23_19", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '23_19'"); // crossing - Assert.assertNull("Should NOT find paratransit stop at link in junction '17_20'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "17_20", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '20_17'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "20_17", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '16_21'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "16_21", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link in junction '21_16'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "21_16", TransitStopFacility.class))); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "17_20", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '17_20'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "20_17", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '20_17'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "16_21", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '16_21'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "21_16", TransitStopFacility.class)), "Should NOT find paratransit stop at link in junction '21_16'"); /* clustered nodes 25-26: dead-end, therefore only one stop approaching */ - Assert.assertNotNull("Should find junction approach paratransit stop 'p_24_25'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "24_25", TransitStopFacility.class))); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "24_25", TransitStopFacility.class)), "Should find junction approach paratransit stop 'p_24_25'"); /* links exiting junctions (towards dead-ends) */ - Assert.assertNull("Should NOT find paratransit stop at link exiting junction '7_2'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "7_2", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link exiting junction '5_4'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "5_4", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link exiting junction '8_9'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "8_9", TransitStopFacility.class))); - Assert.assertNull("Should NOT find paratransit stop at link exiting junction '18_19'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "7_2", TransitStopFacility.class))); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "7_2", TransitStopFacility.class)), "Should NOT find paratransit stop at link exiting junction '7_2'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "5_4", TransitStopFacility.class)), "Should NOT find paratransit stop at link exiting junction '5_4'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "8_9", TransitStopFacility.class)), "Should NOT find paratransit stop at link exiting junction '8_9'"); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "7_2", TransitStopFacility.class)), "Should NOT find paratransit stop at link exiting junction '18_19'"); /* Infill Stops between junctions / dead-ends */ - Assert.assertNotNull("Should find infill paratransit stop 'p_30_29'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "30_29", TransitStopFacility.class))); - Assert.assertNotNull("Should find infill paratransit stop 'p_27_28'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "27_28", TransitStopFacility.class))); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "30_29", TransitStopFacility.class)), "Should find infill paratransit stop 'p_30_29'"); + Assertions.assertNotNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "27_28", TransitStopFacility.class)), "Should find infill paratransit stop 'p_27_28'"); /* Check whether CalcTopoTypes is considered (type 8 : intersections only) */ pC.addParam("TopoTypesForStops", "8"); transitSchedule = CreatePStopsOnJunctionApproachesAndBetweenJunctions.createPStops(network, pC, new NetworkConfigGroup()); - Assert.assertNull("Should NOT find paratransit stop at link with wrong topo type (not an intersection) '30_31'", transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "30_31", TransitStopFacility.class))); + Assertions.assertNull(transitSchedule.getFacilities().get(Id.create(pC.getPIdentifier() + "30_31", TransitStopFacility.class)), "Should NOT find paratransit stop at link with wrong topo type (not an intersection) '30_31'"); } /** diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java index 38a447f0a74..d4fae5d5c8e 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/schedule/CreateStopsForAllCarLinksTest.java @@ -19,7 +19,7 @@ package org.matsim.contrib.minibus.schedule; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -60,7 +60,7 @@ final void testCreateStopsForAllCarLinks() { } } - Assert.assertEquals("All car links got a paratransit stop", numberOfCarLinks, numberOfParaStops, MatsimTestUtils.EPSILON); + Assertions.assertEquals(numberOfCarLinks, numberOfParaStops, MatsimTestUtils.EPSILON, "All car links got a paratransit stop"); TransitScheduleFactoryImpl tSF = new TransitScheduleFactoryImpl(); @@ -78,7 +78,7 @@ final void testCreateStopsForAllCarLinks() { } } - Assert.assertEquals("All car links minus one stop from formal transit got a paratransit stop", numberOfCarLinks - 1, numberOfParaStops, MatsimTestUtils.EPSILON); + Assertions.assertEquals(numberOfCarLinks - 1, numberOfParaStops, MatsimTestUtils.EPSILON, "All car links minus one stop from formal transit got a paratransit stop"); } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java index 8c4e676cfeb..c4a80910840 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java @@ -22,8 +22,8 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -133,7 +133,7 @@ void testRectangularLine() { double actual = penalty.getScore(pPlan1, route1); // area 10 x 10 = 100; beeline termini ({0,0}, {10,0}) = 10 double expected = -1 * ((10.0 * 10.0 / 10.0) - 1); - Assert.assertEquals(expected, actual, 0.001); + Assertions.assertEquals(expected, actual, 0.001); } private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java index 1cd63090a0e..bd2ee9230a3 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java @@ -22,8 +22,8 @@ import java.util.ArrayList; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -107,7 +107,7 @@ void testRectangularLine() { double actual = manager1.scoreRouteDesign(pPlan1); // 6 stop->stop distances of 10 units each in the stops (not stopsToBeServed) double expected = -1 * ((6 * 10 / (10 * Math.sqrt(2))) - 1); - Assert.assertEquals(expected, actual, 0.001); + Assertions.assertEquals(expected, actual, 0.001); /* option StopListToEvaluate.pPlanStopsToBeServed */ stop2stopVsBeeline.setStopListToEvaluate(StopListToEvaluate.pPlanStopsToBeServed); @@ -117,7 +117,7 @@ void testRectangularLine() { actual = manager1.scoreRouteDesign(pPlan1); // 4 stop->stop distances of 10 units each in the stops expected = -1 * ((4 * 10 / (10 * Math.sqrt(2))) - 1); - Assert.assertEquals(expected, actual, 0.001); + Assertions.assertEquals(expected, actual, 0.001); pConfig.removeRouteDesignScoreParams(RouteDesignScoreFunctionName.stop2StopVsBeelinePenalty); @@ -135,7 +135,7 @@ void testRectangularLine() { actual = manager1.scoreRouteDesign(pPlan1); // x=[-10,10], y=[0,10] -> 20 X 10 expected = -1 * ((20 * 10 / (10 * Math.sqrt(2))) - 1); - Assert.assertEquals(expected, actual, 0.001); + Assertions.assertEquals(expected, actual, 0.001); /* option StopListToEvaluate.pPlanStopsToBeServed */ areaVsBeeline.setStopListToEvaluate(StopListToEvaluate.pPlanStopsToBeServed); @@ -145,7 +145,7 @@ void testRectangularLine() { actual = manager1.scoreRouteDesign(pPlan1); // x=[0,10], y=[0,10] -> 10 X 10 expected = -1 * ((10 * 10 / (10 * Math.sqrt(2))) - 1); - Assert.assertEquals(expected, actual, 0.001); + Assertions.assertEquals(expected, actual, 0.001); /* check summing up of both */ pConfig.addRouteDesignScoreParams(stop2stopVsBeeline); @@ -155,7 +155,7 @@ void testRectangularLine() { actual = manager1.scoreRouteDesign(pPlan1); // x=[0,10], y=[0,10] -> 10 X 10 ; 4 stop->stop distances of 10 units each in the stops expected = -1 * ((10 * 10 / (10 * Math.sqrt(2))) - 1) + (-1) * ((4 * 10 / (10 * Math.sqrt(2))) - 1); - Assert.assertEquals(expected, actual, 0.001); + Assertions.assertEquals(expected, actual, 0.001); /* Check route with only two stops */ stopsToBeServed = new ArrayList<>(); @@ -181,7 +181,7 @@ void testRectangularLine() { actual = manager1.scoreRouteDesign(pPlan2); // would be positive expected = -1; - Assert.assertEquals(expected, actual, 0.001); + Assertions.assertEquals(expected, actual, 0.001); /* check that no subsidy emerges (no positive route design score) */ // high valueToStartScoring -> all scores below would be positive, check that they are capped at 0 @@ -205,7 +205,7 @@ void testRectangularLine() { actual = manager1.scoreRouteDesign(pPlan3); // would be positive expected = 0; - Assert.assertEquals(expected, actual, 0.001); + Assertions.assertEquals(expected, actual, 0.001); } private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java index 88c2217c9a6..1a5d848bfe1 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java @@ -21,8 +21,8 @@ import java.util.ArrayList; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -95,7 +95,7 @@ void testRouteServingSameStopTwice() { double actual = penalty.getScore(pPlan1, route1); // 4 stops served, but only 3 different stop ids double expected = -1 * ((4.0 / 3) - 1); - Assert.assertEquals(expected, actual, 0.001); + Assertions.assertEquals(expected, actual, 0.001); } private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java index 5d7d6647979..5d643653006 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsApproxContainerTest.java @@ -19,7 +19,7 @@ package org.matsim.contrib.minibus.stats; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.minibus.stats.RecursiveStatsApproxContainer; @@ -35,45 +35,45 @@ final void testRecursiveStatsContainer() { RecursiveStatsApproxContainer stats = new RecursiveStatsApproxContainer(0.1, 3); stats.handleNewEntry(1.0, 4.0, 2.0, 3.0); - Assert.assertEquals("mean coop", 1.0, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean route", 4.0, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean pax", 2.0, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean veh", 3.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev coop", Double.NaN, stats.getStdDevOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev route", Double.NaN, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev pax", Double.NaN, stats.getStdDevPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev veh", Double.NaN, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.0, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON, "mean coop"); + Assertions.assertEquals(4.0, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON, "mean route"); + Assertions.assertEquals(2.0, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON, "mean pax"); + Assertions.assertEquals(3.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON, "mean veh"); + Assertions.assertEquals(Double.NaN, stats.getStdDevOperators(), MatsimTestUtils.EPSILON, "std dev coop"); + Assertions.assertEquals(Double.NaN, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON, "std dev route"); + Assertions.assertEquals(Double.NaN, stats.getStdDevPax(), MatsimTestUtils.EPSILON, "std dev pax"); + Assertions.assertEquals(Double.NaN, stats.getStdDevVeh(), MatsimTestUtils.EPSILON, "std dev veh"); stats.handleNewEntry(2.0, 3.0, 3.0, 1.0); - Assert.assertEquals("mean coop", 1.5, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean route", 3.5, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean pax", 2.5, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean veh", 2.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev coop", 0.7071067811865476, stats.getStdDevOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev route", 0.7071067811865476, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev pax", 0.7071067811865476, stats.getStdDevPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev veh", 1.4142135623730951, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.5, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON, "mean coop"); + Assertions.assertEquals(3.5, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON, "mean route"); + Assertions.assertEquals(2.5, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON, "mean pax"); + Assertions.assertEquals(2.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON, "mean veh"); + Assertions.assertEquals(0.7071067811865476, stats.getStdDevOperators(), MatsimTestUtils.EPSILON, "std dev coop"); + Assertions.assertEquals(0.7071067811865476, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON, "std dev route"); + Assertions.assertEquals(0.7071067811865476, stats.getStdDevPax(), MatsimTestUtils.EPSILON, "std dev pax"); + Assertions.assertEquals(1.4142135623730951, stats.getStdDevVeh(), MatsimTestUtils.EPSILON, "std dev veh"); stats.handleNewEntry(3.0, 2.0, 1.0, 2.0); - Assert.assertEquals("mean coop", 2.0, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean route", 3.0, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean pax", 2.0, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean veh", 2.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev coop", 1.0, stats.getStdDevOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev route", 1.0, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev pax", 1.0, stats.getStdDevPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev veh", 1.0, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON, "mean coop"); + Assertions.assertEquals(3.0, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON, "mean route"); + Assertions.assertEquals(2.0, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON, "mean pax"); + Assertions.assertEquals(2.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON, "mean veh"); + Assertions.assertEquals(1.0, stats.getStdDevOperators(), MatsimTestUtils.EPSILON, "std dev coop"); + Assertions.assertEquals(1.0, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON, "std dev route"); + Assertions.assertEquals(1.0, stats.getStdDevPax(), MatsimTestUtils.EPSILON, "std dev pax"); + Assertions.assertEquals(1.0, stats.getStdDevVeh(), MatsimTestUtils.EPSILON, "std dev veh"); stats.handleNewEntry(1.0, 4.0, 2.0, 3.0); stats.handleNewEntry(2.0, 3.0, 3.0, 1.0); stats.handleNewEntry(12.0, 12345.0, 123.0, 1234.0); - Assert.assertEquals("mean coop", 2.9190000000000005, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean route", 1237.281, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean pax", 14.190000000000001, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean veh", 125.191, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev coop", 1.7181000000000002, stats.getStdDevOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev route", 1111.5819000000001, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev pax", 11.691, stats.getStdDevPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev veh", 111.7719, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.9190000000000005, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON, "mean coop"); + Assertions.assertEquals(1237.281, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON, "mean route"); + Assertions.assertEquals(14.190000000000001, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON, "mean pax"); + Assertions.assertEquals(125.191, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON, "mean veh"); + Assertions.assertEquals(1.7181000000000002, stats.getStdDevOperators(), MatsimTestUtils.EPSILON, "std dev coop"); + Assertions.assertEquals(1111.5819000000001, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON, "std dev route"); + Assertions.assertEquals(11.691, stats.getStdDevPax(), MatsimTestUtils.EPSILON, "std dev pax"); + Assertions.assertEquals(111.7719, stats.getStdDevVeh(), MatsimTestUtils.EPSILON, "std dev veh"); } } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java index 60afd38171d..4544e36e4f7 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/stats/RecursiveStatsContainerTest.java @@ -19,7 +19,7 @@ package org.matsim.contrib.minibus.stats; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.contrib.minibus.stats.RecursiveStatsContainer; @@ -35,45 +35,45 @@ final void testRecursiveStatsContainer() { RecursiveStatsContainer stats = new RecursiveStatsContainer(); stats.handleNewEntry(1.0, 4.0, 2.0, 3.0); - Assert.assertEquals("mean coop", 1.0, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean route", 4.0, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean pax", 2.0, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean veh", 3.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev coop", Double.NaN, stats.getStdDevOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev route", Double.NaN, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev pax", Double.NaN, stats.getStdDevPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev veh", Double.NaN, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.0, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON, "mean coop"); + Assertions.assertEquals(4.0, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON, "mean route"); + Assertions.assertEquals(2.0, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON, "mean pax"); + Assertions.assertEquals(3.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON, "mean veh"); + Assertions.assertEquals(Double.NaN, stats.getStdDevOperators(), MatsimTestUtils.EPSILON, "std dev coop"); + Assertions.assertEquals(Double.NaN, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON, "std dev route"); + Assertions.assertEquals(Double.NaN, stats.getStdDevPax(), MatsimTestUtils.EPSILON, "std dev pax"); + Assertions.assertEquals(Double.NaN, stats.getStdDevVeh(), MatsimTestUtils.EPSILON, "std dev veh"); stats.handleNewEntry(2.0, 3.0, 3.0, 1.0); - Assert.assertEquals("mean coop", 1.5, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean route", 3.5, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean pax", 2.5, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean veh", 2.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev coop", 0.7071067811865476, stats.getStdDevOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev route", 0.7071067811865476, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev pax", 0.7071067811865476, stats.getStdDevPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev veh", 1.4142135623730951, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.5, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON, "mean coop"); + Assertions.assertEquals(3.5, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON, "mean route"); + Assertions.assertEquals(2.5, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON, "mean pax"); + Assertions.assertEquals(2.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON, "mean veh"); + Assertions.assertEquals(0.7071067811865476, stats.getStdDevOperators(), MatsimTestUtils.EPSILON, "std dev coop"); + Assertions.assertEquals(0.7071067811865476, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON, "std dev route"); + Assertions.assertEquals(0.7071067811865476, stats.getStdDevPax(), MatsimTestUtils.EPSILON, "std dev pax"); + Assertions.assertEquals(1.4142135623730951, stats.getStdDevVeh(), MatsimTestUtils.EPSILON, "std dev veh"); stats.handleNewEntry(3.0, 2.0, 1.0, 2.0); - Assert.assertEquals("mean coop", 2.0, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean route", 3.0, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean pax", 2.0, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean veh", 2.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev coop", 1.0, stats.getStdDevOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev route", 1.0, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev pax", 1.0, stats.getStdDevPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev veh", 1.0, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON, "mean coop"); + Assertions.assertEquals(3.0, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON, "mean route"); + Assertions.assertEquals(2.0, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON, "mean pax"); + Assertions.assertEquals(2.0, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON, "mean veh"); + Assertions.assertEquals(1.0, stats.getStdDevOperators(), MatsimTestUtils.EPSILON, "std dev coop"); + Assertions.assertEquals(1.0, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON, "std dev route"); + Assertions.assertEquals(1.0, stats.getStdDevPax(), MatsimTestUtils.EPSILON, "std dev pax"); + Assertions.assertEquals(1.0, stats.getStdDevVeh(), MatsimTestUtils.EPSILON, "std dev veh"); stats.handleNewEntry(1.0, 4.0, 2.0, 3.0); stats.handleNewEntry(2.0, 3.0, 3.0, 1.0); stats.handleNewEntry(12.0, 12345.0, 123.0, 1234.0); - Assert.assertEquals("mean coop", 3.5, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean route", 2060.1666666666665, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean pax", 22.33333333333, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("mean veh", 207.33333333333, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev coop", 4.230839160261236, stats.getStdDevOperators(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev route", 5038.518806818793, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev pax", 49.32207078648124, stats.getStdDevPax(), MatsimTestUtils.EPSILON); - Assert.assertEquals("std dev veh", 502.962689139728, stats.getStdDevVeh(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.5, stats.getArithmeticMeanOperators(), MatsimTestUtils.EPSILON, "mean coop"); + Assertions.assertEquals(2060.1666666666665, stats.getArithmeticMeanRoutes(), MatsimTestUtils.EPSILON, "mean route"); + Assertions.assertEquals(22.33333333333, stats.getArithmeticMeanPax(), MatsimTestUtils.EPSILON, "mean pax"); + Assertions.assertEquals(207.33333333333, stats.getArithmeticMeanVeh(), MatsimTestUtils.EPSILON, "mean veh"); + Assertions.assertEquals(4.230839160261236, stats.getStdDevOperators(), MatsimTestUtils.EPSILON, "std dev coop"); + Assertions.assertEquals(5038.518806818793, stats.getStdDevRoutes(), MatsimTestUtils.EPSILON, "std dev route"); + Assertions.assertEquals(49.32207078648124, stats.getStdDevPax(), MatsimTestUtils.EPSILON, "std dev pax"); + Assertions.assertEquals(502.962689139728, stats.getStdDevVeh(), MatsimTestUtils.EPSILON, "std dev veh"); } } diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java index 158a897f8d9..995516bba38 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java @@ -25,8 +25,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -181,10 +181,10 @@ static void runSimpleScenario(int numberOfThreads) { controler.run(); // assume that the number of arrival events is correct - Assert.assertEquals(4, linkModeChecker.arrivalCount); + Assertions.assertEquals(4, linkModeChecker.arrivalCount); // assume that the number of link left events is correct - Assert.assertEquals(8, linkModeChecker.linkLeftCount); + Assertions.assertEquals(8, linkModeChecker.linkLeftCount); } @Ignore("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm @@ -288,23 +288,16 @@ public void install() { int carCount = linkModeChecker.leftCountPerMode.get(TransportMode.car); int bikeCount = linkModeChecker.leftCountPerMode.get(TransportMode.bike); int walkCount = linkModeChecker.leftCountPerMode.get(TransportMode.walk); - Assert.assertEquals( - "unexpected number of link leave events for mode car with number of threads "+numberOfThreads, -// 513445, carCount); - 692259, carCount); - Assert.assertEquals( - "unexpected number of link leave events for mode bike with number of threads "+numberOfThreads, - 4577, bikeCount); - Assert.assertEquals( - "unexpected number of link leave events for mode walk with number of threads "+numberOfThreads, -// 5834, walkCount); - 7970, walkCount); + Assertions.assertEquals( + 692259, carCount, "unexpected number of link leave events for mode car with number of threads "+numberOfThreads); + Assertions.assertEquals( + 4577, bikeCount, "unexpected number of link leave events for mode bike with number of threads "+numberOfThreads); + Assertions.assertEquals( + 7970, walkCount, "unexpected number of link leave events for mode walk with number of threads "+numberOfThreads); // check the total number of link left events - Assert.assertEquals( - "unexpected total number of link leave events with number of threads "+numberOfThreads, -// 523856, linkModeChecker.linkLeftCount); - 704806, linkModeChecker.linkLeftCount); + Assertions.assertEquals( + 704806, linkModeChecker.linkLeftCount, "unexpected total number of link leave events with number of threads "+numberOfThreads); // check the total mode travel times double carTravelTime = linkModeChecker.travelTimesPerMode.get(TransportMode.car); @@ -314,23 +307,16 @@ public void install() { LogManager.getLogger( this.getClass() ).warn( "bikeTravelTime: " + bikeTravelTime ) ; LogManager.getLogger( this.getClass() ).warn( "walkTravelTime: " + walkTravelTime ) ; if ( !config.routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - Assert.assertEquals( - "unexpected total travel time for car mode with number of threads "+numberOfThreads, - 1.1186864E8, carTravelTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals( + 1.1186864E8, carTravelTime, MatsimTestUtils.EPSILON, "unexpected total travel time for car mode with number of threads "+numberOfThreads); } else { - Assert.assertEquals( - "unexpected total travel time for car mode with number of threads "+numberOfThreads, -// 5.7263255E7, carTravelTime, MatsimTestUtils.EPSILON); - 1.11881636E8, carTravelTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals( + 1.11881636E8, carTravelTime, MatsimTestUtils.EPSILON, "unexpected total travel time for car mode with number of threads "+numberOfThreads); } - Assert.assertEquals( - "unexpected total travel time for bike mode with number of threads "+numberOfThreads, -// 480275.0, bikeTravelTime, MatsimTestUtils.EPSILON); - 480275.0, bikeTravelTime, MatsimTestUtils.EPSILON); - Assert.assertEquals( - "unexpected total travel time for walk mode with number of threads "+numberOfThreads, -// 3259757.0, walkTravelTime, MatsimTestUtils.EPSILON); - 3885025.0, walkTravelTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals( + 480275.0, bikeTravelTime, MatsimTestUtils.EPSILON, "unexpected total travel time for bike mode with number of threads "+numberOfThreads); + Assertions.assertEquals( + 3885025.0, walkTravelTime, MatsimTestUtils.EPSILON, "unexpected total travel time for walk mode with number of threads "+numberOfThreads); } private static Person createPerson(Scenario scenario, String id, String mode) { @@ -416,7 +402,7 @@ public void handleEvent(LinkLeaveEvent event) { } // assume that the agent is allowed to travel on the link - Assert.assertEquals(true, link.getAllowedModes().contains(mode)); + Assertions.assertEquals(true, link.getAllowedModes().contains(mode)); if ( mode.contains(TransportMode.non_network_walk ) || mode.contains(TransportMode.non_network_walk ) ) { return ; diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalTripRouterTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalTripRouterTest.java index f7edb1a21c8..a939cb76327 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalTripRouterTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalTripRouterTest.java @@ -21,7 +21,7 @@ package org.matsim.contrib.multimodal; import com.google.inject.name.Names; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -200,7 +200,7 @@ private void checkRoute(Leg leg, Network network) { break; } } - Assert.assertTrue(validMode); + Assertions.assertTrue(validMode); } } diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java index 7e2f7edc25f..3a3c2101c9a 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/RunMultimodalExampleTest.java @@ -2,7 +2,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.utils.io.IOUtils; @@ -27,7 +27,7 @@ void main(){ RunMultimodalExample.main( args ); } catch ( Exception ee ) { ee.printStackTrace(); - Assert.fail(); + Assertions.fail(); } } diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java index 3b224c976f0..ca3a78fce35 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/pt/MultiModalPTCombinationTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -130,13 +130,13 @@ void testMultiModalPtCombination() { * "home-transit_walk-pt_interact-pt-pt_interact-transit_walk-home" */ Plan ptPlan = ptPerson.getSelectedPlan(); - Assert.assertEquals(ptPlan.getPlanElements().toString(), 7, ptPlan.getPlanElements().size()); + Assertions.assertEquals(7, ptPlan.getPlanElements().size(), ptPlan.getPlanElements().toString()); Plan walkPlan = walkPerson.getSelectedPlan(); if ( !config.routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - Assert.assertEquals(walkPlan.getPlanElements().toString(), 7, walkPlan.getPlanElements().size()); + Assertions.assertEquals(7, walkPlan.getPlanElements().size(), walkPlan.getPlanElements().toString()); } else { - Assert.assertEquals(walkPlan.getPlanElements().toString(), 3, walkPlan.getPlanElements().size()); + Assertions.assertEquals(3, walkPlan.getPlanElements().size(), walkPlan.getPlanElements().toString()); } /* @@ -203,7 +203,7 @@ public void handleEvent(LinkLeaveEvent event) { } // assume that the agent is allowed to travel on the link - Assert.assertEquals(true, link.getAllowedModes().contains(this.modes.get(driverId))); + Assertions.assertEquals(true, link.getAllowedModes().contains(this.modes.get(driverId))); String mode = this.modes.get(driverId); int count = this.leftCountPerMode.get(mode); diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java index a8d88a3b193..c5a53f49b34 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/BikeTravelTimeTest.java @@ -20,14 +20,14 @@ package org.matsim.contrib.multimodal.router.util; -import static org.junit.Assert.assertTrue; - import java.util.HashMap; import java.util.Map; import org.apache.logging.log4j.LogManager; + +import static org.junit.jupiter.api.Assertions.assertTrue; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -95,7 +95,7 @@ void testLinkTravelTimeCalculation() { expectedTravelTime = link.getLength() / speed; printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 0.09368418280727171, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 0.09368418280727171, 0.0, 0); // increase age PersonUtils.setAge(person, 80); @@ -105,7 +105,7 @@ void testLinkTravelTimeCalculation() { expectedTravelTime = link.getLength() / speed; printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 0.2206463555843433, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 0.2206463555843433, 0.0, 0); // change gender PersonUtils.setSex(person, "f"); @@ -115,7 +115,7 @@ void testLinkTravelTimeCalculation() { expectedTravelTime = link.getLength() / speed; printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 0.24496957588497956, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 0.24496957588497956, 0.0, 0); // change slope from 0% to 10% h2 = 0.1; @@ -130,7 +130,7 @@ void testLinkTravelTimeCalculation() { expectedTravelTime = link.getLength() / speed; printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 0.7332007724445855, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 0.7332007724445855, 0.0, 0); // change slope from 10% to -10% h2 = -0.1; @@ -145,7 +145,7 @@ void testLinkTravelTimeCalculation() { expectedTravelTime = link.getLength() / speed; printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 0.40547153706106515, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 0.40547153706106515, 0.0, 0); // on very steep links bike speed should equals walk speed - set slope to 25% h2 = 0.25; @@ -158,7 +158,7 @@ void testLinkTravelTimeCalculation() { expectedTravelTime = walkTravelTime.getLinkTravelTime(link, 0.0, person, null); printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 1.7305194978040106, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 1.7305194978040106, 0.0, 0); } private void printInfo(Person p, double expected, double calculated, double slope) { diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java index b5ec67bb8a5..2d5abb0fff1 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/router/util/WalkTravelTimeTest.java @@ -20,14 +20,14 @@ package org.matsim.contrib.multimodal.router.util; -import static org.junit.Assert.assertTrue; - import java.util.HashMap; import java.util.Map; import org.apache.logging.log4j.LogManager; + +import static org.junit.jupiter.api.Assertions.assertTrue; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -92,7 +92,7 @@ void testLinkTravelTimeCalculation() { printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 0.42018055124753945, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 0.42018055124753945, 0.0, 0); // increase age PersonUtils.setAge(person, 80); @@ -102,7 +102,7 @@ void testLinkTravelTimeCalculation() { expectedTravelTime = link.getLength() / speed; printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 0.9896153709417187, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 0.9896153709417187, 0.0, 0); // change gender PersonUtils.setSex(person, "f"); @@ -112,7 +112,7 @@ void testLinkTravelTimeCalculation() { expectedTravelTime = link.getLength() / speed; printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 1.0987068291557665, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 1.0987068291557665, 0.0, 0); // change slope from 0% to -10% h2 = -0.1; @@ -126,7 +126,7 @@ void testLinkTravelTimeCalculation() { expectedTravelTime = link.getLength() / speed; printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 1.0489849428640121, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 1.0489849428640121, 0.0, 0); // change slope from -10% to 10% h2 = 0.1; @@ -139,7 +139,7 @@ void testLinkTravelTimeCalculation() { expectedTravelTime = link.getLength() / speed; printInfo(person, expectedTravelTime, calculatedTravelTime, slope); assertTrue(Math.abs(expectedTravelTime - calculatedTravelTime) < MatsimTestUtils.EPSILON); - Assert.assertEquals(calculatedTravelTime - 1.2397955643824945, 0.0, 0); + Assertions.assertEquals(calculatedTravelTime - 1.2397955643824945, 0.0, 0); } private void printInfo(Person p, double expected, double calculated, double slope) { diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java index 082b470276f..790922dd590 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/simengine/StuckAgentTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -170,8 +170,8 @@ void testStuckEvents() { } } - Assert.assertEquals(2, stuckBeforeSimulationEnd); - Assert.assertEquals(4, stuckCnt); + Assertions.assertEquals(2, stuckBeforeSimulationEnd); + Assertions.assertEquals(4, stuckCnt); } private Person createPerson(Scenario scenario, String id, String mode, Route route, double departureTime) { diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java index 2e28c957bdb..d5b61b0b590 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseConfigGroupIT.java @@ -22,7 +22,7 @@ */ package org.matsim.contrib.noise; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -53,22 +53,22 @@ final void test0(){ NoiseConfigGroup noiseParameters = (NoiseConfigGroup) config.getModule("noise"); // test the config parameters - Assert.assertEquals("wrong config parameter", 12345., noiseParameters.getReceiverPointGap(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(12345., noiseParameters.getReceiverPointGap(), MatsimTestUtils.EPSILON, "wrong config parameter"); String actForRecPtGrid = noiseParameters.getConsideredActivitiesForReceiverPointGridArray()[0] + "," + noiseParameters.getConsideredActivitiesForReceiverPointGridArray()[1] + "," + noiseParameters.getConsideredActivitiesForReceiverPointGridArray()[2]; - Assert.assertEquals("wrong config parameter", "home,sleep,eat", actForRecPtGrid); + Assertions.assertEquals("home,sleep,eat", actForRecPtGrid, "wrong config parameter"); String actForSpatFct = noiseParameters.getConsideredActivitiesForDamageCalculationArray()[0] + "," + noiseParameters.getConsideredActivitiesForDamageCalculationArray()[1] + "," + noiseParameters.getConsideredActivitiesForDamageCalculationArray()[2]; - Assert.assertEquals("wrong config parameter", "work,leisure,other", actForSpatFct); + Assertions.assertEquals("work,leisure,other", actForSpatFct, "wrong config parameter"); - Assert.assertEquals("wrong config parameter", 12345789., noiseParameters.getRelevantRadius(), MatsimTestUtils.EPSILON); - Assert.assertFalse("wrong config parameter", noiseParameters.isComputeNoiseDamages()); + Assertions.assertEquals(12345789., noiseParameters.getRelevantRadius(), MatsimTestUtils.EPSILON, "wrong config parameter"); + Assertions.assertFalse(noiseParameters.isComputeNoiseDamages(), "wrong config parameter"); String hgvIdPrefixes = noiseParameters.getHgvIdPrefixesArray()[0] + "," + noiseParameters.getHgvIdPrefixesArray()[1] + "," + noiseParameters.getHgvIdPrefixesArray()[2] + "," + noiseParameters.getHgvIdPrefixesArray()[3]; - Assert.assertEquals("wrong config parameter", "lkw,LKW,HGV,hgv", hgvIdPrefixes); + Assertions.assertEquals("lkw,LKW,HGV,hgv", hgvIdPrefixes, "wrong config parameter"); String tunnelLinkIds = noiseParameters.getTunnelLinkIDsSet().toArray()[0] + "," + noiseParameters.getTunnelLinkIDsSet().toArray()[1]; - Assert.assertEquals("wrong config parameter", "link1,link2", tunnelLinkIds); + Assertions.assertEquals("link1,link2", tunnelLinkIds, "wrong config parameter"); } @Test @@ -91,7 +91,7 @@ final void test1(){ Config outputConfig = ConfigUtils.loadConfig(controler.getConfig().controller().getOutputDirectory() + "/output_config.xml", new NoiseConfigGroup()); NoiseConfigGroup outputNoiseParameters = (NoiseConfigGroup) outputConfig.getModule("noise"); - Assert.assertEquals("input and output config parameters are not the same", noiseParameters.toString(), outputNoiseParameters.toString()); + Assertions.assertEquals(noiseParameters.toString(), outputNoiseParameters.toString(), "input and output config parameters are not the same"); } } diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java index 50b7321388a..e8aa97a3ab3 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseIT.java @@ -29,7 +29,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -106,17 +106,17 @@ final void test1(){ NoiseContext noiseContext = injector.getInstance( NoiseContext.class ) ; // test the grid of receiver points - Assert.assertEquals("wrong number of receiver points", 16, noiseContext.getReceiverPoints().size(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong coord for receiver point Id '10'", new Coord((double) 500, (double) 100).toString(), noiseContext.getReceiverPoints().get(Id.create(10, ReceiverPoint.class)).getCoord().toString()); + Assertions.assertEquals(16, noiseContext.getReceiverPoints().size(), MatsimTestUtils.EPSILON, "wrong number of receiver points"); + Assertions.assertEquals(new Coord((double) 500, (double) 100).toString(), noiseContext.getReceiverPoints().get(Id.create(10, ReceiverPoint.class)).getCoord().toString(), "wrong coord for receiver point Id '10'"); // test the allocation of activity coordinates to the nearest receiver point - Assert.assertEquals("wrong nearest receiver point Id for coord 300/300 (x/y)", "5", noiseContext.getGrid().getActivityCoord2receiverPointId().get(new Coord((double) 300, (double) 300)).toString()); - Assert.assertEquals("wrong nearest receiver point Id for coord 150/150 (x/y)", "9", noiseContext.getGrid().getActivityCoord2receiverPointId().get(new Coord((double) 150, (double) 150)).toString()); - Assert.assertEquals("wrong nearest receiver point Id for coord 100/100 (x/y)", "8", noiseContext.getGrid().getActivityCoord2receiverPointId().get(new Coord((double) 100, (double) 100)).toString()); - Assert.assertEquals("wrong nearest receiver point Id for coord 500/500 (x/y)", "2", noiseContext.getGrid().getActivityCoord2receiverPointId().get(new Coord((double) 500, (double) 500)).toString()); + Assertions.assertEquals("5", noiseContext.getGrid().getActivityCoord2receiverPointId().get(new Coord((double) 300, (double) 300)).toString(), "wrong nearest receiver point Id for coord 300/300 (x/y)"); + Assertions.assertEquals("9", noiseContext.getGrid().getActivityCoord2receiverPointId().get(new Coord((double) 150, (double) 150)).toString(), "wrong nearest receiver point Id for coord 150/150 (x/y)"); + Assertions.assertEquals("8", noiseContext.getGrid().getActivityCoord2receiverPointId().get(new Coord((double) 100, (double) 100)).toString(), "wrong nearest receiver point Id for coord 100/100 (x/y)"); + Assertions.assertEquals("2", noiseContext.getGrid().getActivityCoord2receiverPointId().get(new Coord((double) 500, (double) 500)).toString(), "wrong nearest receiver point Id for coord 500/500 (x/y)"); // test the allocation of relevant links to the receiver point - Assert.assertEquals("wrong relevant link for receiver point Id '15'", 3, noiseContext.getReceiverPoints().get(Id.create("15", Link.class)).getRelevantLinks().size()); + Assertions.assertEquals(3, noiseContext.getReceiverPoints().get(Id.create("15", Link.class)).getRelevantLinks().size(), "wrong relevant link for receiver point Id '15'"); // Assert.assertEquals("wrong relevant link for receiver point Id '15'", 3, noiseContext.getReceiverPoints().get(Id.create("15", Link.class)).getLinkId2angleCorrection().size()); // test the distance correction term @@ -406,7 +406,7 @@ else if(event.getActType().equals("work")){ double durationInThisIntervalMethod = actInfo.getDurationWithinInterval(currentTimeSlot, noiseParameters.getTimeBinSizeNoiseComputation()); - Assert.assertEquals("Durations of activities do not match!", durationInThisIntervalMethod, durationInThisInterval, MatsimTestUtils.EPSILON); + Assertions.assertEquals(durationInThisIntervalMethod, durationInThisInterval, MatsimTestUtils.EPSILON, "Durations of activities do not match!"); double unitsThisPersonActivityInfo = durationInThisInterval / noiseParameters.getTimeBinSizeNoiseComputation(); affectedPersons = ( unitsThisPersonActivityInfo * noiseParameters.getScaleFactor() ); @@ -442,17 +442,17 @@ else if(event.getActType().equals("work")){ if(currentTimeSlot == endTime){ if ( !runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("Wrong number of affected persons at receiver point 16", 2.3447222222222224, - affectedPersonsPerReceiverPointTest.get(Id.create("16", ReceiverPoint.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.3447222222222224, + affectedPersonsPerReceiverPointTest.get(Id.create("16", ReceiverPoint.class)), MatsimTestUtils.EPSILON, "Wrong number of affected persons at receiver point 16"); // result changed after changing where agents are walking to in access/egress (July 20) - Assert.assertEquals("Wrong number of affected persons at receiver point 0", 0.479722222222222, - affectedPersonsPerReceiverPointTest.get(Id.create("0", ReceiverPoint.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.479722222222222, + affectedPersonsPerReceiverPointTest.get(Id.create("0", ReceiverPoint.class)), MatsimTestUtils.EPSILON, "Wrong number of affected persons at receiver point 0"); } else { - Assert.assertEquals("Wrong number of affected persons at receiver point 16", 2.35305555555555, - affectedPersonsPerReceiverPointTest.get(Id.create("16", ReceiverPoint.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong number of affected persons at receiver point 0", 0.479722222222222, - affectedPersonsPerReceiverPointTest.get(Id.create("0", ReceiverPoint.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.35305555555555, + affectedPersonsPerReceiverPointTest.get(Id.create("16", ReceiverPoint.class)), MatsimTestUtils.EPSILON, "Wrong number of affected persons at receiver point 16"); + Assertions.assertEquals(0.479722222222222, + affectedPersonsPerReceiverPointTest.get(Id.create("0", ReceiverPoint.class)), MatsimTestUtils.EPSILON, "Wrong number of affected persons at receiver point 0"); } } @@ -475,9 +475,9 @@ else if(event.getActType().equals("work")){ log.warn( "affected:" + list ) ; } if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("Wrong number of affected persons", expected, actual, MatsimTestUtils.EPSILON); + Assertions.assertEquals(expected, actual, MatsimTestUtils.EPSILON, "Wrong number of affected persons"); } else { - Assert.assertEquals("Wrong number of affected persons", expected, actual, MatsimTestUtils.EPSILON); + Assertions.assertEquals(expected, actual, MatsimTestUtils.EPSILON, "Wrong number of affected persons"); } } @@ -562,14 +562,14 @@ else if(event.getActType().equals("work")){ double Dv = RLS90NoiseEmission.calculateGeschwindigkeitskorrekturDv(vCar, vHdv, p); double noiseEmission = mittelungspegel + Dv; - Assert.assertEquals("Wrong amount of emission!", noiseEmission, emissionsPerLink.get(linkId), MatsimTestUtils.EPSILON); + Assertions.assertEquals(noiseEmission, emissionsPerLink.get(linkId), MatsimTestUtils.EPSILON, "Wrong amount of emission!"); noiseEmissionsPerLink.put(linkId, noiseEmission); } - Assert.assertEquals("Wrong amount of emission!", 56.4418948379387, noiseEmissionsPerLink.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong amount of emission!", 86.4302864851097, noiseEmissionsPerLink.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong amount of emission!", 0., noiseEmissionsPerLink.get(Id.create("link4", Link.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(56.4418948379387, noiseEmissionsPerLink.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON, "Wrong amount of emission!"); + Assertions.assertEquals(86.4302864851097, noiseEmissionsPerLink.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON, "Wrong amount of emission!"); + Assertions.assertEquals(0., noiseEmissionsPerLink.get(Id.create("link4", Link.class)), MatsimTestUtils.EPSILON, "Wrong amount of emission!"); // ############################################ @@ -631,13 +631,13 @@ else if(event.getActType().equals("work")){ } - Assert.assertEquals("Wrong amount of immission!", rls90NoiseImmission.calculateResultingNoiseImmission(linkId2IsolatedImmission.values()), immissionPerReceiverPointId.get(rp.getId()), MatsimTestUtils.EPSILON); + Assertions.assertEquals(rls90NoiseImmission.calculateResultingNoiseImmission(linkId2IsolatedImmission.values()), immissionPerReceiverPointId.get(rp.getId()), MatsimTestUtils.EPSILON, "Wrong amount of immission!"); } - Assert.assertEquals("Wrong amount of immission!", 77.25915342419277, immissionPerReceiverPointId.get(Id.create("15", ReceiverPoint.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong amount of immission!", 67.9561670074151, immissionPerReceiverPointId.get(Id.create("31", ReceiverPoint.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong amount of immission!", 0., immissionPerReceiverPointId.get(Id.create("0", ReceiverPoint.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(77.25915342419277, immissionPerReceiverPointId.get(Id.create("15", ReceiverPoint.class)), MatsimTestUtils.EPSILON, "Wrong amount of immission!"); + Assertions.assertEquals(67.9561670074151, immissionPerReceiverPointId.get(Id.create("31", ReceiverPoint.class)), MatsimTestUtils.EPSILON, "Wrong amount of immission!"); + Assertions.assertEquals(0., immissionPerReceiverPointId.get(Id.create("0", ReceiverPoint.class)), MatsimTestUtils.EPSILON, "Wrong amount of immission!"); // ############################################ // test damages per receiver point and time @@ -681,19 +681,19 @@ else if(event.getActType().equals("work")){ double noiseImmission = immissionPerReceiverPointId.get(rp.getId()); double affectedAgentUnits = consideredAgentsPerReceiverPoint.get(rp.getId()).get(1); - Assert.assertEquals("Wrong damage!", NoiseDamageCalculation.calculateDamageCosts(noiseImmission, affectedAgentUnits, endTime, noiseParameters.getAnnualCostRate(), noiseParameters.getTimeBinSizeNoiseComputation()), damagesPerReceiverPointId.get(rp.getId()), MatsimTestUtils.EPSILON); + Assertions.assertEquals(NoiseDamageCalculation.calculateDamageCosts(noiseImmission, affectedAgentUnits, endTime, noiseParameters.getAnnualCostRate(), noiseParameters.getTimeBinSizeNoiseComputation()), damagesPerReceiverPointId.get(rp.getId()), MatsimTestUtils.EPSILON, "Wrong damage!"); } if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("Wrong damage!", 0.0664164095284536, - damagesPerReceiverPointId.get(Id.create("16", ReceiverPoint.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0664164095284536, + damagesPerReceiverPointId.get(Id.create("16", ReceiverPoint.class)), MatsimTestUtils.EPSILON, "Wrong damage!"); } else { - Assert.assertEquals("Wrong damage!", 0.06618119616706872 , - damagesPerReceiverPointId.get(Id.create("16", ReceiverPoint.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.06618119616706872 , + damagesPerReceiverPointId.get(Id.create("16", ReceiverPoint.class)), MatsimTestUtils.EPSILON, "Wrong damage!"); // result changed after changing walk distances } - Assert.assertEquals("Wrong damage!", 0., damagesPerReceiverPointId.get(Id.create("0", ReceiverPoint.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., damagesPerReceiverPointId.get(Id.create("0", ReceiverPoint.class)), MatsimTestUtils.EPSILON, "Wrong damage!"); // ############################################ // test average damages per link and time @@ -740,17 +740,17 @@ else if(event.getActType().equals("work")){ } if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("Wrong link's damage contribution!", 0.00079854651258, - damagesPerlinkId.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong link's damage contribution!", 0.06561786301587, - damagesPerlinkId.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.00079854651258, + damagesPerlinkId.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON, "Wrong link's damage contribution!"); + Assertions.assertEquals(0.06561786301587, + damagesPerlinkId.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON, "Wrong link's damage contribution!"); } else { - Assert.assertEquals("Wrong link's damage contribution!", 7.957184286235844E-4, - damagesPerlinkId.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong link's damage contribution!", 0.06538547773844494, - damagesPerlinkId.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7.957184286235844E-4, + damagesPerlinkId.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON, "Wrong link's damage contribution!"); + Assertions.assertEquals(0.06538547773844494, + damagesPerlinkId.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON, "Wrong link's damage contribution!"); } - Assert.assertEquals("Wrong link's damage contribution!", 0., damagesPerlinkId.get(Id.create("linkB5", Link.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., damagesPerlinkId.get(Id.create("linkB5", Link.class)), MatsimTestUtils.EPSILON, "Wrong link's damage contribution!"); // ############################################ // test average damages per link, car and time @@ -790,18 +790,18 @@ else if(event.getActType().equals("work")){ } if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("Wrong damage per car per link!", 0.00079854651258 / 2.0, - damagesPerCar.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong damage per car per link!", 0.06561786301587 / 2.0, - damagesPerCar.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.00079854651258 / 2.0, + damagesPerCar.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); + Assertions.assertEquals(0.06561786301587 / 2.0, + damagesPerCar.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); } else { - Assert.assertEquals("Wrong damage per car per link!", 3.978592143117922E-4, - damagesPerCar.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong damage per car per link!", 0.03269273886922247, - damagesPerCar.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.978592143117922E-4, + damagesPerCar.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); + Assertions.assertEquals(0.03269273886922247, + damagesPerCar.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); } - Assert.assertEquals("Wrong damage per car per link!", 0., - damagesPerCar.get(Id.create("linkB5", Link.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., + damagesPerCar.get(Id.create("linkB5", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); line = null; @@ -837,19 +837,19 @@ else if(event.getActType().equals("work")){ } if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("Wrong damage per car per link!", 0.00011994155845965193, - marginaldamagesPerCar.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong damage per car per link!", 0.008531432493391652, - marginaldamagesPerCar.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong damage per car per link!", 3.440988380343235E-8, - marginaldamagesPerCar.get(Id.create("linkB5", Link.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.00011994155845965193, + marginaldamagesPerCar.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); + Assertions.assertEquals(0.008531432493391652, + marginaldamagesPerCar.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); + Assertions.assertEquals(3.440988380343235E-8, + marginaldamagesPerCar.get(Id.create("linkB5", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); } else { - Assert.assertEquals("Wrong damage per car per link!", 1.1951678071236982E-4, - marginaldamagesPerCar.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong damage per car per link!", 0.008501218474617364, - marginaldamagesPerCar.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong damage per car per link!", 3.428802136662412E-8, - marginaldamagesPerCar.get(Id.create("linkB5", Link.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.1951678071236982E-4, + marginaldamagesPerCar.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); + Assertions.assertEquals(0.008501218474617364, + marginaldamagesPerCar.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); + Assertions.assertEquals(3.428802136662412E-8, + marginaldamagesPerCar.get(Id.create("linkB5", Link.class)), MatsimTestUtils.EPSILON, "Wrong damage per car per link!"); } // ############################################ @@ -863,47 +863,47 @@ else if(event.getActType().equals("work")){ if (event.getTimeBinEndTime() == 11 * 3600. && event.getLinkId().toString().equals(Id.create("linkA5", Link.class).toString()) && event.getCausingVehicleId().toString().equals((Id.create("person_car_test1", Vehicle.class).toString()))) { if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.0328089315079348, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0328089315079348, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } else { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.03269273886922247, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.03269273886922247, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } counter++; } else if (event.getTimeBinEndTime() == 11 * 3600. && event.getLinkId().toString().equals(Id.create("linkA5", Link.class).toString()) && event.getCausingVehicleId().toString().equals((Id.create("person_car_test2", Vehicle.class).toString()))) { if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.0328089315079348, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0328089315079348, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } else { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.03269273886922247, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.03269273886922247, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } counter++; } else if (event.getTimeBinEndTime() == 11 * 3600. && event.getLinkId().toString().equals(Id.create("link2", Link.class).toString()) && event.getCausingVehicleId().toString().equals((Id.create("person_car_test1", Vehicle.class).toString()))) { if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 3.992732562920194E-4, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.992732562920194E-4, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } else { - Assert.assertEquals("wrong cost per car for the given link and time interval", 3.978592143117922E-4, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.978592143117922E-4, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } counter++; } else if (event.getTimeBinEndTime() == 11 * 3600. && event.getLinkId().toString().equals(Id.create("link2", Link.class).toString()) && event.getCausingVehicleId().toString().equals((Id.create("person_car_test2", Vehicle.class).toString()))) { if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 3.992732562920194E-4, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.992732562920194E-4, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } else { - Assert.assertEquals("wrong cost per car for the given link and time interval", 3.978592143117922E-4, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.978592143117922E-4, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } counter++; } else { log.warn(event.toString()); - Assert.assertEquals("There should either be no further events, or the amount should be zero.", 0., event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., event.getAmount(), MatsimTestUtils.EPSILON, "There should either be no further events, or the amount should be zero."); } } - Assert.assertTrue("No event found to be tested.", tested); - Assert.assertEquals("Wrong number of total events.", 4, counter, MatsimTestUtils.EPSILON); + Assertions.assertTrue(tested, "No event found to be tested."); + Assertions.assertEquals(4, counter, MatsimTestUtils.EPSILON, "Wrong number of total events."); boolean tested2 = false; int counter2 = 0; @@ -912,38 +912,38 @@ else if(event.getActType().equals("work")){ if (event.getTimeBinEndTime() == 11 * 3600. && event.getrReceiverPointId().toString().equals(Id.create("16", ReceiverPoint.class).toString()) && event.getAffectedAgentId().toString().equals((Id.create("person_car_test1", Person.class).toString())) && event.getActType().equals("work") ) { if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.020745817449213576, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.020745817449213576, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } else { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.02062821077070937, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.02062821077070937, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } counter2++; } else if (event.getTimeBinEndTime() == 11 * 3600. && event.getrReceiverPointId().toString().equals(Id.create("16", ReceiverPoint.class).toString()) && event.getAffectedAgentId().toString().equals((Id.create("person_car_test2", Person.class).toString())) && event.getActType().equals("work")) { if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.017444990107520864, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.017444990107520864, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } else { - Assert.assertEquals("wrong cost per car for the given link and time interval",0.017327383429596242, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.017327383429596242, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } counter2++; } else if (event.getTimeBinEndTime() == 11 * 3600. && event.getrReceiverPointId().toString().equals(Id.create("16", ReceiverPoint.class).toString()) && event.getAffectedAgentId().toString().equals((Id.create("person_car_test3", Person.class).toString())) && event.getActType().equals("home")) { if ( !!runConfig.routing().getAccessEgressType().equals(AccessEgressType.none) ) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.028225601971719153, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.028225601971719153, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } else { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.028225601971719153, - event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.028225601971719153, + event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); } counter2++; } else { - Assert.assertEquals("There should either be no further events, or the amount should be zero.", 0., event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., event.getAmount(), MatsimTestUtils.EPSILON, "There should either be no further events, or the amount should be zero."); } } - Assert.assertTrue("No event found to be tested.", tested2); - Assert.assertEquals("Wrong number of total events.", 3, counter2, MatsimTestUtils.EPSILON); + Assertions.assertTrue(tested2, "No event found to be tested."); + Assertions.assertEquals(3, counter2, MatsimTestUtils.EPSILON, "Wrong number of total events."); } @@ -1004,23 +1004,23 @@ final void test2b(){ tested = true; if (event.getTimeBinEndTime() == 11 * 3600. && event.getLinkId().toString().equals(Id.create("linkA5", Link.class).toString()) && event.getCausingVehicleId().toString().equals((Id.create("person_car_test1", Vehicle.class).toString()))) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.008531432493391652, event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.008531432493391652, event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); counter++; } else if (event.getTimeBinEndTime() == 11 * 3600. && event.getLinkId().toString().equals(Id.create("linkA5", Link.class).toString()) && event.getCausingVehicleId().toString().equals((Id.create("person_car_test2", Vehicle.class).toString()))) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.008531432493391652, event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.008531432493391652, event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); counter++; } else if (event.getTimeBinEndTime() == 11 * 3600. && event.getLinkId().toString().equals(Id.create("link2", Link.class).toString()) && event.getCausingVehicleId().toString().equals((Id.create("person_car_test1", Vehicle.class).toString()))) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.00011994155845965193, event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.00011994155845965193, event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); counter++; } else if (event.getTimeBinEndTime() == 11 * 3600. && event.getLinkId().toString().equals(Id.create("link2", Link.class).toString()) && event.getCausingVehicleId().toString().equals((Id.create("person_car_test2", Vehicle.class).toString()))) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.00011994155845965193, event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.00011994155845965193, event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); counter++; } else { - Assert.assertEquals("There should either be no further events, or the amount should be zero.", 0., event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., event.getAmount(), MatsimTestUtils.EPSILON, "There should either be no further events, or the amount should be zero."); } } - Assert.assertTrue("No event found to be tested.", tested); - Assert.assertEquals("Wrong number of total events.", 4, counter, MatsimTestUtils.EPSILON); + Assertions.assertTrue(tested, "No event found to be tested."); + Assertions.assertEquals(4, counter, MatsimTestUtils.EPSILON, "Wrong number of total events."); boolean tested2 = false; int counter2 = 0; @@ -1028,21 +1028,21 @@ final void test2b(){ tested2 = true; if (event.getTimeBinEndTime() == 11 * 3600. && event.getrReceiverPointId().toString().equals(Id.create("16", ReceiverPoint.class).toString()) && event.getAffectedAgentId().toString().equals((Id.create("person_car_test1", Person.class).toString())) && event.getActType().equals("work") ) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.020745817449213576, event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.020745817449213576, event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); counter2++; } else if (event.getTimeBinEndTime() == 11 * 3600. && event.getrReceiverPointId().toString().equals(Id.create("16", ReceiverPoint.class).toString()) && event.getAffectedAgentId().toString().equals((Id.create("person_car_test2", Person.class).toString())) && event.getActType().equals("work")) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.017444990107520864, event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.017444990107520864, event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); counter2++; } else if (event.getTimeBinEndTime() == 11 * 3600. && event.getrReceiverPointId().toString().equals(Id.create("16", ReceiverPoint.class).toString()) && event.getAffectedAgentId().toString().equals((Id.create("person_car_test3", Person.class).toString())) && event.getActType().equals("home")) { - Assert.assertEquals("wrong cost per car for the given link and time interval", 0.028225601971719153, event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.028225601971719153, event.getAmount(), MatsimTestUtils.EPSILON, "wrong cost per car for the given link and time interval"); counter2++; } else { - Assert.assertEquals("There should either be no further events, or the amount should be zero.", 0., event.getAmount(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., event.getAmount(), MatsimTestUtils.EPSILON, "There should either be no further events, or the amount should be zero."); } } - Assert.assertTrue("No event found to be tested.", tested2); - Assert.assertEquals("Wrong number of total events.", 3, counter2, MatsimTestUtils.EPSILON); + Assertions.assertTrue(tested2, "No event found to be tested."); + Assertions.assertEquals(3, counter2, MatsimTestUtils.EPSILON, "Wrong number of total events."); } @@ -1164,9 +1164,9 @@ public void handleEvent(ActivityEndEvent event) { } - Assert.assertEquals("Wrong amount of emission!", 56.4418948379387, emissionsPerLink.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong amount of emission!", 77.3994680630406, emissionsPerLink.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong amount of emission!", 0., emissionsPerLink.get(Id.create("link4", Link.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(56.4418948379387, emissionsPerLink.get(Id.create("link2", Link.class)), MatsimTestUtils.EPSILON, "Wrong amount of emission!"); + Assertions.assertEquals(77.3994680630406, emissionsPerLink.get(Id.create("linkA5", Link.class)), MatsimTestUtils.EPSILON, "Wrong amount of emission!"); + Assertions.assertEquals(0., emissionsPerLink.get(Id.create("link4", Link.class)), MatsimTestUtils.EPSILON, "Wrong amount of emission!"); } catch (IOException e) { e.printStackTrace(); @@ -1189,12 +1189,12 @@ final void test3(){ double expectedEcar = 37.2424250943932; double expectedEhgv = 48.1; - Assert.assertEquals("Error in deviation term for speed correction (car)", expectedEcar, eCar, MatsimTestUtils.EPSILON); - Assert.assertEquals("Error in deviation term for speed correction (car)", expectedEcar, RLS90NoiseEmission.calculateLCar(vCar), MatsimTestUtils.EPSILON); - Assert.assertEquals("Error in deviation term for speed correction (hgv)", expectedEhgv, eHgv, MatsimTestUtils.EPSILON); - Assert.assertEquals("Error in deviation term for speed correction (hgv)", expectedEhgv, RLS90NoiseEmission.calculateLHdv(vHgv), MatsimTestUtils.EPSILON); + Assertions.assertEquals(expectedEcar, eCar, MatsimTestUtils.EPSILON, "Error in deviation term for speed correction (car)"); + Assertions.assertEquals(expectedEcar, RLS90NoiseEmission.calculateLCar(vCar), MatsimTestUtils.EPSILON, "Error in deviation term for speed correction (car)"); + Assertions.assertEquals(expectedEhgv, eHgv, MatsimTestUtils.EPSILON, "Error in deviation term for speed correction (hgv)"); + Assertions.assertEquals(expectedEhgv, RLS90NoiseEmission.calculateLHdv(vHgv), MatsimTestUtils.EPSILON, "Error in deviation term for speed correction (hgv)"); - Assert.assertTrue("Error in deviation term for speed correction (eCar > eHgv)", eCar < eHgv); + Assertions.assertTrue(eCar < eHgv, "Error in deviation term for speed correction (eCar > eHgv)"); // test mittelungspegel and speed correction @@ -1230,8 +1230,8 @@ else if( nHgvs == 2){ } } - Assert.assertEquals("Error while calculating Mittelungspegel for " + nCars + " car(s) and " + nHgvs + " hgv(s)!", expectedMittelungspegel, mittelungspegel, MatsimTestUtils.EPSILON); - Assert.assertEquals("Error while calculating Mittelungspegel for " + nCars + " car(s) and " + nHgvs + " hgv(s)!", expectedMittelungspegel, RLS90NoiseEmission.calculateMittelungspegelLm(n, p), MatsimTestUtils.EPSILON); + Assertions.assertEquals(expectedMittelungspegel, mittelungspegel, MatsimTestUtils.EPSILON, "Error while calculating Mittelungspegel for " + nCars + " car(s) and " + nHgvs + " hgv(s)!"); + Assertions.assertEquals(expectedMittelungspegel, RLS90NoiseEmission.calculateMittelungspegelLm(n, p), MatsimTestUtils.EPSILON, "Error while calculating Mittelungspegel for " + nCars + " car(s) and " + nHgvs + " hgv(s)!"); //test speed correction double speedCorrection = expectedEcar - 37.3 + 10 * Math.log10( (100 + ( Math.pow(10, 0.1*(expectedEhgv - expectedEcar)) - 1 ) * pInPercent ) / (100 + 8.23*pInPercent) ); @@ -1243,8 +1243,8 @@ else if( nHgvs == 2){ else if(p == 2./3.) expectedSpeedCorrection = 1.09354779994927; else if( p == 1) expectedSpeedCorrection = 1.14798298974089; - Assert.assertEquals("Error while calculating speed correction term for p = " + p + "!", expectedSpeedCorrection, speedCorrection, MatsimTestUtils.EPSILON); - Assert.assertEquals("Error while calculating speed correction term for p = " + p + "!", expectedSpeedCorrection, RLS90NoiseEmission.calculateGeschwindigkeitskorrekturDv(vCar, vHgv, p), MatsimTestUtils.EPSILON); + Assertions.assertEquals(expectedSpeedCorrection, speedCorrection, MatsimTestUtils.EPSILON, "Error while calculating speed correction term for p = " + p + "!"); + Assertions.assertEquals(expectedSpeedCorrection, RLS90NoiseEmission.calculateGeschwindigkeitskorrekturDv(vCar, vHgv, p), MatsimTestUtils.EPSILON, "Error while calculating speed correction term for p = " + p + "!"); } @@ -1262,8 +1262,8 @@ else if( nHgvs == 2){ else if(distance == 95) expectedDistanceCorrection = -4.8327746143211; else if(distance == 140) expectedDistanceCorrection = -6.87412053759382; - Assert.assertEquals("Error while calculating distance correction term!", expectedDistanceCorrection, distanceCorrection, MatsimTestUtils.EPSILON); - Assert.assertEquals("Error while calculating distance correction term!", expectedDistanceCorrection, RLS90NoiseImmission.calculateDistanceCorrection(distance), MatsimTestUtils.EPSILON); + Assertions.assertEquals(expectedDistanceCorrection, distanceCorrection, MatsimTestUtils.EPSILON, "Error while calculating distance correction term!"); + Assertions.assertEquals(expectedDistanceCorrection, RLS90NoiseImmission.calculateDistanceCorrection(distance), MatsimTestUtils.EPSILON, "Error while calculating distance correction term!"); } @@ -1283,8 +1283,8 @@ else if( nHgvs == 2){ else if(angle == 315) expectedAngleCorrection = 2.43038048686294; else if(angle == 360) expectedAngleCorrection = 3.01029995663981; - Assert.assertEquals("Error while calculating angle correction term!", expectedAngleCorrection, angleCorrection, MatsimTestUtils.EPSILON); - Assert.assertEquals("Error while calculating angle correction term!", expectedAngleCorrection, RLS90NoiseImmission.calculateAngleCorrection(angle), MatsimTestUtils.EPSILON); + Assertions.assertEquals(expectedAngleCorrection, angleCorrection, MatsimTestUtils.EPSILON, "Error while calculating angle correction term!"); + Assertions.assertEquals(expectedAngleCorrection, RLS90NoiseImmission.calculateAngleCorrection(angle), MatsimTestUtils.EPSILON, "Error while calculating angle correction term!"); } @@ -1326,7 +1326,7 @@ else if( nHgvs == 2){ double resultingNoiseImmission = 10*Math.log10(tmp); double expectedResultingNoiseImmission = 41.279204220881; - Assert.assertEquals("Error in noise immission calculation!", expectedResultingNoiseImmission, resultingNoiseImmission, MatsimTestUtils.EPSILON); + Assertions.assertEquals(expectedResultingNoiseImmission, resultingNoiseImmission, MatsimTestUtils.EPSILON, "Error in noise immission calculation!"); double resultingNoiseImmission1 = 0.; if (((Collection) immissions).size() > 0) { @@ -1341,7 +1341,7 @@ else if( nHgvs == 2){ resultingNoiseImmission1 = 0.; } } - Assert.assertEquals("Error in noise immission calculation!", expectedResultingNoiseImmission, resultingNoiseImmission1, MatsimTestUtils.EPSILON); + Assertions.assertEquals(expectedResultingNoiseImmission, resultingNoiseImmission1, MatsimTestUtils.EPSILON, "Error in noise immission calculation!"); //test noise damage double annualCostRate = (85.0/(1.95583)) * (Math.pow(1.02, (2014-1995))); @@ -1360,12 +1360,12 @@ else if( nHgvs == 2){ double expectedCostsEvening = 0.; double expectedCostsNight = 0.031590380365211; - Assert.assertEquals("Error in damage calculation!", expectedCostsDay, costsDay , MatsimTestUtils.EPSILON); - Assert.assertEquals("Error in damage calculation!", expectedCostsDay, NoiseDamageCalculation.calculateDamageCosts(resultingNoiseImmission, nPersons, 7.*3600, annualCostRate, 3600.) , MatsimTestUtils.EPSILON); - Assert.assertEquals("Error in damage calculation!", expectedCostsEvening, costsEvening, MatsimTestUtils.EPSILON); - Assert.assertEquals("Error in damage calculation!", expectedCostsEvening, NoiseDamageCalculation.calculateDamageCosts(resultingNoiseImmission, nPersons, 19.*3600, annualCostRate, 3600.), MatsimTestUtils.EPSILON); - Assert.assertEquals("Error in damage calculation!", expectedCostsNight, costsNight, MatsimTestUtils.EPSILON); - Assert.assertEquals("Error in damage calculation!", expectedCostsNight, NoiseDamageCalculation.calculateDamageCosts(resultingNoiseImmission, nPersons, 23.*3600, annualCostRate, 3600.), MatsimTestUtils.EPSILON); + Assertions.assertEquals(expectedCostsDay, costsDay , MatsimTestUtils.EPSILON, "Error in damage calculation!"); + Assertions.assertEquals(expectedCostsDay, NoiseDamageCalculation.calculateDamageCosts(resultingNoiseImmission, nPersons, 7.*3600, annualCostRate, 3600.) , MatsimTestUtils.EPSILON, "Error in damage calculation!"); + Assertions.assertEquals(expectedCostsEvening, costsEvening, MatsimTestUtils.EPSILON, "Error in damage calculation!"); + Assertions.assertEquals(expectedCostsEvening, NoiseDamageCalculation.calculateDamageCosts(resultingNoiseImmission, nPersons, 19.*3600, annualCostRate, 3600.), MatsimTestUtils.EPSILON, "Error in damage calculation!"); + Assertions.assertEquals(expectedCostsNight, costsNight, MatsimTestUtils.EPSILON, "Error in damage calculation!"); + Assertions.assertEquals(expectedCostsNight, NoiseDamageCalculation.calculateDamageCosts(resultingNoiseImmission, nPersons, 23.*3600, annualCostRate, 3600.), MatsimTestUtils.EPSILON, "Error in damage calculation!"); } // tests the static methods within class "noiseEquations" @@ -1382,19 +1382,19 @@ final void test4(){ double p = ( (double) nHGV / (double) (nCar + nHGV)); double mittelungspegel = RLS90NoiseEmission.calculateMittelungspegelLm(n, p); - Assert.assertEquals("Wrong mittelungspegel for n="+ n + " and p=" + p + "!", 69.22567453336540, mittelungspegel, MatsimTestUtils.EPSILON); + Assertions.assertEquals(69.22567453336540, mittelungspegel, MatsimTestUtils.EPSILON, "Wrong mittelungspegel for n="+ n + " and p=" + p + "!"); double lCar = RLS90NoiseEmission.calculateLCar(vCar); - Assert.assertEquals("Wrong LCar for vCar="+ vCar + "!", 27.70000000425900, lCar, MatsimTestUtils.EPSILON); + Assertions.assertEquals(27.70000000425900, lCar, MatsimTestUtils.EPSILON, "Wrong LCar for vCar="+ vCar + "!"); double lHGV = RLS90NoiseEmission.calculateLHdv(vHGV); - Assert.assertEquals("Wrong LHGV for vHGV="+ vHGV + "!", 6.60145932205085, lHGV, MatsimTestUtils.EPSILON); + Assertions.assertEquals(6.60145932205085, lHGV, MatsimTestUtils.EPSILON, "Wrong LHGV for vHGV="+ vHGV + "!"); double dV = RLS90NoiseEmission.calculateGeschwindigkeitskorrekturDv(vCar, vHGV, p); - Assert.assertEquals("Wrong Dv!", -10.772415234056300, dV, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-10.772415234056300, dV, MatsimTestUtils.EPSILON, "Wrong Dv!"); double emission = mittelungspegel + dV; - Assert.assertEquals("Wrong emission!", 58.453259299309124, emission, MatsimTestUtils.EPSILON); + Assertions.assertEquals(58.453259299309124, emission, MatsimTestUtils.EPSILON, "Wrong emission!"); // plus one car @@ -1403,7 +1403,7 @@ final void test4(){ double mittelungspegelPlusOneCar = RLS90NoiseEmission.calculateMittelungspegelLm(nPlusOneCar, pPlusOneCar); double dVPlusOneCar = RLS90NoiseEmission.calculateGeschwindigkeitskorrekturDv(vCar, vHGV, pPlusOneCar); double emissionPlusOneCar = mittelungspegelPlusOneCar + dVPlusOneCar; - Assert.assertEquals("Wrong emission!", 58.4896140186478, emissionPlusOneCar, MatsimTestUtils.EPSILON); + Assertions.assertEquals(58.4896140186478, emissionPlusOneCar, MatsimTestUtils.EPSILON, "Wrong emission!"); // plus one HGV @@ -1412,7 +1412,7 @@ final void test4(){ double mittelungspegelPlusOneHGV = RLS90NoiseEmission.calculateMittelungspegelLm(nPlusOneHGV, pPlusOneHGV); double dVPlusOneHGV = RLS90NoiseEmission.calculateGeschwindigkeitskorrekturDv(vCar, vHGV, pPlusOneHGV); double emissionPlusOneHGV = mittelungspegelPlusOneHGV + dVPlusOneHGV; - Assert.assertEquals("Wrong emission!", 58.4529399949061, emissionPlusOneHGV, MatsimTestUtils.EPSILON); + Assertions.assertEquals(58.4529399949061, emissionPlusOneHGV, MatsimTestUtils.EPSILON, "Wrong emission!"); } @@ -1430,19 +1430,19 @@ final void test5(){ double p = ( (double) nHGV / (double) (nCar + nHGV)); double mittelungspegel = RLS90NoiseEmission.calculateMittelungspegelLm(n, p); - Assert.assertEquals("Wrong mittelungspegel for n="+ n + " and p=" + p + "!", 69.22567453336540, mittelungspegel, MatsimTestUtils.EPSILON); + Assertions.assertEquals(69.22567453336540, mittelungspegel, MatsimTestUtils.EPSILON, "Wrong mittelungspegel for n="+ n + " and p=" + p + "!"); double lCar = RLS90NoiseEmission.calculateLCar(vCar); - Assert.assertEquals("Wrong LCar for vCar="+ vCar + "!", 28.54933574936720, lCar, MatsimTestUtils.EPSILON); + Assertions.assertEquals(28.54933574936720, lCar, MatsimTestUtils.EPSILON, "Wrong LCar for vCar="+ vCar + "!"); double lHGV = RLS90NoiseEmission.calculateLHdv(vHGV); - Assert.assertEquals("Wrong LHGV for vHGV="+ vHGV + "!", 41.56401568399580, lHGV, MatsimTestUtils.EPSILON); + Assertions.assertEquals(41.56401568399580, lHGV, MatsimTestUtils.EPSILON, "Wrong LHGV for vHGV="+ vHGV + "!"); double dV = RLS90NoiseEmission.calculateGeschwindigkeitskorrekturDv(vCar, vHGV, p); - Assert.assertEquals("Wrong Dv!", -7.689390421466860, dV, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-7.689390421466860, dV, MatsimTestUtils.EPSILON, "Wrong Dv!"); double emission = mittelungspegel + dV; - Assert.assertEquals("Wrong emission!", 61.5362841118986, emission, MatsimTestUtils.EPSILON); + Assertions.assertEquals(61.5362841118986, emission, MatsimTestUtils.EPSILON, "Wrong emission!"); // plus one car @@ -1451,7 +1451,7 @@ final void test5(){ double mittelungspegelPlusOneCar = RLS90NoiseEmission.calculateMittelungspegelLm(nPlusOneCar, pPlusOneCar); double dVPlusOneCar = RLS90NoiseEmission.calculateGeschwindigkeitskorrekturDv(vCar, vHGV, pPlusOneCar); double emissionPlusOneCar = mittelungspegelPlusOneCar + dVPlusOneCar; - Assert.assertEquals("Wrong emission!", 61.5580658162266, emissionPlusOneCar, MatsimTestUtils.EPSILON); + Assertions.assertEquals(61.5580658162266, emissionPlusOneCar, MatsimTestUtils.EPSILON, "Wrong emission!"); // plus one HGV @@ -1460,6 +1460,6 @@ final void test5(){ double mittelungspegelPlusOneHGV = RLS90NoiseEmission.calculateMittelungspegelLm(nPlusOneHGV, pPlusOneHGV); double dVPlusOneHGV = RLS90NoiseEmission.calculateGeschwindigkeitskorrekturDv(vCar, vHGV, pPlusOneHGV); double emissionPlusOneHGV = mittelungspegelPlusOneHGV + dVPlusOneHGV; - Assert.assertEquals("Wrong emission!", 61.9518310976080, emissionPlusOneHGV, MatsimTestUtils.EPSILON); + Assertions.assertEquals(61.9518310976080, emissionPlusOneHGV, MatsimTestUtils.EPSILON, "Wrong emission!"); } } diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java index 969ec85aef0..58218c5fa2b 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseOnlineExampleIT.java @@ -25,7 +25,7 @@ import com.google.inject.multibindings.Multibinder; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.analysis.XYTRecord; @@ -169,13 +169,13 @@ final void testOnTheFlyAggregationTerms() { //check whether on the fly caluclation equals file based aggregation terms for(Map.Entry, Double> entry: ldenByRp.entrySet()) { - Assert.assertEquals(entry.getValue(), nrps.get(entry.getKey()).getLden(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(entry.getValue(), nrps.get(entry.getKey()).getLden(), MatsimTestUtils.EPSILON); } for(Map.Entry, Double> entry: l69ByRp.entrySet()) { - Assert.assertEquals(entry.getValue(), nrps.get(entry.getKey()).getL69(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(entry.getValue(), nrps.get(entry.getKey()).getL69(), MatsimTestUtils.EPSILON); } for(Map.Entry, Double> entry: l1619ByRp.entrySet()) { - Assert.assertEquals(entry.getValue(), nrps.get(entry.getKey()).getL1619(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(entry.getValue(), nrps.get(entry.getKey()).getL1619(), MatsimTestUtils.EPSILON); } } diff --git a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java index 41c3ebb8836..a3e8bc91d45 100644 --- a/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java +++ b/contribs/noise/src/test/java/org/matsim/contrib/noise/NoiseRLS19IT.java @@ -22,7 +22,7 @@ */ package org.matsim.contrib.noise; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.locationtech.jts.geom.Coordinate; @@ -58,8 +58,8 @@ void testShielding() { final RLS19ShieldingCorrection shieldingCorrection = new RLS19ShieldingCorrection(); - Assert.assertEquals("Wrong shielding value z!", 34.463933081239965, - shieldingCorrection.calculateShieldingCorrection(10,15,15,15), MatsimTestUtils.EPSILON); + Assertions.assertEquals(34.463933081239965, + shieldingCorrection.calculateShieldingCorrection(10,15,15,15), MatsimTestUtils.EPSILON, "Wrong shielding value z!"); Config config = ConfigUtils.createConfig(); NoiseConfigGroup noiseConfigGroup = ConfigUtils.addOrGetModule(config, NoiseConfigGroup.class); @@ -89,8 +89,8 @@ void testShielding() { link.getFromNode().getCoord(), link.getToNode().getCoord(), rp.getCoord()); final double v = context.determineShieldingValue(rp, link, coord); - Assert.assertEquals("Wrong shielding correction!", 30.78517993490919, - v, MatsimTestUtils.EPSILON); + Assertions.assertEquals(30.78517993490919, + v, MatsimTestUtils.EPSILON, "Wrong shielding correction!"); } @@ -107,24 +107,24 @@ void testEmission() { RLS19NoiseEmission emission = new RLS19NoiseEmission(scenario, new RoadSurfaceContext(network), new DEMContextImpl(scenario.getConfig())); final double basePkwEmission = emission.calculateBaseVehicleTypeEmission(RLS19VehicleType.pkw, 40); - Assert.assertEquals("Wrong base pkw emission!", 97.70334139531323, basePkwEmission, MatsimTestUtils.EPSILON); + Assertions.assertEquals(97.70334139531323, basePkwEmission, MatsimTestUtils.EPSILON, "Wrong base pkw emission!"); double singleVehicleEmission = emission.calculateSingleVehicleEmission(noiseLink, RLS19VehicleType.pkw, 40); - Assert.assertEquals("Wrong single pkw emission!", 97.70334139531323, singleVehicleEmission, MatsimTestUtils.EPSILON); + Assertions.assertEquals(97.70334139531323, singleVehicleEmission, MatsimTestUtils.EPSILON, "Wrong single pkw emission!"); final double vehicleTypePart = emission.calculateVehicleTypeNoise(1, 40, singleVehicleEmission); - Assert.assertEquals("Wrong pkw emission sum part!", 1.4732421924637252E8, vehicleTypePart, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.4732421924637252E8, vehicleTypePart, MatsimTestUtils.EPSILON, "Wrong pkw emission sum part!"); final double noiseLinkEmission = emission.calculateEmission(noiseLink, 40, 40, 40, 1800, 0, 0); - Assert.assertEquals("Wrong noise link emission!", 84.23546653306667, noiseLinkEmission, MatsimTestUtils.EPSILON); + Assertions.assertEquals(84.23546653306667, noiseLinkEmission, MatsimTestUtils.EPSILON, "Wrong noise link emission!"); for (int i = 0; i < 1800; i++) { noiseLink.addEnteringAgent(RLS19VehicleType.pkw); } emission.calculateEmission(noiseLink); - Assert.assertEquals("Wrong final noise link emission!", 84.23546653306667, noiseLink.getEmission(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(84.23546653306667, noiseLink.getEmission(), MatsimTestUtils.EPSILON, "Wrong final noise link emission!"); } @Test @@ -177,7 +177,7 @@ void testImmission() { emission.calculateEmission(noiseLink); emission.calculateEmission(noiseLink2); - Assert.assertEquals("Wrong final noise link emission!", 84.23546653306667, noiseLink.getEmission(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(84.23546653306667, noiseLink.getEmission(), MatsimTestUtils.EPSILON, "Wrong final noise link emission!"); NoiseReceiverPoint rp = new NoiseReceiverPoint(Id.create("a", ReceiverPoint.class), new Coord(0,0)); @@ -193,7 +193,7 @@ void testImmission() { immission.calculateImmission(rp, 8*3600); final double currentImmission = rp.getCurrentImmission(); - Assert.assertEquals("Wrong immission!", 73.77467715144601, - currentImmission, MatsimTestUtils.EPSILON); + Assertions.assertEquals(73.77467715144601, + currentImmission, MatsimTestUtils.EPSILON, "Wrong immission!"); } } diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/LinkPropertiesTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/LinkPropertiesTest.java index 30e886f88d8..6576ff30bb9 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/LinkPropertiesTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/LinkPropertiesTest.java @@ -1,10 +1,10 @@ package org.matsim.contrib.osm.networkReader; +import static org.junit.jupiter.api.Assertions.assertEquals; + import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.network.Link; -import static org.junit.Assert.assertEquals; - public class LinkPropertiesTest { @Test diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java index 788c58bf779..cbe253f63dd 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmBicycleReaderTest.java @@ -19,7 +19,7 @@ import java.util.Map; import java.util.concurrent.ConcurrentHashMap; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class OsmBicycleReaderTest { diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java index ec2aadb4cc5..be16614ebf8 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java @@ -18,8 +18,8 @@ import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; public class OsmNetworkParserTest { private final ExecutorService executor = Executors.newSingleThreadExecutor(); diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java index 9aed196716b..96a13bec584 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java @@ -21,8 +21,8 @@ import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; public class OsmSignalsParserTest { diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java index 0a8771b6649..7d4793481e7 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/SupersonicOsmNetworkReaderTest.java @@ -30,7 +30,7 @@ import java.util.*; import java.util.function.Predicate; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class SupersonicOsmNetworkReaderTest { diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/Utils.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/Utils.java index 90eeba92a48..e9ba1daa961 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/Utils.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/Utils.java @@ -11,7 +11,7 @@ import de.topobyte.osm4j.pbf.seq.PbfWriter; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; import org.matsim.core.utils.geometry.CoordinateTransformation; @@ -23,8 +23,8 @@ import java.nio.file.Path; import java.util.*; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertTrue; public class Utils { @@ -196,13 +196,13 @@ static void assertEquals(Network expected, Network actual) { private static void testLinksAreEqual(Link expected, Link actual) { expected.getAllowedModes().forEach(mode -> assertTrue(actual.getAllowedModes().contains(mode))); - Assert.assertEquals(expected.getCapacity(), actual.getCapacity(), 0.001); - Assert.assertEquals(expected.getFlowCapacityPerSec(), actual.getFlowCapacityPerSec(), 0.001); - Assert.assertEquals(expected.getFreespeed(), actual.getFreespeed(), 0.001); - Assert.assertEquals(expected.getLength(), actual.getLength(), 0.001); - Assert.assertEquals(expected.getNumberOfLanes(), actual.getNumberOfLanes(), 0.001); - Assert.assertEquals(expected.getFromNode().getId(), actual.getFromNode().getId()); - Assert.assertEquals(expected.getToNode().getId(), actual.getToNode().getId()); + Assertions.assertEquals(expected.getCapacity(), actual.getCapacity(), 0.001); + Assertions.assertEquals(expected.getFlowCapacityPerSec(), actual.getFlowCapacityPerSec(), 0.001); + Assertions.assertEquals(expected.getFreespeed(), actual.getFreespeed(), 0.001); + Assertions.assertEquals(expected.getLength(), actual.getLength(), 0.001); + Assertions.assertEquals(expected.getNumberOfLanes(), actual.getNumberOfLanes(), 0.001); + Assertions.assertEquals(expected.getFromNode().getId(), actual.getFromNode().getId()); + Assertions.assertEquals(expected.getToNode().getId(), actual.getToNode().getId()); } private static void testNodesAreEqual(org.matsim.api.core.v01.network.Node expected, org.matsim.api.core.v01.network.Node actual) { @@ -210,10 +210,10 @@ private static void testNodesAreEqual(org.matsim.api.core.v01.network.Node expec // test x and y separately, so that we can have a delta. // In java version >=11 Assert.assertEquals(expected.getCoord(), actual.getCoord()) also works // keep this in as long as we use java-8 - Assert.assertEquals(expected.getCoord().getX(), actual.getCoord().getX(), 0.00000001); - Assert.assertEquals(expected.getCoord().getY(), actual.getCoord().getY(), 0.00000001); - expected.getOutLinks().forEach((id, link) -> Assert.assertEquals(link.getId(), actual.getOutLinks().get(id).getId())); - expected.getInLinks().forEach((id, link) -> Assert.assertEquals(link.getId(), actual.getInLinks().get(id).getId())); + Assertions.assertEquals(expected.getCoord().getX(), actual.getCoord().getX(), 0.00000001); + Assertions.assertEquals(expected.getCoord().getY(), actual.getCoord().getY(), 0.00000001); + expected.getOutLinks().forEach((id, link) -> Assertions.assertEquals(link.getId(), actual.getOutLinks().get(id).getId())); + expected.getInLinks().forEach((id, link) -> Assertions.assertEquals(link.getId(), actual.getInLinks().get(id).getId())); } static class OsmData { diff --git a/contribs/osm/src/test/java/otherPackage/SupersonicOsmNetworkReaderBuilderTest.java b/contribs/osm/src/test/java/otherPackage/SupersonicOsmNetworkReaderBuilderTest.java index e408f441573..15ffb2602f8 100644 --- a/contribs/osm/src/test/java/otherPackage/SupersonicOsmNetworkReaderBuilderTest.java +++ b/contribs/osm/src/test/java/otherPackage/SupersonicOsmNetworkReaderBuilderTest.java @@ -1,11 +1,11 @@ package otherPackage; +import static org.junit.jupiter.api.Assertions.assertNotNull; + import org.junit.jupiter.api.Test; import org.matsim.contrib.osm.networkReader.SupersonicOsmNetworkReader; import org.matsim.core.utils.geometry.transformations.IdentityTransformation; -import static org.junit.Assert.assertNotNull; - public class SupersonicOsmNetworkReaderBuilderTest { @Test diff --git a/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java b/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java index d54fb3ef32e..c24c225fe3b 100644 --- a/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java +++ b/contribs/otfvis/src/test/java/org/matsim/contrib/otfvis/OTFVisIT.java @@ -23,7 +23,7 @@ */ package org.matsim.contrib.otfvis; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.config.Config; @@ -61,7 +61,7 @@ void testConvert() { OTFVis.main(args); File f = new File(mviFilename); - Assert.assertTrue("No mvi file written!", f.exists()); + Assertions.assertTrue(f.exists(), "No mvi file written!"); } @Test @@ -83,9 +83,9 @@ void testOTFVisSnapshotWriterOnQSim() { controler.getConfig().controller().setDumpDataAtEnd(false); controler.run(); - Assert.assertTrue(new File(controler.getControlerIO().getIterationFilename(0, "otfvis.mvi")).exists()); - Assert.assertTrue(new File(controler.getControlerIO().getIterationFilename(1, "otfvis.mvi")).exists()); - Assert.assertTrue(new File(controler.getControlerIO().getIterationFilename(2, "otfvis.mvi")).exists()); + Assertions.assertTrue(new File(controler.getControlerIO().getIterationFilename(0, "otfvis.mvi")).exists()); + Assertions.assertTrue(new File(controler.getControlerIO().getIterationFilename(1, "otfvis.mvi")).exists()); + Assertions.assertTrue(new File(controler.getControlerIO().getIterationFilename(2, "otfvis.mvi")).exists()); } } diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/GeneralLibTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/GeneralLibTest.java index 23663b17e77..db32de7e1e3 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/GeneralLibTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/GeneralLibTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.parking.lib; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; import org.matsim.contrib.parking.parkingchoice.lib.GeneralLib; diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/DoubleValueHashMapTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/DoubleValueHashMapTest.java index 896c5cd8849..607ea846b72 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/DoubleValueHashMapTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/DoubleValueHashMapTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.parking.lib.obj; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.matsim.contrib.parking.parkingchoice.lib.obj.DoubleValueHashMap; diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/LinkedListValueHashMapTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/LinkedListValueHashMapTest.java index 99f18824563..d99c1b6195b 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/LinkedListValueHashMapTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/lib/obj/LinkedListValueHashMapTest.java @@ -1,10 +1,10 @@ package org.matsim.contrib.parking.lib.obj; -import static org.junit.Assert.assertEquals; - import java.util.HashMap; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.contrib.parking.parkingchoice.lib.obj.HashMapInverter; import org.matsim.contrib.parking.parkingchoice.lib.obj.LinkedListValueHashMap; diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/ParkingCostVehicleTrackerTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/ParkingCostVehicleTrackerTest.java index ba933fa274b..0cbb0de9f99 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/ParkingCostVehicleTrackerTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/ParkingCostVehicleTrackerTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.parking.parkingcost.eventhandling; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -78,53 +78,53 @@ void testParkingCostEvents() { f.events.processEvent(new VehicleEntersTrafficEvent(7.00 * 3600, personId, linkHome, vehicleId, "car", 1.0)); f.events.processEvent(new VehicleLeavesTrafficEvent(7.25 * 3600, personId, linkWork, vehicleId, "car", 1.0)); f.events.processEvent(new ActivityStartEvent(7.25 * 3600, personId, linkWork, null, "work", null)); - Assert.assertEquals(3, collector.getEvents().size()); + Assertions.assertEquals(3, collector.getEvents().size()); f.events.processEvent(new VehicleEntersTrafficEvent(12.00 * 3600, personId, linkWork, vehicleId, "car", 1.0)); - Assert.assertEquals(5, collector.getEvents().size()); + Assertions.assertEquals(5, collector.getEvents().size()); - Assert.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(3).getClass()); + Assertions.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(3).getClass()); PersonMoneyEvent parkingEvent1 = (PersonMoneyEvent) collector.getEvents().get(3); - Assert.assertEquals(personId, parkingEvent1.getPersonId()); - Assert.assertEquals(12.00 * 3600, parkingEvent1.getTime(), 1e-8); - Assert.assertEquals((12 - 7.25) * hourlyParkingCostWork, -parkingEvent1.getAmount(), 1e-8); + Assertions.assertEquals(personId, parkingEvent1.getPersonId()); + Assertions.assertEquals(12.00 * 3600, parkingEvent1.getTime(), 1e-8); + Assertions.assertEquals((12 - 7.25) * hourlyParkingCostWork, -parkingEvent1.getAmount(), 1e-8); f.events.processEvent(new VehicleLeavesTrafficEvent(12.25 * 3600, personId, linkShop, vehicleId, "car", 1.0)); f.events.processEvent(new ActivityStartEvent(12.25 * 3600, personId, linkShop, null, "shop", null)); - Assert.assertEquals(7, collector.getEvents().size()); + Assertions.assertEquals(7, collector.getEvents().size()); f.events.processEvent(new VehicleEntersTrafficEvent(13.00 * 3600, personId, linkShop, vehicleId, "car", 1.0)); - Assert.assertEquals(9, collector.getEvents().size()); + Assertions.assertEquals(9, collector.getEvents().size()); - Assert.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(7).getClass()); + Assertions.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(7).getClass()); PersonMoneyEvent parkingEvent2 = (PersonMoneyEvent) collector.getEvents().get(7); - Assert.assertEquals(personId, parkingEvent2.getPersonId()); - Assert.assertEquals(13.00 * 3600, parkingEvent2.getTime(), 1e-8); - Assert.assertEquals((13 - 12.25) * hourlyParkingCostShop, -parkingEvent2.getAmount(), 1e-8); + Assertions.assertEquals(personId, parkingEvent2.getPersonId()); + Assertions.assertEquals(13.00 * 3600, parkingEvent2.getTime(), 1e-8); + Assertions.assertEquals((13 - 12.25) * hourlyParkingCostShop, -parkingEvent2.getAmount(), 1e-8); f.events.processEvent(new VehicleLeavesTrafficEvent(13.25 * 3600, personId, linkHome, vehicleId, "car", 1.0)); f.events.processEvent(new ActivityStartEvent(13.25 * 3600, personId, linkHome, null, "home", null)); - Assert.assertEquals(11, collector.getEvents().size()); + Assertions.assertEquals(11, collector.getEvents().size()); f.events.processEvent(new VehicleEntersTrafficEvent(15.00 * 3600, personId, linkShop, vehicleId, "car", 1.0)); - Assert.assertEquals(12, collector.getEvents().size()); // there should be no parking cost event at home + Assertions.assertEquals(12, collector.getEvents().size()); // there should be no parking cost event at home f.events.processEvent(new VehicleLeavesTrafficEvent(15.25 * 3600, personId, linkWork, vehicleId, "car", 1.0)); f.events.processEvent(new ActivityStartEvent(13.25 * 3600, personId, linkWork, null, "shop", null)); - Assert.assertEquals(14, collector.getEvents().size()); + Assertions.assertEquals(14, collector.getEvents().size()); f.events.processEvent(new VehicleEntersTrafficEvent(18.00 * 3600, personId, linkWork, vehicleId, "car", 1.0)); - Assert.assertEquals(16, collector.getEvents().size()); + Assertions.assertEquals(16, collector.getEvents().size()); - Assert.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(14).getClass()); + Assertions.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(14).getClass()); PersonMoneyEvent parkingEvent3 = (PersonMoneyEvent) collector.getEvents().get(14); - Assert.assertEquals(personId, parkingEvent3.getPersonId()); - Assert.assertEquals(18.00 * 3600, parkingEvent3.getTime(), 1e-8); - Assert.assertEquals((18 - 15.25) * hourlyParkingCostWork, -parkingEvent3.getAmount(), 1e-8); + Assertions.assertEquals(personId, parkingEvent3.getPersonId()); + Assertions.assertEquals(18.00 * 3600, parkingEvent3.getTime(), 1e-8); + Assertions.assertEquals((18 - 15.25) * hourlyParkingCostWork, -parkingEvent3.getAmount(), 1e-8); f.events.processEvent(new VehicleLeavesTrafficEvent(18.50 * 3600, personId, linkHome, vehicleId, "car", 1.0)); f.events.processEvent(new ActivityStartEvent(18.00 * 3600, personId, linkHome, null, "shop", null)); - Assert.assertEquals(18, collector.getEvents().size()); + Assertions.assertEquals(18, collector.getEvents().size()); } /** diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RideParkingCostTrackerTest.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RideParkingCostTrackerTest.java index 98e4f56a9b7..20bdf69263f 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RideParkingCostTrackerTest.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingcost/eventhandling/RideParkingCostTrackerTest.java @@ -19,7 +19,7 @@ package org.matsim.contrib.parking.parkingcost.eventhandling; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -74,53 +74,53 @@ void testPersonMoneyEvents() { f.scenario.getNetwork().getLinks().get(linkShop).getAttributes().putAttribute("pc_ride", hourlyParkingCostShop); f.events.processEvent(new PersonArrivalEvent(7.25 * 3600, personId, linkWork, "ride")); f.events.processEvent(new ActivityStartEvent(7.25 * 3600, personId, linkWork, null, "work", null)); - Assert.assertEquals(2, collector.getEvents().size()); + Assertions.assertEquals(2, collector.getEvents().size()); f.events.processEvent(new ActivityEndEvent(12.00 * 3600, personId, linkWork, null, "work", new Coord(0, 0))); - Assert.assertEquals(4, collector.getEvents().size()); + Assertions.assertEquals(4, collector.getEvents().size()); - Assert.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(2).getClass()); + Assertions.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(2).getClass()); PersonMoneyEvent parkingEvent1 = (PersonMoneyEvent) collector.getEvents().get(2); - Assert.assertEquals(personId, parkingEvent1.getPersonId()); - Assert.assertEquals(12.00 * 3600, parkingEvent1.getTime(), 1e-8); - Assert.assertEquals((12 - 7.25) * hourlyParkingCostWork, -parkingEvent1.getAmount(), 1e-8); + Assertions.assertEquals(personId, parkingEvent1.getPersonId()); + Assertions.assertEquals(12.00 * 3600, parkingEvent1.getTime(), 1e-8); + Assertions.assertEquals((12 - 7.25) * hourlyParkingCostWork, -parkingEvent1.getAmount(), 1e-8); f.events.processEvent(new PersonArrivalEvent(12.25 * 3600, personId, linkShop, "ride")); f.events.processEvent(new ActivityStartEvent(12.25 * 3600, personId, linkShop, null, "shop", null)); - Assert.assertEquals(6, collector.getEvents().size()); + Assertions.assertEquals(6, collector.getEvents().size()); f.events.processEvent(new ActivityEndEvent(13.00 * 3600, personId, linkShop, null, "shop", new Coord(0, 0))); - Assert.assertEquals(8, collector.getEvents().size()); + Assertions.assertEquals(8, collector.getEvents().size()); - Assert.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(6).getClass()); + Assertions.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(6).getClass()); PersonMoneyEvent parkingEvent2 = (PersonMoneyEvent) collector.getEvents().get(6); - Assert.assertEquals(personId, parkingEvent2.getPersonId()); - Assert.assertEquals(13.00 * 3600, parkingEvent2.getTime(), 1e-8); - Assert.assertEquals((13 - 12.25) * hourlyParkingCostShop, -parkingEvent2.getAmount(), 1e-8); + Assertions.assertEquals(personId, parkingEvent2.getPersonId()); + Assertions.assertEquals(13.00 * 3600, parkingEvent2.getTime(), 1e-8); + Assertions.assertEquals((13 - 12.25) * hourlyParkingCostShop, -parkingEvent2.getAmount(), 1e-8); f.events.processEvent(new PersonArrivalEvent(13.25 * 3600, personId, linkHome, "ride")); f.events.processEvent(new ActivityStartEvent(13.25 * 3600, personId, linkHome, null, "home", null)); - Assert.assertEquals(10, collector.getEvents().size()); + Assertions.assertEquals(10, collector.getEvents().size()); f.events.processEvent(new ActivityEndEvent(15.00 * 3600, personId, linkShop, null, "home", new Coord(0, 0))); - Assert.assertEquals(11, collector.getEvents().size()); // there should be no parking cost event at home + Assertions.assertEquals(11, collector.getEvents().size()); // there should be no parking cost event at home f.events.processEvent(new PersonArrivalEvent(15.25 * 3600, personId, linkWork, "ride")); f.events.processEvent(new ActivityStartEvent(13.25 * 3600, personId, linkWork, null, "shop", null)); - Assert.assertEquals(13, collector.getEvents().size()); + Assertions.assertEquals(13, collector.getEvents().size()); f.events.processEvent(new ActivityEndEvent(18.00 * 3600, personId, linkWork, null, "shop", new Coord(0, 0))); - Assert.assertEquals(15, collector.getEvents().size()); + Assertions.assertEquals(15, collector.getEvents().size()); - Assert.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(13).getClass()); + Assertions.assertEquals(PersonMoneyEvent.class, collector.getEvents().get(13).getClass()); PersonMoneyEvent parkingEvent3 = (PersonMoneyEvent) collector.getEvents().get(13); - Assert.assertEquals(personId, parkingEvent3.getPersonId()); - Assert.assertEquals(18.00 * 3600, parkingEvent3.getTime(), 1e-8); - Assert.assertEquals((18 - 15.25) * hourlyParkingCostWork, -parkingEvent3.getAmount(), 1e-8); + Assertions.assertEquals(personId, parkingEvent3.getPersonId()); + Assertions.assertEquals(18.00 * 3600, parkingEvent3.getTime(), 1e-8); + Assertions.assertEquals((18 - 15.25) * hourlyParkingCostWork, -parkingEvent3.getAmount(), 1e-8); f.events.processEvent(new PersonArrivalEvent(18.50 * 3600, personId, linkHome, "ride")); f.events.processEvent(new ActivityStartEvent(18.00 * 3600, personId, linkHome, null, "shop", null)); - Assert.assertEquals(17, collector.getEvents().size()); + Assertions.assertEquals(17, collector.getEvents().size()); } /** diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java index d614a1edd4c..d6feb304be0 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/run/RunParkingSearchScenarioIT.java @@ -19,7 +19,7 @@ package org.matsim.contrib.parking.run; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -57,7 +57,7 @@ void testRunParkingBenesonStrategy() { } catch (Exception e) { e.printStackTrace(); - Assert.fail("something went wrong"); + Assertions.fail("something went wrong"); } } @@ -75,7 +75,7 @@ void testRunParkingRandomStrategy() { new RunParkingSearchExample().run(config, false); } catch (Exception e) { e.printStackTrace(); - Assert.fail("something went wrong"); + Assertions.fail("something went wrong"); } } @@ -101,7 +101,7 @@ void testRunParkingDistanceMemoryStrategy() { for (Id personId : expected.getPersons().keySet()) { double scoreReference = expected.getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = actual.getPersons().get(personId).getSelectedPlan().getScore(); - Assert.assertEquals("Scores of person=" + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of person=" + personId + " are different"); } } @@ -109,11 +109,11 @@ void testRunParkingDistanceMemoryStrategy() { String expected = utils.getInputDirectory() + "/output_events.xml.gz"; String actual = utils.getOutputDirectory() + "/output_events.xml.gz"; EventsFileComparator.Result result = EventsUtils.compareEventsFiles(expected, actual); - Assert.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result); + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result); } } catch (Exception e) { e.printStackTrace(); - Assert.fail("something went wrong"); + Assertions.fail("something went wrong"); } } @@ -139,7 +139,7 @@ void testRunParkingNearestParkingSpotStrategy() { for (Id personId : expected.getPersons().keySet()) { double scoreReference = expected.getPersons().get(personId).getSelectedPlan().getScore(); double scoreCurrent = actual.getPersons().get(personId).getSelectedPlan().getScore(); - Assert.assertEquals("Scores of person=" + personId + " are different", scoreReference, scoreCurrent, MatsimTestUtils.EPSILON); + Assertions.assertEquals(scoreReference, scoreCurrent, MatsimTestUtils.EPSILON, "Scores of person=" + personId + " are different"); } } @@ -147,11 +147,11 @@ void testRunParkingNearestParkingSpotStrategy() { String expected = utils.getInputDirectory() + "/output_events.xml.gz"; String actual = utils.getOutputDirectory() + "/output_events.xml.gz"; EventsFileComparator.Result result = EventsUtils.compareEventsFiles(expected, actual); - Assert.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result); + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result); } } catch (Exception e) { e.printStackTrace(); - Assert.fail("something went wrong"); + Assertions.fail("something went wrong"); } } } diff --git a/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java b/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java index 98b6c1fa889..12c258a2d6e 100644 --- a/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java +++ b/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java @@ -3,8 +3,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.FixMethodOrder; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.runners.MethodSorters; @@ -103,7 +103,7 @@ public void install() { Population popActual = PopulationUtils.createPopulation( config ); PopulationUtils.readPopulation( popActual, outDir + "/output_plans.xml.gz" ); new PopulationComparison().compare( popExpected, popActual ) ; - Assert.assertEquals("RunPsim score changed.", 138.86084460860525, psimScore, MatsimTestUtils.EPSILON); + Assertions.assertEquals(138.86084460860525, psimScore, MatsimTestUtils.EPSILON, "RunPsim score changed."); } @@ -129,7 +129,7 @@ void testB() { double qsimScore = execScoreTracker.executedScore; logger.info("Default controler score was " + qsimScore ); // Assert.assertEquals("Default controler score changed.", 131.84309487251033d, qsimScore, MatsimTestUtils.EPSILON); - Assert.assertEquals("Default controler score changed.", 131.8303325803256, qsimScore, MatsimTestUtils.EPSILON); + Assertions.assertEquals(131.8303325803256, qsimScore, MatsimTestUtils.EPSILON, "Default controler score changed."); } class ExecScoreTracker implements ShutdownListener { diff --git a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java index ec938145c09..6a61f5d0f16 100644 --- a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java +++ b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/integration/RailsimIntegrationTest.java @@ -22,7 +22,7 @@ import ch.sbb.matsim.contrib.railsim.RailsimModule; import ch.sbb.matsim.contrib.railsim.events.RailsimTrainStateEvent; import ch.sbb.matsim.contrib.railsim.qsimengine.RailsimQSimModule; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -289,7 +289,7 @@ void testMicroSimpleUniDirectionalTrack() { if (vehicleArrivesEvent.getVehicleId().toString().equals("train1") && vehicleArrivesEvent.getFacilityId().toString() .equals("stop_3-4")) { - Assert.assertEquals("The arrival time of train1 at stop_3-4 has changed.", 29594., event.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(29594., event.getTime(), MatsimTestUtils.EPSILON, "The arrival time of train1 at stop_3-4 has changed."); } } } @@ -428,17 +428,17 @@ private void assertTrainState(double time, double speed, double targetSpeed, dou for (RailsimTrainStateEvent event : events) { if (event.getTime() > Math.ceil(time)) { - Assert.fail( + Assertions.fail( String.format("No matching event found for time %f, speed %f pos %f, Closest event is%s", time, speed, headPosition, prev)); } // If all assertions are true, returns successfully try { - Assert.assertEquals(Math.ceil(time), event.getTime(), 1e-7); - Assert.assertEquals(speed, event.getSpeed(), 1e-5); - Assert.assertEquals(targetSpeed, event.getTargetSpeed(), 1e-7); - Assert.assertEquals(acceleration, event.getAcceleration(), 1e-5); - Assert.assertEquals(headPosition, event.getHeadPosition(), 1e-5); + Assertions.assertEquals(Math.ceil(time), event.getTime(), 1e-7); + Assertions.assertEquals(speed, event.getSpeed(), 1e-5); + Assertions.assertEquals(targetSpeed, event.getTargetSpeed(), 1e-7); + Assertions.assertEquals(acceleration, event.getAcceleration(), 1e-5); + Assertions.assertEquals(headPosition, event.getHeadPosition(), 1e-5); return; } catch (AssertionError e) { // Check further events in loop diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java index d7661de699c..383dbc7c9f0 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/AvoidTolledRouteTest.java @@ -23,9 +23,9 @@ package org.matsim.contrib.roadpricing; import java.util.HashMap; -import java.util.Map; - -import org.junit.Assert; +import java.util.Map; + +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -120,8 +120,8 @@ public void handleEvent(LinkLeaveEvent event) { controler2.getConfig().controller().setCreateGraphs(false); controler2.run(); - Assert.assertEquals("Base Case: all agents should use the faster route.", 3, (Integer) linkId2demand1.get(Id.createLinkId("link_4_5")), 0); - Assert.assertEquals("Pricing: all agents should use the slow but untolled route.", 3, linkId2demand2.get(Id.createLinkId("link_1_2")), 0); + Assertions.assertEquals(3, (Integer) linkId2demand1.get(Id.createLinkId("link_4_5")), 0, "Base Case: all agents should use the faster route."); + Assertions.assertEquals(3, linkId2demand2.get(Id.createLinkId("link_1_2")), 0, "Pricing: all agents should use the slow but untolled route."); } } diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java index 63ac002412e..85c90cb3e79 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/CalcPaidTollTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -196,7 +196,7 @@ private void compareScores(final double scoreWithoutToll, final double scoreWith log.info("score without toll: " + scoreWithoutToll); log.info("score with toll: " + scoreWithToll); log.info("expected toll: " + expectedToll); - Assert.assertEquals(expectedToll, scoreWithoutToll - scoreWithToll, 1e-8); + Assertions.assertEquals(expectedToll, scoreWithoutToll - scoreWithToll, 1e-8); } /** @@ -212,7 +212,7 @@ private Population runTollSimulation(final String tollFile, final String tollTyp RoadPricingSchemeImpl scheme = RoadPricingUtils.addOrGetMutableRoadPricingScheme(scenario ); RoadPricingReaderXMLv1 reader = new RoadPricingReaderXMLv1(scheme); reader.readFile(tollFile); - Assert.assertEquals(tollType, scheme.getType()); + Assertions.assertEquals(tollType, scheme.getType()); RoadPricingTestUtils.createPopulation1(scenario); runTollSimulation(scenario, scheme); diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java index a22f0d46b39..4211519005b 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingConfigGroupTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.roadpricing; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -14,7 +14,7 @@ public class RoadPricingConfigGroupTest { @Test void getTollLinksFile() { RoadPricingConfigGroup cg = new RoadPricingConfigGroup(); - Assert.assertNull("Default roadpricing file is not set.", cg.getTollLinksFile()); + Assertions.assertNull(cg.getTollLinksFile(), "Default roadpricing file is not set."); } @Test @@ -22,17 +22,17 @@ void setTollLinksFile() { String file = "./test.xml.gz"; RoadPricingConfigGroup cg = new RoadPricingConfigGroup(); cg.setTollLinksFile(file); - Assert.assertEquals("Wrong input file.", file, cg.getTollLinksFile()); + Assertions.assertEquals(file, cg.getTollLinksFile(), "Wrong input file."); } @Test void getEnforcementProbability() { RoadPricingConfigGroup cg = new RoadPricingConfigGroup(); - Assert.assertEquals("Default probability should be 1.0", 1.0, cg.getEnforcementProbability(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.0, cg.getEnforcementProbability(), MatsimTestUtils.EPSILON, "Default probability should be 1.0"); double prob = 0.9; cg.setEnforcementProbability(prob); - Assert.assertEquals("Didn't get the adjusted probability.", prob, cg.getEnforcementProbability(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(prob, cg.getEnforcementProbability(), MatsimTestUtils.EPSILON, "Didn't get the adjusted probability."); } @Test @@ -40,7 +40,7 @@ void setEnforcementProbability() { RoadPricingConfigGroup cg = new RoadPricingConfigGroup(); try{ cg.setEnforcementProbability(1.2); - Assert.fail("Should not accept probability > 1.0"); + Assertions.fail("Should not accept probability > 1.0"); } catch (Exception e){ e.printStackTrace(); } diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java index 98260925936..250ef1758fe 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingControlerIT.java @@ -20,7 +20,7 @@ package org.matsim.contrib.roadpricing; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -73,7 +73,7 @@ void testPaidTollsEndUpInScores() { double scoreTollcase = controler2.getScenario().getPopulation().getPersons().get(Id.create("1", Person.class)).getPlans().get(0).getScore(); // there should be a score difference - Assert.assertEquals(3.0, scoreBasecase - scoreTollcase, MatsimTestUtils.EPSILON); // toll amount: 10000*0.00020 + 5000*0.00020 + Assertions.assertEquals(3.0, scoreBasecase - scoreTollcase, MatsimTestUtils.EPSILON); // toll amount: 10000*0.00020 + 5000*0.00020 } } diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java index 012e8117b2d..abf55722642 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingIOTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.roadpricing; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.File; import java.util.Iterator; diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingTestUtils.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingTestUtils.java index b299a872a7c..2065ee627c8 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingTestUtils.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/RoadPricingTestUtils.java @@ -22,7 +22,7 @@ import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -274,9 +274,9 @@ protected static Population createReferencePopulation1(final Config config) { } protected static void compareRoutes(final String expectedRoute, final NetworkRoute realRoute) { - Assert.assertNotNull(expectedRoute) ; - Assert.assertNotNull(realRoute); - Assert.assertNotNull(realRoute.getLinkIds()) ; + Assertions.assertNotNull(expectedRoute) ; + Assertions.assertNotNull(realRoute); + Assertions.assertNotNull(realRoute.getLinkIds()) ; StringBuilder strBuilder = new StringBuilder(); @@ -285,6 +285,6 @@ protected static void compareRoutes(final String expectedRoute, final NetworkRou strBuilder.append(' '); } String route = strBuilder.toString(); - Assert.assertEquals(expectedRoute + " ", route); + Assertions.assertEquals(expectedRoute + " ", route); } } diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java index 8f41e3d40ab..84052e33d8c 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/TollTravelCostCalculatorTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.roadpricing; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertNull; +import static org.junit.jupiter.api.Assertions.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertNull; import java.util.List; diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java index 1869561d3b8..70b4bc9344d 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RoadPricingByConfigfileTest.java @@ -18,9 +18,11 @@ * *********************************************************************** */ package org.matsim.contrib.roadpricing.run; +import static org.junit.jupiter.api.Assertions.fail; + import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.population.Population; @@ -32,8 +34,6 @@ import org.matsim.testcases.MatsimTestUtils; import org.matsim.utils.eventsfilecomparison.EventsFileComparator; -import static org.junit.Assert.fail; - /** * @author vsp-gleich * @@ -55,14 +55,14 @@ final void testMain() { { String expected = utils.getInputDirectory() + "/output_events.xml.gz" ; String actual = utils.getOutputDirectory() + "/output_events.xml.gz" ; - Assert.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, EventsUtils.compareEventsFiles( expected, actual )); + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, EventsUtils.compareEventsFiles( expected, actual )); } { final Population expected = PopulationUtils.createPopulation( ConfigUtils.createConfig() ); PopulationUtils.readPopulation( expected, utils.getInputDirectory() + "/output_plans.xml.gz" ); final Population actual = PopulationUtils.createPopulation( ConfigUtils.createConfig() ); PopulationUtils.readPopulation( actual, utils.getOutputDirectory() + "/output_plans.xml.gz" ); - Assert.assertTrue("Populations are different", PopulationUtils.comparePopulations( expected, actual )); + Assertions.assertTrue(PopulationUtils.comparePopulations( expected, actual ), "Populations are different"); } diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java index 263b07483bd..fc9f4870876 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingExampleIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.roadpricing.run; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -19,7 +19,7 @@ void testRunToadPricingExample() { RunRoadPricingExample.main(args); } catch (Exception e) { e.printStackTrace(); - Assert.fail("Example should run without exceptions."); + Assertions.fail("Example should run without exceptions."); } } } diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingFromCodeIT.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingFromCodeIT.java index 6f29178e7e8..d22d577c3ac 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingFromCodeIT.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingFromCodeIT.java @@ -2,7 +2,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import java.io.File; @@ -19,7 +19,7 @@ void testRunRoadPricingFromCode(){ RunRoadPricingFromCode.main(args); } catch (Exception e){ e.printStackTrace(); - Assert.fail("Example should run without exception."); + Assertions.fail("Example should run without exception."); } } } \ No newline at end of file diff --git a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingUsingTollFactorExampleIT.java b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingUsingTollFactorExampleIT.java index 6431c4dab75..2b5e05ae84e 100644 --- a/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingUsingTollFactorExampleIT.java +++ b/contribs/roadpricing/src/test/java/org/matsim/contrib/roadpricing/run/RunRoadPricingUsingTollFactorExampleIT.java @@ -1,6 +1,6 @@ package org.matsim.contrib.roadpricing.run; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; public class RunRoadPricingUsingTollFactorExampleIT { @@ -13,7 +13,7 @@ void testRunRoadPRicingUsingTollFactorExample() { RunRoadPricingUsingTollFactorExample.main(args); } catch (Exception e) { e.printStackTrace(); - Assert.fail("Example should run without exceptions."); + Assertions.fail("Example should run without exceptions."); } } } \ No newline at end of file diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/FloatMatrixIOTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/FloatMatrixIOTest.java index 8ee80d8a82b..689f88c2381 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/FloatMatrixIOTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/FloatMatrixIOTest.java @@ -24,7 +24,8 @@ import java.io.IOException; import java.util.HashSet; import java.util.Set; -import org.junit.Assert; + +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** @@ -60,14 +61,14 @@ void testIO() throws IOException { inStream.close(); float epsilon = 1e-6f; - Assert.assertEquals(2.0f, matrix2.get("un", "un"), epsilon); - Assert.assertEquals(3.0f, matrix2.get("un", "dos"), epsilon); - Assert.assertEquals(4.0f, matrix2.get("un", "tres"), epsilon); - Assert.assertEquals(4.0f, matrix2.get("dos", "un"), epsilon); - Assert.assertEquals(9.0f, matrix2.get("dos", "dos"), epsilon); - Assert.assertEquals(16.0f, matrix2.get("dos", "tres"), epsilon); - Assert.assertEquals(8.0f, matrix2.get("tres", "un"), epsilon); - Assert.assertEquals(27.0f, matrix2.get("tres", "dos"), epsilon); - Assert.assertEquals(64.0f, matrix2.get("tres", "tres"), epsilon); + Assertions.assertEquals(2.0f, matrix2.get("un", "un"), epsilon); + Assertions.assertEquals(3.0f, matrix2.get("un", "dos"), epsilon); + Assertions.assertEquals(4.0f, matrix2.get("un", "tres"), epsilon); + Assertions.assertEquals(4.0f, matrix2.get("dos", "un"), epsilon); + Assertions.assertEquals(9.0f, matrix2.get("dos", "dos"), epsilon); + Assertions.assertEquals(16.0f, matrix2.get("dos", "tres"), epsilon); + Assertions.assertEquals(8.0f, matrix2.get("tres", "un"), epsilon); + Assertions.assertEquals(27.0f, matrix2.get("tres", "dos"), epsilon); + Assertions.assertEquals(64.0f, matrix2.get("tres", "tres"), epsilon); } } diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/RooftopUtilsTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/RooftopUtilsTest.java index 77d95e9430a..6ec46f26396 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/RooftopUtilsTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/analysis/skims/RooftopUtilsTest.java @@ -20,10 +20,11 @@ package ch.sbb.matsim.analysis.skims; import ch.sbb.matsim.analysis.skims.RooftopUtils.ODConnection; +import org.junit.jupiter.api.Assertions; + import java.util.ArrayList; import java.util.List; import java.util.Map; -import org.junit.Assert; import org.junit.jupiter.api.Test; import org.matsim.core.utils.misc.Time; @@ -57,12 +58,12 @@ void testSortAndFilterConnections() { // connection 5 (dep 10900) should be dominated by connection 2 (dep 11000) // connection 1 (dep 12700) should be dominated by connection 6 (dep 12600) - Assert.assertEquals(5, connections.size()); - Assert.assertEquals(0, connections.get(0).transferCount, 0.0); - Assert.assertEquals(2, connections.get(1).transferCount, 0.0); - Assert.assertEquals(3, connections.get(2).transferCount, 0.0); - Assert.assertEquals(6, connections.get(3).transferCount, 0.0); - Assert.assertEquals(4, connections.get(4).transferCount, 0.0); + Assertions.assertEquals(5, connections.size()); + Assertions.assertEquals(0, connections.get(0).transferCount, 0.0); + Assertions.assertEquals(2, connections.get(1).transferCount, 0.0); + Assertions.assertEquals(3, connections.get(2).transferCount, 0.0); + Assertions.assertEquals(6, connections.get(3).transferCount, 0.0); + Assertions.assertEquals(4, connections.get(4).transferCount, 0.0); } @Test @@ -79,7 +80,7 @@ void testCalcAverageAdaptionTime_1() { double adaptionTime = RooftopUtils.calcAverageAdaptionTime(connections, Time.parseTime("08:00:00"), Time.parseTime("09:00:00")); // there is a departure every 900 seconds, max adaption time would be 450, average of that would be 225.0. - Assert.assertEquals(225, adaptionTime, 1e-7); + Assertions.assertEquals(225, adaptionTime, 1e-7); // the frequency would be 3600 / 225 / 4 = 4.0 // two special, fast courses @@ -87,22 +88,22 @@ void testCalcAverageAdaptionTime_1() { connections.add(new ODConnection(Time.parseTime("08:48:00"), 300, 60, 150, 0, null)); connections = RooftopUtils.sortAndFilterConnections(connections, 9 * 3600); - Assert.assertEquals(6, connections.size()); + Assertions.assertEquals(6, connections.size()); // there should now be departures at 08:05, 08:22, 08:35, 08:48, 09:05 // resulting in a slightly higher adaption time adaptionTime = RooftopUtils.calcAverageAdaptionTime(connections, Time.parseTime("08:00:00"), Time.parseTime("09:00:00")); - Assert.assertEquals(254, adaptionTime, 1e-7); + Assertions.assertEquals(254, adaptionTime, 1e-7); // the frequency would be 3600 / 254 / 4 = 3.5433 connections.add(new ODConnection(Time.parseTime("08:15:00"), 300, 60, 150, 0, null)); connections = RooftopUtils.sortAndFilterConnections(connections, 9 * 3600); - Assert.assertEquals(7, connections.size()); + Assertions.assertEquals(7, connections.size()); adaptionTime = RooftopUtils.calcAverageAdaptionTime(connections, Time.parseTime("08:00:00"), Time.parseTime("09:00:00")); - Assert.assertEquals(219, adaptionTime, 1e-7); + Assertions.assertEquals(219, adaptionTime, 1e-7); // the frequency would be 3600 / 219 / 4 = 4.1096 } @@ -120,7 +121,7 @@ void testCalcAverageAdaptionTime_2() { double adaptionTime = RooftopUtils.calcAverageAdaptionTime(connections, Time.parseTime("08:00:00"), Time.parseTime("09:00:00")); // there is a departure every 900 seconds, max adaption time would be 450, average of that would be 225.0. - Assert.assertEquals(225, adaptionTime, 1e-7); + Assertions.assertEquals(225, adaptionTime, 1e-7); // the frequency would be 3600 / 225 / 4 = 4.0 } @@ -140,7 +141,7 @@ void testCalcAverageAdaptionTime_noEarlierDeparture() { // average adaption time should be: 20min between 7:00 and 7:40, and 10min between 7:40 and 8:00 // ==> 40*20 + 20*10 = 800 + 200 = 1000 --> 1000 / 60 = 16.666min = 1000 seconds - Assert.assertEquals(1000.0, adaptionTime, 1e-7); + Assertions.assertEquals(1000.0, adaptionTime, 1e-7); } @Test @@ -157,7 +158,7 @@ void testCalcAverageAdaptionTime_noLaterDeparture() { // average adaption time should be: 25min between 7:00 and 7:10, 15min between 7:10 and 7:40, 10min between 7:40 and 8:00 // ==> 25*10 + 15*30 + 10*20 = 250 + 450 + 200 = 900 --> 900 seconds - Assert.assertEquals(900.0, adaptionTime, 1e-7); + Assertions.assertEquals(900.0, adaptionTime, 1e-7); } @Test @@ -174,7 +175,7 @@ void testCalcAverageAdaptionTime_noDepartureInRange() { // average adaption time should be: 40min between 7:00 and 7:40, 50min between 7:40 and 8:00 // ==> 40*40 + 50*20 = 1600 + 1000 = 2600 --> 2600 seconds - Assert.assertEquals(2600.0, adaptionTime, 1e-7); + Assertions.assertEquals(2600.0, adaptionTime, 1e-7); } @Test @@ -190,7 +191,7 @@ void testCalcAverageAdaptionTime_singleDepartureEarly() { // average adaption time should be: 80min between 7:00 and 8:00 // ==> 80*60 = 4800 --> 4800 seconds - Assert.assertEquals(4800.0, adaptionTime, 1e-7); + Assertions.assertEquals(4800.0, adaptionTime, 1e-7); } @Test @@ -206,7 +207,7 @@ void testCalcAverageAdaptionTime_singleDepartureInRange() { // average adaption time should be: 5min between 7:00 and 7:10, 25min between 7:10 and 8:00 // ==> 5*10 + 25*50 = 50 + 1250 = 1300 --> 1300 seconds - Assert.assertEquals(1300.0, adaptionTime, 1e-7); + Assertions.assertEquals(1300.0, adaptionTime, 1e-7); } @Test @@ -222,7 +223,7 @@ void testCalcAverageAdaptionTime_singleDepartureLate() { // average adaption time should be: 40min between 7:00 and 8:00 // ==> 40*60 = 2400 --> 2400 seconds - Assert.assertEquals(2400.0, adaptionTime, 1e-7); + Assertions.assertEquals(2400.0, adaptionTime, 1e-7); } @Test @@ -241,46 +242,46 @@ void testCalcConnectionShares() { Map shares = RooftopUtils.calcConnectionShares(connections, Time.parseTime("08:00:00"), Time.parseTime("09:00:00")); // there is a departure every 900 seconds, max adaption time would be 450, average of that would be 225.0. // every connection should have the same share, i.e. 1/4th = 0.25, but the first and the last only cover part of the time, so they have less - Assert.assertEquals(6, shares.size()); - Assert.assertEquals(0.0 / 60.0, shares.get(c0), 1e-7); - Assert.assertEquals(11.5 / 60.0, shares.get(c1), 1e-7); - Assert.assertEquals(15.0 / 60.0, shares.get(c2), 1e-7); - Assert.assertEquals(15.0 / 60.0, shares.get(c3), 1e-7); - Assert.assertEquals(15.0 / 60.0, shares.get(c4), 1e-7); - Assert.assertEquals(3.5 / 60.0, shares.get(c5), 1e-7); + Assertions.assertEquals(6, shares.size()); + Assertions.assertEquals(0.0 / 60.0, shares.get(c0), 1e-7); + Assertions.assertEquals(11.5 / 60.0, shares.get(c1), 1e-7); + Assertions.assertEquals(15.0 / 60.0, shares.get(c2), 1e-7); + Assertions.assertEquals(15.0 / 60.0, shares.get(c3), 1e-7); + Assertions.assertEquals(15.0 / 60.0, shares.get(c4), 1e-7); + Assertions.assertEquals(3.5 / 60.0, shares.get(c5), 1e-7); // two special, fast courses connections.add(c6 = new ODConnection(Time.parseTime("08:22:00"), 300, 60, 150, 0, null)); connections.add(c7 = new ODConnection(Time.parseTime("08:48:00"), 300, 60, 150, 0, null)); connections = RooftopUtils.sortAndFilterConnections(connections, 9 * 3600); - Assert.assertEquals(6, connections.size()); + Assertions.assertEquals(6, connections.size()); // there should now be departures at 08:05, 08:22, 08:35, 08:48, 09:05 shares = RooftopUtils.calcConnectionShares(connections, Time.parseTime("08:00:00"), Time.parseTime("09:00:00")); - Assert.assertEquals(6, shares.size()); - Assert.assertEquals(10.0 / 60.0, shares.get(c1), 1e-7); - Assert.assertEquals(20.0 / 60.0, shares.get(c6), 1e-7); - Assert.assertEquals(8.0 / 60.0, shares.get(c3), 1e-7); - Assert.assertEquals(20.0 / 60.0, shares.get(c7), 1e-7); - Assert.assertEquals(2.0 / 60.0, shares.get(c5), 1e-7); + Assertions.assertEquals(6, shares.size()); + Assertions.assertEquals(10.0 / 60.0, shares.get(c1), 1e-7); + Assertions.assertEquals(20.0 / 60.0, shares.get(c6), 1e-7); + Assertions.assertEquals(8.0 / 60.0, shares.get(c3), 1e-7); + Assertions.assertEquals(20.0 / 60.0, shares.get(c7), 1e-7); + Assertions.assertEquals(2.0 / 60.0, shares.get(c5), 1e-7); connections.add(c8 = new ODConnection(Time.parseTime("08:15:00"), 300, 60, 150, 0, null)); connections = RooftopUtils.sortAndFilterConnections(connections, 9 * 3600); - Assert.assertEquals(7, connections.size()); + Assertions.assertEquals(7, connections.size()); // there should now be departures at 08:05, 08:15, 08:22, 08:35, 08:48, 09:05 shares = RooftopUtils.calcConnectionShares(connections, Time.parseTime("08:00:00"), Time.parseTime("09:00:00")); - Assert.assertEquals(7, shares.size()); - Assert.assertEquals(6.5 / 60.0, shares.get(c1), 1e-7); - Assert.assertEquals(11.0 / 60.0, shares.get(c8), 1e-7); - Assert.assertEquals(12.5 / 60.0, shares.get(c6), 1e-7); - Assert.assertEquals(8.0 / 60.0, shares.get(c3), 1e-7); - Assert.assertEquals(20.0 / 60.0, shares.get(c7), 1e-7); - Assert.assertEquals(2.0 / 60.0, shares.get(c5), 1e-7); + Assertions.assertEquals(7, shares.size()); + Assertions.assertEquals(6.5 / 60.0, shares.get(c1), 1e-7); + Assertions.assertEquals(11.0 / 60.0, shares.get(c8), 1e-7); + Assertions.assertEquals(12.5 / 60.0, shares.get(c6), 1e-7); + Assertions.assertEquals(8.0 / 60.0, shares.get(c3), 1e-7); + Assertions.assertEquals(20.0 / 60.0, shares.get(c7), 1e-7); + Assertions.assertEquals(2.0 / 60.0, shares.get(c5), 1e-7); } @Test @@ -304,10 +305,10 @@ void testCalculationShares_noEarlierDeparture() { System.out.println(Time.writeTime(c.departureTime) + " --> " + share); } - Assert.assertEquals(1.0, sum, 1e-7); + Assertions.assertEquals(1.0, sum, 1e-7); - Assert.assertEquals(1.0, shares.get(c0), 1e-7); - Assert.assertEquals(0.0, shares.get(c1), 1e-7); + Assertions.assertEquals(1.0, shares.get(c0), 1e-7); + Assertions.assertEquals(0.0, shares.get(c1), 1e-7); } @Test @@ -333,10 +334,10 @@ void testCalculationShares_noEarlierDeparture2() { System.out.println(Time.writeTime(c.departureTime) + " --> " + share); } - Assert.assertEquals(1.0, sum, 1e-7); + Assertions.assertEquals(1.0, sum, 1e-7); - Assert.assertEquals(2.0 / 3.0, shares.get(c0), 1e-7); - Assert.assertEquals(1.0 / 3.0, shares.get(c1), 1e-7); + Assertions.assertEquals(2.0 / 3.0, shares.get(c0), 1e-7); + Assertions.assertEquals(1.0 / 3.0, shares.get(c1), 1e-7); } @Test @@ -362,10 +363,10 @@ void testCalculationShares_noLaterDeparture() { System.out.println(Time.writeTime(c.departureTime) + " --> " + share); } - Assert.assertEquals(1.0, sum, 1e-7); + Assertions.assertEquals(1.0, sum, 1e-7); - Assert.assertEquals(1.0 / 6.0, shares.get(c0), 1e-7); - Assert.assertEquals(5.0 / 6.0, shares.get(c1), 1e-7); + Assertions.assertEquals(1.0 / 6.0, shares.get(c0), 1e-7); + Assertions.assertEquals(5.0 / 6.0, shares.get(c1), 1e-7); } @Test @@ -391,10 +392,10 @@ void testCalculationShares_noDepartureInRange() { System.out.println(Time.writeTime(c.departureTime) + " --> " + share); } - Assert.assertEquals(1.0, sum, 1e-7); + Assertions.assertEquals(1.0, sum, 1e-7); - Assert.assertEquals(2.0 / 3.0, shares.get(c0), 1e-7); - Assert.assertEquals(1.0 / 3.0, shares.get(c1), 1e-7); + Assertions.assertEquals(2.0 / 3.0, shares.get(c0), 1e-7); + Assertions.assertEquals(1.0 / 3.0, shares.get(c1), 1e-7); } @Test @@ -405,7 +406,7 @@ void testCalculationShares_singleDepartureEarly() { connections.add(c0 = new ODConnection(Time.parseTime("06:15:00"), 16080, 245, 125, 5, null)); Map shares = RooftopUtils.calcConnectionShares(connections, Time.parseTime("07:00:00"), Time.parseTime("08:00:00")); - Assert.assertEquals(1.0, shares.get(c0), 1e-7); + Assertions.assertEquals(1.0, shares.get(c0), 1e-7); } @Test @@ -416,7 +417,7 @@ void testCalculationShares_singleDepartureInRange() { connections.add(c0 = new ODConnection(Time.parseTime("07:15:00"), 16080, 245, 125, 5, null)); Map shares = RooftopUtils.calcConnectionShares(connections, Time.parseTime("07:00:00"), Time.parseTime("08:00:00")); - Assert.assertEquals(1.0, shares.get(c0), 1e-7); + Assertions.assertEquals(1.0, shares.get(c0), 1e-7); } @Test @@ -427,6 +428,6 @@ void testCalculationShares_singleDepartureLate() { connections.add(c0 = new ODConnection(Time.parseTime("08:15:00"), 16080, 245, 125, 5, null)); Map shares = RooftopUtils.calcConnectionShares(connections, Time.parseTime("07:00:00"), Time.parseTime("08:00:00")); - Assert.assertEquals(1.0, shares.get(c0), 1e-7); + Assertions.assertEquals(1.0, shares.get(c0), 1e-7); } } diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/config/SBBTransitConfigGroupTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/config/SBBTransitConfigGroupTest.java index e78c20f85e2..c2ac906d1b1 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/config/SBBTransitConfigGroupTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/config/SBBTransitConfigGroupTest.java @@ -23,7 +23,7 @@ import java.io.ByteArrayOutputStream; import java.io.OutputStreamWriter; import java.util.Collections; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigReader; @@ -55,8 +55,8 @@ void testConfigIO() { ByteArrayInputStream input = new ByteArrayInputStream(output.toByteArray()); new ConfigReader(config2).parse(input); - Assert.assertEquals(1, ptConfig2.getDeterministicServiceModes().size()); - Assert.assertTrue(ptConfig2.getDeterministicServiceModes().contains("schienenfahrzeug")); - Assert.assertEquals(4, ptConfig2.getCreateLinkEventsInterval()); + Assertions.assertEquals(1, ptConfig2.getDeterministicServiceModes().size()); + Assertions.assertTrue(ptConfig2.getDeterministicServiceModes().contains("schienenfahrzeug")); + Assertions.assertEquals(4, ptConfig2.getCreateLinkEventsInterval()); } } diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java index 5c0b3452454..3484f72f2f3 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java @@ -24,8 +24,8 @@ import com.google.inject.Provides; import java.io.ByteArrayInputStream; import java.nio.charset.StandardCharsets; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -95,7 +95,7 @@ QSimComponentsConfig provideQSimComponentsConfig() { // this test mostly checks that no exception occurred - Assert.assertTrue(config.getModules().get(SBBTransitConfigGroup.GROUP_NAME) instanceof SBBTransitConfigGroup); + Assertions.assertTrue(config.getModules().get(SBBTransitConfigGroup.GROUP_NAME) instanceof SBBTransitConfigGroup); } } diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java index 7a06e85d0ed..c60a6c91a02 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineIntegrationTest.java @@ -24,7 +24,7 @@ import java.util.Set; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.controler.Controler; @@ -58,13 +58,13 @@ void testIntegration() { controler.run(); Mobsim mobsim = controler.getInjector().getInstance(Mobsim.class); - Assert.assertNotNull(mobsim); - Assert.assertEquals(QSim.class, mobsim.getClass()); + Assertions.assertNotNull(mobsim); + Assertions.assertEquals(QSim.class, mobsim.getClass()); QSim qsim = (QSim) mobsim; QSimComponentsConfig components = qsim.getChildInjector().getInstance(QSimComponentsConfig.class); - Assert.assertTrue(components.hasNamedComponent(SBBTransitEngineQSimModule.COMPONENT_NAME)); - Assert.assertFalse(components.hasNamedComponent(TransitEngineModule.TRANSIT_ENGINE_NAME)); + Assertions.assertTrue(components.hasNamedComponent(SBBTransitEngineQSimModule.COMPONENT_NAME)); + Assertions.assertFalse(components.hasNamedComponent(TransitEngineModule.TRANSIT_ENGINE_NAME)); } @Test @@ -86,9 +86,9 @@ void testIntegration_misconfiguration() { try { controler.run(); - Assert.fail("Expected exception, got none."); + Assertions.fail("Expected exception, got none."); } catch (RuntimeException e) { - Assert.assertTrue(e.getMessage().endsWith("This will not work! common modes = train")); + Assertions.assertTrue(e.getMessage().endsWith("This will not work! common modes = train")); } } diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineTest.java index f176c763bd0..04f2a54a88e 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/pt/SBBTransitQSimEngineTest.java @@ -23,7 +23,7 @@ import java.util.Map; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -65,8 +65,8 @@ public class SBBTransitQSimEngineTest { private static final Logger log = LogManager.getLogger(SBBTransitQSimEngineTest.class); private static void assertEqualEvent(Class eventClass, double time, Event event) { - Assert.assertTrue(event.getClass().isAssignableFrom(event.getClass())); - Assert.assertEquals(time, event.getTime(), 1e-7); + Assertions.assertTrue(event.getClass().isAssignableFrom(event.getClass())); + Assertions.assertEquals(time, event.getTime(), 1e-7); } @Test @@ -81,9 +81,9 @@ void testDriver() { trEngine.insertAgentsIntoMobsim(); Map, MobsimAgent> agents = qSim.getAgents(); - Assert.assertEquals("Expected one driver as agent.", 1, agents.size()); + Assertions.assertEquals(1, agents.size(), "Expected one driver as agent."); MobsimAgent agent = agents.values().iterator().next(); - Assert.assertTrue(agent instanceof SBBTransitDriverAgent); + Assertions.assertTrue(agent instanceof SBBTransitDriverAgent); SBBTransitDriverAgent driver = (SBBTransitDriverAgent) agent; TransitRoute route = driver.getTransitRoute(); List stops = route.getStops(); @@ -95,7 +95,7 @@ void testDriver() { assertNextStop(driver, stops.get(3), depTime); assertNextStop(driver, stops.get(4), depTime); - Assert.assertNull(driver.getNextRouteStop()); + Assertions.assertNull(driver.getNextRouteStop()); } private void assertNextStop(SBBTransitDriverAgent driver, TransitRouteStop stop, double routeDepTime) { @@ -103,7 +103,7 @@ private void assertNextStop(SBBTransitDriverAgent driver, TransitRouteStop stop, double depOffset = stop.getDepartureOffset().or(stop.getArrivalOffset()).seconds(); TransitStopFacility f = stop.getStopFacility(); - Assert.assertEquals(stop, driver.getNextRouteStop()); + Assertions.assertEquals(stop, driver.getNextRouteStop()); driver.arrive(stop, routeDepTime + arrOffset); double stopTimeSum = 0.0; @@ -112,8 +112,8 @@ private void assertNextStop(SBBTransitDriverAgent driver, TransitRouteStop stop, stopTime = driver.handleTransitStop(f, routeDepTime + arrOffset + stopTimeSum); stopTimeSum += stopTime; } while (stopTime > 0); - Assert.assertEquals(depOffset - arrOffset, stopTimeSum, 1e-7); - Assert.assertEquals("last stop time should have been 0.0", 0.0, stopTime, 1e-7); + Assertions.assertEquals(depOffset - arrOffset, stopTimeSum, 1e-7); + Assertions.assertEquals(0.0, stopTime, 1e-7, "last stop time should have been 0.0"); driver.depart(f, routeDepTime + depOffset); } @@ -141,7 +141,7 @@ void testEvents_withoutPassengers_withoutLinks() { System.out.println(event.toString()); } - Assert.assertEquals("wrong number of events.", 15, allEvents.size()); + Assertions.assertEquals(15, allEvents.size(), "wrong number of events."); assertEqualEvent(TransitDriverStartsEvent.class, 30000, allEvents.get(0)); assertEqualEvent(PersonDepartureEvent.class, 30000, allEvents.get(1)); assertEqualEvent(PersonEntersVehicleEvent.class, 30000, allEvents.get(2)); @@ -189,7 +189,7 @@ void testEvents_withPassengers_withoutLinks() { System.out.println(event.toString()); } - Assert.assertEquals("wrong number of events.", 22, allEvents.size()); + Assertions.assertEquals(22, allEvents.size(), "wrong number of events."); assertEqualEvent(ActivityEndEvent.class, 29500, allEvents.get(0)); // passenger assertEqualEvent(PersonDepartureEvent.class, 29500, allEvents.get(1)); // passenger assertEqualEvent(AgentWaitingForPtEvent.class, 29500, allEvents.get(2)); // passenger @@ -241,7 +241,7 @@ void testEvents_withThreePassengers_withoutLinks() { System.out.println(event.toString()); } - Assert.assertEquals("wrong number of events.", 36, allEvents.size()); + Assertions.assertEquals(36, allEvents.size(), "wrong number of events."); assertEqualEvent(ActivityEndEvent.class, 29500, allEvents.get(0)); // passenger 1 assertEqualEvent(ActivityEndEvent.class, 29500, allEvents.get(1)); // passenger 2 assertEqualEvent(ActivityEndEvent.class, 29500, allEvents.get(2)); // passenger 3 @@ -305,7 +305,7 @@ void testEvents_withoutPassengers_withLinks() { System.out.println(event.toString()); } - Assert.assertEquals("wrong number of events.", 23, allEvents.size()); + Assertions.assertEquals(23, allEvents.size(), "wrong number of events."); assertEqualEvent(TransitDriverStartsEvent.class, 30000, allEvents.get(0)); assertEqualEvent(PersonDepartureEvent.class, 30000, allEvents.get(1)); assertEqualEvent(PersonEntersVehicleEvent.class, 30000, allEvents.get(2)); @@ -357,7 +357,7 @@ void testEvents_withoutPassengers_withLinks_Sesselbahn() { System.out.println(event.toString()); } - Assert.assertEquals("wrong number of events.", 13, allEvents.size()); + Assertions.assertEquals(13, allEvents.size(), "wrong number of events."); assertEqualEvent(TransitDriverStartsEvent.class, 35000, allEvents.get(0)); assertEqualEvent(PersonDepartureEvent.class, 35000, allEvents.get(1)); assertEqualEvent(PersonEntersVehicleEvent.class, 35000, allEvents.get(2)); @@ -404,7 +404,7 @@ void testEvents_withoutPassengers_withLinks_SesselbahnMalformed() { System.out.println(event.toString()); } - Assert.assertEquals("wrong number of events.", 13, allEvents.size()); + Assertions.assertEquals(13, allEvents.size(), "wrong number of events."); assertEqualEvent(TransitDriverStartsEvent.class, 35000, allEvents.get(0)); assertEqualEvent(PersonDepartureEvent.class, 35000, allEvents.get(1)); assertEqualEvent(PersonEntersVehicleEvent.class, 35000, allEvents.get(2)); @@ -450,7 +450,7 @@ void testEvents_withoutPassengers_withLinks_DelayedFirstDeparture() { System.out.println(event.toString()); } - Assert.assertEquals("wrong number of events.", 23, allEvents.size()); + Assertions.assertEquals(23, allEvents.size(), "wrong number of events."); assertEqualEvent(TransitDriverStartsEvent.class, 30000, allEvents.get(0)); assertEqualEvent(PersonDepartureEvent.class, 30000, allEvents.get(1)); assertEqualEvent(PersonEntersVehicleEvent.class, 30000, allEvents.get(2)); @@ -505,7 +505,7 @@ void testEvents_withoutPassengers_withLinks_FromToLoopLink() { System.out.println(event.toString()); } - Assert.assertEquals("wrong number of events.", 23, allEvents.size()); + Assertions.assertEquals(23, allEvents.size(), "wrong number of events."); assertEqualEvent(TransitDriverStartsEvent.class, 30000, allEvents.get(0)); assertEqualEvent(PersonDepartureEvent.class, 30000, allEvents.get(1)); assertEqualEvent(PersonEntersVehicleEvent.class, 30000, allEvents.get(2)); @@ -550,7 +550,7 @@ void testMisconfiguration() { try { qSim.run(); - Assert.fail("Expected a RuntimeException due misconfiguration, but got none."); + Assertions.fail("Expected a RuntimeException due misconfiguration, but got none."); } catch (RuntimeException e) { log.info("Caught expected exception, all is fine.", e); } @@ -586,7 +586,7 @@ void testCreateEventsInterval() { if (iteration == 0 || iteration == 3 || iteration == 6 || iteration == 9) { expectedEventsCount = 23; } - Assert.assertEquals("wrong number of events in iteration " + iteration, expectedEventsCount, collector.getEvents().size()); + Assertions.assertEquals(expectedEventsCount, collector.getEvents().size(), "wrong number of events in iteration " + iteration); } } } diff --git a/contribs/shared_mobility/src/test/java/org/matsim/contrib/shared_mobility/RunIT.java b/contribs/shared_mobility/src/test/java/org/matsim/contrib/shared_mobility/RunIT.java index 5e6a5d0cd48..007d4ff73b1 100644 --- a/contribs/shared_mobility/src/test/java/org/matsim/contrib/shared_mobility/RunIT.java +++ b/contribs/shared_mobility/src/test/java/org/matsim/contrib/shared_mobility/RunIT.java @@ -9,7 +9,7 @@ import java.util.List; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.events.handler.PersonDepartureEventHandler; import org.matsim.contrib.shared_mobility.run.SharingConfigGroup; @@ -157,30 +157,30 @@ final void test() throws UncheckedIOException, ConfigurationException, URISyntax OutputData data = countLegs(controller.getControlerIO().getOutputPath() + "/output_events.xml.gz"); - Assert.assertEquals(82629, (long) data.counts.get("car")); - Assert.assertEquals(29739, (long) data.counts.get("walk")); - Assert.assertEquals(31, (long) data.counts.get("bike")); - Assert.assertEquals(19029, (long) data.counts.get("pt")); + Assertions.assertEquals(82629, (long) data.counts.get("car")); + Assertions.assertEquals(29739, (long) data.counts.get("walk")); + Assertions.assertEquals(31, (long) data.counts.get("bike")); + Assertions.assertEquals(19029, (long) data.counts.get("pt")); - Assert.assertEquals(21, (long) data.pickupCounts.get("wheels")); - Assert.assertEquals(2, (long) data.pickupCounts.get("mobility")); - Assert.assertEquals(10, (long) data.pickupCounts.get("velib")); + Assertions.assertEquals(21, (long) data.pickupCounts.get("wheels")); + Assertions.assertEquals(2, (long) data.pickupCounts.get("mobility")); + Assertions.assertEquals(10, (long) data.pickupCounts.get("velib")); - Assert.assertEquals(21, (long) data.dropoffCounts.get("wheels")); - Assert.assertEquals(0, (long) data.dropoffCounts.getOrDefault("mobility", 0L)); - Assert.assertEquals(10, (long) data.dropoffCounts.get("velib")); + Assertions.assertEquals(21, (long) data.dropoffCounts.get("wheels")); + Assertions.assertEquals(0, (long) data.dropoffCounts.getOrDefault("mobility", 0L)); + Assertions.assertEquals(10, (long) data.dropoffCounts.get("velib")); - Assert.assertEquals(0, (long) data.failedPickupCounts.getOrDefault("wheels",0L)); - Assert.assertEquals(0, (long) data.failedPickupCounts.getOrDefault("mobility",0L)); - Assert.assertEquals(0, (long) data.failedPickupCounts.getOrDefault("velib",0L)); + Assertions.assertEquals(0, (long) data.failedPickupCounts.getOrDefault("wheels",0L)); + Assertions.assertEquals(0, (long) data.failedPickupCounts.getOrDefault("mobility",0L)); + Assertions.assertEquals(0, (long) data.failedPickupCounts.getOrDefault("velib",0L)); - Assert.assertEquals(0, (long) data.failedDropoffCounts.getOrDefault("wheels", 0L)); - Assert.assertEquals(0, (long) data.failedDropoffCounts.getOrDefault("mobility", 0L)); - Assert.assertEquals(0, (long) data.failedDropoffCounts.getOrDefault("velib", 0L)); + Assertions.assertEquals(0, (long) data.failedDropoffCounts.getOrDefault("wheels", 0L)); + Assertions.assertEquals(0, (long) data.failedDropoffCounts.getOrDefault("mobility", 0L)); + Assertions.assertEquals(0, (long) data.failedDropoffCounts.getOrDefault("velib", 0L)); - Assert.assertEquals(2, (long) data.vehicleCounts.get("wheels")); - Assert.assertEquals(2, (long) data.vehicleCounts.get("mobility")); - Assert.assertEquals(2, (long) data.vehicleCounts.get("velib")); + Assertions.assertEquals(2, (long) data.vehicleCounts.get("wheels")); + Assertions.assertEquals(2, (long) data.vehicleCounts.get("mobility")); + Assertions.assertEquals(2, (long) data.vehicleCounts.get("velib")); } static class OutputData { diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java index f49b8bb8cca..4d5296fe17a 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateIntergreensExampleTest.java @@ -23,7 +23,7 @@ import java.io.IOException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.utils.misc.CRCChecksum; @@ -46,12 +46,12 @@ void testIntergreenExample(){ CreateIntergreensExample.main(args); } catch (IOException e) { e.printStackTrace(); - Assert.fail("something went wrong") ; + Assertions.fail("something went wrong") ; } // compare intergreen output - Assert.assertEquals("different intergreen files", - CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "intergreens.xml"), - CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "intergreens.xml")); + Assertions.assertEquals(CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "intergreens.xml"), + CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "intergreens.xml"), + "different intergreen files"); } } diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java index bd97d5c2c26..1bfd33ff1f3 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleTest.java @@ -24,8 +24,8 @@ import java.io.IOException; import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.utils.misc.CRCChecksum; @@ -48,7 +48,7 @@ void testCreateSignalInputExample(){ (new CreateSignalInputExample()).run(testUtils.getOutputDirectory()); } catch (IOException e) { e.printStackTrace(); - Assert.fail("something went wrong") ; + Assertions.fail("something went wrong") ; } // compare signal output { @@ -56,16 +56,16 @@ void testCreateSignalInputExample(){ final String referenceFilename = DIR_TO_COMPARE_WITH + "signal_systems.xml"; log.info( "outputFilename=" + outputFilename ) ; log.info( "referenceFilename=" + referenceFilename ) ; - Assert.assertEquals("different signal system files", - CRCChecksum.getCRCFromFile(outputFilename), - CRCChecksum.getCRCFromFile(referenceFilename)); + Assertions.assertEquals(CRCChecksum.getCRCFromFile(outputFilename), + CRCChecksum.getCRCFromFile(referenceFilename), + "different signal system files"); } - Assert.assertEquals("different signal group files", - CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), - CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml")); - Assert.assertEquals("different signal control files", - CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), - CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml")); + Assertions.assertEquals(CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), + CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml"), + "different signal group files"); + Assertions.assertEquals(CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), + CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml"), + "different signal control files"); } } diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java index f76efe99da2..38eb9821c37 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/CreateSignalInputExampleWithLanesTest.java @@ -23,7 +23,7 @@ import java.io.IOException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.utils.misc.CRCChecksum; @@ -45,21 +45,21 @@ void testCreateSignalInputExampleWithLanes(){ (new CreateSignalInputWithLanesExample()).run(testUtils.getOutputDirectory()); } catch (IOException e) { e.printStackTrace(); - Assert.fail("something went wrong") ; + Assertions.fail("something went wrong") ; } // compare signal output - Assert.assertEquals("different signal system files", - CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_systems.xml"), - CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_systems.xml")); - Assert.assertEquals("different signal group files", - CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), - CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml")); - Assert.assertEquals("different signal control files", - CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), - CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml")); - Assert.assertEquals("different lane files", - CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "lane_definitions_v2.0.xml"), - CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "lane_definitions_v2.0.xml")); + Assertions.assertEquals(CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_systems.xml"), + CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_systems.xml"), + "different signal system files"); + Assertions.assertEquals(CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), + CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml"), + "different signal group files"); + Assertions.assertEquals(CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "signal_groups.xml"), + CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "signal_groups.xml"), + "different signal control files"); + Assertions.assertEquals(CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "lane_definitions_v2.0.xml"), + CRCChecksum.getCRCFromFile(DIR_TO_COMPARE_WITH + "lane_definitions_v2.0.xml"), + "different lane files"); } } diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java index 9da52c5d00a..52438c7aa96 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunSignalSystemsExampleTest.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.codeexamples.fixedTimeSignals; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.config.Config; @@ -41,7 +41,7 @@ final void testExampleWithHoles() { RunSignalSystemsExampleWithHoles.run(usingOTFVis); } catch (Exception ee ) { ee.printStackTrace(); - Assert.fail("something went wrong: " + ee.getMessage()) ; + Assertions.fail("something went wrong: " + ee.getMessage()) ; } } @@ -56,7 +56,7 @@ final void testMinimalExample() { RunSignalSystemsExample.run(config, false); } catch (Exception ee ) { ee.printStackTrace(); - Assert.fail("something went wrong: " + ee.getMessage()) ; + Assertions.fail("something went wrong: " + ee.getMessage()) ; } } diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunVisualizeSignalScenarioWithLanesGUITest.java b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunVisualizeSignalScenarioWithLanesGUITest.java index c40f531b26f..552be371b31 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunVisualizeSignalScenarioWithLanesGUITest.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/fixedTimeSignals/RunVisualizeSignalScenarioWithLanesGUITest.java @@ -1,6 +1,6 @@ package org.matsim.codeexamples.fixedTimeSignals; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** @@ -22,7 +22,7 @@ public static void main(String[] args) { VisualizeSignalScenarioWithLanes.run(startOtfvis); } catch (Exception ee ) { ee.printStackTrace(); - Assert.fail("something went wrong") ; + Assertions.fail("something went wrong") ; } } @@ -38,7 +38,7 @@ void testSignalExampleVisualizationWoLanes(){ VisualizeSignalScenario.run(false); } catch (Exception ee) { ee.printStackTrace(); - Assert.fail("something went wrong"); + Assertions.fail("something went wrong"); } } diff --git a/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java b/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java index ce1989f66de..3e4c472ffb2 100644 --- a/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java +++ b/contribs/signals/src/test/java/org/matsim/codeexamples/simpleResponsiveSignalEngine/FixResponsiveSignalResultsIT.java @@ -24,8 +24,8 @@ import java.util.SortedMap; import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -66,10 +66,10 @@ void testOneCrossingExample() { LOG.info("SignalGroup1: onset " + group1Setting.getOnset() + ", dropping " + group1Setting.getDropping()); LOG.info("SignalGroup2: onset " + group2Setting.getOnset() + ", dropping " + group2Setting.getDropping()); - Assert.assertEquals(0, group1Setting.getOnset()); - Assert.assertEquals(25, group1Setting.getDropping()); - Assert.assertEquals(30, group2Setting.getOnset()); - Assert.assertEquals(55, group2Setting.getDropping()); + Assertions.assertEquals(0, group1Setting.getOnset()); + Assertions.assertEquals(25, group1Setting.getDropping()); + Assertions.assertEquals(30, group2Setting.getOnset()); + Assertions.assertEquals(55, group2Setting.getDropping()); } } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/io/MatsimFileTypeGuesserSignalsTest.java b/contribs/signals/src/test/java/org/matsim/contrib/io/MatsimFileTypeGuesserSignalsTest.java index 7bd326a50b0..e74c5396807 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/io/MatsimFileTypeGuesserSignalsTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/io/MatsimFileTypeGuesserSignalsTest.java @@ -19,9 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.io; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertNull; +import static org.junit.jupiter.api.Assertions.*; import java.io.IOException; diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java index 196d6674661..e822de14af0 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/CalculateAngleTest.java @@ -4,8 +4,8 @@ import java.util.TreeMap; import org.apache.logging.log4j.LogManager; -import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -43,22 +43,21 @@ void testGetLeftLane() { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(conf); new MatsimNetworkReader(scenario.getNetwork()).parse(conf.network().getInputFileURL(conf.getContext())); - Assert.assertEquals("Has to be 'null', since there is no other way back but Link 11.", - null, NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("1", Link.class)))); + Assertions.assertEquals(null, NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("1", Link.class))), "Has to be 'null', since there is no other way back but Link 11."); - Assert.assertEquals( + Assertions.assertEquals( scenario.getNetwork().getLinks().get(Id.create("2", Link.class)), NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("11", Link.class)))); - Assert.assertEquals( + Assertions.assertEquals( scenario.getNetwork().getLinks().get(Id.create("3", Link.class)), NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("22", Link.class)))); - Assert.assertEquals( + Assertions.assertEquals( scenario.getNetwork().getLinks().get(Id.create("4", Link.class)), NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("33", Link.class)))); - Assert.assertEquals( + Assertions.assertEquals( scenario.getNetwork().getLinks().get(Id.create("1", Link.class)), NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("44", Link.class)))); - Assert.assertEquals( + Assertions.assertEquals( scenario.getNetwork().getLinks().get(Id.create("5", Link.class)), NetworkUtils.getLeftmostTurnExcludingU(scenario.getNetwork().getLinks().get(Id.create("3", Link.class)))); } @@ -77,14 +76,14 @@ void testGetOutLinksSortedByAngle(){ Network net = scenario.getNetwork(); TreeMap m = NetworkUtils.getOutLinksSortedClockwiseByAngle(net.getLinks().get(Id.create(1, Link.class))); Entry entry = m.firstEntry(); - Assert.assertEquals("For angle " + angle + "CalculateAngle returns not the correct order of outlinks", Id.create(2, Link.class), entry.getValue().getId()); + Assertions.assertEquals(Id.create(2, Link.class), entry.getValue().getId(), "For angle " + angle + "CalculateAngle returns not the correct order of outlinks"); entry = m.higherEntry(entry.getKey()); - Assert.assertEquals("For angle " + angle + "CalculateAngle returns not the correct order of outlinks", Id.create(3, Link.class), entry.getValue().getId()); + Assertions.assertEquals(Id.create(3, Link.class), entry.getValue().getId(), "For angle " + angle + "CalculateAngle returns not the correct order of outlinks"); entry = m.higherEntry(entry.getKey()); - Assert.assertEquals("For angle " + angle + "CalculateAngle returns not the correct order of outlinks", Id.create(4, Link.class), entry.getValue().getId()); + Assertions.assertEquals(Id.create(4, Link.class), entry.getValue().getId(), "For angle " + angle + "CalculateAngle returns not the correct order of outlinks"); Link leftLane = NetworkUtils.getLeftmostTurnExcludingU(net.getLinks().get(Id.create(1, Link.class))); - Assert.assertEquals(Id.create(2, Link.class), leftLane.getId()); + Assertions.assertEquals(Id.create(2, Link.class), leftLane.getId()); } } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/SignalUtilsTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/SignalUtilsTest.java index 69a06a655fd..26e7d9b4cb2 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/SignalUtilsTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/SignalUtilsTest.java @@ -21,7 +21,7 @@ import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.contrib.signals.data.SignalsDataImpl; @@ -60,21 +60,21 @@ final void testCreateAndAddSignalGroups4Signals() { SignalUtils.createAndAddSignalGroups4Signals(groups, system); Map, SignalGroupData> system1Groups = groups.getSignalGroupDataBySignalSystemId().get(id1); - Assert.assertNotNull(system1Groups); - Assert.assertEquals(2, system1Groups.size()); + Assertions.assertNotNull(system1Groups); + Assertions.assertEquals(2, system1Groups.size()); - Assert.assertTrue(system1Groups.containsKey(idSg1)); + Assertions.assertTrue(system1Groups.containsKey(idSg1)); SignalGroupData group4sys = system1Groups.get(idSg1); - Assert.assertNotNull(group4sys); - Assert.assertEquals(idSg1, group4sys.getId()); - Assert.assertNotNull(group4sys.getSignalIds()); - Assert.assertEquals(idS1, group4sys.getSignalIds().iterator().next()); + Assertions.assertNotNull(group4sys); + Assertions.assertEquals(idSg1, group4sys.getId()); + Assertions.assertNotNull(group4sys.getSignalIds()); + Assertions.assertEquals(idS1, group4sys.getSignalIds().iterator().next()); group4sys = system1Groups.get(idSg3); - Assert.assertNotNull(group4sys); - Assert.assertEquals(idSg3, group4sys.getId()); - Assert.assertNotNull(group4sys.getSignalIds()); - Assert.assertEquals(idS3, group4sys.getSignalIds().iterator().next()); + Assertions.assertNotNull(group4sys); + Assertions.assertEquals(idSg3, group4sys.getId()); + Assertions.assertNotNull(group4sys.getSignalIds()); + Assertions.assertEquals(idS3, group4sys.getSignalIds().iterator().next()); } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java index a733aaac266..22c34ad8ddc 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/analysis/DelayAnalysisToolTest.java @@ -3,7 +3,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -88,7 +88,7 @@ public void handleEvent(Event event) { PrepareForSimUtils.createDefaultPrepareForSim(scenario).run(); new QSimBuilder(scenario.getConfig()).useDefaults().build(scenario, events).run(); - Assert.assertEquals("Total Delay of one agent is not correct", 0.0, handler.getTotalDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, handler.getTotalDelay(), MatsimTestUtils.EPSILON, "Total Delay of one agent is not correct"); if(WRITE_OUTPUT){ generateOutput(scenario, eventslist); } @@ -125,7 +125,7 @@ public void handleEvent(Event event) { for(int i=0; i eventslist) { diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java index d46a231d78e..663d9076e37 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/QSimSignalTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -123,7 +123,7 @@ void testIntergreensAbortOneAgentDriving() { runQSimWithSignals(scenario, false); // if this code is reached, no exception has been thrown - Assert.fail("The simulation should abort because of intergreens violation."); + Assertions.fail("The simulation should abort because of intergreens violation."); }); } @@ -162,7 +162,7 @@ void testConflictingDirectionsAbortOneAgentDriving() { runQSimWithSignals(scenario, false); // if this code is reached, no exception has been thrown - Assert.fail("The simulation should abort because of intergreens violation."); + Assertions.fail("The simulation should abort because of intergreens violation."); }); } @@ -236,10 +236,10 @@ private void runQSimWithSignals(final Scenario scenario, boolean handleEvents) t public void handleEvent(LinkEnterEvent e) { log.info("Link id: " + e.getLinkId().toString() + " enter time: " + e.getTime()); if (e.getLinkId().equals( fixture.linkId1 )){ - Assert.assertEquals(1.0, e.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.0, e.getTime(), MatsimTestUtils.EPSILON); } else if (e.getLinkId().equals( fixture.linkId2 )){ - Assert.assertEquals(this.link2EnterTime, e.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(this.link2EnterTime, e.getTime(), MatsimTestUtils.EPSILON); } } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java index 30c81f963c2..9e341d444a6 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeFourWaysTest.java @@ -20,7 +20,7 @@ package org.matsim.contrib.signals.builder; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -125,7 +125,7 @@ private void runQSimWithSignals(final Scenario scenario) { eventsXmlWriter.closeFile(); // Assert.assertEquals("different events files", EventsFileComparator.compareAndReturnInt(this.testUtils.getInputDirectory() + EVENTSFILE, eventsOut), 0); - Assert.assertEquals( Result.FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( this.testUtils.getInputDirectory() + EVENTSFILE, eventsOut ) ); + Assertions.assertEquals( Result.FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( this.testUtils.getInputDirectory() + EVENTSFILE, eventsOut ) ); } } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java index 958b2b252c4..436a2470b1c 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/builder/TravelTimeOneWayTestIT.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -138,14 +138,14 @@ private static void runAndCompareAllGreenWithNoSignals(final Scenario scenario) log.debug("tF = 60s, " + resultsWoSignals.numberOfVehPassedDuringTimeToMeasure + ", " + resultsWoSignals.numberOfVehPassed + ", " + resultsWoSignals.firstVehPassTime_s + ", " + resultsWoSignals.lastVehPassTime_s); } else { - Assert.fail("seems like no LinkEnterEvent was handled, as this.beginningOfLink2 is not set."); + Assertions.fail("seems like no LinkEnterEvent was handled, as this.beginningOfLink2 is not set."); } // compare values - Assert.assertEquals(5000.0, resultsWithSignals.numberOfVehPassed, MatsimTestUtils.EPSILON); - Assert.assertEquals(resultsWithSignals.firstVehPassTime_s, resultsWoSignals.firstVehPassTime_s, MatsimTestUtils.EPSILON); - Assert.assertEquals(resultsWithSignals.numberOfVehPassed, resultsWoSignals.numberOfVehPassed, MatsimTestUtils.EPSILON); - Assert.assertEquals(resultsWithSignals.numberOfVehPassedDuringTimeToMeasure, resultsWoSignals.numberOfVehPassedDuringTimeToMeasure, MatsimTestUtils.EPSILON); + Assertions.assertEquals(5000.0, resultsWithSignals.numberOfVehPassed, MatsimTestUtils.EPSILON); + Assertions.assertEquals(resultsWithSignals.firstVehPassTime_s, resultsWoSignals.firstVehPassTime_s, MatsimTestUtils.EPSILON); + Assertions.assertEquals(resultsWithSignals.numberOfVehPassed, resultsWoSignals.numberOfVehPassed, MatsimTestUtils.EPSILON); + Assertions.assertEquals(resultsWithSignals.numberOfVehPassedDuringTimeToMeasure, resultsWoSignals.numberOfVehPassedDuringTimeToMeasure, MatsimTestUtils.EPSILON); } private static void runAndTestDifferentGreensplitSignals(final Scenario scenario) { @@ -167,8 +167,8 @@ private static void runAndTestDifferentGreensplitSignals(final Scenario scenario log.debug("circulationTime: " + circulationTime); log.debug("dropping : " + dropping); - Assert.assertEquals((dropping * linkCapacity / circulationTime), stubLinkEnterEventHandler.beginningOfLink2.numberOfVehPassedDuringTimeToMeasure, 1.0); - Assert.assertEquals(5000.0, stubLinkEnterEventHandler.beginningOfLink2.numberOfVehPassed, MatsimTestUtils.EPSILON); + Assertions.assertEquals((dropping * linkCapacity / circulationTime), stubLinkEnterEventHandler.beginningOfLink2.numberOfVehPassedDuringTimeToMeasure, 1.0); + Assertions.assertEquals(5000.0, stubLinkEnterEventHandler.beginningOfLink2.numberOfVehPassed, MatsimTestUtils.EPSILON); } } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java index 8fc875966e6..e5f7d325967 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/fixedTime/DefaultPlanbasedSignalSystemControllerIT.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -98,14 +98,14 @@ void test2SequentialPlansCompleteDay(){ log.info("First cycle time after 0am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(0)); log.info("First cycle time after 1am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(1)); // test time when signal plans are switched on and off - Assert.assertEquals("First signal state event unexpected.", 0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 2, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 3600*1, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("There was an unexpected event that switches off signals.", signalAnalyzer.getLastSignalOffEventTime()); - Assert.assertEquals("Number of signal off events is wrong.", 0, signalAnalyzer.getNumberOfOffEvents()); + Assertions.assertNull(signalAnalyzer.getLastSignalOffEventTime(), "There was an unexpected event that switches off signals."); + Assertions.assertEquals(0, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); // test if signal plans are both running - Assert.assertEquals("Cycle time of first signal plan wrong.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Cycle time of second signal plan wrong.", 60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON, "Cycle time of first signal plan wrong."); + Assertions.assertEquals(60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON, "Cycle time of second signal plan wrong."); } @Test @@ -122,18 +122,18 @@ void test2SequentialPlansUncompleteDayEnd(){ log.info("First cycle time after 2am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(2)); log.info("Number of signal events after 2am " + signalAnalyzer.getNumberOfSignalEventsInHour(2)); // test time when signal plans are switched on and off - Assert.assertEquals("First signal state event unexpected.", 0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 2, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 3600*1, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Time when signals are finally switched off is wrong.", 3600*2, signalAnalyzer.getLastSignalOffEventTime(), 5 + MatsimTestUtils.EPSILON); + Assertions.assertEquals(3600*2, signalAnalyzer.getLastSignalOffEventTime(), 5 + MatsimTestUtils.EPSILON, "Time when signals are finally switched off is wrong."); /* "5 + " because there is SignalSystemImpl.SWITCH_OFF_SEQUENCE_LENGTH of 5 seconds that is added to each signal plans end time as buffer */ - Assert.assertEquals("Number of signal off events is wrong.", 1, signalAnalyzer.getNumberOfOffEvents()); - Assert.assertEquals("Signals where unexpectedly switched on after 2am.", 0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(2), MatsimTestUtils.EPSILON); - Assert.assertTrue("Signals where unexpectedly switched on after 2am.", 3 > signalAnalyzer.getNumberOfSignalEventsInHour(2)); + Assertions.assertEquals(1, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); + Assertions.assertEquals(0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(2), MatsimTestUtils.EPSILON, "Signals where unexpectedly switched on after 2am."); + Assertions.assertTrue(3 > signalAnalyzer.getNumberOfSignalEventsInHour(2), "Signals where unexpectedly switched on after 2am."); /* "3 >" because last signal switches of the second plan are allowed at 2am and switch off is only after 5 seconds (in 2:00:05 am) */ // test if signal plans are both running - Assert.assertEquals("Cycle time of first signal plan wrong.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Cycle time of second signal plan wrong.", 60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON, "Cycle time of first signal plan wrong."); + Assertions.assertEquals(60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON, "Cycle time of second signal plan wrong."); } @Test @@ -150,18 +150,18 @@ void test2SequentialPlansUncompleteDayStart(){ log.info("First cycle time after 2am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(2)); log.info("Number of signal events between 0am and 1am " + signalAnalyzer.getNumberOfSignalEventsInHour(0)); // test time when signal plans are switched on and off - Assert.assertEquals("First signal state event unexpected.", 3600*1, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3600*1, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 2, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 3600*2, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("There was an unexpected event that switches off signals.", signalAnalyzer.getLastSignalOffEventTime()); - Assert.assertEquals("Number of signal off events is wrong.", 0, signalAnalyzer.getNumberOfOffEvents()); + Assertions.assertNull(signalAnalyzer.getLastSignalOffEventTime(), "There was an unexpected event that switches off signals."); + Assertions.assertEquals(0, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); // test if first hour is simulated correctly without signals - Assert.assertEquals("Signals where unexpectedly switched on between 0am and 1am.", 0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON); - Assert.assertTrue("Signals where unexpectedly switched on between 0am and 1am.", 1 > signalAnalyzer.getNumberOfSignalEventsInHour(0)); + Assertions.assertEquals(0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON, "Signals where unexpectedly switched on between 0am and 1am."); + Assertions.assertTrue(1 > signalAnalyzer.getNumberOfSignalEventsInHour(0), "Signals where unexpectedly switched on between 0am and 1am."); /* "1 > " because the first signal event should be at 1am, i.e. outside (after) this count interval */ // test if signal plans are both running - Assert.assertEquals("Cycle time of first signal plan wrong.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON); - Assert.assertEquals("Cycle time of second signal plan wrong.", 60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON, "Cycle time of first signal plan wrong."); + Assertions.assertEquals(60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(2), MatsimTestUtils.EPSILON, "Cycle time of second signal plan wrong."); } @Test @@ -178,14 +178,14 @@ void test2SequentialPlans1SecGap(){ log.info("First cycle time after 0am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(0)); log.info("First cycle time after 1am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(1)); // test time when signal plans are switched on and off - Assert.assertEquals("First signal state event unexpected.", 0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 2, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 3600*1+1, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("There was an unexpected event that switches off signals.", signalAnalyzer.getLastSignalOffEventTime()); - Assert.assertEquals("Number of signal off events is wrong.", 0, signalAnalyzer.getNumberOfOffEvents()); + Assertions.assertNull(signalAnalyzer.getLastSignalOffEventTime(), "There was an unexpected event that switches off signals."); + Assertions.assertEquals(0, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); // test if signal plans are both running - Assert.assertEquals("Cycle time of first signal plan wrong.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Cycle time of second signal plan wrong.", 60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON, "Cycle time of first signal plan wrong."); + Assertions.assertEquals(60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON, "Cycle time of second signal plan wrong."); } @Test @@ -202,19 +202,19 @@ void test2SequentialPlans1HourGap(){ log.info("First cycle time after 2am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(2)); log.info("Number of signal events between 1am and 2am " + signalAnalyzer.getNumberOfSignalEventsInHour(1)); // test time when signal plans are switched on and off - Assert.assertEquals("First signal state event unexpected.", 0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 2, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 3600*2, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Time when signals are finally switched off is wrong.", 3600*1, signalAnalyzer.getLastSignalOffEventTime(), 5 + MatsimTestUtils.EPSILON); + Assertions.assertEquals(3600*1, signalAnalyzer.getLastSignalOffEventTime(), 5 + MatsimTestUtils.EPSILON, "Time when signals are finally switched off is wrong."); /* "5 + " because there is SignalSystemImpl.SWITCH_OFF_SEQUENCE_LENGTH of 5 seconds that is added to each signal plans end time as buffer */ - Assert.assertEquals("Number of signal off events is wrong.", 1, signalAnalyzer.getNumberOfOffEvents()); + Assertions.assertEquals(1, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); // test if break between signal plans is simulated correctly - Assert.assertEquals("Signals where unexpectedly switched on between the signal plans.", 0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON); - Assert.assertTrue("Signals where unexpectedly switched on between the signal plans.", 3 > signalAnalyzer.getNumberOfSignalEventsInHour(1)); + Assertions.assertEquals(0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON, "Signals where unexpectedly switched on between the signal plans."); + Assertions.assertTrue(3 > signalAnalyzer.getNumberOfSignalEventsInHour(1), "Signals where unexpectedly switched on between the signal plans."); /* "3 >" because last signal switches of the first plan are allowed at 1am and switch off is only after 5 seconds (in 1:00:05 am) */ // test if signal plans are both running - Assert.assertEquals("Cycle time of first signal plan wrong.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Cycle time of second signal plan wrong.", 60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON, "Cycle time of first signal plan wrong."); + Assertions.assertEquals(60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(2), MatsimTestUtils.EPSILON, "Cycle time of second signal plan wrong."); } @Test @@ -235,19 +235,19 @@ void test2SequentialPlans1HourGap2TimesOff(){ log.info("Number of signal events between 1am and 2am " + signalAnalyzer.getNumberOfSignalEventsInHour(1)); log.info("Number of signal events after 3am " + signalAnalyzer.getNumberOfSignalEventsInHour(3)); // test time when signal plans are switched on and off - Assert.assertEquals("First signal state event unexpected.", 0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Time when signals are finally switched off is wrong.", 3600*3, signalAnalyzer.getLastSignalOffEventTime(), 5 + MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); + Assertions.assertEquals(3600*3, signalAnalyzer.getLastSignalOffEventTime(), 5 + MatsimTestUtils.EPSILON, "Time when signals are finally switched off is wrong."); /* "5 + " because there is SignalSystemImpl.SWITCH_OFF_SEQUENCE_LENGTH of 5 seconds that is added to each signal plans end time as buffer */ - Assert.assertEquals("Number of signal off events is wrong.", 2, signalAnalyzer.getNumberOfOffEvents()); - Assert.assertEquals("Signals where unexpectedly switched on between the signal plans.", 0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON); - Assert.assertTrue("Signals where unexpectedly switched on between the signal plans.", 3 > signalAnalyzer.getNumberOfSignalEventsInHour(1)); + Assertions.assertEquals(2, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); + Assertions.assertEquals(0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON, "Signals where unexpectedly switched on between the signal plans."); + Assertions.assertTrue(3 > signalAnalyzer.getNumberOfSignalEventsInHour(1), "Signals where unexpectedly switched on between the signal plans."); /* "3 >" because last signal switches of the first plan are allowed at 1am and switch off is only after 5 seconds (in 1:00:05 am) */ - Assert.assertEquals("Signals where unexpectedly switched on after the last signal plan.", 0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(3), MatsimTestUtils.EPSILON); - Assert.assertTrue("Signals where unexpectedly switched on after 3am.", 3 > signalAnalyzer.getNumberOfSignalEventsInHour(3)); + Assertions.assertEquals(0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(3), MatsimTestUtils.EPSILON, "Signals where unexpectedly switched on after the last signal plan."); + Assertions.assertTrue(3 > signalAnalyzer.getNumberOfSignalEventsInHour(3), "Signals where unexpectedly switched on after 3am."); /* "3 >" because last signal switches of the second plan are allowed at 3am and switch off is only after 5 seconds (in 3:00:05 am) */ // test if signal plans are both running - Assert.assertEquals("Cycle time of first signal plan wrong.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Cycle time of second signal plan wrong.", 60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON, "Cycle time of first signal plan wrong."); + Assertions.assertEquals(60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(2), MatsimTestUtils.EPSILON, "Cycle time of second signal plan wrong."); } @Test @@ -262,14 +262,14 @@ void test2SequentialPlansOverMidnight(){ log.info("First cycle time after 0am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(0)); log.info("First cycle time after 1am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(1)); // test time when signal plans are switched on and off - Assert.assertEquals("First signal state event unexpected.", 0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 2, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 3600*1, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("There was an unexpected event that switches off signals.", signalAnalyzer.getLastSignalOffEventTime()); - Assert.assertEquals("Number of signal off events is wrong.", 0, signalAnalyzer.getNumberOfOffEvents()); + Assertions.assertNull(signalAnalyzer.getLastSignalOffEventTime(), "There was an unexpected event that switches off signals."); + Assertions.assertEquals(0, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); // test if signal plans are both running - Assert.assertEquals("Cycle time of first signal plan wrong.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Cycle time of second signal plan wrong.", 60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON, "Cycle time of first signal plan wrong."); + Assertions.assertEquals(60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON, "Cycle time of second signal plan wrong."); } @Test @@ -287,17 +287,17 @@ void test1SignalPlanUncompleteDay(){ log.info("Number of signal events between 0am and 1am " + signalAnalyzer.getNumberOfSignalEventsInHour(0)); log.info("Number of signal events after 2am " + signalAnalyzer.getNumberOfSignalEventsInHour(2)); // test time when signal plan is switched on and off - Assert.assertEquals("First signal state event unexpected.", 3600.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3600.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 1, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 3600*1, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Time when signals are finally switched off is wrong.", 3600*2, signalAnalyzer.getLastSignalOffEventTime(), 5 + MatsimTestUtils.EPSILON); - Assert.assertEquals("Number of signal off events is wrong.", 1, signalAnalyzer.getNumberOfOffEvents()); - Assert.assertEquals("Signals where unexpectedly switched on before 1am.", 0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON); - Assert.assertTrue("Signals where unexpectedly switched on before 1am.", 1 > signalAnalyzer.getNumberOfSignalEventsInHour(0)); + Assertions.assertEquals(3600*2, signalAnalyzer.getLastSignalOffEventTime(), 5 + MatsimTestUtils.EPSILON, "Time when signals are finally switched off is wrong."); + Assertions.assertEquals(1, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); + Assertions.assertEquals(0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON, "Signals where unexpectedly switched on before 1am."); + Assertions.assertTrue(1 > signalAnalyzer.getNumberOfSignalEventsInHour(0), "Signals where unexpectedly switched on before 1am."); /* "1 > " because the first signal event should be at 1am, i.e. outside (after) this count interval */ - Assert.assertEquals("Signal plan is not active between 1am and 2am.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON); - Assert.assertEquals("Signals where unexpectedly switched on after 2am.", 0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(2), MatsimTestUtils.EPSILON); - Assert.assertTrue("Signals where unexpectedly switched on after 2am.", 3 > signalAnalyzer.getNumberOfSignalEventsInHour(2)); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(1), MatsimTestUtils.EPSILON, "Signal plan is not active between 1am and 2am."); + Assertions.assertEquals(0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(2), MatsimTestUtils.EPSILON, "Signals where unexpectedly switched on after 2am."); + Assertions.assertTrue(3 > signalAnalyzer.getNumberOfSignalEventsInHour(2), "Signals where unexpectedly switched on after 2am."); /* "3 >" because last signal switches of the first plan are allowed at 2am and switch off is only after 5 seconds (in 2:00:05 am) */ } @@ -320,14 +320,14 @@ void test1AllDaySignalPlanOverMidnightLateStart(){ log.info("First cycle time after 0am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(23)); log.info("First cycle time after 0am next day " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(24)); // test time when signal plan is switched on and off - Assert.assertEquals("First signal state event unexpected.", 3600*23, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3600*23, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 2, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 3600*24, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("There was an unexpected event that switches off signals.", signalAnalyzer.getLastSignalOffEventTime()); - Assert.assertEquals("Number of signal off events is wrong.", 0, signalAnalyzer.getNumberOfOffEvents()); + Assertions.assertNull(signalAnalyzer.getLastSignalOffEventTime(), "There was an unexpected event that switches off signals."); + Assertions.assertEquals(0, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); // test if signal plan is running for more than 24h - Assert.assertEquals("Signal plan is not active between 11pmam and 12pm.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(23), MatsimTestUtils.EPSILON); - Assert.assertEquals("Signal plan is not active anymore after 0am next day.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(24), MatsimTestUtils.EPSILON); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(23), MatsimTestUtils.EPSILON, "Signal plan is not active between 11pmam and 12pm."); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(24), MatsimTestUtils.EPSILON, "Signal plan is not active anymore after 0am next day."); } /** @@ -346,13 +346,13 @@ void test1AllDaySignalPlanMidnightStart(){ log.info("Number of signal off events " + signalAnalyzer.getNumberOfOffEvents()); log.info("First cycle time after 0am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(0)); // test time when signal plan is switched on and off - Assert.assertEquals("First signal state event unexpected.", 0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 1, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 0.0, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("There was an unexpected event that switches off signals.", signalAnalyzer.getLastSignalOffEventTime()); - Assert.assertEquals("Number of signal off events is wrong.", 0, signalAnalyzer.getNumberOfOffEvents()); + Assertions.assertNull(signalAnalyzer.getLastSignalOffEventTime(), "There was an unexpected event that switches off signals."); + Assertions.assertEquals(0, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); // test if signal plan is running for more than 24h - Assert.assertEquals("Signal plan is not active between 0am and 1am.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON, "Signal plan is not active between 0am and 1am."); } @Test @@ -370,15 +370,15 @@ void test2SignalPlanFor25h(){ log.info("First cycle time after 12am " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(12)); log.info("First cycle time after 0am next day " + signalAnalyzer.getCycleTimeOfFirstCycleInHour(24)); // test time when signal plans are switched on and off - Assert.assertEquals("First signal state event unexpected.", 0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 3, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 3600*24, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertNull("There was an unexpected event that switches off signals.", signalAnalyzer.getLastSignalOffEventTime()); - Assert.assertEquals("Number of signal off events is wrong.", 0, signalAnalyzer.getNumberOfOffEvents()); + Assertions.assertNull(signalAnalyzer.getLastSignalOffEventTime(), "There was an unexpected event that switches off signals."); + Assertions.assertEquals(0, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); // test if signal plans are correctly running for more than 24h - Assert.assertEquals("First signal plan is not active between 0am and 1am.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON); - Assert.assertEquals("Second signal plan is not active between 12am and 1pm.", 60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(12), MatsimTestUtils.EPSILON); - Assert.assertEquals("First signal plan is not active again after 0am next day.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(24), MatsimTestUtils.EPSILON); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(0), MatsimTestUtils.EPSILON, "First signal plan is not active between 0am and 1am."); + Assertions.assertEquals(60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(12), MatsimTestUtils.EPSILON, "Second signal plan is not active between 12am and 1pm."); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(24), MatsimTestUtils.EPSILON, "First signal plan is not active again after 0am next day."); } @Test @@ -400,18 +400,18 @@ void testSimStartAfterFirstDayPlan(){ log.info("Number of signal events before 11pm " + signalAnalyzer.getNumberOfSignalEventsInHour(22)); log.info("Number of signal events after 1am next day " + signalAnalyzer.getNumberOfSignalEventsInHour(25)); // test time when signal plans are switched on and off - Assert.assertEquals("First signal state event unexpected.", 23*3600, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(23*3600, signalAnalyzer.getFirstSignalEventTime(), MatsimTestUtils.EPSILON, "First signal state event unexpected."); // Assert.assertEquals("Number of plan start events is wrong.", 2, signalAnalyzer.getNumberOfPlanStartEvents()); // Assert.assertEquals("Time when last plan starts is wrong.", 3600*24, signalAnalyzer.getLastPlanStartEventTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("Time when signals are finally switched off is wrong.", 3600*25, signalAnalyzer.getLastSignalOffEventTime(), 5 + MatsimTestUtils.EPSILON); - Assert.assertEquals("Number of signal off events is wrong.", 1, signalAnalyzer.getNumberOfOffEvents()); - Assert.assertEquals("Signals where unexpectedly switched on before 11pm.", 0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(22), MatsimTestUtils.EPSILON); - Assert.assertTrue("Signals where unexpectedly switched on before 11pm.", 1 > signalAnalyzer.getNumberOfSignalEventsInHour(22)); - Assert.assertEquals("Signals where unexpectedly switched on after 1am next day.", 0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(25), MatsimTestUtils.EPSILON); - Assert.assertTrue("Signals where unexpectedly switched on after 1am next day.", 3 > signalAnalyzer.getNumberOfSignalEventsInHour(25)); + Assertions.assertEquals(3600*25, signalAnalyzer.getLastSignalOffEventTime(), 5 + MatsimTestUtils.EPSILON, "Time when signals are finally switched off is wrong."); + Assertions.assertEquals(1, signalAnalyzer.getNumberOfOffEvents(), "Number of signal off events is wrong."); + Assertions.assertEquals(0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(22), MatsimTestUtils.EPSILON, "Signals where unexpectedly switched on before 11pm."); + Assertions.assertTrue(1 > signalAnalyzer.getNumberOfSignalEventsInHour(22), "Signals where unexpectedly switched on before 11pm."); + Assertions.assertEquals(0, signalAnalyzer.getCycleTimeOfFirstCycleInHour(25), MatsimTestUtils.EPSILON, "Signals where unexpectedly switched on after 1am next day."); + Assertions.assertTrue(3 > signalAnalyzer.getNumberOfSignalEventsInHour(25), "Signals where unexpectedly switched on after 1am next day."); // test if signal plans are correctly running - Assert.assertEquals("Second signal plan is not active between 11pm and 12pm.", 60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(23), MatsimTestUtils.EPSILON); - Assert.assertEquals("First signal plan is not active between 0am and 1pm next day.", 120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(24), MatsimTestUtils.EPSILON); + Assertions.assertEquals(60, signalAnalyzer.getCycleTimeOfFirstCycleInHour(23), MatsimTestUtils.EPSILON, "Second signal plan is not active between 11pm and 12pm."); + Assertions.assertEquals(120, signalAnalyzer.getCycleTimeOfFirstCycleInHour(24), MatsimTestUtils.EPSILON, "First signal plan is not active between 0am and 1pm next day."); } /** @@ -424,10 +424,10 @@ void test2PlansSameTimesUncompleteDay(){ try{ (new ScenarioRunner(0.0, 1.0, 0.0, 1.0)).run(); - Assert.fail("The simulation has not stopped with an exception although the signal plans overlap."); + Assertions.fail("The simulation has not stopped with an exception although the signal plans overlap."); } catch (UnsupportedOperationException e) { log.info("Exception message: " + e.getMessage()); - Assert.assertEquals("Wrong exception message.", exceptionMessageOverlapping21, e.getMessage()); + Assertions.assertEquals(exceptionMessageOverlapping21, e.getMessage(), "Wrong exception message."); } } @@ -443,10 +443,10 @@ void test2PlansSameTimesCompleteDay(){ try{ (new ScenarioRunner(0.0, 0.0, 0.0, 0.0)).run(); // (new ScenarioRunner(1.0, 1.0, 1.0, 1.0)).run(); // alternativ. produces same results - Assert.fail("The simulation has not stopped with an exception although multiple signal plans exist and at least one of them covers the hole day (i.e. they overlap)."); + Assertions.fail("The simulation has not stopped with an exception although multiple signal plans exist and at least one of them covers the hole day (i.e. they overlap)."); } catch (UnsupportedOperationException e) { log.info("Exception message: " + e.getMessage()); - Assert.assertEquals("Wrong exception message.", exceptionMessageHoleDay, e.getMessage()); + Assertions.assertEquals(exceptionMessageHoleDay, e.getMessage(), "Wrong exception message."); } } @@ -456,10 +456,10 @@ void test2OverlappingPlans(){ try{ (new ScenarioRunner(0.0, 2.0, 1.0, 3.0)).run(); - Assert.fail("The simulation has not stopped with an exception although the signal plans overlap."); + Assertions.fail("The simulation has not stopped with an exception although the signal plans overlap."); } catch (UnsupportedOperationException e) { log.info("Exception message: " + e.getMessage()); - Assert.assertEquals("Wrong exception message.", exceptionMessageOverlapping12, e.getMessage()); + Assertions.assertEquals(exceptionMessageOverlapping12, e.getMessage(), "Wrong exception message."); } } @@ -474,8 +474,8 @@ void testNegativeOffset() { // in this case, the first event should be a RED-switch at second 57 log.info("Offset " + offset1 + " leads to the first signal event at second: " + signalAnalyzer.getFirstSignalEventTime()); - Assert.assertEquals("The first signal event should be at the first second after simulation start corresponding to offset, " - + "cycle time and plan start time. Also if the offset is negative!", 60+offset1 , signalAnalyzer.getFirstSignalEventTime() , MatsimTestUtils.EPSILON); + Assertions.assertEquals(60+offset1 , signalAnalyzer.getFirstSignalEventTime() , MatsimTestUtils.EPSILON, "The first signal event should be at the first second after simulation start corresponding to offset, " + + "cycle time and plan start time. Also if the offset is negative!"); } @Test @@ -489,8 +489,8 @@ void testNegativeOffsetEqualCycleTime() { // in this case, the first event should be a GREEN-switch at second 0 log.info("Offset " + offset1 + " leads to the first signal event at second: " + signalAnalyzer.getFirstSignalEventTime()); - Assert.assertEquals("The first signal event should be at the first second after simulation start corresponding to offset, " - + "cycle time and plan start time. Also if the offset is negative!", 120+offset1 , signalAnalyzer.getFirstSignalEventTime() , MatsimTestUtils.EPSILON); + Assertions.assertEquals(120+offset1 , signalAnalyzer.getFirstSignalEventTime() , MatsimTestUtils.EPSILON, "The first signal event should be at the first second after simulation start corresponding to offset, " + + "cycle time and plan start time. Also if the offset is negative!"); } @Test @@ -511,8 +511,8 @@ void testTwoPlansWithNegativeOffsets(){ // in this case, the first event should be a RED-switch at second 3625 log.info("Offsets " + offset1 + " and " + offset2 + " with a simulation start at second " + simStart_s + " lead to the first signal event at second: " + signalAnalyzer.getFirstSignalEventTime()); - Assert.assertEquals("The first signal event should be at the first second after simulation start corresponding to offset, " - + "cycle time and plan start time. Also if the offset is negative!", simStart_s+30+offset2 , signalAnalyzer.getFirstSignalEventTime() , MatsimTestUtils.EPSILON); + Assertions.assertEquals(simStart_s+30+offset2 , signalAnalyzer.getFirstSignalEventTime() , MatsimTestUtils.EPSILON, "The first signal event should be at the first second after simulation start corresponding to offset, " + + "cycle time and plan start time. Also if the offset is negative!"); } @Test @@ -533,8 +533,8 @@ void testTwoPlansWithNegativeOffsetsEqualCycleTime(){ // in this case, the first event should be a GREEN-switch at second 3600 log.info("Offsets " + offset1 + " and " + offset2 + " with a simulation start at second " + simStart_s + " lead to the first signal event at second: " + signalAnalyzer.getFirstSignalEventTime()); - Assert.assertEquals("The first signal event should be at the first second after simulation start corresponding to offset, " - + "cycle time and plan start time. Also if the offset is negative!", simStart_s+60+offset2 , signalAnalyzer.getFirstSignalEventTime() , MatsimTestUtils.EPSILON); + Assertions.assertEquals(simStart_s+60+offset2 , signalAnalyzer.getFirstSignalEventTime() , MatsimTestUtils.EPSILON, "The first signal event should be at the first second after simulation start corresponding to offset, " + + "cycle time and plan start time. Also if the offset is negative!"); } private class ScenarioRunner{ diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java index 8ce61447ac4..a0691c83396 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/laemmerFix/LaemmerIT.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -97,9 +97,9 @@ void testSingleCrossingScenarioDemandNS() { log.info("avg cycle time per system: " + avgCycleTimePerSystem.get(signalSystemId)); log.info("avg delay per link: " + avgDelayWE + ", " + avgDelayNS); - Assert.assertNull("signal group 1 should show no green", avgSignalGreenTimePerCycle.get(signalGroupId1)); - Assert.assertNotNull("signal group 2 should show green", avgSignalGreenTimePerCycle.get(signalGroupId2)); - Assert.assertEquals("avg delay at NS-direction should be zero", 0.0, avgDelayNS, MatsimTestUtils.EPSILON); + Assertions.assertNull(avgSignalGreenTimePerCycle.get(signalGroupId1), "signal group 1 should show no green"); + Assertions.assertNotNull(avgSignalGreenTimePerCycle.get(signalGroupId2), "signal group 2 should show green"); + Assertions.assertEquals(0.0, avgDelayNS, MatsimTestUtils.EPSILON, "avg delay at NS-direction should be zero"); } /** @@ -125,14 +125,13 @@ void testSingleCrossingScenarioLowVsHighDemandWithMinG(){ log.info("avg cycle time per system: " + avgCycleTimePerSystem.get(signalSystemId)); log.info("avg delay per link: " + avgDelayWE + ", " + avgDelayNS); - Assert.assertTrue("total signal green time of WE-direction should be higher than NS-direction", - totalSignalGreenTimes.get(signalGroupId1)-totalSignalGreenTimes.get(signalGroupId2) > 0); - Assert.assertTrue("avg signal green time per cycle of WE-direction should be higher than NS-direction", - avgSignalGreenTimePerCycle.get(signalGroupId1)-avgSignalGreenTimePerCycle.get(signalGroupId2) > 0); - Assert.assertEquals("avg signal green time per cycle of NS-direction should be the minimum green time of 5 seconds", - 5.0, avgSignalGreenTimePerCycle.get(signalGroupId2), MatsimTestUtils.EPSILON); - Assert.assertTrue("cycle time should stay below 90 seconds", avgCycleTimePerSystem.get(signalSystemId) <= 90); - Assert.assertTrue("avg delay per vehicle on WS-direction should be less than on NS-direction", avgDelayWE 0, + "total signal green time of WE-direction should be higher than NS-direction"); + Assertions.assertTrue(avgSignalGreenTimePerCycle.get(signalGroupId1)-avgSignalGreenTimePerCycle.get(signalGroupId2) > 0, + "avg signal green time per cycle of WE-direction should be higher than NS-direction"); + Assertions.assertEquals(5.0, avgSignalGreenTimePerCycle.get(signalGroupId2), MatsimTestUtils.EPSILON, "avg signal green time per cycle of NS-direction should be the minimum green time of 5 seconds"); + Assertions.assertTrue(avgCycleTimePerSystem.get(signalSystemId) <= 90, "cycle time should stay below 90 seconds"); + Assertions.assertTrue(avgDelayWE 0); - Assert.assertTrue("avg signal green time per cycle of WE-direction should be higher than NS-direction", - avgSignalGreenTimePerCycle.get(signalGroupId1)-avgSignalGreenTimePerCycle.get(signalGroupId2) > 0); - Assert.assertTrue("avg signal green time per cycle of NS-direction should be less than 5 seconds", avgSignalGreenTimePerCycle.get(signalGroupId2) < 5.0); - Assert.assertTrue("cycle time should stay below 90 seconds", avgCycleTimePerSystem.get(signalSystemId) <= 90); - Assert.assertTrue("avg delay per vehicle on WS-direction should be less than on NS-direction", avgDelayWE 0, + "total signal green time of WE-direction should be higher than NS-direction"); + Assertions.assertTrue(avgSignalGreenTimePerCycle.get(signalGroupId1)-avgSignalGreenTimePerCycle.get(signalGroupId2) > 0, + "avg signal green time per cycle of WE-direction should be higher than NS-direction"); + Assertions.assertTrue(avgSignalGreenTimePerCycle.get(signalGroupId2) < 5.0, "avg signal green time per cycle of NS-direction should be less than 5 seconds"); + Assertions.assertTrue(avgCycleTimePerSystem.get(signalSystemId) <= 90, "cycle time should stay below 90 seconds"); + Assertions.assertTrue(avgDelayWE linkId : avgDelayPerLinkStab.keySet()) { - Assert.assertTrue("stab: avg delay per link should be below a threshold (i.e. still stable)", avgDelayPerLinkStab.get(linkId) < maxCycleTime); + Assertions.assertTrue(avgDelayPerLinkStab.get(linkId) < maxCycleTime, "stab: avg delay per link should be below a threshold (i.e. still stable)"); } - Assert.assertTrue("stab: total delay should be higher than for the other regimes", generalAnalyzerStab.getTotalDelay() > generalAnalyzerOpt.getTotalDelay()); - Assert.assertTrue("stab: total delay should be higher than for the other regimes", generalAnalyzerStab.getTotalDelay() > generalAnalyzerComb.getTotalDelay()); - Assert.assertTrue("the stabilizing regime should satisfy the maximum cycle time", avgCycleTimePerSystemStab.get(signalSystemId) < maxCycleTime); + Assertions.assertTrue(generalAnalyzerStab.getTotalDelay() > generalAnalyzerOpt.getTotalDelay(), "stab: total delay should be higher than for the other regimes"); + Assertions.assertTrue(generalAnalyzerStab.getTotalDelay() > generalAnalyzerComb.getTotalDelay(), "stab: total delay should be higher than for the other regimes"); + Assertions.assertTrue(avgCycleTimePerSystemStab.get(signalSystemId) < maxCycleTime, "the stabilizing regime should satisfy the maximum cycle time"); // stabilizing regime only shows green when number of vehicles beyond a critical number, i.e. some of the cycle time is given away (all signals show red) - Assert.assertTrue("stab: sum of green times per cycle plus 10 seconds intergreen time should be more than 10 seconds less than the avg cycle time", - avgSignalGreenTimePerCycleStab.get(signalGroupId1) + avgSignalGreenTimePerCycleStab.get(signalGroupId2) + cycleIntergreenTime - < avgCycleTimePerSystemStab.get(signalSystemId) - 10); + Assertions.assertTrue(avgSignalGreenTimePerCycleStab.get(signalGroupId1) + avgSignalGreenTimePerCycleStab.get(signalGroupId2) + cycleIntergreenTime + < avgCycleTimePerSystemStab.get(signalSystemId) - 10, + "stab: sum of green times per cycle plus 10 seconds intergreen time should be more than 10 seconds less than the avg cycle time"); // Test Optimizing Regime: for (Id linkId : avgDelayPerLinkOpt.keySet()) { - Assert.assertTrue("opt: avg delay per link should be below a threshold (i.e. still stable)", avgDelayPerLinkOpt.get(linkId) < maxCycleTime); + Assertions.assertTrue(avgDelayPerLinkOpt.get(linkId) < maxCycleTime, "opt: avg delay per link should be below a threshold (i.e. still stable)"); } - Assert.assertEquals("sum of green times per cycle plus 10 seconds intergreen time should be more or less equal to the avg cycle time", - avgCycleTimePerSystemOpt.get(signalSystemId), + Assertions.assertEquals(avgCycleTimePerSystemOpt.get(signalSystemId), avgSignalGreenTimePerCycleOpt.get(signalGroupId1) + avgSignalGreenTimePerCycleOpt.get(signalGroupId2) + cycleIntergreenTime, - 2); - Assert.assertTrue("for this demand, the cycle time of the optimizing regime should be still reasonable, i.e. below a threshold", - avgCycleTimePerSystemOpt.get(signalSystemId) < maxCycleTime); + 2, + "sum of green times per cycle plus 10 seconds intergreen time should be more or less equal to the avg cycle time"); + Assertions.assertTrue(avgCycleTimePerSystemOpt.get(signalSystemId) < maxCycleTime, + "for this demand, the cycle time of the optimizing regime should be still reasonable, i.e. below a threshold"); // Test Combined Regime: for (Id linkId : avgDelayPerLinkComb.keySet()) { - Assert.assertTrue("avg delay per link should be below a threshold (i.e. still stable)", avgDelayPerLinkComb.get(linkId) < maxCycleTime); + Assertions.assertTrue(avgDelayPerLinkComb.get(linkId) < maxCycleTime, "avg delay per link should be below a threshold (i.e. still stable)"); } - Assert.assertEquals("comb: sum of green times per cycle plus 10 seconds intergreen time should be more or less equal to the avg cycle time", - avgCycleTimePerSystemComb.get(signalSystemId), + Assertions.assertEquals(avgCycleTimePerSystemComb.get(signalSystemId), avgSignalGreenTimePerCycleComb.get(signalGroupId1) + avgSignalGreenTimePerCycleComb.get(signalGroupId2) + cycleIntergreenTime, - 2); - Assert.assertTrue("the combined regime should satisfy the maximum cycle time", avgCycleTimePerSystemComb.get(signalSystemId) < maxCycleTime); - Assert.assertTrue("total delay with the combined regime should be the lowest", generalAnalyzerOpt.getTotalDelay() > generalAnalyzerComb.getTotalDelay()); + 2, + "comb: sum of green times per cycle plus 10 seconds intergreen time should be more or less equal to the avg cycle time"); + Assertions.assertTrue(avgCycleTimePerSystemComb.get(signalSystemId) < maxCycleTime, "the combined regime should satisfy the maximum cycle time"); + Assertions.assertTrue(generalAnalyzerOpt.getTotalDelay() > generalAnalyzerComb.getTotalDelay(), "total delay with the combined regime should be the lowest"); } /** @@ -341,31 +339,31 @@ void testSingleCrossingScenarioStabilizingVsOptimizingRegimeHighDemand(){ // Test Stabilizing Regime: for (Id linkId : avgDelayPerLinkStab.keySet()) { - Assert.assertTrue("stab: avg delay per link should be below a threshold (i.e. still stable)", avgDelayPerLinkStab.get(linkId) < maxCycleTime); + Assertions.assertTrue(avgDelayPerLinkStab.get(linkId) < maxCycleTime, "stab: avg delay per link should be below a threshold (i.e. still stable)"); } - Assert.assertTrue("the stabilizing regime should satisfy the maximum cycle time", avgCycleTimePerSystemStab.get(signalSystemId) < maxCycleTime); + Assertions.assertTrue(avgCycleTimePerSystemStab.get(signalSystemId) < maxCycleTime, "the stabilizing regime should satisfy the maximum cycle time"); // stabilizing regime only shows green when number of vehicles beyond a critical number, i.e. some of the cycle time is given away (all signals show red) - Assert.assertTrue("stab: sum of green times per cycle plus 10 seconds intergreen time should be more than 9 seconds less than the avg cycle time", - avgSignalGreenTimePerCycleStab.get(signalGroupId1) + avgSignalGreenTimePerCycleStab.get(signalGroupId2) + cycleIntergreenTime - < avgCycleTimePerSystemStab.get(signalSystemId) - 9); + Assertions.assertTrue(avgSignalGreenTimePerCycleStab.get(signalGroupId1) + avgSignalGreenTimePerCycleStab.get(signalGroupId2) + cycleIntergreenTime + < avgCycleTimePerSystemStab.get(signalSystemId) - 9, + "stab: sum of green times per cycle plus 10 seconds intergreen time should be more than 9 seconds less than the avg cycle time"); // Test Optimizing Regime: - Assert.assertTrue("avg delay for NS-direction should be very high for the optimizing regime with high demand", avgDelayPerLinkOpt.get(Id.createLinkId("7_3")) > maxCycleTime); - Assert.assertTrue("total delay of optimizing regime should be the highest", generalAnalyzerStab.getTotalDelay() < generalAnalyzerOpt.getTotalDelay()); - Assert.assertTrue("for this demand, the cycle time of the optimizing regime should be very high, i.e. not stable anymore", - avgCycleTimePerSystemOpt.get(signalSystemId) > 10*maxCycleTime); + Assertions.assertTrue(avgDelayPerLinkOpt.get(Id.createLinkId("7_3")) > maxCycleTime, "avg delay for NS-direction should be very high for the optimizing regime with high demand"); + Assertions.assertTrue(generalAnalyzerStab.getTotalDelay() < generalAnalyzerOpt.getTotalDelay(), "total delay of optimizing regime should be the highest"); + Assertions.assertTrue(avgCycleTimePerSystemOpt.get(signalSystemId) > 10*maxCycleTime, + "for this demand, the cycle time of the optimizing regime should be very high, i.e. not stable anymore"); // Test Combined Regime: for (Id linkId : avgDelayPerLinkComb.keySet()) { - Assert.assertTrue("avg delay per link should be below a threshold (i.e. still stable)", avgDelayPerLinkComb.get(linkId) < maxCycleTime); + Assertions.assertTrue(avgDelayPerLinkComb.get(linkId) < maxCycleTime, "avg delay per link should be below a threshold (i.e. still stable)"); } - Assert.assertEquals("comb: sum of green times per cycle plus 10 seconds intergreen time should be more or less equal to the avg cycle time", - avgCycleTimePerSystemComb.get(signalSystemId), + Assertions.assertEquals(avgCycleTimePerSystemComb.get(signalSystemId), avgSignalGreenTimePerCycleComb.get(signalGroupId1) + avgSignalGreenTimePerCycleComb.get(signalGroupId2) + cycleIntergreenTime, - 2); - Assert.assertTrue("the combined regime should satisfy the maximum cycle time", avgCycleTimePerSystemComb.get(signalSystemId) < maxCycleTime); - Assert.assertTrue("total delay with the combined regime should be the lowest", generalAnalyzerOpt.getTotalDelay() > generalAnalyzerComb.getTotalDelay()); - Assert.assertTrue("total delay with the combined regime should be the lowest", generalAnalyzerStab.getTotalDelay() > generalAnalyzerComb.getTotalDelay()); + 2, + "comb: sum of green times per cycle plus 10 seconds intergreen time should be more or less equal to the avg cycle time"); + Assertions.assertTrue(avgCycleTimePerSystemComb.get(signalSystemId) < maxCycleTime, "the combined regime should satisfy the maximum cycle time"); + Assertions.assertTrue(generalAnalyzerOpt.getTotalDelay() > generalAnalyzerComb.getTotalDelay(), "total delay with the combined regime should be the lowest"); + Assertions.assertTrue(generalAnalyzerStab.getTotalDelay() > generalAnalyzerComb.getTotalDelay(), "total delay with the combined regime should be the lowest"); } /** @@ -410,21 +408,19 @@ void testSingleCrossingScenarioWithDifferentFlowCapacityFactors(){ log.info("avg delay per link: " + avgDelayPerLinkFlowCap1.get(Id.createLinkId("2_3")) + ", " + avgDelayPerLinkFlowCap1.get(Id.createLinkId("7_3"))); log.info("Total delay: " + generalAnalyzerFlowCap1.getTotalDelay()); - Assert.assertEquals("total signal green times should not differ", 1, - totalSignalGreenTimesFlowCap1.get(signalGroupId1)/totalSignalGreenTimesFlowCap2.get(signalGroupId1), 0.01); - Assert.assertEquals("total signal green times should not differ", 1, - totalSignalGreenTimesFlowCap1.get(signalGroupId2)/totalSignalGreenTimesFlowCap2.get(signalGroupId2), 0.01); - Assert.assertEquals("avg signal green times per cycle should not differ", avgSignalGreenTimePerCycleFlowCap1.get(signalGroupId1), - avgSignalGreenTimePerCycleFlowCap2.get(signalGroupId1), 0.1); - Assert.assertEquals("avg signal green times per cycle should not differ", avgSignalGreenTimePerCycleFlowCap1.get(signalGroupId2), - avgSignalGreenTimePerCycleFlowCap2.get(signalGroupId2), 0.1); - Assert.assertEquals("avg cycle time should not differ", avgCycleTimePerSystemFlowCap1.get(signalSystemId), - avgCycleTimePerSystemFlowCap2.get(signalSystemId), 0.1); - Assert.assertEquals("avg delay per vehicle per link should not differ", - avgDelayPerLinkFlowCap1.get(Id.createLinkId("2_3")), avgDelayPerLinkFlowCap2.get(Id.createLinkId("2_3")), 0.1); - Assert.assertEquals("avg delay per vehicle per link should not differ", - avgDelayPerLinkFlowCap1.get(Id.createLinkId("7_3")), avgDelayPerLinkFlowCap2.get(Id.createLinkId("7_3")), 2); - Assert.assertEquals("total delay for doubled demand should be doubled", 2, generalAnalyzerFlowCap2.getTotalDelay()/generalAnalyzerFlowCap1.getTotalDelay(), 0.1); + Assertions.assertEquals(1, + totalSignalGreenTimesFlowCap1.get(signalGroupId1)/totalSignalGreenTimesFlowCap2.get(signalGroupId1), 0.01, "total signal green times should not differ"); + Assertions.assertEquals(1, + totalSignalGreenTimesFlowCap1.get(signalGroupId2)/totalSignalGreenTimesFlowCap2.get(signalGroupId2), 0.01, "total signal green times should not differ"); + Assertions.assertEquals(avgSignalGreenTimePerCycleFlowCap1.get(signalGroupId1), + avgSignalGreenTimePerCycleFlowCap2.get(signalGroupId1), 0.1, "avg signal green times per cycle should not differ"); + Assertions.assertEquals(avgSignalGreenTimePerCycleFlowCap1.get(signalGroupId2), + avgSignalGreenTimePerCycleFlowCap2.get(signalGroupId2), 0.1, "avg signal green times per cycle should not differ"); + Assertions.assertEquals(avgCycleTimePerSystemFlowCap1.get(signalSystemId), + avgCycleTimePerSystemFlowCap2.get(signalSystemId), 0.1, "avg cycle time should not differ"); + Assertions.assertEquals(avgDelayPerLinkFlowCap1.get(Id.createLinkId("2_3")), avgDelayPerLinkFlowCap2.get(Id.createLinkId("2_3")), 0.1, "avg delay per vehicle per link should not differ"); + Assertions.assertEquals(avgDelayPerLinkFlowCap1.get(Id.createLinkId("7_3")), avgDelayPerLinkFlowCap2.get(Id.createLinkId("7_3")), 2, "avg delay per vehicle per link should not differ"); + Assertions.assertEquals(2, generalAnalyzerFlowCap2.getTotalDelay()/generalAnalyzerFlowCap1.getTotalDelay(), 0.1, "total delay for doubled demand should be doubled"); } /** @@ -475,19 +471,19 @@ void testMultipleIterations() { log.info("avg delay per link in itertion 1: " + avgDelayWE1It + ", " + avgDelayNS1It); - Assert.assertEquals("total green time of signal group 1 should be the same as in the first iteration", totalSignalGreenTimes0It.get(signalGroupId1), totalSignalGreenTimes1It.get(signalGroupId1), MatsimTestUtils.EPSILON); - Assert.assertEquals("total green time of signal group 1l should be the same as in the first iteration", totalSignalGreenTimes0It.get(signalGroupId1l), totalSignalGreenTimes1It.get(signalGroupId1l), MatsimTestUtils.EPSILON); - Assert.assertEquals("total green time of signal group 2 should be the same as in the first iteration", totalSignalGreenTimes0It.get(signalGroupId2), totalSignalGreenTimes1It.get(signalGroupId2), MatsimTestUtils.EPSILON); - Assert.assertEquals("avg green time of signal group 1 should be the same as in the first iteration", avgSignalGreenTimePerCycle0It.get(signalGroupId1), avgSignalGreenTimePerCycle1It.get(signalGroupId1), .01); - Assert.assertEquals("avg green time of signal group 1l should be the same as in the first iteration", avgSignalGreenTimePerCycle0It.get(signalGroupId1l), avgSignalGreenTimePerCycle1It.get(signalGroupId1l), .01); - Assert.assertEquals("avg green time of signal group 2 should be the same as in the first iteration", avgSignalGreenTimePerCycle0It.get(signalGroupId2), avgSignalGreenTimePerCycle1It.get(signalGroupId2), .01); - Assert.assertEquals("avg cycle time should be the same as in the first iteration", avgCycleTimePerSystem0It.get(signalSystemId), avgCycleTimePerSystem1It.get(signalSystemId), .01); - Assert.assertEquals("avg delay in direction WE should be the same as in the first iteration", avgDelayWE0It, avgDelayWE1It, .01); - Assert.assertEquals("avg delay in direction NS should be the same as in the first iteration", avgDelayNS0It, avgDelayNS1It, .01); + Assertions.assertEquals(totalSignalGreenTimes0It.get(signalGroupId1), totalSignalGreenTimes1It.get(signalGroupId1), MatsimTestUtils.EPSILON, "total green time of signal group 1 should be the same as in the first iteration"); + Assertions.assertEquals(totalSignalGreenTimes0It.get(signalGroupId1l), totalSignalGreenTimes1It.get(signalGroupId1l), MatsimTestUtils.EPSILON, "total green time of signal group 1l should be the same as in the first iteration"); + Assertions.assertEquals(totalSignalGreenTimes0It.get(signalGroupId2), totalSignalGreenTimes1It.get(signalGroupId2), MatsimTestUtils.EPSILON, "total green time of signal group 2 should be the same as in the first iteration"); + Assertions.assertEquals(avgSignalGreenTimePerCycle0It.get(signalGroupId1), avgSignalGreenTimePerCycle1It.get(signalGroupId1), .01, "avg green time of signal group 1 should be the same as in the first iteration"); + Assertions.assertEquals(avgSignalGreenTimePerCycle0It.get(signalGroupId1l), avgSignalGreenTimePerCycle1It.get(signalGroupId1l), .01, "avg green time of signal group 1l should be the same as in the first iteration"); + Assertions.assertEquals(avgSignalGreenTimePerCycle0It.get(signalGroupId2), avgSignalGreenTimePerCycle1It.get(signalGroupId2), .01, "avg green time of signal group 2 should be the same as in the first iteration"); + Assertions.assertEquals(avgCycleTimePerSystem0It.get(signalSystemId), avgCycleTimePerSystem1It.get(signalSystemId), .01, "avg cycle time should be the same as in the first iteration"); + Assertions.assertEquals(avgDelayWE0It, avgDelayWE1It, .01, "avg delay in direction WE should be the same as in the first iteration"); + Assertions.assertEquals(avgDelayNS0It, avgDelayNS1It, .01, "avg delay in direction NS should be the same as in the first iteration"); // compare signal event files long checksum_it0 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "ITERS/it.0/signalEvents2Via.csv"); long checksum_itLast = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "ITERS/it."+lastIt+"/signalEvents2Via.csv"); - Assert.assertEquals("Signal events are different", checksum_it0, checksum_itLast); + Assertions.assertEquals(checksum_it0, checksum_itLast, "Signal events are different"); } // TODO test stochasticity (laemmer better than fixed-time; different than for constant demand) diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java index 21c110b666a..195082ff66a 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/controller/sylvia/SylviaIT.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -118,12 +118,12 @@ void testDemandABPrioA() { log.info("total signal green times: " + totalSignalGreenTimes.get(signalGroupId1) + ", " + totalSignalGreenTimes.get(signalGroupId2)); log.info("avg signal green times per cycle: " + avgSignalGreenTimePerCycle.get(signalGroupId1) + ", " + avgSignalGreenTimePerCycle.get(signalGroupId2)); log.info("avg cycle time per system: " + avgCycleTimePerSystem.get(signalSystemId)); - Assert.assertEquals("total signal green time of signal group 1 is wrong", 2900, totalSignalGreenTimes.get(signalGroupId1), 50); - Assert.assertEquals("total signal green time of signal group 2 is wrong", 2000, totalSignalGreenTimes.get(signalGroupId2), 50); - Assert.assertEquals("avg green time per cycle of signal group 1 is wrong", 30, avgSignalGreenTimePerCycle.get(signalGroupId1), 1); - Assert.assertEquals("avg green time per cycle of signal group 2 is wrong", 20, avgSignalGreenTimePerCycle.get(signalGroupId2), 1); + Assertions.assertEquals(2900, totalSignalGreenTimes.get(signalGroupId1), 50, "total signal green time of signal group 1 is wrong"); + Assertions.assertEquals(2000, totalSignalGreenTimes.get(signalGroupId2), 50, "total signal green time of signal group 2 is wrong"); + Assertions.assertEquals(30, avgSignalGreenTimePerCycle.get(signalGroupId1), 1, "avg green time per cycle of signal group 1 is wrong"); + Assertions.assertEquals(20, avgSignalGreenTimePerCycle.get(signalGroupId2), 1, "avg green time per cycle of signal group 2 is wrong"); // can differ from the fixed cycle length because the analysis is quit after the last activity start event - Assert.assertEquals("avg cycle time of the system is wrong", 60, avgCycleTimePerSystem.get(signalSystemId), 1); + Assertions.assertEquals(60, avgCycleTimePerSystem.get(signalSystemId), 1, "avg cycle time of the system is wrong"); } /** @@ -157,12 +157,12 @@ void testDemandABPrioB() { log.info("total signal green times: " + totalSignalGreenTimes.get(signalGroupId1) + ", " + totalSignalGreenTimes.get(signalGroupId2)); log.info("avg signal green times per cycle: " + avgSignalGreenTimePerCycle.get(signalGroupId1) + ", " + avgSignalGreenTimePerCycle.get(signalGroupId2)); log.info("avg cycle time per system: " + avgCycleTimePerSystem.get(signalSystemId)); - Assert.assertEquals("total signal green time of signal group 2 is wrong", 2900, totalSignalGreenTimes.get(signalGroupId2), 50); - Assert.assertEquals("total signal green time of signal group 1 is wrong", 2000, totalSignalGreenTimes.get(signalGroupId1), 50); - Assert.assertEquals("avg green time per cycle of signal group 2 is wrong", 30, avgSignalGreenTimePerCycle.get(signalGroupId2), 1); - Assert.assertEquals("avg green time per cycle of signal group 1 is wrong", 20, avgSignalGreenTimePerCycle.get(signalGroupId1), 1); + Assertions.assertEquals(2900, totalSignalGreenTimes.get(signalGroupId2), 50, "total signal green time of signal group 2 is wrong"); + Assertions.assertEquals(2000, totalSignalGreenTimes.get(signalGroupId1), 50, "total signal green time of signal group 1 is wrong"); + Assertions.assertEquals(30, avgSignalGreenTimePerCycle.get(signalGroupId2), 1, "avg green time per cycle of signal group 2 is wrong"); + Assertions.assertEquals(20, avgSignalGreenTimePerCycle.get(signalGroupId1), 1, "avg green time per cycle of signal group 1 is wrong"); // can differ from the fixed cycle length because the analysis is quit after the last activity start event - Assert.assertEquals("avg cycle time of the system is wrong", 60, avgCycleTimePerSystem.get(signalSystemId), 1); + Assertions.assertEquals(60, avgCycleTimePerSystem.get(signalSystemId), 1, "avg cycle time of the system is wrong"); } /** @@ -184,11 +184,11 @@ void testDemandA() { log.info("total signal green times: " + totalSignalGreenTimes.get(signalGroupId1) + ", " + totalSignalGreenTimes.get(signalGroupId2)); log.info("avg signal green times per cycle: " + avgSignalGreenTimePerCycle.get(signalGroupId1) + ", " + avgSignalGreenTimePerCycle.get(signalGroupId2)); log.info("avg cycle time per system: " + avgCycleTimePerSystem.get(signalSystemId)); - Assert.assertTrue("total signal green time of group 1 is not bigger than of group 2", totalSignalGreenTimes.get(signalGroupId1) > totalSignalGreenTimes.get(signalGroupId2)); - Assert.assertEquals("avg green time per cycle of signal group 1 is wrong", 45, avgSignalGreenTimePerCycle.get(signalGroupId1), 5); - Assert.assertEquals("avg green time per cycle of signal group 2 is wrong", 5, avgSignalGreenTimePerCycle.get(signalGroupId2), 5); + Assertions.assertTrue(totalSignalGreenTimes.get(signalGroupId1) > totalSignalGreenTimes.get(signalGroupId2), "total signal green time of group 1 is not bigger than of group 2"); + Assertions.assertEquals(45, avgSignalGreenTimePerCycle.get(signalGroupId1), 5, "avg green time per cycle of signal group 1 is wrong"); + Assertions.assertEquals(5, avgSignalGreenTimePerCycle.get(signalGroupId2), 5, "avg green time per cycle of signal group 2 is wrong"); // can differ from the fixed cycle length because the analysis is quit after the last activity start event - Assert.assertEquals("avg cycle time of the system is wrong", 60, avgCycleTimePerSystem.get(signalSystemId), 1); + Assertions.assertEquals(60, avgCycleTimePerSystem.get(signalSystemId), 1, "avg cycle time of the system is wrong"); } private SignalAnalysisTool runScenario(double[] noPersons, int offset) { diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java index 55e3b0ff974..522ae6a08b9 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/ambertimes/v10/AmberTimesData10ReaderWriterTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -82,21 +82,21 @@ void testWriter() throws JAXBException, SAXException, ParserConfigurationExcepti private void checkContent(AmberTimesData ats) { // global defaults - Assert.assertNotNull(ats); - Assert.assertEquals(0.3, ats.getDefaultAmberTimeGreen(), 1e-7); - Assert.assertEquals(1, ats.getDefaultRedAmber().intValue()); - Assert.assertEquals(4, ats.getDefaultAmber().intValue()); + Assertions.assertNotNull(ats); + Assertions.assertEquals(0.3, ats.getDefaultAmberTimeGreen(), 1e-7); + Assertions.assertEquals(1, ats.getDefaultRedAmber().intValue()); + Assertions.assertEquals(4, ats.getDefaultAmber().intValue()); // system id1 defaults AmberTimeData atdata = ats.getAmberTimeDataBySystemId().get(Id.create(1, SignalSystem.class)); - Assert.assertNotNull(atdata); - Assert.assertEquals(1, atdata.getDefaultRedAmber().intValue()); - Assert.assertEquals(4, atdata.getDefaultAmber().intValue()); + Assertions.assertNotNull(atdata); + Assertions.assertEquals(1, atdata.getDefaultRedAmber().intValue()); + Assertions.assertEquals(4, atdata.getDefaultAmber().intValue()); // Signal 1 defaults - Assert.assertNotNull(atdata.getAmberOfSignal(Id.create(1, Signal.class))); - Assert.assertNotNull(atdata.getSignalAmberMap()); - Assert.assertNotNull(atdata.getSignalRedAmberMap()); - Assert.assertEquals(4, atdata.getAmberOfSignal(Id.create(1, Signal.class)).intValue()); - Assert.assertEquals(2, atdata.getRedAmberOfSignal(Id.create(1, Signal.class)).intValue()); + Assertions.assertNotNull(atdata.getAmberOfSignal(Id.create(1, Signal.class))); + Assertions.assertNotNull(atdata.getSignalAmberMap()); + Assertions.assertNotNull(atdata.getSignalRedAmberMap()); + Assertions.assertEquals(4, atdata.getAmberOfSignal(Id.create(1, Signal.class)).intValue()); + Assertions.assertEquals(2, atdata.getRedAmberOfSignal(Id.create(1, Signal.class)).intValue()); } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java index 295e85c40eb..835b9502513 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/SignalConflictDataReaderWriterTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -63,32 +63,32 @@ void testReaderAndWriter() { } private void compare(ConflictData conflictData1, ConflictData conflictData2) { - Assert.assertEquals("not the same number of intersections", conflictData1.getConflictsPerNode().size(), conflictData2.getConflictsPerNode().size()); + Assertions.assertEquals(conflictData1.getConflictsPerNode().size(), conflictData2.getConflictsPerNode().size(), "not the same number of intersections"); for (IntersectionDirections intersection1 : conflictData1.getConflictsPerSignalSystem().values()) { IntersectionDirections intersection2 = conflictData2.getConflictsPerSignalSystem().get(intersection1.getSignalSystemId()); - Assert.assertNotNull("no conflict data exists for signal system " + intersection1.getSignalSystemId(), intersection2); - Assert.assertEquals("not the same node, but the same signal system " + intersection1.getSignalSystemId(), intersection1.getNodeId(), intersection2.getNodeId()); - Assert.assertEquals("not the same number of direction at node " + intersection1.getNodeId(), intersection1.getDirections().size(), intersection2.getDirections().size()); + Assertions.assertNotNull(intersection2, "no conflict data exists for signal system " + intersection1.getSignalSystemId()); + Assertions.assertEquals(intersection1.getNodeId(), intersection2.getNodeId(), "not the same node, but the same signal system " + intersection1.getSignalSystemId()); + Assertions.assertEquals(intersection1.getDirections().size(), intersection2.getDirections().size(), "not the same number of direction at node " + intersection1.getNodeId()); for (Direction dir1 : intersection1.getDirections().values()) { Direction dir2 = intersection2.getDirections().get(dir1.getId()); - Assert.assertNotNull("no direction exists for id " + dir1.getId(), dir2); - Assert.assertEquals("direction " + dir1.getId() + " has not the same from link", dir1.getFromLink(), dir2.getFromLink()); - Assert.assertEquals("direction " + dir1.getId() + " has not the same to link", dir1.getToLink(), dir2.getToLink()); - Assert.assertEquals("not the same number of conflicting directions for direction " + dir1.getId(), dir1.getConflictingDirections().size(), dir2.getConflictingDirections().size()); - Assert.assertEquals("not the same number of directions with right of way for direction " + dir1.getId(), dir1.getDirectionsWithRightOfWay().size(), dir2.getDirectionsWithRightOfWay().size()); - Assert.assertEquals("not the same number of directions which must yield for direction " + dir1.getId(), dir1.getDirectionsWhichMustYield().size(), dir2.getDirectionsWhichMustYield().size()); - Assert.assertEquals("not the same number of non-conflicting directions for direction " + dir1.getId(), dir1.getNonConflictingDirections().size(), dir2.getNonConflictingDirections().size()); + Assertions.assertNotNull(dir2, "no direction exists for id " + dir1.getId()); + Assertions.assertEquals(dir1.getFromLink(), dir2.getFromLink(), "direction " + dir1.getId() + " has not the same from link"); + Assertions.assertEquals(dir1.getToLink(), dir2.getToLink(), "direction " + dir1.getId() + " has not the same to link"); + Assertions.assertEquals(dir1.getConflictingDirections().size(), dir2.getConflictingDirections().size(), "not the same number of conflicting directions for direction " + dir1.getId()); + Assertions.assertEquals(dir1.getDirectionsWithRightOfWay().size(), dir2.getDirectionsWithRightOfWay().size(), "not the same number of directions with right of way for direction " + dir1.getId()); + Assertions.assertEquals(dir1.getDirectionsWhichMustYield().size(), dir2.getDirectionsWhichMustYield().size(), "not the same number of directions which must yield for direction " + dir1.getId()); + Assertions.assertEquals(dir1.getNonConflictingDirections().size(), dir2.getNonConflictingDirections().size(), "not the same number of non-conflicting directions for direction " + dir1.getId()); for (Id conflDir1 : dir1.getConflictingDirections()) { - Assert.assertTrue("direction " + conflDir1 + " is not a conflicting direction for " + dir1.getId(), dir2.getConflictingDirections().contains(conflDir1)); + Assertions.assertTrue(dir2.getConflictingDirections().contains(conflDir1), "direction " + conflDir1 + " is not a conflicting direction for " + dir1.getId()); } for (Id conflDir1 : dir1.getDirectionsWithRightOfWay()) { - Assert.assertTrue("direction " + conflDir1 + " is not a direction with right of way for " + dir1.getId(), dir2.getDirectionsWithRightOfWay().contains(conflDir1)); + Assertions.assertTrue(dir2.getDirectionsWithRightOfWay().contains(conflDir1), "direction " + conflDir1 + " is not a direction with right of way for " + dir1.getId()); } for (Id conflDir1 : dir1.getDirectionsWhichMustYield()) { - Assert.assertTrue("direction " + conflDir1 + " is not a direction which must yield for " + dir1.getId(), dir2.getDirectionsWhichMustYield().contains(conflDir1)); + Assertions.assertTrue(dir2.getDirectionsWhichMustYield().contains(conflDir1), "direction " + conflDir1 + " is not a direction which must yield for " + dir1.getId()); } for (Id conflDir1 : dir1.getNonConflictingDirections()) { - Assert.assertTrue("direction " + conflDir1 + " is not a non-conflicting direction for " + dir1.getId(), dir2.getNonConflictingDirections().contains(conflDir1)); + Assertions.assertTrue(dir2.getNonConflictingDirections().contains(conflDir1), "direction " + conflDir1 + " is not a non-conflicting direction for " + dir1.getId()); } } } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java index e1c44259dab..4dc256cf370 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/conflicts/UnprotectedLeftTurnLogicTest.java @@ -20,7 +20,7 @@ */ package org.matsim.contrib.signals.data.conflicts; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -57,10 +57,10 @@ void testSingleIntersectionScenarioWithLeftTurns() { System.out.println("delay wTurn: " + leftTurnDelayWTurnRestriction); System.out.println("delay w/oTurn: " + leftTurnDelayWoTurnRestriction); System.out.println("delay w/oLogic: " + leftTurnDelayWithoutLogic); - Assert.assertTrue("Delay without restriction should be less than with restricted left turns.", 2 * leftTurnDelayWoTurnRestriction < leftTurnDelayWTurnRestriction); - Assert.assertEquals("Delay without turn restriction should be equal to the case without conflicting data.", leftTurnDelayWoTurnRestriction, leftTurnDelayWithoutLogic, MatsimTestUtils.EPSILON); - Assert.assertEquals("Delay value for the case without turn restrictions is not as expected!", 21120, leftTurnDelayWoTurnRestriction, MatsimTestUtils.EPSILON); - Assert.assertEquals("Delay value for the case with turn restrictions is not as expected!", 80845, leftTurnDelayWTurnRestriction, MatsimTestUtils.EPSILON); + Assertions.assertTrue(2 * leftTurnDelayWoTurnRestriction < leftTurnDelayWTurnRestriction, "Delay without restriction should be less than with restricted left turns."); + Assertions.assertEquals(leftTurnDelayWoTurnRestriction, leftTurnDelayWithoutLogic, MatsimTestUtils.EPSILON, "Delay without turn restriction should be equal to the case without conflicting data."); + Assertions.assertEquals(21120, leftTurnDelayWoTurnRestriction, MatsimTestUtils.EPSILON, "Delay value for the case without turn restrictions is not as expected!"); + Assertions.assertEquals(80845, leftTurnDelayWTurnRestriction, MatsimTestUtils.EPSILON, "Delay value for the case with turn restrictions is not as expected!"); } private AnalyzeSingleIntersectionLeftTurnDelays runSimulation(IntersectionLogic intersectionLogic) { diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java index 9ac1b9ff35e..0d103e94553 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/intergreens/v10/IntergreenTimesData10ReaderWriterTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -88,22 +88,22 @@ void testWriter() throws JAXBException, SAXException, ParserConfigurationExcepti } private void checkContent(IntergreenTimesData itd) { - Assert.assertNotNull(itd); - Assert.assertNotNull(itd.getIntergreensForSignalSystemDataMap()); - Assert.assertEquals(2, itd.getIntergreensForSignalSystemDataMap().size()); + Assertions.assertNotNull(itd); + Assertions.assertNotNull(itd.getIntergreensForSignalSystemDataMap()); + Assertions.assertEquals(2, itd.getIntergreensForSignalSystemDataMap().size()); IntergreensForSignalSystemData ig23 = itd.getIntergreensForSignalSystemDataMap().get(systemId23); - Assert.assertNotNull(ig23); - Assert.assertEquals(Integer.valueOf(5), ig23.getIntergreenTime(groupId1, groupId2)); - Assert.assertEquals(Integer.valueOf(3), ig23.getIntergreenTime(groupId1, groupId3)); - Assert.assertEquals(Integer.valueOf(3), ig23.getIntergreenTime(groupId1, groupId4)); - Assert.assertNull(ig23.getIntergreenTime(groupId2, groupId3)); + Assertions.assertNotNull(ig23); + Assertions.assertEquals(Integer.valueOf(5), ig23.getIntergreenTime(groupId1, groupId2)); + Assertions.assertEquals(Integer.valueOf(3), ig23.getIntergreenTime(groupId1, groupId3)); + Assertions.assertEquals(Integer.valueOf(3), ig23.getIntergreenTime(groupId1, groupId4)); + Assertions.assertNull(ig23.getIntergreenTime(groupId2, groupId3)); IntergreensForSignalSystemData ig42 = itd.getIntergreensForSignalSystemDataMap().get(systemId42); - Assert.assertNotNull(ig42); - Assert.assertEquals(Integer.valueOf(5), ig42.getIntergreenTime(groupId1, groupId2)); - Assert.assertEquals(Integer.valueOf(3), ig42.getIntergreenTime(groupId2, groupId1)); - Assert.assertNull(ig42.getIntergreenTime(groupId1, groupId3)); - Assert.assertNull(ig42.getIntergreenTime(groupId1, groupId1)); + Assertions.assertNotNull(ig42); + Assertions.assertEquals(Integer.valueOf(5), ig42.getIntergreenTime(groupId1, groupId2)); + Assertions.assertEquals(Integer.valueOf(3), ig42.getIntergreenTime(groupId2, groupId1)); + Assertions.assertNull(ig42.getIntergreenTime(groupId1, groupId3)); + Assertions.assertNull(ig42.getIntergreenTime(groupId1, groupId1)); } } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java index 283af98f161..43d3c4bc250 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalcontrol/v20/SignalControlData20ReaderWriterTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -95,41 +95,41 @@ void testWriter() throws JAXBException, SAXException, ParserConfigurationExcepti private void checkContent(SignalControlData controlData) { - Assert.assertNotNull(controlData); - Assert.assertEquals(2, controlData.getSignalSystemControllerDataBySystemId().size()); + Assertions.assertNotNull(controlData); + Assertions.assertEquals(2, controlData.getSignalSystemControllerDataBySystemId().size()); //first controller SignalSystemControllerData systemController = controlData.getSignalSystemControllerDataBySystemId().get(systemId42); - Assert.assertNotNull(systemController); - Assert.assertNotNull(systemController.getControllerIdentifier()); - Assert.assertEquals("DefaultPlanbasedSignalSystemController", systemController.getControllerIdentifier()); - Assert.assertNotNull(systemController.getSignalPlanData()); + Assertions.assertNotNull(systemController); + Assertions.assertNotNull(systemController.getControllerIdentifier()); + Assertions.assertEquals("DefaultPlanbasedSignalSystemController", systemController.getControllerIdentifier()); + Assertions.assertNotNull(systemController.getSignalPlanData()); SignalPlanData plan = systemController.getSignalPlanData().get(signalPlanId8); - Assert.assertNotNull(plan); + Assertions.assertNotNull(plan); double startTime = plan.getStartTime(); - Assert.assertEquals(0.0, startTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, startTime, MatsimTestUtils.EPSILON); double stopTime = plan.getEndTime(); - Assert.assertEquals(0.0, stopTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, stopTime, MatsimTestUtils.EPSILON); Integer cycleTime = plan.getCycleTime(); - Assert.assertNotNull(cycleTime); - Assert.assertEquals(Integer.valueOf(60), cycleTime); - Assert.assertEquals(3, plan.getOffset()); + Assertions.assertNotNull(cycleTime); + Assertions.assertEquals(Integer.valueOf(60), cycleTime); + Assertions.assertEquals(3, plan.getOffset()); - Assert.assertNotNull(plan.getSignalGroupSettingsDataByGroupId()); + Assertions.assertNotNull(plan.getSignalGroupSettingsDataByGroupId()); SignalGroupSettingsData signalGroupSettings = plan.getSignalGroupSettingsDataByGroupId().get(groupId23); - Assert.assertNotNull(signalGroupSettings); - Assert.assertEquals(groupId23, signalGroupSettings.getSignalGroupId()); - Assert.assertNotNull(signalGroupSettings.getOnset()); - Assert.assertEquals(0, signalGroupSettings.getOnset()); - Assert.assertNotNull(signalGroupSettings.getDropping()); - Assert.assertEquals(45, signalGroupSettings.getDropping()); + Assertions.assertNotNull(signalGroupSettings); + Assertions.assertEquals(groupId23, signalGroupSettings.getSignalGroupId()); + Assertions.assertNotNull(signalGroupSettings.getOnset()); + Assertions.assertEquals(0, signalGroupSettings.getOnset()); + Assertions.assertNotNull(signalGroupSettings.getDropping()); + Assertions.assertEquals(45, signalGroupSettings.getDropping()); //second controller systemController = controlData.getSignalSystemControllerDataBySystemId().get(systemId43); - Assert.assertNotNull(systemController); - Assert.assertNotNull(systemController.getControllerIdentifier()); - Assert.assertEquals("logicbasedActuatedController", systemController.getControllerIdentifier()); - Assert.assertNull(systemController.getSignalPlanData()); + Assertions.assertNotNull(systemController); + Assertions.assertNotNull(systemController.getControllerIdentifier()); + Assertions.assertEquals("logicbasedActuatedController", systemController.getControllerIdentifier()); + Assertions.assertNull(systemController.getSignalPlanData()); } } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java index 1086d595d2a..c789f80118c 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalgroups/v20/SignalGroups20ReaderWriterTest.java @@ -29,7 +29,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -97,28 +97,28 @@ void testWriter() throws JAXBException, SAXException, ParserConfigurationExcepti private void checkContent(SignalGroupsData sgd) { - Assert.assertNotNull(sgd); - Assert.assertNotNull(sgd.getSignalGroupDataBySignalSystemId()); - Assert.assertNotNull(sgd.getSignalGroupDataBySystemId(id23)); + Assertions.assertNotNull(sgd); + Assertions.assertNotNull(sgd.getSignalGroupDataBySignalSystemId()); + Assertions.assertNotNull(sgd.getSignalGroupDataBySystemId(id23)); //sg23 Map,SignalGroupData> ss23 = sgd.getSignalGroupDataBySystemId(id23); - Assert.assertEquals(id23,ss23.get(idSg1).getSignalSystemId()); + Assertions.assertEquals(id23,ss23.get(idSg1).getSignalSystemId()); Set> sg = ss23.get(idSg1).getSignalIds(); - Assert.assertTrue(sg.contains(id1)); + Assertions.assertTrue(sg.contains(id1)); //sg42 - Assert.assertNotNull(sgd.getSignalGroupDataBySystemId(id42)); + Assertions.assertNotNull(sgd.getSignalGroupDataBySystemId(id42)); Map,SignalGroupData> ss42 = sgd.getSignalGroupDataBySystemId(id42); - Assert.assertEquals(id42,ss42.get(idSg1).getSignalSystemId()); + Assertions.assertEquals(id42,ss42.get(idSg1).getSignalSystemId()); sg = ss42.get(idSg1).getSignalIds(); - Assert.assertTrue(sg.contains(id1)); + Assertions.assertTrue(sg.contains(id1)); sg = ss42.get(idSg2).getSignalIds(); - Assert.assertTrue(sg.contains(id1)); - Assert.assertTrue(sg.contains(id4)); - Assert.assertTrue(sg.contains(id5)); + Assertions.assertTrue(sg.contains(id1)); + Assertions.assertTrue(sg.contains(id4)); + Assertions.assertTrue(sg.contains(id5)); diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java index 1fb40b18f1b..a3388a46d6e 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/data/signalsystems/v20/SignalSystemsData20ReaderWriterTest.java @@ -24,7 +24,7 @@ import jakarta.xml.bind.JAXBException; import javax.xml.parsers.ParserConfigurationException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -98,48 +98,48 @@ void testWriter() throws JAXBException, SAXException, ParserConfigurationExcepti private void checkContent(SignalSystemsData ss) { //system id 1 SignalSystemData ssdata = ss.getSignalSystemData().get(systemId1); - Assert.assertNotNull(ssdata); - Assert.assertEquals(2, ssdata.getSignalData().size()); + Assertions.assertNotNull(ssdata); + Assertions.assertEquals(2, ssdata.getSignalData().size()); SignalData signaldata = ssdata.getSignalData().get(signalId1); - Assert.assertNotNull(signaldata); - Assert.assertEquals(signalId1, signaldata.getId()); - Assert.assertEquals(linkId1, signaldata.getLinkId()); - Assert.assertNull(signaldata.getLaneIds()); - Assert.assertNull(signaldata.getTurningMoveRestrictions()); + Assertions.assertNotNull(signaldata); + Assertions.assertEquals(signalId1, signaldata.getId()); + Assertions.assertEquals(linkId1, signaldata.getLinkId()); + Assertions.assertNull(signaldata.getLaneIds()); + Assertions.assertNull(signaldata.getTurningMoveRestrictions()); signaldata = ssdata.getSignalData().get(signalId2); - Assert.assertNotNull(signaldata); - Assert.assertEquals(signalId2, signaldata.getId()); - Assert.assertEquals(linkId2, signaldata.getLinkId()); - Assert.assertNotNull(signaldata.getTurningMoveRestrictions()); - Assert.assertEquals(1, signaldata.getTurningMoveRestrictions().size()); - Assert.assertEquals(linkId3, signaldata.getTurningMoveRestrictions().iterator().next()); - Assert.assertNull(signaldata.getLaneIds()); + Assertions.assertNotNull(signaldata); + Assertions.assertEquals(signalId2, signaldata.getId()); + Assertions.assertEquals(linkId2, signaldata.getLinkId()); + Assertions.assertNotNull(signaldata.getTurningMoveRestrictions()); + Assertions.assertEquals(1, signaldata.getTurningMoveRestrictions().size()); + Assertions.assertEquals(linkId3, signaldata.getTurningMoveRestrictions().iterator().next()); + Assertions.assertNull(signaldata.getLaneIds()); //system id 2 ssdata = ss.getSignalSystemData().get(systemId2); - Assert.assertNotNull(ssdata); + Assertions.assertNotNull(ssdata); signaldata = ssdata.getSignalData().get(signalId1); - Assert.assertNotNull(signaldata); - Assert.assertEquals(signalId1, signaldata.getId()); - Assert.assertEquals(linkId3, signaldata.getLinkId()); - Assert.assertNotNull(signaldata.getLaneIds()); - Assert.assertEquals(laneId1, signaldata.getLaneIds().iterator().next()); - Assert.assertNull(signaldata.getTurningMoveRestrictions()); + Assertions.assertNotNull(signaldata); + Assertions.assertEquals(signalId1, signaldata.getId()); + Assertions.assertEquals(linkId3, signaldata.getLinkId()); + Assertions.assertNotNull(signaldata.getLaneIds()); + Assertions.assertEquals(laneId1, signaldata.getLaneIds().iterator().next()); + Assertions.assertNull(signaldata.getTurningMoveRestrictions()); signaldata = ssdata.getSignalData().get(signalId2); - Assert.assertNotNull(signaldata); - Assert.assertEquals(signalId2, signaldata.getId()); - Assert.assertEquals(linkId4, signaldata.getLinkId()); - Assert.assertNotNull(signaldata.getLaneIds()); - Assert.assertEquals(2, signaldata.getLaneIds().size()); - Assert.assertTrue(signaldata.getLaneIds().contains(laneId1)); - Assert.assertTrue(signaldata.getLaneIds().contains(laneId2)); - Assert.assertNotNull(signaldata.getTurningMoveRestrictions()); - Assert.assertEquals(1, signaldata.getTurningMoveRestrictions().size()); - Assert.assertTrue(signaldata.getTurningMoveRestrictions().contains(linkId3)); + Assertions.assertNotNull(signaldata); + Assertions.assertEquals(signalId2, signaldata.getId()); + Assertions.assertEquals(linkId4, signaldata.getLinkId()); + Assertions.assertNotNull(signaldata.getLaneIds()); + Assertions.assertEquals(2, signaldata.getLaneIds().size()); + Assertions.assertTrue(signaldata.getLaneIds().contains(laneId1)); + Assertions.assertTrue(signaldata.getLaneIds().contains(laneId2)); + Assertions.assertNotNull(signaldata.getTurningMoveRestrictions()); + Assertions.assertEquals(1, signaldata.getTurningMoveRestrictions().size()); + Assertions.assertTrue(signaldata.getTurningMoveRestrictions().contains(linkId3)); } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java index 3091d160258..49e8af1f140 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/SignalSystemsIT.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.signals.integration; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -88,10 +88,10 @@ void testSignalSystems() { //iteration 0 String iterationOutput = controlerOutputDir + "ITERS/it.0/"; - Assert.assertEquals("different events files after iteration 0 ", - EventsFileComparator.Result.FILES_ARE_EQUAL, + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( inputDirectory + "0.events.xml.gz", - iterationOutput + "0.events.xml.gz") + iterationOutput + "0.events.xml.gz"), + "different events files after iteration 0 " ); Scenario expectedPopulation = ScenarioUtils.createScenario(c.getConfig()); @@ -107,15 +107,15 @@ void testSignalSystems() { new org.matsim.api.core.v01.population.PopulationWriter(expectedPopulation.getPopulation()).write(testUtils.getOutputDirectory()+"/expected_plans_it0.xml.gz"); new org.matsim.api.core.v01.population.PopulationWriter(actualPopulation.getPopulation()).write(testUtils.getOutputDirectory()+"/actual_plans_it0.xml.gz"); } - Assert.assertTrue("different population files after iteration 0 ", works); + Assertions.assertTrue(works, "different population files after iteration 0 "); } { //iteration 10 String iterationOutput = controlerOutputDir + "ITERS/it.10/"; - Assert.assertEquals("different event files after iteration 10", - EventsFileComparator.Result.FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( inputDirectory + "10.events.xml.gz", iterationOutput + "10.events.xml.gz" ) + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( inputDirectory + "10.events.xml.gz", iterationOutput + "10.events.xml.gz" ), + "different event files after iteration 10" ); Scenario expectedPopulation = ScenarioUtils.createScenario(c.getConfig()); @@ -131,19 +131,19 @@ void testSignalSystems() { new org.matsim.api.core.v01.population.PopulationWriter(expectedPopulation.getPopulation()).write(testUtils.getOutputDirectory()+"/expected_plans_it10.xml.gz"); new org.matsim.api.core.v01.population.PopulationWriter(actualPopulation.getPopulation()).write(testUtils.getOutputDirectory()+"/actual_plans_it10.xml.gz"); } - Assert.assertTrue("different population files after iteration 10 ", works); + Assertions.assertTrue(works, "different population files after iteration 10 "); } SignalsScenarioWriter writer = new SignalsScenarioWriter(c.getControlerIO()); File file = new File(writer.getSignalSystemsOutputFilename()); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); file = new File(writer.getSignalGroupsOutputFilename()); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); file = new File(writer.getSignalControlOutputFilename()); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); file = new File(writer.getAmberTimesOutputFilename()); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); file = new File(writer.getIntergreenTimesOutputFilename()); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); } @@ -181,10 +181,10 @@ void testSignalSystemsWTryEndTimeThenDuration() { //iteration 0 String iterationOutput = controlerOutputDir + "ITERS/it.0/"; - Assert.assertEquals("different events files after iteration 0 ", - EventsFileComparator.Result.FILES_ARE_EQUAL, + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( inputDirectory + "0.events.xml.gz", - iterationOutput + "0.events.xml.gz") + iterationOutput + "0.events.xml.gz"), + "different events files after iteration 0 " ); Scenario expectedPopulation = ScenarioUtils.createScenario(c.getConfig()); @@ -200,15 +200,15 @@ void testSignalSystemsWTryEndTimeThenDuration() { new org.matsim.api.core.v01.population.PopulationWriter(expectedPopulation.getPopulation()).write(testUtils.getOutputDirectory()+"/expected_plans_it0.xml.gz"); new org.matsim.api.core.v01.population.PopulationWriter(actualPopulation.getPopulation()).write(testUtils.getOutputDirectory()+"/actual_plans_it0.xml.gz"); } - Assert.assertTrue("different population files after iteration 0 ", works); + Assertions.assertTrue(works, "different population files after iteration 0 "); } { //iteration 10 String iterationOutput = controlerOutputDir + "ITERS/it.10/"; - Assert.assertEquals("different event files after iteration 10", - EventsFileComparator.Result.FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( inputDirectory + "10.events.xml.gz", iterationOutput + "10.events.xml.gz") + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( inputDirectory + "10.events.xml.gz", iterationOutput + "10.events.xml.gz"), + "different event files after iteration 10" ); @@ -225,19 +225,19 @@ void testSignalSystemsWTryEndTimeThenDuration() { new org.matsim.api.core.v01.population.PopulationWriter(expectedPopulation.getPopulation()).write(testUtils.getOutputDirectory()+"/expected_plans_it10.xml.gz"); new org.matsim.api.core.v01.population.PopulationWriter(actualPopulation.getPopulation()).write(testUtils.getOutputDirectory()+"/actual_plans_it10.xml.gz"); } - Assert.assertTrue("different population files after iteration 10 ", works); + Assertions.assertTrue(works, "different population files after iteration 10 "); } SignalsScenarioWriter writer = new SignalsScenarioWriter(c.getControlerIO()); File file = new File(writer.getSignalSystemsOutputFilename()); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); file = new File(writer.getSignalGroupsOutputFilename()); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); file = new File(writer.getSignalControlOutputFilename()); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); file = new File(writer.getAmberTimesOutputFilename()); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); file = new File(writer.getIntergreenTimesOutputFilename()); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java index 3cbb0e162d2..72d7dcab19c 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/integration/invertednetworks/InvertedNetworksSignalsIT.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.signals.integration.invertednetworks; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -63,7 +63,7 @@ public void notifyStartup(StartupEvent event) { } }); c.run(); - Assert.assertTrue("No traffic on link", testHandler.hadTrafficOnLink25); + Assertions.assertTrue(testHandler.hadTrafficOnLink25, "No traffic on link"); } @Test @@ -91,7 +91,7 @@ public void notifyStartup(StartupEvent event) { } }); c.run(); - Assert.assertTrue("No traffic on link", testHandler.hadTrafficOnLink25); + Assertions.assertTrue(testHandler.hadTrafficOnLink25, "No traffic on link"); } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java index 297db365105..6860c74bd76 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java @@ -13,7 +13,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.runner.RunWith; @@ -209,9 +209,9 @@ void singleJunction(){ signalReader.parse(file.toAbsolutePath().toString()); - Assert.assertEquals("Assert number of nodes", 5, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 8, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 1, signalsData.getSignalSystemsData().getSignalSystemData().size()); + Assertions.assertEquals(5, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(8, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(1, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); Coord junctionCoord = new Coord(osmData.nodes.get(1).getLatitude(), osmData.nodes.get(1).getLongitude()); @@ -224,21 +224,19 @@ void singleJunction(){ if (shouldHave4Lanes){ //Note: 3 lanes and one original lane - Assert.assertEquals("Number of Lanes on InLink of SignalisedJunction incorrect", - 4, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size()); + Assertions.assertEquals(4, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size(), "Number of Lanes on InLink of SignalisedJunction incorrect"); } else { - Assert.assertEquals("Number of Lanes on InLink of SignalisedJunction incorrect", - 2, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size()); + Assertions.assertEquals(2, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size(), "Number of Lanes on InLink of SignalisedJunction incorrect"); } } Id systemId = signalsData.getSignalSystemsData().getSignalSystemData().keySet().iterator().next(); int groups = signalsData.getSignalGroupsData().getSignalGroupDataBySignalSystemId().get(systemId).size(); - Assert.assertEquals("Assert number of Signalgroups", 4, groups); + Assertions.assertEquals(4, groups, "Assert number of Signalgroups"); int signals = signalsData.getSignalSystemsData().getSignalSystemData().get(systemId).getSignalData().size(); - Assert.assertEquals("Assert number of Signals", 8, signals); + Assertions.assertEquals(8, signals, "Assert number of Signals"); } @Test @@ -275,9 +273,9 @@ void singleJunctionWithBoundingBox(){ signalReader.parse(file.toAbsolutePath().toString()); - Assert.assertEquals("Assert number of nodes", 5, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 8, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 1, signalsData.getSignalSystemsData().getSignalSystemData().size()); + Assertions.assertEquals(5, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(8, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(1, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); Coord junctionCoord = new Coord(osmData.nodes.get(1).getLatitude(), osmData.nodes.get(1).getLongitude()); @@ -290,21 +288,19 @@ void singleJunctionWithBoundingBox(){ if (shouldHave4Lanes){ //Note: 3 lanes and one original lane - Assert.assertEquals("Number of Lanes on InLink of SignalisedJunction incorrect", - 4, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size()); + Assertions.assertEquals(4, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size(), "Number of Lanes on InLink of SignalisedJunction incorrect"); } else { - Assert.assertEquals("Number of Lanes on InLink of SignalisedJunction incorrect", - 2, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size()); + Assertions.assertEquals(2, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size(), "Number of Lanes on InLink of SignalisedJunction incorrect"); } } Id systemId = signalsData.getSignalSystemsData().getSignalSystemData().keySet().iterator().next(); int groups = signalsData.getSignalGroupsData().getSignalGroupDataBySignalSystemId().get(systemId).size(); - Assert.assertEquals("Assert number of Signalgroups", 4, groups); + Assertions.assertEquals(4, groups, "Assert number of Signalgroups"); int signals = signalsData.getSignalSystemsData().getSignalSystemData().get(systemId).getSignalData().size(); - Assert.assertEquals("Assert number of Signals", 8, signals); + Assertions.assertEquals(8, signals, "Assert number of Signals"); } @Test @@ -341,9 +337,9 @@ void singleJunctionBadBoundingBox(){ signalReader.parse(file.toAbsolutePath().toString()); - Assert.assertEquals("Assert number of nodes", 5, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 8, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 0, signalsData.getSignalSystemsData().getSignalSystemData().size()); + Assertions.assertEquals(5, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(8, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(0, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); Coord junctionCoord = new Coord(osmData.nodes.get(1).getLatitude(), osmData.nodes.get(1).getLongitude()); @@ -356,11 +352,9 @@ void singleJunctionBadBoundingBox(){ if (shouldHave4Lanes){ //Note: 3 lanes and one original lane - Assert.assertEquals("Number of Lanes on InLink of SignalisedJunction incorrect", - 4, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size()); + Assertions.assertEquals(4, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size(), "Number of Lanes on InLink of SignalisedJunction incorrect"); } else { - Assert.assertEquals("Number of Lanes on InLink of SignalisedJunction incorrect", - 2, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size()); + Assertions.assertEquals(2, scenario.getLanes().getLanesToLinkAssignments().get(link).getLanes().size(), "Number of Lanes on InLink of SignalisedJunction incorrect"); } } @@ -438,75 +432,75 @@ void berlinSnippet(){ if (setMakePedestrianSignals && setAllowUTurnAtLeftLaneOnly && setMergeOnewaySignalSystems){ - Assert.assertEquals("Assert number of nodes", 322, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 658, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 65, signalsData.getSignalSystemsData().getSignalSystemData().size()); - Assert.assertEquals("Assert number of total SignalGroups", 136, noSignalGroups); - Assert.assertEquals("Assert number of total Signals", 266, noSignals); - Assert.assertEquals("Assert no of links with lanes",128,scenario.getLanes().getLanesToLinkAssignments().size()); + Assertions.assertEquals(322, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(658, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(65, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); + Assertions.assertEquals(136, noSignalGroups, "Assert number of total SignalGroups"); + Assertions.assertEquals(266, noSignals, "Assert number of total Signals"); + Assertions.assertEquals(128,scenario.getLanes().getLanesToLinkAssignments().size(),"Assert no of links with lanes"); } if (setMakePedestrianSignals && setAllowUTurnAtLeftLaneOnly && !setMergeOnewaySignalSystems){ - Assert.assertEquals("Assert number of nodes", 339, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 692, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 82, signalsData.getSignalSystemsData().getSignalSystemData().size()); - Assert.assertEquals("Assert number of total SignalGroups", 157, noSignalGroups); - Assert.assertEquals("Assert number of total Signals", 302, noSignals); - Assert.assertEquals("Assert no of links with lanes",137,scenario.getLanes().getLanesToLinkAssignments().size()); + Assertions.assertEquals(339, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(692, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(82, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); + Assertions.assertEquals(157, noSignalGroups, "Assert number of total SignalGroups"); + Assertions.assertEquals(302, noSignals, "Assert number of total Signals"); + Assertions.assertEquals(137,scenario.getLanes().getLanesToLinkAssignments().size(),"Assert no of links with lanes"); } if (setMakePedestrianSignals && !setAllowUTurnAtLeftLaneOnly && setMergeOnewaySignalSystems){ - Assert.assertEquals("Assert number of nodes", 322, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 658, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 65, signalsData.getSignalSystemsData().getSignalSystemData().size()); - Assert.assertEquals("Assert number of total SignalGroups", 136, noSignalGroups); - Assert.assertEquals("Assert number of total Signals", 265, noSignals); - Assert.assertEquals("Assert no of links with lanes",128,scenario.getLanes().getLanesToLinkAssignments().size()); + Assertions.assertEquals(322, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(658, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(65, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); + Assertions.assertEquals(136, noSignalGroups, "Assert number of total SignalGroups"); + Assertions.assertEquals(265, noSignals, "Assert number of total Signals"); + Assertions.assertEquals(128,scenario.getLanes().getLanesToLinkAssignments().size(),"Assert no of links with lanes"); } if (!setMakePedestrianSignals && setAllowUTurnAtLeftLaneOnly && setMergeOnewaySignalSystems){ - Assert.assertEquals("Assert number of nodes", 296, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 623, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 41, signalsData.getSignalSystemsData().getSignalSystemData().size()); - Assert.assertEquals("Assert number of total SignalGroups", 112, noSignalGroups); - Assert.assertEquals("Assert number of total Signals", 223, noSignals); - Assert.assertEquals("Assert no of links with lanes",115,scenario.getLanes().getLanesToLinkAssignments().size()); + Assertions.assertEquals(296, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(623, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(41, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); + Assertions.assertEquals(112, noSignalGroups, "Assert number of total SignalGroups"); + Assertions.assertEquals(223, noSignals, "Assert number of total Signals"); + Assertions.assertEquals(115,scenario.getLanes().getLanesToLinkAssignments().size(),"Assert no of links with lanes"); } if (setMakePedestrianSignals && !setAllowUTurnAtLeftLaneOnly && !setMergeOnewaySignalSystems){ - Assert.assertEquals("Assert number of nodes", 339, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 692, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 82, signalsData.getSignalSystemsData().getSignalSystemData().size()); - Assert.assertEquals("Assert number of total SignalGroups", 157, noSignalGroups); - Assert.assertEquals("Assert number of total Signals", 301, noSignals); - Assert.assertEquals("Assert no of links with lanes",137,scenario.getLanes().getLanesToLinkAssignments().size()); + Assertions.assertEquals(339, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(692, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(82, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); + Assertions.assertEquals(157, noSignalGroups, "Assert number of total SignalGroups"); + Assertions.assertEquals(301, noSignals, "Assert number of total Signals"); + Assertions.assertEquals(137,scenario.getLanes().getLanesToLinkAssignments().size(),"Assert no of links with lanes"); } if (!setMakePedestrianSignals && setAllowUTurnAtLeftLaneOnly && !setMergeOnewaySignalSystems){ - Assert.assertEquals("Assert number of nodes", 314, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 658, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 56, signalsData.getSignalSystemsData().getSignalSystemData().size()); - Assert.assertEquals("Assert number of total SignalGroups", 131, noSignalGroups); - Assert.assertEquals("Assert number of total Signals", 252, noSignals); - Assert.assertEquals("Assert no of links with lanes",122,scenario.getLanes().getLanesToLinkAssignments().size()); + Assertions.assertEquals(314, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(658, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(56, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); + Assertions.assertEquals(131, noSignalGroups, "Assert number of total SignalGroups"); + Assertions.assertEquals(252, noSignals, "Assert number of total Signals"); + Assertions.assertEquals(122,scenario.getLanes().getLanesToLinkAssignments().size(),"Assert no of links with lanes"); } if (!setMakePedestrianSignals && !setAllowUTurnAtLeftLaneOnly && setMergeOnewaySignalSystems){ - Assert.assertEquals("Assert number of nodes", 296, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 623, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 41, signalsData.getSignalSystemsData().getSignalSystemData().size()); - Assert.assertEquals("Assert number of total SignalGroups", 112, noSignalGroups); - Assert.assertEquals("Assert number of total Signals", 222, noSignals); - Assert.assertEquals("Assert no of links with lanes",115,scenario.getLanes().getLanesToLinkAssignments().size()); + Assertions.assertEquals(296, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(623, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(41, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); + Assertions.assertEquals(112, noSignalGroups, "Assert number of total SignalGroups"); + Assertions.assertEquals(222, noSignals, "Assert number of total Signals"); + Assertions.assertEquals(115,scenario.getLanes().getLanesToLinkAssignments().size(),"Assert no of links with lanes"); } if (!setMakePedestrianSignals && !setAllowUTurnAtLeftLaneOnly && !setMergeOnewaySignalSystems){ - Assert.assertEquals("Assert number of nodes", 314, network.getNodes().size()); - Assert.assertEquals("Assert number of links", 658, network.getLinks().size()); - Assert.assertEquals("Assert number of Systems", 56, signalsData.getSignalSystemsData().getSignalSystemData().size()); - Assert.assertEquals("Assert number of total SignalGroups", 131, noSignalGroups); - Assert.assertEquals("Assert number of total Signals", 251, noSignals); - Assert.assertEquals("Assert no of links with lanes",122,scenario.getLanes().getLanesToLinkAssignments().size()); + Assertions.assertEquals(314, network.getNodes().size(), "Assert number of nodes"); + Assertions.assertEquals(658, network.getLinks().size(), "Assert number of links"); + Assertions.assertEquals(56, signalsData.getSignalSystemsData().getSignalSystemData().size(), "Assert number of Systems"); + Assertions.assertEquals(131, noSignalGroups, "Assert number of total SignalGroups"); + Assertions.assertEquals(251, noSignals, "Assert number of total Signals"); + Assertions.assertEquals(122,scenario.getLanes().getLanesToLinkAssignments().size(),"Assert no of links with lanes"); } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java index 79d7a09eb7c..31f7e100544 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/oneagent/ControlerTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.signals.oneagent; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -120,10 +120,10 @@ public void reset(int i) {} @Override public void handleEvent(SignalGroupStateChangedEvent e) { if (e.getNewState().equals(SignalGroupState.RED)){ - Assert.assertEquals(0.0, e.getTime(), 1e-7); + Assertions.assertEquals(0.0, e.getTime(), 1e-7); } else if (e.getNewState().equals(SignalGroupState.GREEN)) { - Assert.assertEquals(100.0, e.getTime(), 1e-7); + Assertions.assertEquals(100.0, e.getTime(), 1e-7); } } } @@ -137,7 +137,7 @@ public void reset(int i) {} @Override public void handleEvent(LinkEnterEvent e){ if (e.getLinkId().equals(linkId2)) { - Assert.assertEquals(link2EnterTime, e.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(link2EnterTime, e.getTime(), MatsimTestUtils.EPSILON); } } } diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LaneSensorTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LaneSensorTest.java index 837ae251427..2f54084b699 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LaneSensorTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LaneSensorTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.signals.sensor; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import org.junit.jupiter.api.Test; import org.matsim.core.api.experimental.events.LaneEnterEvent; diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LinkSensorTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LinkSensorTest.java index 66e78addeb7..c29b1c71ae9 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LinkSensorTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/sensor/LinkSensorTest.java @@ -1,9 +1,9 @@ package org.matsim.contrib.signals.sensor; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -155,7 +155,7 @@ void testSensorNumberOfCarsMonitoring(){ Link link = sc.getNetwork().getLinks().get(Id.create(1, Link.class)); LinkSensor sensor = new LinkSensor(link); int numberOfCars = sensor.getNumberOfCarsOnLink(); - Assert.assertEquals(0, numberOfCars); + Assertions.assertEquals(0, numberOfCars); Id agId2 = Id.createPersonId(2); Id vehId1 = Id.create(1, Vehicle.class); @@ -164,7 +164,7 @@ void testSensorNumberOfCarsMonitoring(){ LinkEnterEvent enterEvent = new LinkEnterEvent(0.0, vehId1, link.getId()); sensor.handleEvent(enterEvent); numberOfCars = sensor.getNumberOfCarsOnLink(); - Assert.assertEquals(1, numberOfCars); + Assertions.assertEquals(1, numberOfCars); //expect NullPointerException as feature is still switched of NullPointerException e = null; try { @@ -173,32 +173,32 @@ void testSensorNumberOfCarsMonitoring(){ catch (NullPointerException ex){ e = ex; } - Assert.assertNotNull(e); + Assertions.assertNotNull(e); LinkEnterEvent enterEvent2 = new LinkEnterEvent(10.0, vehId2, link.getId()); sensor.handleEvent(enterEvent2); numberOfCars = sensor.getNumberOfCarsOnLink(); - Assert.assertEquals(2, numberOfCars); + Assertions.assertEquals(2, numberOfCars); LinkLeaveEvent leaveEvent = new LinkLeaveEvent(100.0, vehId1, link.getId()); sensor.handleEvent(leaveEvent); numberOfCars = sensor.getNumberOfCarsOnLink(); - Assert.assertEquals(1, numberOfCars); + Assertions.assertEquals(1, numberOfCars); VehicleLeavesTrafficEvent link2WaitEvent = new VehicleLeavesTrafficEvent(110.0, agId2, link.getId(), vehId2, TransportMode.car, 1.0); sensor.handleEvent(link2WaitEvent); numberOfCars = sensor.getNumberOfCarsOnLink(); - Assert.assertEquals(0, numberOfCars); + Assertions.assertEquals(0, numberOfCars); PersonEntersVehicleEvent enterVehEvent = new PersonEntersVehicleEvent(120., agId2, vehId2); sensor.handleEvent(enterVehEvent); numberOfCars = sensor.getNumberOfCarsOnLink(); - Assert.assertEquals(1, numberOfCars); + Assertions.assertEquals(1, numberOfCars); leaveEvent = new LinkLeaveEvent(120.0, vehId2, link.getId()); sensor.handleEvent(leaveEvent); numberOfCars = sensor.getNumberOfCarsOnLink(); - Assert.assertEquals(0, numberOfCars); + Assertions.assertEquals(0, numberOfCars); } @Test @@ -208,9 +208,9 @@ void testSensorDistanceMonitoring(){ LinkSensor sensor = new LinkSensor(link); sensor.registerDistanceToMonitor(100.0); int numberOfCars = sensor.getNumberOfCarsOnLink(); - Assert.assertEquals(0, numberOfCars); + Assertions.assertEquals(0, numberOfCars); int numberOfCarsInDistance = sensor.getNumberOfCarsInDistance(100.0, 0.0); - Assert.assertEquals(0, numberOfCarsInDistance); + Assertions.assertEquals(0, numberOfCarsInDistance); Id agId2 = Id.createPersonId(2); Id vehId1 = Id.create(1, Vehicle.class); @@ -219,12 +219,12 @@ void testSensorDistanceMonitoring(){ LinkEnterEvent enterEvent = new LinkEnterEvent(0.0, vehId1, link.getId()); sensor.handleEvent(enterEvent); numberOfCars = sensor.getNumberOfCarsOnLink(); - Assert.assertEquals(1, numberOfCars); + Assertions.assertEquals(1, numberOfCars); enterEvent = new LinkEnterEvent(1.0, vehId2, link.getId()); sensor.handleEvent(enterEvent); numberOfCars = sensor.getNumberOfCarsOnLink(); - Assert.assertEquals(2, numberOfCars); + Assertions.assertEquals(2, numberOfCars); //expect NullPointerException as feature is not switched on for distance 500.0 m NullPointerException e = null; @@ -234,43 +234,43 @@ void testSensorDistanceMonitoring(){ catch (NullPointerException ex){ e = ex; } - Assert.assertNotNull(e); + Assertions.assertNotNull(e); numberOfCarsInDistance = sensor.getNumberOfCarsInDistance(100.0, 10.0); - Assert.assertEquals(0, numberOfCarsInDistance); + Assertions.assertEquals(0, numberOfCarsInDistance); numberOfCarsInDistance = sensor.getNumberOfCarsInDistance(100.0, 83.0); - Assert.assertEquals(0, numberOfCarsInDistance); + Assertions.assertEquals(0, numberOfCarsInDistance); numberOfCarsInDistance = sensor.getNumberOfCarsInDistance(100.0, 84.0); - Assert.assertEquals(1, numberOfCarsInDistance); + Assertions.assertEquals(1, numberOfCarsInDistance); numberOfCarsInDistance = sensor.getNumberOfCarsInDistance(100.0, 85.0); - Assert.assertEquals(2, numberOfCarsInDistance); + Assertions.assertEquals(2, numberOfCarsInDistance); LinkLeaveEvent leaveEvent = new LinkLeaveEvent(100.0, vehId1, link.getId()); sensor.handleEvent(leaveEvent); numberOfCarsInDistance = sensor.getNumberOfCarsInDistance(100.0, 100.0); - Assert.assertEquals(1, numberOfCarsInDistance); + Assertions.assertEquals(1, numberOfCarsInDistance); VehicleLeavesTrafficEvent link2WaitEvent = new VehicleLeavesTrafficEvent(101.0, agId2, link.getId(), vehId2, TransportMode.car, 1.0); sensor.handleEvent(link2WaitEvent); numberOfCarsInDistance = sensor.getNumberOfCarsInDistance(100.0, 101.0); - Assert.assertEquals(0, numberOfCarsInDistance); + Assertions.assertEquals(0, numberOfCarsInDistance); PersonEntersVehicleEvent enterVehEvent = new PersonEntersVehicleEvent(120., agId2, vehId2); sensor.handleEvent(enterVehEvent); numberOfCarsInDistance = sensor.getNumberOfCarsInDistance(100.0, 120.0); - Assert.assertEquals(1, numberOfCarsInDistance); + Assertions.assertEquals(1, numberOfCarsInDistance); leaveEvent = new LinkLeaveEvent(120.0, vehId2, link.getId()); sensor.handleEvent(leaveEvent); numberOfCarsInDistance = sensor.getNumberOfCarsInDistance(100.0, 120.0); - Assert.assertEquals(0, numberOfCarsInDistance); + Assertions.assertEquals(0, numberOfCarsInDistance); } diff --git a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/DefaultAnnealingAcceptorTest.java b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/DefaultAnnealingAcceptorTest.java index 0fc9099c9b0..6ad7ebd5208 100644 --- a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/DefaultAnnealingAcceptorTest.java +++ b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/DefaultAnnealingAcceptorTest.java @@ -9,7 +9,7 @@ package org.matsim.contrib.simulatedannealing; import org.apache.commons.lang3.mutable.MutableInt; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.controler.IterationCounter; import org.matsim.contrib.simulatedannealing.acceptor.DefaultAnnealingAcceptor; @@ -37,27 +37,27 @@ void testAcceptor() { TemperatureFunction.DefaultFunctions temperatureFunction = TemperatureFunction.DefaultFunctions.exponentialMultiplicative; boolean accept = acceptor.accept(currentSolution, acceptedSolution, temperature(iteration)); - Assert.assertTrue(accept); + Assertions.assertTrue(accept); currentSolution = new SimulatedAnnealing.Solution<>("current", 15); - Assert.assertTrue(acceptor.accept(currentSolution, acceptedSolution, temperature(iteration))); + Assertions.assertTrue(acceptor.accept(currentSolution, acceptedSolution, temperature(iteration))); currentSolution = new SimulatedAnnealing.Solution<>("current", 20); - Assert.assertTrue(acceptor.accept(currentSolution, acceptedSolution, temperature(iteration))); + Assertions.assertTrue(acceptor.accept(currentSolution, acceptedSolution, temperature(iteration))); iteration.setValue(10); - Assert.assertTrue(acceptor.accept(currentSolution, acceptedSolution, temperature(iteration))); + Assertions.assertTrue(acceptor.accept(currentSolution, acceptedSolution, temperature(iteration))); iteration.setValue(1000); - Assert.assertFalse(acceptor.accept(currentSolution, acceptedSolution, temperature(iteration))); + Assertions.assertFalse(acceptor.accept(currentSolution, acceptedSolution, temperature(iteration))); currentSolution = new SimulatedAnnealing.Solution<>("current", 10); - Assert.assertTrue(acceptor.accept(currentSolution, acceptedSolution, temperature(iteration))); + Assertions.assertTrue(acceptor.accept(currentSolution, acceptedSolution, temperature(iteration))); - Assert.assertThrows(RuntimeException.class, () -> acceptor.accept(null, null, temperature(iteration))); - Assert.assertThrows(RuntimeException.class, () -> acceptor.accept(new SimulatedAnnealing.Solution<>("notnull"), null, temperature(iteration))); - Assert.assertThrows(RuntimeException.class, () -> acceptor.accept(new SimulatedAnnealing.Solution<>("notnull"), new SimulatedAnnealing.Solution<>("notnull"), temperature(iteration))); + Assertions.assertThrows(RuntimeException.class, () -> acceptor.accept(null, null, temperature(iteration))); + Assertions.assertThrows(RuntimeException.class, () -> acceptor.accept(new SimulatedAnnealing.Solution<>("notnull"), null, temperature(iteration))); + Assertions.assertThrows(RuntimeException.class, () -> acceptor.accept(new SimulatedAnnealing.Solution<>("notnull"), new SimulatedAnnealing.Solution<>("notnull"), temperature(iteration))); } private double temperature(MutableInt iteration) { diff --git a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java index 4596d83435c..7b5ac7bfb78 100644 --- a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java +++ b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java @@ -8,7 +8,7 @@ */ package org.matsim.contrib.simulatedannealing; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; @@ -59,9 +59,9 @@ void loadConfigGroupTest() throws IOException { Config config = ConfigUtils.createConfig(); ConfigUtils.loadConfig(config, configFile.toString()); SimulatedAnnealingConfigGroup loadedCfg = ConfigUtils.addOrGetModule(config, SimulatedAnnealingConfigGroup.class); - Assert.assertEquals(42., loadedCfg.alpha, MatsimTestUtils.EPSILON); - Assert.assertEquals(42., loadedCfg.initialTemperature, MatsimTestUtils.EPSILON); - Assert.assertEquals(TemperatureFunction.DefaultFunctions.exponentialAdditive, loadedCfg.coolingSchedule); + Assertions.assertEquals(42., loadedCfg.alpha, MatsimTestUtils.EPSILON); + Assertions.assertEquals(42., loadedCfg.initialTemperature, MatsimTestUtils.EPSILON); + Assertions.assertEquals(TemperatureFunction.DefaultFunctions.exponentialAdditive, loadedCfg.coolingSchedule); } @@ -70,7 +70,7 @@ void perturbationParamsTest() { Config config = createConfig(); SimulatedAnnealingConfigGroup saConfig = ConfigUtils.addOrGetModule(config, SimulatedAnnealingConfigGroup.class); - Assert.assertTrue(saConfig.getPerturbationParams().isEmpty()); + Assertions.assertTrue(saConfig.getPerturbationParams().isEmpty()); saConfig.addPerturbationParams(new SimulatedAnnealingConfigGroup.PerturbationParams("perturb", 1.) { @Override @@ -79,9 +79,9 @@ public Map getComments() { } }); - Assert.assertFalse(saConfig.getPerturbationParams().isEmpty()); - Assert.assertTrue(saConfig.getPerturbationParamsPerType().containsKey("perturb")); - Assert.assertEquals(1., saConfig.getPerturbationParamsPerType().get("perturb").weight, MatsimTestUtils.EPSILON); + Assertions.assertFalse(saConfig.getPerturbationParams().isEmpty()); + Assertions.assertTrue(saConfig.getPerturbationParamsPerType().containsKey("perturb")); + Assertions.assertEquals(1., saConfig.getPerturbationParamsPerType().get("perturb").weight, MatsimTestUtils.EPSILON); } } diff --git a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingTest.java b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingTest.java index 020a184d6ef..ae3594ac1d4 100644 --- a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingTest.java +++ b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingTest.java @@ -16,7 +16,7 @@ import org.apache.logging.log4j.core.LoggerContext; import org.apache.logging.log4j.core.config.Configuration; import org.apache.logging.log4j.core.config.LoggerConfig; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.contrib.simulatedannealing.acceptor.Acceptor; import org.matsim.contrib.simulatedannealing.acceptor.DefaultAnnealingAcceptor; @@ -62,7 +62,7 @@ void testSimulatedAnnealing() { simulatedAnnealing.notifyAfterMobsim(new AfterMobsimEvent(null, i, false)); } - Assert.assertEquals("matsim", simulatedAnnealing.getCurrentState().get().accepted().get()); + Assertions.assertEquals("matsim", simulatedAnnealing.getCurrentState().get().accepted().get()); } private PerturbatorFactory perturbatorFactory() { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/events/CourtesyEventsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/events/CourtesyEventsTest.java index 63c5ecc5a71..4ddee30e796 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/events/CourtesyEventsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/events/CourtesyEventsTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -241,10 +241,10 @@ public void handleEvent( Event event ) { eventManager.finishProcessing(); - Assert.assertEquals( - "wrong number of events in "+collected, + Assertions.assertEquals( expectedCourtesy, - collected.size() ); + collected.size(), + "wrong number of events in "+collected ); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanFactoryTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanFactoryTest.java index 6e2bd112d94..bc5d946d0df 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanFactoryTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanFactoryTest.java @@ -19,12 +19,12 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.framework.population; -import static org.junit.Assert.assertEquals; - import java.util.LinkedHashMap; import java.util.Map; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; @@ -53,14 +53,14 @@ void testAddAtIndividualLevel() throws Exception { new JointPlanFactory().createJointPlan( jp , true ); assertEquals( - "unexpected number of plans for first person", 1, - person1.getPlans().size()); + person1.getPlans().size(), + "unexpected number of plans for first person"); assertEquals( - "unexpected number of plans for second person", 1, - person2.getPlans().size()); + person2.getPlans().size(), + "unexpected number of plans for second person"); } @Test @@ -82,14 +82,14 @@ void testDoNotAddAtIndividualLevel() throws Exception { new JointPlanFactory().createJointPlan( jp , false ); assertEquals( - "unexpected number of plans for first person", 0, - person1.getPlans().size()); + person1.getPlans().size(), + "unexpected number of plans for first person"); assertEquals( - "unexpected number of plans for second person", 0, - person2.getPlans().size()); + person2.getPlans().size(), + "unexpected number of plans for second person"); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java index cf248036757..d1b1a8d9889 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlanIOTest.java @@ -26,7 +26,7 @@ import java.util.Queue; import java.util.Random; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -70,25 +70,25 @@ void testDumpAndRead() throws Exception { final JointPlan read = reReadJointPlans.getJointPlan( plan ); if ( dumped == null ) { - Assert.assertNull( - "dumped is null but read is not", - read ); + Assertions.assertNull( + read, + "dumped is null but read is not" ); continue; } - Assert.assertNotNull( - "dumped is not null but read is", - read ); + Assertions.assertNotNull( + read, + "dumped is not null but read is" ); - Assert.assertEquals( - "dumped has not the same size as read", + Assertions.assertEquals( dumped.getIndividualPlans().size(), - read.getIndividualPlans().size() ); + read.getIndividualPlans().size(), + "dumped has not the same size as read" ); - Assert.assertTrue( - "plans in dumped and read do not match", + Assertions.assertTrue( dumped.getIndividualPlans().values().containsAll( - read.getIndividualPlans().values() ) ); + read.getIndividualPlans().values() ), + "plans in dumped and read do not match" ); } } } @@ -115,11 +115,11 @@ void testPlansOrderIsStableInCoreIO() throws Exception { final Iterator readPlans = readPerson.getPlans().iterator(); while( dumpedPlans.hasNext() ) { // score are set different for every plan in the sequence - Assert.assertEquals( - "order of plans have changed through IO", + Assertions.assertEquals( dumpedPlans.next().getScore(), readPlans.next().getScore(), - MatsimTestUtils.EPSILON ); + MatsimTestUtils.EPSILON, + "order of plans have changed through IO" ); } } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlansTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlansTest.java index b8898723c03..5aeecce937d 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlansTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/JointPlansTest.java @@ -22,7 +22,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -68,9 +68,9 @@ private static void testExceptionAdd( final boolean withCache ) throws Exception gotException = true; } - Assert.assertTrue( - "got no exception when associating two joint plans to one individual plan", - gotException); + Assertions.assertTrue( + gotException, + "got no exception when associating two joint plans to one individual plan"); } @Test @@ -109,9 +109,9 @@ private static void testExceptionRemove( final boolean withCache ) throws Except gotException = true; } - Assert.assertTrue( - "got no exception when associating two joint plans to one individual plan", - gotException); + Assertions.assertTrue( + gotException, + "got no exception when associating two joint plans to one individual plan"); } @Test @@ -152,50 +152,50 @@ private static void testAddAndGetSeveralInstances( final boolean withCache ) { final JointPlan jointPlan5 = jointPlans5.getFactory().createJointPlan( jp ); jointPlans5.addJointPlan( jointPlan5 ); - Assert.assertSame( - "wrong joint plan 1 for person 1", + Assertions.assertSame( jointPlan1, - jointPlans1.getJointPlan( p1 ) ); - Assert.assertSame( - "wrong joint plan 1 for person 2", + jointPlans1.getJointPlan( p1 ), + "wrong joint plan 1 for person 1" ); + Assertions.assertSame( jointPlan1, - jointPlans1.getJointPlan( p2 ) ); + jointPlans1.getJointPlan( p2 ), + "wrong joint plan 1 for person 2" ); - Assert.assertSame( - "wrong joint plan 2 for person 1", + Assertions.assertSame( jointPlan2, - jointPlans2.getJointPlan( p1 ) ); - Assert.assertSame( - "wrong joint plan 2 for person 2", + jointPlans2.getJointPlan( p1 ), + "wrong joint plan 2 for person 1" ); + Assertions.assertSame( jointPlan2, - jointPlans2.getJointPlan( p2 ) ); + jointPlans2.getJointPlan( p2 ), + "wrong joint plan 2 for person 2" ); - Assert.assertSame( - "wrong joint plan 3 for person 1", + Assertions.assertSame( jointPlan3, - jointPlans3.getJointPlan( p1 ) ); - Assert.assertSame( - "wrong joint plan 3 for person 2", + jointPlans3.getJointPlan( p1 ), + "wrong joint plan 3 for person 1" ); + Assertions.assertSame( jointPlan3, - jointPlans3.getJointPlan( p2 ) ); + jointPlans3.getJointPlan( p2 ), + "wrong joint plan 3 for person 2" ); - Assert.assertSame( - "wrong joint plan 4 for person 1", + Assertions.assertSame( jointPlan4, - jointPlans4.getJointPlan( p1 ) ); - Assert.assertSame( - "wrong joint plan 4 for person 2", + jointPlans4.getJointPlan( p1 ), + "wrong joint plan 4 for person 1" ); + Assertions.assertSame( jointPlan4, - jointPlans4.getJointPlan( p2 ) ); + jointPlans4.getJointPlan( p2 ), + "wrong joint plan 4 for person 2" ); - Assert.assertSame( - "wrong joint plan 5 for person 1", + Assertions.assertSame( jointPlan5, - jointPlans5.getJointPlan( p1 ) ); - Assert.assertSame( - "wrong joint plan 5 for person 2", + jointPlans5.getJointPlan( p1 ), + "wrong joint plan 5 for person 1" ); + Assertions.assertSame( jointPlan5, - jointPlans5.getJointPlan( p2 ) ); + jointPlans5.getJointPlan( p2 ), + "wrong joint plan 5 for person 2" ); } @@ -221,14 +221,14 @@ private static void testClear( final boolean withCache ) { jointPlans.addJointPlan( jointPlans.getFactory().createJointPlan( jp1 ) ); - Assert.assertNotNull( - "joint plan was not added???", - jointPlans.getJointPlan( p1 ) ); + Assertions.assertNotNull( + jointPlans.getJointPlan( p1 ), + "joint plan was not added???" ); jointPlans.clear(); - Assert.assertNull( - "still a joint plan after clear...", - jointPlans.getJointPlan( p1 ) ); + Assertions.assertNull( + jointPlans.getJointPlan( p1 ), + "still a joint plan after clear..." ); } private static Plan createPlan( final Person person , final boolean withCache ) { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java index 0a44ae0fd97..4ba6ec658e8 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkIOTest.java @@ -24,7 +24,7 @@ import java.util.Random; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -64,20 +64,20 @@ private void testReinput(final boolean isReflective) { final SocialNetwork input = (SocialNetwork) sc.getScenarioElement( SocialNetwork.ELEMENT_NAME ); - Assert.assertEquals( - "unexpected reflectiveness", + Assertions.assertEquals( output.isReflective(), - input.isReflective() ); + input.isReflective(), + "unexpected reflectiveness" ); - Assert.assertEquals( - "unexpected number of egos", + Assertions.assertEquals( output.getEgos().size(), - input.getEgos().size() ); + input.getEgos().size(), + "unexpected number of egos" ); - Assert.assertEquals( - "different ego ids", + Assertions.assertEquals( output.getEgos(), - input.getEgos() ); + input.getEgos(), + "different ego ids" ); final Counter c = new Counter( "Test alters of ego # " ); for ( Id ego : output.getEgos() ) { @@ -85,21 +85,21 @@ private void testReinput(final boolean isReflective) { final Set> expectedAlters = output.getAlters( ego ); final Set> actualAlters = input.getAlters( ego ); - Assert.assertEquals( - "unexpected number of alters for ego "+ego, + Assertions.assertEquals( expectedAlters.size(), - actualAlters.size() ); + actualAlters.size(), + "unexpected number of alters for ego "+ego ); - Assert.assertEquals( - "unexpected alters for ego "+ego, + Assertions.assertEquals( expectedAlters, - actualAlters ); + actualAlters, + "unexpected alters for ego "+ego ); } - Assert.assertEquals( - "different metadata", + Assertions.assertEquals( output.getMetadata(), - input.getMetadata() ); + input.getMetadata(), + "different metadata" ); c.printCounter(); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkTest.java index 4728c8d94fb..71aa36c301f 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/population/SocialNetworkTest.java @@ -23,7 +23,7 @@ import java.util.Collections; import java.util.HashSet; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import static org.junit.jupiter.api.Assertions.assertThrows; import org.junit.jupiter.api.Test; @@ -52,20 +52,20 @@ void testMonodirectionalTie() { sn.addEgo( alter ); sn.addMonodirectionalTie( ego , alter ); - Assert.assertEquals( - "unexpected egos", + Assertions.assertEquals( new HashSet>( Arrays.asList( ego , alter ) ), - sn.getEgos() ); + sn.getEgos(), + "unexpected egos" ); - Assert.assertEquals( - "unexpected alters of ego", + Assertions.assertEquals( Collections.singleton( alter ), - sn.getAlters( ego ) ); + sn.getAlters( ego ), + "unexpected alters of ego" ); - Assert.assertEquals( - "unexpected alters of alter", + Assertions.assertEquals( Collections.>emptySet(), - sn.getAlters( alter ) ); + sn.getAlters( alter ), + "unexpected alters of alter" ); } @Test @@ -78,20 +78,20 @@ void testBidirectionalTie() { sn.addEgo( alter ); sn.addBidirectionalTie( ego , alter ); - Assert.assertEquals( - "unexpected egos", + Assertions.assertEquals( new HashSet>( Arrays.asList( ego , alter ) ), - sn.getEgos() ); + sn.getEgos(), + "unexpected egos" ); - Assert.assertEquals( - "unexpected alters of ego", + Assertions.assertEquals( Collections.singleton( alter ), - sn.getAlters( ego ) ); + sn.getAlters( ego ), + "unexpected alters of ego" ); - Assert.assertEquals( - "unexpected alters of alter", + Assertions.assertEquals( Collections.singleton( ego ), - sn.getAlters( alter ) ); + sn.getAlters( alter ), + "unexpected alters of alter" ); } @Test @@ -136,34 +136,34 @@ void testRemoveEgo() { } sn.removeEgo( ego ); - Assert.assertFalse( - "ego still in social network", - sn.getEgos().contains( ego ) ); + Assertions.assertFalse( + sn.getEgos().contains( ego ), + "ego still in social network" ); for ( Id alter : new Id[]{ a1 , a2 , a3 , a4 , a5 , a6 , a7 , a8 , a9 , a10 } ) { - Assert.assertFalse( - "ego still in network of agent "+alter, - sn.getAlters( alter ).contains( ego ) ); + Assertions.assertFalse( + sn.getAlters( alter ).contains( ego ), + "ego still in network of agent "+alter ); } for ( Id alter : new Id[]{ a1 , a2 , a3 , a4 , a5 } ) { - Assert.assertEquals( - "wrong network size for "+alter, + Assertions.assertEquals( 0, - sn.getAlters( alter ).size() ); + sn.getAlters( alter ).size(), + "wrong network size for "+alter ); } for ( Id alter : new Id[]{ a7 , a8 , a9 , a10 } ) { - Assert.assertEquals( - "wrong network size for "+alter, + Assertions.assertEquals( 1, - sn.getAlters( alter ).size() ); + sn.getAlters( alter ).size(), + "wrong network size for "+alter ); } - Assert.assertEquals( - "wrong network size for "+a6, + Assertions.assertEquals( 4, - sn.getAlters( a6 ).size() ); + sn.getAlters( a6 ).size(), + "wrong network size for "+a6 ); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/DynamicGroupIdentifierTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/DynamicGroupIdentifierTest.java index 1b992c0a25b..59fe40fda96 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/DynamicGroupIdentifierTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/DynamicGroupIdentifierTest.java @@ -23,7 +23,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -198,18 +198,18 @@ private void test( final Fixture fixture ) { final GroupIdentifier testee = new DynamicGroupIdentifier( fixture.scenario ); final Collection groups = testee.identifyGroups( fixture.scenario.getPopulation() ); - Assert.assertEquals( - "unexpected number of groups", + Assertions.assertEquals( fixture.expectedNGroups, - groups.size() ); + groups.size(), + "unexpected number of groups" ); int n = 0; for ( ReplanningGroup g : groups ) n += g.getPersons().size(); - Assert.assertEquals( - "unexpected number of persons in groups", + Assertions.assertEquals( fixture.scenario.getPopulation().getPersons().size(), - n ); + n, + "unexpected number of persons in groups" ); } private static class Fixture { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java index 8e521b385ec..171278bea52 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/FixedGroupsIT.java @@ -19,6 +19,8 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.framework.replanning.grouping; +import static org.junit.jupiter.api.Assertions.assertEquals; + import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -40,8 +42,6 @@ import java.util.Iterator; import java.util.Random; -import static org.junit.Assert.assertEquals; - /** * @author thibautd */ @@ -79,9 +79,9 @@ private static void assertIterationOrder( final Collection expected, final Collection actual) { assertEquals( - "not the same number of groups", expected.size(), - actual.size()); + actual.size(), + "not the same number of groups"); final Iterator expectedIter = expected.iterator(); final Iterator actualIter = actual.iterator(); @@ -95,10 +95,10 @@ private static void assertIterationOrder( final Iterator actualGroupIterator = actualGroup.getPersons().iterator(); for (Person expectedPerson : expectedGroup.getPersons()) { assertEquals( - "groups "+expectedGroup+" and "+actualGroup+" in position "+ - c+" are not equal or do not present the persons in the same order", expectedPerson.getId(), - actualGroupIterator.next().getId()); + actualGroupIterator.next().getId(), + "groups "+expectedGroup+" and "+actualGroup+" in position "+ + c+" are not equal or do not present the persons in the same order"); } } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java index 3893c8cb2ba..bb64b0ae091 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java @@ -19,9 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.framework.replanning.grouping; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertNotSame; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; import java.util.Collections; @@ -117,19 +115,19 @@ void testGetters() throws Exception { final GroupPlans testee = new GroupPlans( jointPlans , indivPlans ); assertEquals( - "wrong number of individual plans", indivPlans.size(), - testee.getIndividualPlans().size()); + testee.getIndividualPlans().size(), + "wrong number of individual plans"); assertEquals( - "wrong number of joint plans", jointPlans.size(), - testee.getJointPlans().size()); + testee.getJointPlans().size(), + "wrong number of joint plans"); assertEquals( - "wrong total number of indiv plans", indivPlans.size() + nIndivInJoints, - testee.getAllIndividualPlans().size()); + testee.getAllIndividualPlans().size(), + "wrong total number of indiv plans"); } @Test @@ -138,14 +136,14 @@ void testCopyLooksValid() throws Exception { GroupPlans copy = GroupPlans.copyPlans( factory , plans ); assertEquals( - "wrong number of individual plans in copy", plans.getIndividualPlans().size(), - copy.getIndividualPlans().size()); + copy.getIndividualPlans().size(), + "wrong number of individual plans in copy"); assertEquals( - "wrong number of joint plans in copy", plans.getJointPlans().size(), - copy.getJointPlans().size()); + copy.getJointPlans().size(), + "wrong number of joint plans in copy"); } } @@ -155,20 +153,20 @@ void testCopyIsNotSame() throws Exception { GroupPlans copy = GroupPlans.copyPlans( factory , plans ); assertNotSame( - "copy is the same instance", plans, - copy); + copy, + "copy is the same instance"); for (Plan p : plans.getIndividualPlans()) { assertFalse( - "the copy contains references from the copied", - copy.getIndividualPlans().contains( p )); + copy.getIndividualPlans().contains( p ), + "the copy contains references from the copied"); } for (JointPlan copiedJointPlan : plans.getJointPlans()) { assertFalse( - "the copy contains references from the copied", - copy.getJointPlans().contains( copiedJointPlan )); + copy.getJointPlans().contains( copiedJointPlan ), + "the copy contains references from the copied"); JointPlan copyJointPlan = getCopy( copiedJointPlan , copy ); for (Plan copyIndivPlan : copyJointPlan.getIndividualPlans().values()) { @@ -179,8 +177,8 @@ void testCopyIsNotSame() throws Exception { // JointPlanFactory.getPlanLinks().getJointPlan( copyIndivPlan )); assertFalse( - "individual plans were not copied when copying joint plan", - copiedJointPlan.getIndividualPlans().values().contains( copyIndivPlan )); + copiedJointPlan.getIndividualPlans().values().contains( copyIndivPlan ), + "individual plans were not copied when copying joint plan"); } } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/ActivitySequenceMutatorAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/ActivitySequenceMutatorAlgorithmTest.java index 2b80b22c47e..00050977cf3 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/ActivitySequenceMutatorAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/ActivitySequenceMutatorAlgorithmTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.framework.replanning.modules; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -54,18 +54,18 @@ void testTwoActivities() throws Exception { StageActivityHandling.StagesAsNormalActivities ); testee.run( plan ); - Assert.assertEquals( - "unexpected size of plan "+plan.getPlanElements(), + Assertions.assertEquals( plan.getPlanElements().size(), - 7 ); - Assert.assertEquals( - "unexpected type of first in-plan activity", + 7, + "unexpected size of plan "+plan.getPlanElements() ); + Assertions.assertEquals( ((Activity) plan.getPlanElements().get( 2 )).getType(), - "l" ); - Assert.assertEquals( - "unexpected type of second in-plan activity", + "l", + "unexpected type of first in-plan activity" ); + Assertions.assertEquals( ((Activity) plan.getPlanElements().get( 4 )).getType(), - "w" ); + "w", + "unexpected type of second in-plan activity" ); } @Test @@ -84,14 +84,14 @@ void testOneActivities() throws Exception { StageActivityHandling.StagesAsNormalActivities ); testee.run( plan ); - Assert.assertEquals( - "unexpected size of plan "+plan.getPlanElements(), + Assertions.assertEquals( plan.getPlanElements().size(), - 5 ); - Assert.assertEquals( - "unexpected type of first in-plan activity", + 5, + "unexpected size of plan "+plan.getPlanElements() ); + Assertions.assertEquals( ((Activity) plan.getPlanElements().get( 2 )).getType(), - "w" ); + "w", + "unexpected type of first in-plan activity" ); } @Test @@ -108,10 +108,10 @@ void testZeroActivities() throws Exception { StageActivityHandling.StagesAsNormalActivities ); testee.run( plan ); - Assert.assertEquals( - "unexpected size of plan "+plan.getPlanElements(), + Assertions.assertEquals( plan.getPlanElements().size(), - 3 ); + 3, + "unexpected size of plan "+plan.getPlanElements() ); } @Test @@ -134,22 +134,22 @@ void testStage() throws Exception { StageActivityHandling.ExcludeStageActivities ); testee.run( plan ); - Assert.assertEquals( - "unexpected size of plan "+plan.getPlanElements(), + Assertions.assertEquals( plan.getPlanElements().size(), - 9 ); - Assert.assertEquals( - "unexpected type of first in-plan activity", + 9, + "unexpected size of plan "+plan.getPlanElements() ); + Assertions.assertEquals( ((Activity) plan.getPlanElements().get( 2 )).getType(), - "stage" ); - Assert.assertEquals( - "unexpected type of second in-plan activity", + "stage", + "unexpected type of first in-plan activity" ); + Assertions.assertEquals( ((Activity) plan.getPlanElements().get( 4 )).getType(), - "l" ); - Assert.assertEquals( - "unexpected type of third in-plan activity", + "l", + "unexpected type of second in-plan activity" ); + Assertions.assertEquals( ((Activity) plan.getPlanElements().get( 6 )).getType(), - "w" ); + "w", + "unexpected type of third in-plan activity" ); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java index 93de284d592..51f2365c46f 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java @@ -19,8 +19,6 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.framework.replanning.modules; -import static org.junit.Assert.assertEquals; - import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; @@ -29,6 +27,8 @@ import java.util.Random; import org.junit.After; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.Before; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -100,17 +100,17 @@ void testProbOne() throws Exception { int nplans = countPlans( gp ); algo.run( gp ); assertEquals( - "unexpected number of joint plans", 1, - gp.getJointPlans().size()); + gp.getJointPlans().size(), + "unexpected number of joint plans"); assertEquals( - "unexpected number of individual plans", 0, - gp.getIndividualPlans().size()); + gp.getIndividualPlans().size(), + "unexpected number of individual plans"); assertEquals( - "unexpected overall number of plans", nplans, - countPlans( gp )); + countPlans( gp ), + "unexpected overall number of plans"); } } @@ -129,17 +129,17 @@ void testProbZero() throws Exception { int njointplans = gp.getJointPlans().size(); algo.run( gp ); assertEquals( - "unexpected number of joint plans", njointplans, - gp.getJointPlans().size()); + gp.getJointPlans().size(), + "unexpected number of joint plans"); assertEquals( - "unexpected number of individual plans", nindivplans, - gp.getIndividualPlans().size()); + gp.getIndividualPlans().size(), + "unexpected number of individual plans"); assertEquals( - "unexpected overall number of plans", nplans, - countPlans( gp )); + countPlans( gp ), + "unexpected overall number of plans"); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/TourModeUnifierAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/TourModeUnifierAlgorithmTest.java index d76f7cb58f8..ce3606c7c18 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/TourModeUnifierAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/TourModeUnifierAlgorithmTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -120,20 +120,20 @@ void testPlanWithOneSingleTour() throws Exception { new MainModeIdentifierImpl() ); testee.run( plan ); - Assert.assertEquals( - "unexpected plan size", + Assertions.assertEquals( 2 * nActs - 1, - plan.getPlanElements().size() ); + plan.getPlanElements().size(), + "unexpected plan size" ); for ( Trip trip : TripStructureUtils.getTrips( plan , TripStructureUtils::isStageActivityType ) ) { - Assert.assertEquals( - "unexpected size of trip "+trip, + Assertions.assertEquals( 1, - trip.getTripElements().size() ); + trip.getTripElements().size(), + "unexpected size of trip "+trip ); - Assert.assertEquals( - "unexpected mode of trip "+trip, + Assertions.assertEquals( mode, - ((Leg) trip.getTripElements().get( 0 )).getMode() ); + ((Leg) trip.getTripElements().get( 0 )).getMode(), + "unexpected mode of trip "+trip ); } } @@ -193,47 +193,47 @@ void testPlanWithTwoToursOnOpenTour() throws Exception { new MainModeIdentifierImpl() ); testee.run( plan ); - Assert.assertEquals( - "unexpected plan size", + Assertions.assertEquals( 31, - plan.getPlanElements().size() ); + plan.getPlanElements().size(), + "unexpected plan size" ); final List trips = TripStructureUtils.getTrips( plan , TripStructureUtils::isStageActivityType ); - Assert.assertEquals( - "unexpected number of trips", + Assertions.assertEquals( 13, - trips.size() ); + trips.size(), + "unexpected number of trips" ); for ( int tripNr : new int[]{0,1,6,11,12} ) { - Assert.assertEquals( - "unexpected mode for trip "+tripNr, + Assertions.assertEquals( modeOfOpenTour, - trips.get( tripNr ).getLegsOnly().get( 0 ).getMode() ); + trips.get( tripNr ).getLegsOnly().get( 0 ).getMode(), + "unexpected mode for trip "+tripNr ); } for ( int tripNr : new int[]{2,3,3,4,5} ) { - Assert.assertEquals( - "unexpected length for trip "+tripNr, + Assertions.assertEquals( 1, - trips.get( tripNr ).getLegsOnly().size() ); + trips.get( tripNr ).getLegsOnly().size(), + "unexpected length for trip "+tripNr ); - Assert.assertEquals( - "unexpected mode for trip "+tripNr, + Assertions.assertEquals( mode1, - trips.get( tripNr ).getLegsOnly().get( 0 ).getMode() ); + trips.get( tripNr ).getLegsOnly().get( 0 ).getMode(), + "unexpected mode for trip "+tripNr ); } for ( int tripNr : new int[]{7,8,9,10} ) { - Assert.assertEquals( - "unexpected length for trip "+tripNr, + Assertions.assertEquals( 1, - trips.get( tripNr ).getLegsOnly().size() ); + trips.get( tripNr ).getLegsOnly().size(), + "unexpected length for trip "+tripNr ); - Assert.assertEquals( - "unexpected mode for trip "+tripNr, + Assertions.assertEquals( mode2, - trips.get( tripNr ).getLegsOnly().get( 0 ).getMode() ); + trips.get( tripNr ).getLegsOnly().get( 0 ).getMode(), + "unexpected mode for trip "+tripNr ); } } @@ -271,7 +271,7 @@ void testPlanWithTwoHomeBasedTours() throws Exception { final List activities = TripStructureUtils.getActivities( plan, StageActivityHandling.ExcludeStageActivities ); final int nActs = activities.size(); - Assert.assertEquals( 9, nActs ); + Assertions.assertEquals( 9, nActs ); final PlanAlgorithm testee = new TourModeUnifierAlgorithm( @@ -279,40 +279,40 @@ void testPlanWithTwoHomeBasedTours() throws Exception { new MainModeIdentifierImpl() ); testee.run( plan ); - Assert.assertEquals( - "unexpected plan size", + Assertions.assertEquals( 2 * nActs - 1, - plan.getPlanElements().size() ); + plan.getPlanElements().size(), + "unexpected plan size" ); final List trips = TripStructureUtils.getTrips( plan , TripStructureUtils::isStageActivityType ); - Assert.assertEquals( - "unexpected number of trips", + Assertions.assertEquals( 8, - trips.size() ); + trips.size(), + "unexpected number of trips" ); for ( int tripNr : new int[]{0,1,2,3} ) { - Assert.assertEquals( - "unexpected length for trip "+tripNr, + Assertions.assertEquals( 1, - trips.get( tripNr ).getLegsOnly().size() ); + trips.get( tripNr ).getLegsOnly().size(), + "unexpected length for trip "+tripNr ); - Assert.assertEquals( - "unexpected mode for trip "+tripNr, + Assertions.assertEquals( mode1, - trips.get( tripNr ).getLegsOnly().get( 0 ).getMode() ); + trips.get( tripNr ).getLegsOnly().get( 0 ).getMode(), + "unexpected mode for trip "+tripNr ); } for ( int tripNr : new int[]{4,5,6,7} ) { - Assert.assertEquals( - "unexpected length for trip "+tripNr, + Assertions.assertEquals( 1, - trips.get( tripNr ).getLegsOnly().size() ); + trips.get( tripNr ).getLegsOnly().size(), + "unexpected length for trip "+tripNr ); - Assert.assertEquals( - "unexpected mode for trip "+tripNr, + Assertions.assertEquals( mode2, - trips.get( tripNr ).getLegsOnly().get( 0 ).getMode() ); + trips.get( tripNr ).getLegsOnly().get( 0 ).getMode(), + "unexpected mode for trip "+tripNr ); } } private static void printPlan( Plan plan ){ diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/removers/LexicographicRemoverTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/removers/LexicographicRemoverTest.java index 84a31fab439..98c821ace65 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/removers/LexicographicRemoverTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/removers/LexicographicRemoverTest.java @@ -23,7 +23,7 @@ import java.util.List; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -173,13 +173,13 @@ private static void test(final Fixture f) { for ( Person p : f.group.getPersons() ) { final Plan expectedRemoved = f.expectedRemovedPlans.get( p.getId() ); - Assert.assertFalse( - expectedRemoved+" not removed for person "+p, - p.getPlans().contains( expectedRemoved ) ); + Assertions.assertFalse( + p.getPlans().contains( expectedRemoved ), + expectedRemoved+" not removed for person "+p ); - Assert.assertNull( - "MEMORY LEAK: There is still a joint plan associated to removed plan "+expectedRemoved, - f.jointPlans.getJointPlan( expectedRemoved ) ); + Assertions.assertNull( + f.jointPlans.getJointPlan( expectedRemoved ), + "MEMORY LEAK: There is still a joint plan associated to removed plan "+expectedRemoved ); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java index e541b2ac672..2bf1b4d1c99 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java @@ -22,8 +22,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.population.Plan; @@ -98,13 +98,13 @@ private void testFullExplorationVsCuttoff( final double scoreFull = calcScore( fullResult ); // allow different results, as long as the scores are identical - Assert.assertEquals( + Assertions.assertEquals( + fastResult, + fullResult, "different solutions with both exploration types."+ " full score: "+scoreFull+ " fast: "+scoreFast+ - " ", - fastResult, - fullResult); + " "); if ( fastResult == null ) countNull++; } count.printCounter(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java index a1a9b606c00..41316c90707 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java @@ -31,8 +31,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -1268,16 +1268,16 @@ void testNoSideEffects() throws Exception { fixture.jointPlans, fixture.group ); - Assert.assertEquals( - "unexpected change in group size for fixture "+fixture.name, + Assertions.assertEquals( initialGroupSize, - fixture.group.getPersons().size() ); + fixture.group.getPersons().size(), + "unexpected change in group size for fixture "+fixture.name ); for (Person p : fixture.group.getPersons()) { - Assert.assertEquals( - "unexpected change in the number of plans for agent "+p.getId()+" in fixture "+fixture.name, + Assertions.assertEquals( planCounts.get( p.getId() ).intValue(), - p.getPlans().size() ); + p.getPlans().size(), + "unexpected change in the number of plans for agent "+p.getId()+" in fixture "+fixture.name ); } } @@ -1307,10 +1307,10 @@ private void testSelectedPlans( (forbidding ? fixture.expectedSelectedPlansWhenForbidding : fixture.expectedSelectedPlans); - Assert.assertEquals( - "unexpected selected plan in test instance <<"+fixture.name+">> ", + Assertions.assertEquals( expected, - selected); + selected, + "unexpected selected plan in test instance <<"+fixture.name+">> "); } private static class CollectionBasedPlanForbidderFactory implements IncompatiblePlansIdentifierFactory { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java index 13628424eaa..deeb0b00ed6 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java @@ -19,12 +19,14 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.framework.replanning.selectors; +import static org.junit.jupiter.api.Assertions.assertEquals; + import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.After; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -45,8 +47,6 @@ import java.util.Map; import java.util.Random; -import static org.junit.Assert.assertEquals; - /** * @author thibautd */ @@ -402,9 +402,9 @@ void testDeterminism() throws Exception { jointPlans , group ); if (previous != null) { assertEquals( - "different results with the same random seed", previous, - selected); + selected, + "different results with the same random seed"); } if (selected == null) throw new NullPointerException( "test is useless if the selector returns null" ); @@ -432,9 +432,9 @@ void testNoFailuresWithVariousSeeds() throws Exception { if (selected == null) throw new NullPointerException( "test is useless if the selector returns null" ); - Assert.assertEquals( "unexpected selected plan size" , - selected.getAllIndividualPlans().size(), - group.getPersons().size() ); + Assertions.assertEquals( selected.getAllIndividualPlans().size(), + group.getPersons().size(), + "unexpected selected plan size" ); } } groupCount.printCounter(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java index f9215f4ac9c..2209f10164b 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java @@ -27,7 +27,7 @@ import java.util.List; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -227,10 +227,10 @@ void testSelectedPlans() { final GroupPlans expected = fixture.expectedSelectedPlans; - Assert.assertEquals( - "unexpected selected plan in test instance <<"+fixture.name+">> ", + Assertions.assertEquals( expected, - selected); + selected, + "unexpected selected plan in test instance <<"+fixture.name+">> "); } catch (Exception e) { throw new RuntimeException( "exception thrown for instance <<"+fixture.name+">>", e ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastAverageWeightJointPlanPruningConflictSolverTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastAverageWeightJointPlanPruningConflictSolverTest.java index dc1a38d25bf..46c66cb8560 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastAverageWeightJointPlanPruningConflictSolverTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastAverageWeightJointPlanPruningConflictSolverTest.java @@ -22,7 +22,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -125,14 +125,14 @@ private static void test(final ConflictSolverTestsFixture fixture) { for ( PlanRecord r : fixture.allRecords ) { if ( fixture.expectedUnfeasiblePlans.contains( r.getPlan() ) ) { - Assert.assertFalse( - "plan "+r.getPlan()+" unexpectedly feasible", - r.isFeasible() ); + Assertions.assertFalse( + r.isFeasible(), + "plan "+r.getPlan()+" unexpectedly feasible" ); } else { - Assert.assertTrue( - "plan "+r.getPlan()+" unexpectedly unfeasible", - r.isFeasible() ); + Assertions.assertTrue( + r.isFeasible(), + "plan "+r.getPlan()+" unexpectedly unfeasible" ); } } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastPointedPlanPruningConflictSolverTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastPointedPlanPruningConflictSolverTest.java index 0626ebe295c..47898a3669e 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastPointedPlanPruningConflictSolverTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/LeastPointedPlanPruningConflictSolverTest.java @@ -21,7 +21,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -120,14 +120,14 @@ private static void test(final ConflictSolverTestsFixture fixture) { for ( PlanRecord r : fixture.allRecords ) { if ( fixture.expectedUnfeasiblePlans.contains( r.getPlan() ) ) { - Assert.assertFalse( - "plan "+r.getPlan()+" unexpectedly feasible", - r.isFeasible() ); + Assertions.assertFalse( + r.isFeasible(), + "plan "+r.getPlan()+" unexpectedly feasible" ); } else { - Assert.assertTrue( - "plan "+r.getPlan()+" unexpectedly unfeasible", - r.isFeasible() ); + Assertions.assertTrue( + r.isFeasible(), + "plan "+r.getPlan()+" unexpectedly unfeasible" ); } } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java index fbbbfe0018c..50823516b3e 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java @@ -31,9 +31,9 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Before; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -83,17 +83,17 @@ void testOnePlanSelectedForEachAgent() throws Exception { } else { countNonNull++; - Assert.assertEquals( - "unexpected number of plans in selected plan", + Assertions.assertEquals( group.getPersons().size(), - selected.getAllIndividualPlans().size() ); + selected.getAllIndividualPlans().size(), + "unexpected number of plans in selected plan" ); final Set groupIds = getGroupIds( group ); final Set selectedIds = getPlanIds( selected ); - Assert.assertEquals( - "unexpected agent ids in selected plan", + Assertions.assertEquals( groupIds, - selectedIds ); + selectedIds, + "unexpected agent ids in selected plan" ); } } counter.printCounter(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java index b653e3a7ec9..e341cb726ae 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java @@ -21,8 +21,8 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -142,11 +142,11 @@ public ScoringFunction createNewScoringFunction( final Person person ) { eventsToScore.finish(); final double score = penalizer.getScore(); - Assert.assertEquals( - "unexpected score", + Assertions.assertEquals( calcExpectedScore( times1[ 0 ] , times1[ times1.length - 1 ] , times2[ 0 ] , times2[ times2.length - 1 ]), score, - 1E-9 ); + 1E-9, + "unexpected score" ); } private double calcExpectedScore( final double start1, final double end1, final double start2, final double end2 ) { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/RecomposeJointPlanAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/RecomposeJointPlanAlgorithmTest.java index 9551650254f..bcda672c647 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/RecomposeJointPlanAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/RecomposeJointPlanAlgorithmTest.java @@ -19,8 +19,8 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.jointactivities.replanning.modules; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.ArrayList; import java.util.Collection; @@ -286,32 +286,32 @@ private static void test( final Fixture fixture ) { algo.run( fixture.groupPlans ); assertEquals( - "unexpected number of plans", initialNPlans, - fixture.groupPlans.getAllIndividualPlans().size()); + fixture.groupPlans.getAllIndividualPlans().size(), + "unexpected number of plans"); assertEquals( - "unexpected number of joint plans", fixture.expectedNJointPlans, - fixture.groupPlans.getJointPlans().size()); + fixture.groupPlans.getJointPlans().size(), + "unexpected number of joint plans"); for (JointPlan jp : fixture.groupPlans.getJointPlans()) { final Set> ids = jp.getIndividualPlans().keySet(); assertTrue( - "unexpected joint plan "+ids+": not in "+fixture.expectedJointPlanStructure, - fixture.expectedJointPlanStructure.contains( ids )); + fixture.expectedJointPlanStructure.contains( ids ), + "unexpected joint plan "+ids+": not in "+fixture.expectedJointPlanStructure); } assertEquals( - "unexpected number of individual plans", fixture.expectedNIndivPlans, - fixture.groupPlans.getIndividualPlans().size()); + fixture.groupPlans.getIndividualPlans().size(), + "unexpected number of individual plans"); for (Plan p : fixture.groupPlans.getIndividualPlans()) { final Set> ids = Collections.singleton( p.getPerson().getId() ); assertTrue( - "unexpected individual plan "+ids+": not in "+fixture.expectedJointPlanStructure, - fixture.expectedJointPlanStructure.contains( ids )); + fixture.expectedJointPlanStructure.contains( ids ), + "unexpected individual plan "+ids+": not in "+fixture.expectedJointPlanStructure); } } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/randomlocationchoice/RandomJointLocationChoiceTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/randomlocationchoice/RandomJointLocationChoiceTest.java index e6cab996be9..0139237b886 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/randomlocationchoice/RandomJointLocationChoiceTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointactivities/replanning/modules/randomlocationchoice/RandomJointLocationChoiceTest.java @@ -24,7 +24,7 @@ import java.util.List; import java.util.Random; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -216,10 +216,10 @@ void testFacilityRetrieval() { f.angle, f.distance ); - Assert.assertEquals( - "wrong facility for fixture "+f, + Assertions.assertEquals( f.expectedFacility, - fac.getId() ); + fac.getId(), + "wrong facility for fixture "+f ); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java index 5943c16f8f6..5d5f3ecea96 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java @@ -20,8 +20,8 @@ package org.matsim.contrib.socnetsim.jointtrips; import org.junit.After; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -806,12 +806,12 @@ void testExtractJointTrips() throws Exception { for ( Fixture f : fixtures ) { JointTravelStructure struct = JointTravelUtils.analyseJointTravel(f.plan); - Assert.assertEquals( + Assertions.assertEquals( + f.structure, + struct, "wrong structure for fixture "+f.name+ " of size "+f.structure.getJointTrips().size()+ - " compared to result of size "+struct.getJointTrips().size(), - f.structure, - struct); + " compared to result of size "+struct.getJointTrips().size()); } } @@ -820,14 +820,14 @@ void testParseDriverTrips() throws Exception { for ( Fixture f : fixtures ) { List trips = JointTravelUtils.parseDriverTrips(f.plan); - Assert.assertEquals( - "wrong number of driver trips: "+f.driverTrips+" is the target, got "+trips, + Assertions.assertEquals( f.driverTrips.size(), - trips.size()); + trips.size(), + "wrong number of driver trips: "+f.driverTrips+" is the target, got "+trips); - Assert.assertTrue( - "wrong driver trips: "+f.driverTrips+" is the target, got "+trips, - trips.containsAll( f.driverTrips )); + Assertions.assertTrue( + trips.containsAll( f.driverTrips ), + "wrong driver trips: "+f.driverTrips+" is the target, got "+trips); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java index 395e7cce92b..07393fe6d22 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/qsim/JointTravelingSimulationIntegrationTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -214,16 +214,16 @@ public void handleEvent(final PersonArrivalEvent event) { } arrCount.incrementAndGet(); - Assert.assertEquals( - "run "+scNr+": unexpected joint arrival time", + Assertions.assertEquals( arrival, event.getTime(), - MatsimTestUtils.EPSILON); + MatsimTestUtils.EPSILON, + "run "+scNr+": unexpected joint arrival time"); - Assert.assertEquals( - "run "+scNr+": unexpected arrival location for mode "+mode, + Assertions.assertEquals( fixture.doLink, - event.getLinkId() ); + event.getLinkId(), + "run "+scNr+": unexpected arrival location for mode "+mode ); } } }); @@ -257,15 +257,15 @@ public void handleEvent(final ActivityStartEvent event) { // for easier tracking of test failures logFinalQSimState( qsim ); - Assert.assertEquals( - "run "+i+": unexpected number of joint arrivals", + Assertions.assertEquals( N_LAPS * 3, - arrCount.get()); + arrCount.get(), + "run "+i+": unexpected number of joint arrivals"); - Assert.assertEquals( - "run "+i+": unexpected number of agents arriving at destination", + Assertions.assertEquals( N_LAPS * sc.getPopulation().getPersons().size(), - atDestCount.get()); + atDestCount.get(), + "run "+i+": unexpected number of agents arriving at destination"); } } @@ -328,10 +328,10 @@ public void handleEvent(final PersonLeavesVehicleEvent event) { final JointQSimFactory factory = new JointQSimFactory( ); factory.createMobsim( sc , events ).run(); - Assert.assertEquals( - "not as many leave events as enter events", + Assertions.assertEquals( enterCount.get(), - leaveCount.get()); + leaveCount.get(), + "not as many leave events as enter events"); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java index 9e55848cf9a..83420c9ea39 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java @@ -19,6 +19,8 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.jointtrips.replanning.modules; +import static org.junit.jupiter.api.Assertions.assertNull; + import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -47,8 +49,6 @@ import java.util.Map; import java.util.Random; -import static org.junit.Assert.assertNull; - /** * @author thibautd */ @@ -72,8 +72,8 @@ void testRemoverIgnorance() throws Exception { JointPlan jointPlan = createPlanWithJointTrips(); assertNull( - "unexpected removed trips", - algo.run( jointPlan , jointPlan.getIndividualPlans().keySet() ) ); + algo.run( jointPlan , jointPlan.getIndividualPlans().keySet() ), + "unexpected removed trips" ); } @@ -89,8 +89,8 @@ void testInsertorIgnorance() throws Exception { JointPlan jointPlan = createPlanWithoutJointTrips(); assertNull( - "unexpected removed trips", - algo.run( jointPlan , jointPlan.getIndividualPlans().keySet() ) ); + algo.run( jointPlan , jointPlan.getIndividualPlans().keySet() ), + "unexpected removed trips" ); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java index 01b85aa8a57..fe45fa49200 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java @@ -19,16 +19,15 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.jointtrips.replanning.modules; -import static org.junit.Assert.assertEquals; - import java.util.HashMap; import java.util.Map; import java.util.Random; import org.apache.logging.log4j.Level; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Before; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -99,18 +98,18 @@ void testNonIterativeRemoval() throws Exception { final String finalPlanDescr = jointPlan.toString(); assertEquals( + N_COUPLES - 1, + d, "unexpected number of driver trips when passing from plan " +initialPlanDescr+" to plan " - +finalPlanDescr, - N_COUPLES - 1, - d); + +finalPlanDescr); assertEquals( + N_COUPLES - 1, + p, "unexpected number of passenger trips when passing from plan " +initialPlanDescr+" to plan " - +finalPlanDescr, - N_COUPLES - 1, - p); + +finalPlanDescr); } @Test @@ -142,18 +141,18 @@ void testIterativeRemoval() throws Exception { final String finalPlanDescr = jointPlan.toString(); assertEquals( + 0, + d, "unexpected number of driver trips when passing from plan " +initialPlanDescr+" to plan " - +finalPlanDescr, - 0, - d); + +finalPlanDescr); assertEquals( + 0, + p, "unexpected number of passenger trips when passing from plan " +initialPlanDescr+" to plan " - +finalPlanDescr, - 0, - p); + +finalPlanDescr); } @Test @@ -178,21 +177,21 @@ void testNonIterativeInsertion() throws Exception { final Leg l = (Leg) pe; final String mode = l.getMode(); if ( JointActingTypes.DRIVER.equals( mode ) ) { - Assert.assertNotNull( - "route must not be null", - l.getRoute() ); - Assert.assertTrue( - "unexpected route type "+l.getRoute().getClass().getName(), - l.getRoute() instanceof DriverRoute ); + Assertions.assertNotNull( + l.getRoute(), + "route must not be null" ); + Assertions.assertTrue( + l.getRoute() instanceof DriverRoute, + "unexpected route type "+l.getRoute().getClass().getName() ); d++; } if ( JointActingTypes.PASSENGER.equals( mode ) ) { - Assert.assertNotNull( - "route must not be null", - l.getRoute() ); - Assert.assertTrue( - "unexpected route type "+l.getRoute().getClass().getName(), - l.getRoute() instanceof PassengerRoute ); + Assertions.assertNotNull( + l.getRoute(), + "route must not be null" ); + Assertions.assertTrue( + l.getRoute() instanceof PassengerRoute, + "unexpected route type "+l.getRoute().getClass().getName() ); p++; } } @@ -201,18 +200,18 @@ void testNonIterativeInsertion() throws Exception { final String finalPlanDescr = jointPlan.toString(); assertEquals( + 1, + d, "unexpected number of driver trips when passing from plan " +initialPlanDescr+" to plan " - +finalPlanDescr, - 1, - d); + +finalPlanDescr); assertEquals( + 1, + p, "unexpected number of passenger trips when passing from plan " +initialPlanDescr+" to plan " - +finalPlanDescr, - 1, - p); + +finalPlanDescr); } @Test @@ -237,21 +236,21 @@ void testIterativeInsertion() throws Exception { final Leg l = (Leg) pe; final String mode = l.getMode(); if ( JointActingTypes.DRIVER.equals( mode ) ) { - Assert.assertNotNull( - "route must not be null", - l.getRoute() ); - Assert.assertTrue( - "unexpected route type "+l.getRoute().getClass().getName(), - l.getRoute() instanceof DriverRoute ); + Assertions.assertNotNull( + l.getRoute(), + "route must not be null" ); + Assertions.assertTrue( + l.getRoute() instanceof DriverRoute, + "unexpected route type "+l.getRoute().getClass().getName() ); d++; } if ( JointActingTypes.PASSENGER.equals( mode ) ) { - Assert.assertNotNull( - "route must not be null", - l.getRoute() ); - Assert.assertTrue( - "unexpected route type "+l.getRoute().getClass().getName(), - l.getRoute() instanceof PassengerRoute ); + Assertions.assertNotNull( + l.getRoute(), + "route must not be null" ); + Assertions.assertTrue( + l.getRoute() instanceof PassengerRoute, + "unexpected route type "+l.getRoute().getClass().getName() ); p++; } } @@ -260,18 +259,18 @@ void testIterativeInsertion() throws Exception { final String finalPlanDescr = jointPlan.toString(); assertEquals( + N_COUPLES, + d, "unexpected number of driver trips when passing from plan " +initialPlanDescr+" to plan " - +finalPlanDescr, - N_COUPLES, - d); + +finalPlanDescr); assertEquals( + N_COUPLES, + p, "unexpected number of passenger trips when passing from plan " +initialPlanDescr+" to plan " - +finalPlanDescr, - N_COUPLES, - p); + +finalPlanDescr); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripInsertionWithSocialNetworkTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripInsertionWithSocialNetworkTest.java index 45ece5211d0..d67580b7692 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripInsertionWithSocialNetworkTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripInsertionWithSocialNetworkTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -90,9 +90,9 @@ void testJointTripsGeneratedOnlyAlongSocialTies() { agentsToIgnore.add( actedUpon.getDriverId() ); agentsToIgnore.add( actedUpon.getPassengerId() ); - Assert.assertTrue( - "passenger not alter of driver!", - sn.getAlters( actedUpon.getDriverId() ).contains( actedUpon.getPassengerId() ) ); + Assertions.assertTrue( + sn.getAlters( actedUpon.getDriverId() ).contains( actedUpon.getPassengerId() ), + "passenger not alter of driver!" ); } log.info( "there were "+agentsToIgnore.size()+" agents handled" ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java index bc43d9c3a50..34cd73df76f 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java @@ -19,9 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.jointtrips.replanning.modules; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; import java.util.Arrays; @@ -983,9 +981,9 @@ private void assertChainsMatch( final List expected, final List actual) { assertEquals( - fixtureName+": sizes do not match "+expected+" and "+actual, expected.size(), - actual.size()); + actual.size(), + fixtureName+": sizes do not match "+expected+" and "+actual); Iterator expectedIter = expected.iterator(); Iterator actualIter = actual.iterator(); @@ -1021,43 +1019,43 @@ private void assertChainsMatch( private void assertLegsMatch(final Leg exp,final Leg act) { assertEquals( - "wrong mode", exp.getMode(), - act.getMode()); + act.getMode(), + "wrong mode"); if ( exp.getMode().equals( JointActingTypes.DRIVER ) ) { Collection> expIds = ((DriverRoute) exp.getRoute()).getPassengersIds(); Collection> actIds = ((DriverRoute) act.getRoute()).getPassengersIds(); assertEquals( - "wrong number of passengers", expIds.size(), - actIds.size()); + actIds.size(), + "wrong number of passengers"); assertTrue( - "wrong passenger ids", - actIds.containsAll( expIds )); + actIds.containsAll( expIds ), + "wrong passenger ids"); } else if ( exp.getMode().equals( JointActingTypes.PASSENGER ) ) { Id expId = ((PassengerRoute) exp.getRoute()).getDriverId(); Id actId = ((PassengerRoute) act.getRoute()).getDriverId(); assertEquals( - "wrong driver Id", expId, - actId); + actId, + "wrong driver Id"); } } private void assertActivitiesMatch(final Activity exp, final Activity act) { assertEquals( - "wrong type", exp.getType(), - act.getType()); + act.getType(), + "wrong type"); assertEquals( - "wrong link", exp.getLinkId(), - act.getLinkId()); + act.getLinkId(), + "wrong link"); } // ///////////////////////////////////////////////////////////////////////// diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java index acce4c6faef..d5f974964b5 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java @@ -25,8 +25,8 @@ import java.util.Map; import org.junit.After; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -331,16 +331,16 @@ void testDepartureTimes() throws Exception { final Double endTime = fixture.expectedEndTimes.remove( activity ); if ( endTime == null ) continue; - Assert.assertEquals( - "unexpected end time for "+activity, + Assertions.assertEquals( endTime.doubleValue(), activity.getEndTime().seconds(), - MatsimTestUtils.EPSILON); + MatsimTestUtils.EPSILON, + "unexpected end time for "+activity); } } - Assert.assertTrue( - "some activities were not found: "+fixture.expectedEndTimes.keySet(), - fixture.expectedEndTimes.isEmpty() ); + Assertions.assertTrue( + fixture.expectedEndTimes.isEmpty(), + "some activities were not found: "+fixture.expectedEndTimes.keySet() ); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointPlanRouterTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointPlanRouterTest.java index 28203a5ed4a..ec2b5100847 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointPlanRouterTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointPlanRouterTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.jointtrips.router; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.Arrays; import java.util.Collection; @@ -93,21 +93,21 @@ void testDriverIdIsKept() throws Exception { final Leg newLeg = (Leg) plan.getPlanElements().get( 1 ); assertNotSame( - "leg not replaced", leg, - newLeg); + newLeg, + "leg not replaced"); final PassengerRoute newRoute = (PassengerRoute) leg.getRoute(); assertNotNull( - "new passenger route is null", + newRoute, - newRoute); + "new passenger route is null"); assertEquals( - "driver id not kept correctly", driverId, - newRoute.getDriverId()); + newRoute.getDriverId(), + "driver id not kept correctly"); } @Test @@ -150,25 +150,25 @@ void testPassengerIdIsKept() throws Exception { final Leg newLeg = (Leg) plan.getPlanElements().get( 1 ); assertNotSame( - "leg not replaced", leg, - newLeg); + newLeg, + "leg not replaced"); final DriverRoute newRoute = (DriverRoute) leg.getRoute(); assertNotNull( - "new driver route is null", - newRoute); + newRoute, + "new driver route is null"); final Collection> passengers = Arrays.asList( passengerId1 , passengerId2 ); assertEquals( - "not the right number of passenger ids in "+newRoute.getPassengersIds(), passengers.size(), - newRoute.getPassengersIds().size()); + newRoute.getPassengersIds().size(), + "not the right number of passenger ids in "+newRoute.getPassengersIds()); assertTrue( - "not the right ids in "+newRoute.getPassengersIds(), passengers.containsAll( - newRoute.getPassengersIds() )); + newRoute.getPassengersIds() ), + "not the right ids in "+newRoute.getPassengersIds()); } private static TripRouter createTripRouter(final PopulationFactory populationFactory, Config config) { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java index dbad52eb7e5..d3e427f262c 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java @@ -26,8 +26,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -227,10 +227,10 @@ void testPassengerRoute() throws Exception { if ( pe instanceof Leg && ((Leg) pe).getMode().equals( JointActingTypes.PASSENGER ) ) { final Id actualDriver = ((PassengerRoute) ((Leg) pe).getRoute()).getDriverId(); - Assert.assertEquals( - "wrong driver Id", + Assertions.assertEquals( driver, - actualDriver); + actualDriver, + "wrong driver Id"); } } @@ -264,14 +264,14 @@ void testDriverRoute() throws Exception { if ( pe instanceof Leg && ((Leg) pe).getMode().equals( JointActingTypes.DRIVER ) ) { final Collection> actualPassengers = ((DriverRoute) ((Leg) pe).getRoute()).getPassengersIds(); - Assert.assertEquals( - "wrong number of passengers", + Assertions.assertEquals( passengerIds.size(), - actualPassengers.size()); + actualPassengers.size(), + "wrong number of passengers"); - Assert.assertTrue( - "wrong passengers ids: "+actualPassengers+" is not "+passengerIds, - passengerIds.containsAll( actualPassengers )); + Assertions.assertTrue( + passengerIds.containsAll( actualPassengers ), + "wrong passengers ids: "+actualPassengers+" is not "+passengerIds); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/HouseholdBasedVehicleRessourcesTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/HouseholdBasedVehicleRessourcesTest.java index eaf2b1b5e08..58f912152ee 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/HouseholdBasedVehicleRessourcesTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/HouseholdBasedVehicleRessourcesTest.java @@ -19,14 +19,14 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.sharedvehicles; -import static org.junit.Assert.assertEquals; - import java.util.Arrays; import java.util.Collections; import java.util.HashSet; import java.util.Set; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.households.Household; @@ -50,9 +50,9 @@ void testVehiclesIdsAreCorrect() throws Exception { for (Id person : household.getMemberIds()) { final Set> actual = testee.identifyVehiclesUsableForAgent( person ); assertEquals( - "unexpected vehicles for agent "+person, expected, - actual); + actual, + "unexpected vehicles for agent "+person); } } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/PlanRouterWithVehicleRessourcesTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/PlanRouterWithVehicleRessourcesTest.java index a05a6cf60eb..fa2e7c679dd 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/PlanRouterWithVehicleRessourcesTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/PlanRouterWithVehicleRessourcesTest.java @@ -19,13 +19,13 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.sharedvehicles; -import static org.junit.Assert.assertEquals; - import java.util.ArrayList; import java.util.Collections; import java.util.List; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -93,9 +93,9 @@ void testVehicleIdsAreKeptIfSomething() throws Exception { for ( Trip trip : TripStructureUtils.getTrips( plan ) ) { for (Leg l : trip.getLegsOnly()) { assertEquals( - "unexpected vehicle id", vehicleId, - ((NetworkRoute) l.getRoute()).getVehicleId()); + ((NetworkRoute) l.getRoute()).getVehicleId(), + "unexpected vehicle id"); } } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/qsim/PopulationAgentSourceWithVehiclesTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/qsim/PopulationAgentSourceWithVehiclesTest.java index dad937c6e08..a35023b69a8 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/qsim/PopulationAgentSourceWithVehiclesTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/qsim/PopulationAgentSourceWithVehiclesTest.java @@ -19,8 +19,8 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.sharedvehicles.qsim; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertFalse; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.Collections; @@ -118,8 +118,8 @@ void testFailsIfOnlySomeRoutesHaveAVehicle() throws Exception { } assertTrue( - "did not get an exception with inconsistent setting", - gotException); + gotException, + "did not get an exception with inconsistent setting"); } @Test @@ -199,8 +199,8 @@ public void testNoFail(final boolean vehicles) throws Exception { } assertFalse( - "got an exception with consistent setting", - gotException); + gotException, + "got an exception with consistent setting"); } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java index 37f66567b28..5ba2aa6069a 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java @@ -31,7 +31,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -139,9 +139,9 @@ void testEnoughVehiclesForEverybody() { final Set allocated = new HashSet(); for ( Plan p : testPlan.getAllIndividualPlans() ) { final Id v = assertSingleVehicleAndGetVehicleId( p ); - Assert.assertTrue( - "vehicle "+v+" already allocated", - v == null || allocated.add( v ) ); + Assertions.assertTrue( + v == null || allocated.add( v ), + "vehicle "+v+" already allocated" ); } } } @@ -174,9 +174,9 @@ void testOneVehiclePerTwoPersons() { } final int max = Collections.max( counts.values() ); - Assert.assertTrue( - "one vehicle was allocated "+max+" times while maximum expected was 2 in "+counts, - max <= 2 ); + Assertions.assertTrue( + max <= 2, + "one vehicle was allocated "+max+" times while maximum expected was 2 in "+counts ); } } @@ -215,10 +215,10 @@ else if ( !oldV.equals( v ) ) { } } - Assert.assertEquals( - "unexpected number of agents having got several vehicles", + Assertions.assertEquals( allocations.size(), - agentsWithSeveralVehicles.size() ); + agentsWithSeveralVehicles.size(), + "unexpected number of agents having got several vehicles" ); } @Test @@ -254,10 +254,10 @@ else if ( !oldV.equals( v ) ) { } } - Assert.assertEquals( - "unexpected number of agents having got several vehicles", + Assertions.assertEquals( 0, - agentsWithSeveralVehicles.size() ); + agentsWithSeveralVehicles.size(), + "unexpected number of agents having got several vehicles" ); } private static Id assertSingleVehicleAndGetVehicleId(final Plan p) { @@ -270,13 +270,13 @@ private static Id assertSingleVehicleAndGetVehicleId(final Plan p) { if ( !MODE.equals( leg.getMode() ) ) continue; final NetworkRoute r = (NetworkRoute) leg.getRoute(); - Assert.assertNotNull( - "null vehicle id in route", - r.getVehicleId() ); + Assertions.assertNotNull( + r.getVehicleId(), + "null vehicle id in route" ); - Assert.assertTrue( - "vehicle "+r.getVehicleId()+" not the same as "+v, - v == null || r.getVehicleId().equals( v ) ); + Assertions.assertTrue( + v == null || r.getVehicleId().equals( v ), + "vehicle "+r.getVehicleId()+" not the same as "+v ); v = r.getVehicleId(); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java index a5b3a7367bc..20514741157 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java @@ -26,8 +26,8 @@ import java.util.Random; import java.util.Set; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -137,9 +137,9 @@ void testCannotFindBetterAllocationRandomly() throws Exception { false, false).run( randomized ); final double randomizedOverlap = algo.calcOverlap( randomized ); - Assert.assertTrue( - "["+i+","+j+"] found better solution than optimized one: "+randomizedOverlap+" < "+optimizedOverlap, - optimizedOverlap <= randomizedOverlap ); + Assertions.assertTrue( + optimizedOverlap <= randomizedOverlap, + "["+i+","+j+"] found better solution than optimized one: "+randomizedOverlap+" < "+optimizedOverlap ); } counter.printCounter(); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java index 203bec54de6..08ff8da07ce 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java @@ -19,9 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.usage.replanning; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertFalse; import java.util.ArrayList; import java.util.Arrays; @@ -75,13 +73,13 @@ void testNewPlanIsSelected() throws Exception { if ( PersonUtils.isSelected(plan) ) { // new plan: selection status inverted assertFalse( - "old plan still selected", - selectedPlans.contains( plan )); + selectedPlans.contains( plan ), + "old plan still selected"); } else { assertTrue( - "old plan still selected", - selectedPlans.contains( plan )); + selectedPlans.contains( plan ), + "old plan still selected"); } } } @@ -100,9 +98,9 @@ void testNumberOfPlans() throws Exception { strategy.run( createContext() , jointPlans , Arrays.asList( group ) ); assertEquals( - "group size changed by strategy!", groupSize, - group.getPersons().size()); + group.getPersons().size(), + "group size changed by strategy!"); } @Test @@ -130,13 +128,13 @@ void testNumberOfSelectedJointPlans() throws Exception { } assertEquals( - "wrong number of selected plans in joint plans", N_INITIALLY_INDIV_PLANS, - countSelectedJoint ); + countSelectedJoint, + "wrong number of selected plans in joint plans" ); assertEquals( - "wrong number of selected plans in individual plans", N_INITIALLY_JOINT_PLANS, - countSelectedIndiv ); + countSelectedIndiv, + "wrong number of selected plans in individual plans" ); } @Test @@ -164,13 +162,13 @@ void testNumberOfNonSelectedJointPlans() throws Exception { } assertEquals( - "wrong number of non selected plans in joint plans", N_INITIALLY_JOINT_PLANS, - countNonSelectedJoint ); + countNonSelectedJoint, + "wrong number of non selected plans in joint plans" ); assertEquals( - "wrong number of non selected plans in individual plans", N_INITIALLY_INDIV_PLANS, - countNonSelectedIndiv ); + countNonSelectedIndiv, + "wrong number of non selected plans in individual plans" ); } private ReplanningGroup createTestGroup(final JointPlans jointPlans) { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/JoinableActivitiesPlanLinkIdentifierTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/JoinableActivitiesPlanLinkIdentifierTest.java index 67e5fe79763..6aaf3ac370e 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/JoinableActivitiesPlanLinkIdentifierTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/JoinableActivitiesPlanLinkIdentifierTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.usage.replanning; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -52,9 +52,9 @@ void testOpenPlansSamePlaceSameType() { final Plan plan2 = createOpenPlan( Id.create( 2 , Person.class ) , type , facility ); final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( type ); - Assert.assertTrue( - "plans with activities of good type at the same place the whole day should be joint", - testee.areLinked( plan1 , plan2 ) ); + Assertions.assertTrue( + testee.areLinked( plan1 , plan2 ), + "plans with activities of good type at the same place the whole day should be joint" ); } @Test @@ -66,13 +66,13 @@ void testOpenPlansSamePlaceDifferentType() { final Plan plan2 = createOpenPlan( Id.create( 2 , Person.class ) , "other type" , facility ); final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( type ); - Assert.assertEquals( - "inconsistency!", + Assertions.assertEquals( + testee.areLinked( plan1 , plan2 ), + testee.areLinked( plan2 , plan1 ), + "inconsistency!" ); + Assertions.assertFalse( testee.areLinked( plan1 , plan2 ), - testee.areLinked( plan2 , plan1 ) ); - Assert.assertFalse( - "plans with activities of different types should not be joined", - testee.areLinked( plan1 , plan2 ) ); + "plans with activities of different types should not be joined" ); } @Test @@ -85,13 +85,13 @@ void testOpenPlansDifferentPlaceSameType() { final Plan plan2 = createOpenPlan( Id.create( 2 , Person.class ) , type , facility2 ); final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( type ); - Assert.assertEquals( - "inconsistency!", + Assertions.assertEquals( testee.areLinked( plan1 , plan2 ), - testee.areLinked( plan2 , plan1 ) ); - Assert.assertFalse( - "plans with activities at different locations should not be joined", - testee.areLinked( plan1 , plan2 ) ); + testee.areLinked( plan2 , plan1 ), + "inconsistency!" ); + Assertions.assertFalse( + testee.areLinked( plan1 , plan2 ), + "plans with activities at different locations should not be joined" ); } @Test @@ -103,13 +103,13 @@ void testOpenPlansSamePlaceSameWrongType() { final Plan plan2 = createOpenPlan( Id.create( 2 , Person.class ) , type , facility ); final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( "other type" ); - Assert.assertEquals( - "inconsistency!", + Assertions.assertEquals( + testee.areLinked( plan1 , plan2 ), + testee.areLinked( plan2 , plan1 ), + "inconsistency!" ); + Assertions.assertFalse( testee.areLinked( plan1 , plan2 ), - testee.areLinked( plan2 , plan1 ) ); - Assert.assertFalse( - "plans with activities of non joinable types should not be joined", - testee.areLinked( plan1 , plan2 ) ); + "plans with activities of non joinable types should not be joined" ); } private static Plan createOpenPlan( @@ -148,13 +148,13 @@ void testSingleTourOverlaping() { final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( type ); - Assert.assertEquals( - "inconsistency!", + Assertions.assertEquals( testee.areLinked( plan1 , plan2 ), - testee.areLinked( plan2 , plan1 ) ); - Assert.assertTrue( - "plans with overlaping activities should be joint", - testee.areLinked( plan1 , plan2 ) ); + testee.areLinked( plan2 , plan1 ), + "inconsistency!" ); + Assertions.assertTrue( + testee.areLinked( plan1 , plan2 ), + "plans with overlaping activities should be joint" ); } @Test @@ -180,13 +180,13 @@ void testSingleTourPlansNonOverlaping() { final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( type ); - Assert.assertEquals( - "inconsistency!", + Assertions.assertEquals( + testee.areLinked( plan1 , plan2 ), + testee.areLinked( plan2 , plan1 ), + "inconsistency!" ); + Assertions.assertFalse( testee.areLinked( plan1 , plan2 ), - testee.areLinked( plan2 , plan1 ) ); - Assert.assertFalse( - "plans with non overlaping activities should not be joint", - testee.areLinked( plan1 , plan2 ) ); + "plans with non overlaping activities should not be joint" ); } @Test @@ -212,13 +212,13 @@ void testSingleTourPlansZeroDurationAct() { final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( type ); - Assert.assertEquals( - "inconsistency!", + Assertions.assertEquals( testee.areLinked( plan1 , plan2 ), - testee.areLinked( plan2 , plan1 ) ); - Assert.assertTrue( - "plans with zero-length overlaping activities should be joint", - testee.areLinked( plan1 , plan2 ) ); + testee.areLinked( plan2 , plan1 ), + "inconsistency!" ); + Assertions.assertTrue( + testee.areLinked( plan1 , plan2 ), + "plans with zero-length overlaping activities should be joint" ); } @Test @@ -243,10 +243,10 @@ void testSingleTourPlansZeroDurationBegin() { 40); final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( type ); - Assert.assertEquals( - "inconsistency!", + Assertions.assertEquals( testee.areLinked( plan1 , plan2 ), - testee.areLinked( plan2 , plan1 ) ); + testee.areLinked( plan2 , plan1 ), + "inconsistency!" ); // actual result irrelevant for this border case, as long as consistent //Assert.assertTrue( // "plans with zero-length overlaping activities should be joint", @@ -275,10 +275,10 @@ void testSingleTourPlansZeroDurationEnd() { 40); final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( type ); - Assert.assertEquals( - "inconsistency!", + Assertions.assertEquals( testee.areLinked( plan1 , plan2 ), - testee.areLinked( plan2 , plan1 ) ); + testee.areLinked( plan2 , plan1 ), + "inconsistency!" ); // actual result irrelevant for this border case, as long as consistent //Assert.assertTrue( // "plans with zero-length overlaping activities should be joint", @@ -311,10 +311,10 @@ void testDoubleTourPlansZeroDurationEnd() { final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( type ); - Assert.assertEquals( - "inconsistency!", + Assertions.assertEquals( testee.areLinked( plan1 , plan2 ), - testee.areLinked( plan2 , plan1 ) ); + testee.areLinked( plan2 , plan1 ), + "inconsistency!" ); // whether plans are linked or not on this border case is irrelevant, // but the result should be consistent. //Assert.assertTrue( @@ -347,13 +347,13 @@ void testSingleTourPlansInconsistentDurationAct() { final PlanLinkIdentifier testee = new JoinableActivitiesPlanLinkIdentifier( type ); - Assert.assertEquals( - "inconsistency!", + Assertions.assertEquals( + testee.areLinked( plan1 , plan2 ), + testee.areLinked( plan2 , plan1 ), + "inconsistency!" ); + Assertions.assertFalse( testee.areLinked( plan1 , plan2 ), - testee.areLinked( plan2 , plan1 ) ); - Assert.assertFalse( - "plans with inconsistent duration not handled correctly", - testee.areLinked( plan1 , plan2 ) ); + "plans with inconsistent duration not handled correctly" ); } private static Plan createDoubleTripPlan( diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/VehicularPlanLinkIdentifierTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/VehicularPlanLinkIdentifierTest.java index 9cdb9bd5e83..198a2642fab 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/VehicularPlanLinkIdentifierTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/VehicularPlanLinkIdentifierTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.usage.replanning; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -48,9 +48,9 @@ void testNotLinkedWhenNoVehicleDefined() { final PlanLinkIdentifier testee = new VehicularPlanBasedIdentifier(); - Assert.assertFalse( - "plans without vehicle allocated are considered linked", - testee.areLinked( plan1 , plan2 ) ); + Assertions.assertFalse( + testee.areLinked( plan1 , plan2 ), + "plans without vehicle allocated are considered linked" ); } @Test @@ -59,9 +59,9 @@ void testDifferentVehiclesAreNotLinked() { final Plan plan2 = createVehicularPlan( Id.create( 2 , Person.class ) , Id.create( 2 , Vehicle.class ) ); final PlanLinkIdentifier testee = new VehicularPlanBasedIdentifier(); - Assert.assertFalse( - "plans with different vehicle allocated are considered linked", - testee.areLinked( plan1 , plan2 ) ); + Assertions.assertFalse( + testee.areLinked( plan1 , plan2 ), + "plans with different vehicle allocated are considered linked" ); } @Test @@ -70,9 +70,9 @@ void testSameVehiclesAreLinked() { final Plan plan2 = createVehicularPlan( Id.create( 2 , Person.class ) , Id.create( "car" , Vehicle.class ) ); final PlanLinkIdentifier testee = new VehicularPlanBasedIdentifier(); - Assert.assertTrue( - "plans with same vehicle allocated are not considered linked", - testee.areLinked( plan1 , plan2 ) ); + Assertions.assertTrue( + testee.areLinked( plan1 , plan2 ), + "plans with same vehicle allocated are not considered linked" ); } // TODO test joint trips diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java index 96cd50a3de0..71aa02e2b0e 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/JointScenarioUtilsTest.java @@ -19,11 +19,11 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.utils; -import static org.junit.Assert.assertEquals; - import java.util.Collection; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -63,9 +63,9 @@ void testJointTripsImport() throws Exception { final Population loadedPopulation = loadedScenario.getPopulation(); assertEquals( - "read pop is not the same size as dumped", dumpedPopulation.getPersons().size(), - loadedPopulation.getPersons().size()); + loadedPopulation.getPersons().size(), + "read pop is not the same size as dumped"); for (Person person : loadedPopulation.getPersons().values()) { final Person dumpedPerson = dumpedPopulation.getPersons().get( person.getId() ); @@ -74,40 +74,40 @@ void testJointTripsImport() throws Exception { final Plan loadedPlan = person.getPlans().get( 0 ); assertEquals( - "incompatible plan sizes", dumpedPlan.getPlanElements().size(), - loadedPlan.getPlanElements().size()); + loadedPlan.getPlanElements().size(), + "incompatible plan sizes"); final Leg dumpedLeg = (Leg) dumpedPlan.getPlanElements().get( 1 ); final Leg loadedLeg = (Leg) loadedPlan.getPlanElements().get( 1 ); if (dumpedLeg.getMode().equals( JointActingTypes.DRIVER )) { assertEquals( - "wrong route class", DriverRoute.class, - loadedLeg.getRoute().getClass()); + loadedLeg.getRoute().getClass(), + "wrong route class"); final Collection> dumpedPassengers = ((DriverRoute) dumpedLeg.getRoute()).getPassengersIds(); final Collection> loadedPassengers = ((DriverRoute) loadedLeg.getRoute()).getPassengersIds(); assertEquals( - "unexpected passenger ids", dumpedPassengers, - loadedPassengers); + loadedPassengers, + "unexpected passenger ids"); } else { assertEquals( - "wrong route class", PassengerRoute.class, - loadedLeg.getRoute().getClass()); + loadedLeg.getRoute().getClass(), + "wrong route class"); final Id dumpedDriver = ((PassengerRoute) dumpedLeg.getRoute()).getDriverId(); final Id loadedDriver = ((PassengerRoute) loadedLeg.getRoute()).getDriverId(); assertEquals( - "unexpected passenger ids", dumpedDriver, - loadedDriver); + loadedDriver, + "unexpected passenger ids"); } } } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/ObjectPoolTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/ObjectPoolTest.java index 22dcdc2bd7e..71757798351 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/ObjectPoolTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/ObjectPoolTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.utils; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; @@ -35,27 +35,27 @@ void testInstanceIsPooled() throws Exception { final String instance2 = new String( "jojo" ); final String instance3 = new String( "jojo" ); - assertTrue("the two variables should be different objects", instance1 != instance2); + assertTrue(instance1 != instance2, "the two variables should be different objects"); assertSame( - "first instance not returned when pooled", instance1, - pool.getPooledInstance( instance1 )); + pool.getPooledInstance( instance1 ), + "first instance not returned when pooled"); assertNotSame( - "second instance returned instead of first", instance2, - pool.getPooledInstance( instance2 )); + pool.getPooledInstance( instance2 ), + "second instance returned instead of first"); assertSame( - "first instance not returned while pooled", instance1, - pool.getPooledInstance( instance2 )); + pool.getPooledInstance( instance2 ), + "first instance not returned while pooled"); assertSame( - "first instance not returned while pooled", instance1, - pool.getPooledInstance( instance3 )); + pool.getPooledInstance( instance3 ), + "first instance not returned while pooled"); } // TODO test forgetting diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/QuadTreeRebuilderTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/QuadTreeRebuilderTest.java index f8f8da6d46c..54c58779a6f 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/QuadTreeRebuilderTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/utils/QuadTreeRebuilderTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.socnetsim.utils; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.collections.QuadTree; @@ -10,33 +10,33 @@ public class QuadTreeRebuilderTest { void testGrowingQuadTree() { final QuadTreeRebuilder rebuilder = new QuadTreeRebuilder<>(); - Assert.assertEquals( - "unexpected quadtree size", + Assertions.assertEquals( 0, - rebuilder.getQuadTree().size()); + rebuilder.getQuadTree().size(), + "unexpected quadtree size"); rebuilder.put(new Coord(0, 0), new Object()); - Assert.assertEquals( - "unexpected quadtree size", + Assertions.assertEquals( 1, - rebuilder.getQuadTree().size()); + rebuilder.getQuadTree().size(), + "unexpected quadtree size"); rebuilder.put(new Coord(100, 100), new Object()); - Assert.assertEquals( - "unexpected quadtree size", + Assertions.assertEquals( 2, - rebuilder.getQuadTree().size()); + rebuilder.getQuadTree().size(), + "unexpected quadtree size"); - Assert.assertEquals( - "unexpected number of elements around origin", + Assertions.assertEquals( 1, - rebuilder.getQuadTree().getDisk(0, 0, 1).size()); + rebuilder.getQuadTree().getDisk(0, 0, 1).size(), + "unexpected number of elements around origin"); - Assert.assertEquals( - "unexpected number of elements far from origin", + Assertions.assertEquals( 2, - rebuilder.getQuadTree().getDisk(0, 0, 1000).size()); + rebuilder.getQuadTree().getDisk(0, 0, 1000).size(), + "unexpected number of elements far from origin"); } } diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java b/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java index 12572b18dcc..c086adedc50 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/etaxi/run/RunETaxiScenarioIT.java @@ -18,7 +18,7 @@ package org.matsim.contrib.etaxi.run; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -68,13 +68,13 @@ private void runScenario(String configPath) { PopulationUtils.readPopulation(actual, utils.getOutputDirectory() + "/output_plans.xml.gz"); boolean result = PopulationUtils.comparePopulations(expected, actual); - Assert.assertTrue(result); + Assertions.assertTrue(result); } { String expected = utils.getInputDirectory() + "/output_events.xml.gz"; String actual = utils.getOutputDirectory() + "/output_events.xml.gz"; EventsFileComparator.Result result = EventsUtils.compareEventsFiles(expected, actual); - Assert.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result); + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result); } } } diff --git a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/TaxiOptimizerTests.java b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/TaxiOptimizerTests.java index f92b30ee28a..ca985585f82 100644 --- a/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/TaxiOptimizerTests.java +++ b/contribs/taxi/src/test/java/org/matsim/contrib/taxi/optimizer/TaxiOptimizerTests.java @@ -22,7 +22,7 @@ import java.net.URL; import java.util.Optional; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Population; import org.matsim.contrib.dvrp.run.DvrpConfigGroup; @@ -65,13 +65,13 @@ public static void runBenchmark(boolean vehicleDiversion, AbstractTaxiOptimizerP PopulationUtils.readPopulation(actual, utils.getOutputDirectory() + "/output_plans.xml.gz"); boolean result = PopulationUtils.comparePopulations(expected, actual); - Assert.assertTrue(result); + Assertions.assertTrue(result); } { String expected = utils.getInputDirectory() + "/output_events.xml.gz"; String actual = utils.getOutputDirectory() + "/output_events.xml.gz"; EventsFileComparator.Result result = EventsUtils.compareEventsFiles(expected, actual); - Assert.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result); + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result); } } } diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java index 26908ea89bc..93e9146f31a 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesIT.java @@ -19,7 +19,7 @@ package org.matsim.core.scoring.functions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -80,10 +80,9 @@ public void install() { double personSpecificModeConstant = Double.parseDouble(PersonUtils.getModeConstants(person).get(TransportMode.car)); // each person has 3 legs -> score should 3 x personSpecificModeConstant since all other scoring parameters are 0 - Assert.assertEquals("Score deviates from what is expected given the personSpecificModeConstant.", - personSpecificModeConstant, score / 3, MatsimTestUtils.EPSILON); - Assert.assertTrue("personSpecificModeConstant has value 0 or higher, this should never happen with log normal distribution for given mean -1 and sigma 1", - personSpecificModeConstant < 0.0d); + Assertions.assertEquals(personSpecificModeConstant, score / 3, MatsimTestUtils.EPSILON, "Score deviates from what is expected given the personSpecificModeConstant."); + Assertions.assertTrue(personSpecificModeConstant < 0.0d, + "personSpecificModeConstant has value 0 or higher, this should never happen with log normal distribution for given mean -1 and sigma 1"); } } } diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java index 70434051a10..57fcaa18660 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java @@ -19,8 +19,8 @@ package org.matsim.core.scoring.functions; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -144,8 +144,8 @@ void testPersonWithLowIncomeLowCarAsc(){ Id id = Id.createPersonId("lowIncomeLowCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 0.5d, 0.5d); - Assert.assertEquals(-0.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); } @Test @@ -153,8 +153,8 @@ void testPersonWithHighIncomeLowCarAsc(){ Id id = Id.createPersonId("highIncomeLowCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 1.5d, 0.5d); - Assert.assertEquals(-0.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); } @Test @@ -162,9 +162,9 @@ void testPersonWithMediumIncomeHighCarAsc(){ Id id = Id.createPersonId("mediumIncomeHighCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 1d, 0.5d); - Assert.assertEquals(-2.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); - Assert.assertEquals(-50.0d, params.modeParams.get(TransportMode.bike).constant, MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-2.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-50.0d, params.modeParams.get(TransportMode.bike).constant, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); } @Test @@ -172,14 +172,14 @@ void testMoneyScore(){ ScoringParameters paramsRich = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("highIncomeLowCarAsc"))); CharyparNagelMoneyScoring moneyScoringRich = new CharyparNagelMoneyScoring(paramsRich); moneyScoringRich.addMoney(100); - Assert.assertEquals("for the rich person, 100 money units should be equal to a score of 66.66", 1./1.5 * 100, moneyScoringRich.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1./1.5 * 100, moneyScoringRich.getScore(), MatsimTestUtils.EPSILON, "for the rich person, 100 money units should be equal to a score of 66.66"); ScoringParameters paramsPoor = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("lowIncomeLowCarAsc"))); CharyparNagelMoneyScoring moneyScoringPoor = new CharyparNagelMoneyScoring(paramsPoor); moneyScoringPoor.addMoney(100); - Assert.assertEquals("for the poor person, 100 money units should be equal to a score of 200.00", 1./0.5 * 100, moneyScoringPoor.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1./0.5 * 100, moneyScoringPoor.getScore(), MatsimTestUtils.EPSILON, "for the poor person, 100 money units should be equal to a score of 200.00"); - Assert.assertTrue("100 money units should worth more for a poor person than for a rich person", moneyScoringPoor.getScore() > moneyScoringRich.getScore()); + Assertions.assertTrue(moneyScoringPoor.getScore() > moneyScoringRich.getScore(), "100 money units should worth more for a poor person than for a rich person"); } @Test @@ -189,27 +189,23 @@ void testPersonSpecificAscScoring(){ Leg carLegZeroDistanceTenSeconds = createLeg(TransportMode.car, 0.0d, 10.0d ); legScoringRichCarLeg.handleLeg(carLegZeroDistanceTenSeconds); - Assert.assertEquals("for the rich person with low car asc, a 0 meter and 10s car trip should be equal to a score of ", - -0.1d -0.001d * 10 -7.5*1./1.5 -0.3, legScoringRichCarLeg.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.1d -0.001d * 10 -7.5*1./1.5 -0.3, legScoringRichCarLeg.getScore(), MatsimTestUtils.EPSILON, "for the rich person with low car asc, a 0 meter and 10s car trip should be equal to a score of "); ScoringParameters paramsMediumIncomeHighCarAsc = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("mediumIncomeHighCarAsc"))); CharyparNagelLegScoring legScoringMediumIncomeHighCarAsc = new CharyparNagelLegScoring(paramsMediumIncomeHighCarAsc, NetworkUtils.createNetwork(), Set.of(TransportMode.pt)); legScoringMediumIncomeHighCarAsc.handleLeg(carLegZeroDistanceTenSeconds); - Assert.assertEquals("for the medium person with high car asc, a 0 meter and 10s car trip should be equal to a score of ", - -2.1d -0.001d * 10 -7.5*1./1.0 -0.3, legScoringMediumIncomeHighCarAsc.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-2.1d -0.001d * 10 -7.5*1./1.0 -0.3, legScoringMediumIncomeHighCarAsc.getScore(), MatsimTestUtils.EPSILON, "for the medium person with high car asc, a 0 meter and 10s car trip should be equal to a score of "); // bike has no person specific asc for high income person and is not affected CharyparNagelLegScoring legScoringRichBikeLeg = new CharyparNagelLegScoring(paramsRich, NetworkUtils.createNetwork(), Set.of(TransportMode.pt)); Leg bikeLegZeroDistanceZeroSeconds = createLeg(TransportMode.bike, 0.0d, 0.0d ); legScoringRichBikeLeg.handleLeg(bikeLegZeroDistanceZeroSeconds); - Assert.assertEquals("for the rich person with low car asc, a 0 meter and 0s bike trip should be equal to a score of ", - -0.55d, legScoringRichBikeLeg.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.55d, legScoringRichBikeLeg.getScore(), MatsimTestUtils.EPSILON, "for the rich person with low car asc, a 0 meter and 0s bike trip should be equal to a score of "); // bike has a person specific asc for the medium income person CharyparNagelLegScoring legScoringMediumIncomeBikeLeg = new CharyparNagelLegScoring(paramsMediumIncomeHighCarAsc, NetworkUtils.createNetwork(), Set.of(TransportMode.pt)); legScoringMediumIncomeBikeLeg.handleLeg(bikeLegZeroDistanceZeroSeconds); - Assert.assertEquals("for the medium income person with high car asc, a 0 meter and 0s bike trip should be equal to a score of ", - -50.0d, legScoringMediumIncomeBikeLeg.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-50.0d, legScoringMediumIncomeBikeLeg.getScore(), MatsimTestUtils.EPSILON, "for the medium income person with high car asc, a 0 meter and 0s bike trip should be equal to a score of "); } private static Leg createLeg(String mode, double distance, double travelTime) { @@ -223,8 +219,8 @@ private static Leg createLeg(String mode, double distance, double travelTime) { } private void makeAssertMarginalUtilityOfMoneyAndPtWait(ScoringParameters params, double income, double marginalUtilityOfWaitingPt_s){ - Assert.assertEquals("marginalUtilityOfMoney is wrong", 1 / income , params.marginalUtilityOfMoney, 0.); - Assert.assertEquals("marginalUtilityOfWaitingPt_s is wrong", marginalUtilityOfWaitingPt_s , params.marginalUtilityOfWaitingPt_s, 0.); + Assertions.assertEquals(1 / income , params.marginalUtilityOfMoney, 0., "marginalUtilityOfMoney is wrong"); + Assertions.assertEquals(marginalUtilityOfWaitingPt_s , params.marginalUtilityOfWaitingPt_s, 0., "marginalUtilityOfWaitingPt_s is wrong"); } diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java index 9ead6090cb8..69d5bb6835f 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java @@ -19,8 +19,8 @@ package org.matsim.core.scoring.functions; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -166,8 +166,8 @@ void testPersonWithLowIncomeLowCarAsc(){ Id id = Id.createPersonId("lowIncomeLowCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 0.5d, 0.5d); - Assert.assertEquals(-0.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); } @Test @@ -175,8 +175,8 @@ void testPersonWithHighIncomeLowCarAsc(){ Id id = Id.createPersonId("highIncomeLowCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 1.5d, 0.5d); - Assert.assertEquals(-0.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); } @Test @@ -184,9 +184,9 @@ void testPersonWithMediumIncomeHighCarAsc(){ Id id = Id.createPersonId("mediumIncomeHighCarAsc"); ScoringParameters params = personScoringParams.getScoringParameters(population.getPersons().get(id)); makeAssertMarginalUtilityOfMoneyAndPtWait(params, 1d, 0.5d); - Assert.assertEquals(-2.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); - Assert.assertEquals(-50.0d, params.modeParams.get(TransportMode.bike).constant, MatsimTestUtils.EPSILON); - Assert.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-2.1d, params.modeParams.get(TransportMode.car).constant, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-50.0d, params.modeParams.get(TransportMode.bike).constant, MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.001d, params.modeParams.get(TransportMode.car).marginalUtilityOfTraveling_s, MatsimTestUtils.EPSILON); } @Test @@ -212,14 +212,14 @@ void testMoneyScore(){ ScoringParameters paramsRich = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("highIncomeLowCarAsc"))); CharyparNagelMoneyScoring moneyScoringRich = new CharyparNagelMoneyScoring(paramsRich); moneyScoringRich.addMoney(100); - Assert.assertEquals("for the rich person, 100 money units should be equal to a score of 66.66", 1./1.5 * 100, moneyScoringRich.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1./1.5 * 100, moneyScoringRich.getScore(), MatsimTestUtils.EPSILON, "for the rich person, 100 money units should be equal to a score of 66.66"); ScoringParameters paramsPoor = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("lowIncomeLowCarAsc"))); CharyparNagelMoneyScoring moneyScoringPoor = new CharyparNagelMoneyScoring(paramsPoor); moneyScoringPoor.addMoney(100); - Assert.assertEquals("for the poor person, 100 money units should be equal to a score of 200.00", 1./0.5 * 100, moneyScoringPoor.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1./0.5 * 100, moneyScoringPoor.getScore(), MatsimTestUtils.EPSILON, "for the poor person, 100 money units should be equal to a score of 200.00"); - Assert.assertTrue("100 money units should worth more for a poor person than for a rich person", moneyScoringPoor.getScore() > moneyScoringRich.getScore()); + Assertions.assertTrue(moneyScoringPoor.getScore() > moneyScoringRich.getScore(), "100 money units should worth more for a poor person than for a rich person"); } @Test @@ -229,27 +229,23 @@ void testPersonSpecificAscScoring(){ Leg carLegZeroDistanceTenSeconds = createLeg(TransportMode.car, 0.0d, 10.0d ); legScoringRichCarLeg.handleLeg(carLegZeroDistanceTenSeconds); - Assert.assertEquals("for the rich person with low car asc, a 0 meter and 10s car trip should be equal to a score of ", - -0.1d -0.001d * 10 -7.5*1./1.5 -0.3, legScoringRichCarLeg.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.1d -0.001d * 10 -7.5*1./1.5 -0.3, legScoringRichCarLeg.getScore(), MatsimTestUtils.EPSILON, "for the rich person with low car asc, a 0 meter and 10s car trip should be equal to a score of "); ScoringParameters paramsMediumIncomeHighCarAsc = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("mediumIncomeHighCarAsc"))); CharyparNagelLegScoring legScoringMediumIncomeHighCarAsc = new CharyparNagelLegScoring(paramsMediumIncomeHighCarAsc, NetworkUtils.createNetwork(), Set.of(TransportMode.pt)); legScoringMediumIncomeHighCarAsc.handleLeg(carLegZeroDistanceTenSeconds); - Assert.assertEquals("for the medium person with high car asc, a 0 meter and 10s car trip should be equal to a score of ", - -2.1d -0.001d * 10 -7.5*1./1.0 -0.3, legScoringMediumIncomeHighCarAsc.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-2.1d -0.001d * 10 -7.5*1./1.0 -0.3, legScoringMediumIncomeHighCarAsc.getScore(), MatsimTestUtils.EPSILON, "for the medium person with high car asc, a 0 meter and 10s car trip should be equal to a score of "); // bike has no person specific asc for high income person and is not affected CharyparNagelLegScoring legScoringRichBikeLeg = new CharyparNagelLegScoring(paramsRich, NetworkUtils.createNetwork(), Set.of(TransportMode.pt)); Leg bikeLegZeroDistanceZeroSeconds = createLeg(TransportMode.bike, 0.0d, 0.0d ); legScoringRichBikeLeg.handleLeg(bikeLegZeroDistanceZeroSeconds); - Assert.assertEquals("for the rich person with low car asc, a 0 meter and 0s bike trip should be equal to a score of ", - -0.55d, legScoringRichBikeLeg.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-0.55d, legScoringRichBikeLeg.getScore(), MatsimTestUtils.EPSILON, "for the rich person with low car asc, a 0 meter and 0s bike trip should be equal to a score of "); // bike has a person specific asc for the medium income person CharyparNagelLegScoring legScoringMediumIncomeBikeLeg = new CharyparNagelLegScoring(paramsMediumIncomeHighCarAsc, NetworkUtils.createNetwork(), Set.of(TransportMode.pt)); legScoringMediumIncomeBikeLeg.handleLeg(bikeLegZeroDistanceZeroSeconds); - Assert.assertEquals("for the medium income person with high car asc, a 0 meter and 0s bike trip should be equal to a score of ", - -50.0d, legScoringMediumIncomeBikeLeg.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(-50.0d, legScoringMediumIncomeBikeLeg.getScore(), MatsimTestUtils.EPSILON, "for the medium income person with high car asc, a 0 meter and 0s bike trip should be equal to a score of "); } private static Leg createLeg(String mode, double distance, double travelTime) { @@ -263,8 +259,8 @@ private static Leg createLeg(String mode, double distance, double travelTime) { } private void makeAssertMarginalUtilityOfMoneyAndPtWait(ScoringParameters params, double income, double marginalUtilityOfWaitingPt_s){ - Assert.assertEquals("marginalUtilityOfMoney is wrong", 1 / income , params.marginalUtilityOfMoney, 0.); - Assert.assertEquals("marginalUtilityOfWaitingPt_s is wrong", marginalUtilityOfWaitingPt_s , params.marginalUtilityOfWaitingPt_s, 0.); + Assertions.assertEquals(1 / income , params.marginalUtilityOfMoney, 0., "marginalUtilityOfMoney is wrong"); + Assertions.assertEquals(marginalUtilityOfWaitingPt_s , params.marginalUtilityOfWaitingPt_s, 0., "marginalUtilityOfWaitingPt_s is wrong"); } diff --git a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java index 5839ac4e77c..b64c9eca7a8 100644 --- a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java +++ b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java @@ -21,8 +21,8 @@ package org.matsim.freight.carriers.analysis; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -115,13 +115,13 @@ void runVehicleTrackerTest(){ if(key.equals(lightVehicle_0)){ Id vehicleType = Id.create( "light", VehicleType.class ); Id driverId_0 = Id.create( "freight_carrier1_veh_carrier_19_lightVehicle_0", Person.class ); - Assert.assertEquals("Road time is not as expected ",Double.valueOf(6195.0),tracker.get(key).roadTime); - Assert.assertEquals("Cost is not as expected ",Double.valueOf(50.88999999999996),tracker.get(key).cost); - Assert.assertEquals("Travel distance is not as expected ",Double.valueOf(35000.0),tracker.get(key).travelDistance); - Assert.assertEquals("Usage time is not as expected ",Double.valueOf(6689.0),tracker.get(key).usageTime); - Assert.assertEquals("Driver Id is not as expected ",driverId_0,tracker.get(key).lastDriverId); - Assert.assertEquals("Vehicle type is not as expected ",vehicleType,tracker.get(key).vehicleType.getId()); - Assert.assertEquals("No: of trips is not as expected ",6,tracker.get(key).tripHistory.size()); + Assertions.assertEquals(Double.valueOf(6195.0),tracker.get(key).roadTime,"Road time is not as expected "); + Assertions.assertEquals(Double.valueOf(50.88999999999996),tracker.get(key).cost,"Cost is not as expected "); + Assertions.assertEquals(Double.valueOf(35000.0),tracker.get(key).travelDistance,"Travel distance is not as expected "); + Assertions.assertEquals(Double.valueOf(6689.0),tracker.get(key).usageTime,"Usage time is not as expected "); + Assertions.assertEquals(driverId_0,tracker.get(key).lastDriverId,"Driver Id is not as expected "); + Assertions.assertEquals(vehicleType,tracker.get(key).vehicleType.getId(),"Vehicle type is not as expected "); + Assertions.assertEquals(6,tracker.get(key).tripHistory.size(),"No: of trips is not as expected "); //trip history LinkedHashSet tripHistory = tracker.get(key).tripHistory; @@ -132,46 +132,46 @@ void runVehicleTrackerTest(){ history.put(i, tripHistoryItr.next()); i++; } - Assert.assertEquals("cost is not as expected ",Double.valueOf(-6.0200000000000005),history.get(0).cost); - Assert.assertEquals("travelDistance is not as expected ",Double.valueOf(10000.0),history.get(0).travelDistance); - Assert.assertEquals("travelTime is not as expected ",Double.valueOf(-1340.0),history.get(0).travelTime); - Assert.assertEquals("driverId is not as expected ",driverId_0,history.get(0).driverId); - - Assert.assertEquals("cost is not as expected ",Double.valueOf(-5.417999999999999),history.get(1).cost); - Assert.assertEquals("travelDistance is not as expected ",Double.valueOf(5000.0),history.get(1).travelDistance); - Assert.assertEquals("travelTime is not as expected ",Double.valueOf(-971.0),history.get(1).travelTime); - Assert.assertEquals("driverId is not as expected ",driverId_0,history.get(1).driverId); - - Assert.assertEquals("cost is not as expected ",Double.valueOf(-4.214),history.get(2).cost); - Assert.assertEquals("travelDistance is not as expected ",Double.valueOf(3000.0),history.get(2).travelDistance); - Assert.assertEquals("travelTime is not as expected ",Double.valueOf(-703.0),history.get(2).travelTime); - Assert.assertEquals("driverId is not as expected ",driverId_0,history.get(2).driverId); - - Assert.assertEquals("cost is not as expected ",Double.valueOf(-4.816),history.get(3).cost); - Assert.assertEquals("travelDistance is not as expected ",Double.valueOf(4000.0),history.get(3).travelDistance); - Assert.assertEquals("travelTime is not as expected ",Double.valueOf(-837.0),history.get(3).travelTime); - Assert.assertEquals("driverId is not as expected ",driverId_0,history.get(3).driverId); - - Assert.assertEquals("cost is not as expected ",Double.valueOf(-4.816),history.get(4).cost); - Assert.assertEquals("travelDistance is not as expected ",Double.valueOf(4000.0),history.get(4).travelDistance); - Assert.assertEquals("travelTime is not as expected ",Double.valueOf(-837.0),history.get(4).travelTime); - Assert.assertEquals("driverId is not as expected ",driverId_0,history.get(4).driverId); - - Assert.assertEquals("cost is not as expected ",Double.valueOf(-7.826000000000001),history.get(5).cost); - Assert.assertEquals("travelDistance is not as expected ",Double.valueOf(9000.0),history.get(5).travelDistance); - Assert.assertEquals("travelTime is not as expected ",Double.valueOf(-1507.0),history.get(5).travelTime); - Assert.assertEquals("driverId is not as expected ",driverId_0,history.get(5).driverId); + Assertions.assertEquals(Double.valueOf(-6.0200000000000005),history.get(0).cost,"cost is not as expected "); + Assertions.assertEquals(Double.valueOf(10000.0),history.get(0).travelDistance,"travelDistance is not as expected "); + Assertions.assertEquals(Double.valueOf(-1340.0),history.get(0).travelTime,"travelTime is not as expected "); + Assertions.assertEquals(driverId_0,history.get(0).driverId,"driverId is not as expected "); + + Assertions.assertEquals(Double.valueOf(-5.417999999999999),history.get(1).cost,"cost is not as expected "); + Assertions.assertEquals(Double.valueOf(5000.0),history.get(1).travelDistance,"travelDistance is not as expected "); + Assertions.assertEquals(Double.valueOf(-971.0),history.get(1).travelTime,"travelTime is not as expected "); + Assertions.assertEquals(driverId_0,history.get(1).driverId,"driverId is not as expected "); + + Assertions.assertEquals(Double.valueOf(-4.214),history.get(2).cost,"cost is not as expected "); + Assertions.assertEquals(Double.valueOf(3000.0),history.get(2).travelDistance,"travelDistance is not as expected "); + Assertions.assertEquals(Double.valueOf(-703.0),history.get(2).travelTime,"travelTime is not as expected "); + Assertions.assertEquals(driverId_0,history.get(2).driverId,"driverId is not as expected "); + + Assertions.assertEquals(Double.valueOf(-4.816),history.get(3).cost,"cost is not as expected "); + Assertions.assertEquals(Double.valueOf(4000.0),history.get(3).travelDistance,"travelDistance is not as expected "); + Assertions.assertEquals(Double.valueOf(-837.0),history.get(3).travelTime,"travelTime is not as expected "); + Assertions.assertEquals(driverId_0,history.get(3).driverId,"driverId is not as expected "); + + Assertions.assertEquals(Double.valueOf(-4.816),history.get(4).cost,"cost is not as expected "); + Assertions.assertEquals(Double.valueOf(4000.0),history.get(4).travelDistance,"travelDistance is not as expected "); + Assertions.assertEquals(Double.valueOf(-837.0),history.get(4).travelTime,"travelTime is not as expected "); + Assertions.assertEquals(driverId_0,history.get(4).driverId,"driverId is not as expected "); + + Assertions.assertEquals(Double.valueOf(-7.826000000000001),history.get(5).cost,"cost is not as expected "); + Assertions.assertEquals(Double.valueOf(9000.0),history.get(5).travelDistance,"travelDistance is not as expected "); + Assertions.assertEquals(Double.valueOf(-1507.0),history.get(5).travelTime,"travelTime is not as expected "); + Assertions.assertEquals(driverId_0,history.get(5).driverId,"driverId is not as expected "); } else if(key.equals(lightVehicle_1)){ Id vehicleType = Id.create( "light", VehicleType.class ); Id driverId_1 = Id.create( "freight_carrier1_veh_carrier_19_lightVehicle_1", Person.class ); - Assert.assertEquals("Road time is not as expected ",Double.valueOf(3684.0),tracker.get(key).roadTime); - Assert.assertEquals("Cost is not as expected ",Double.valueOf(65.33799999999991),tracker.get(key).cost); - Assert.assertEquals("Travel distance is not as expected ",Double.valueOf(23000.0),tracker.get(key).travelDistance); - Assert.assertEquals("Usage time is not as expected ",Double.valueOf(3818.0),tracker.get(key).usageTime); - Assert.assertEquals("Driver Id is not as expected ",driverId_1,tracker.get(key).lastDriverId); - Assert.assertEquals("Vehicle type is not as expected ",vehicleType,tracker.get(key).vehicleType.getId()); - Assert.assertEquals("No: of trips is not as expected ",3,tracker.get(key).tripHistory.size()); + Assertions.assertEquals(Double.valueOf(3684.0),tracker.get(key).roadTime,"Road time is not as expected "); + Assertions.assertEquals(Double.valueOf(65.33799999999991),tracker.get(key).cost,"Cost is not as expected "); + Assertions.assertEquals(Double.valueOf(23000.0),tracker.get(key).travelDistance,"Travel distance is not as expected "); + Assertions.assertEquals(Double.valueOf(3818.0),tracker.get(key).usageTime,"Usage time is not as expected "); + Assertions.assertEquals(driverId_1,tracker.get(key).lastDriverId,"Driver Id is not as expected "); + Assertions.assertEquals(vehicleType,tracker.get(key).vehicleType.getId(),"Vehicle type is not as expected "); + Assertions.assertEquals(3,tracker.get(key).tripHistory.size(),"No: of trips is not as expected "); //trip history LinkedHashSet tripHistory = tracker.get(key).tripHistory; @@ -182,20 +182,20 @@ void runVehicleTrackerTest(){ history.put(i, tripHistoryItr.next()); i++; } - Assert.assertEquals("cost is not as expected ",Double.valueOf(-3.6120000000000005),history.get(0).cost); - Assert.assertEquals("travelDistance is not as expected ",Double.valueOf(6000.0),history.get(0).travelDistance); - Assert.assertEquals("travelTime is not as expected ",Double.valueOf(-804.0),history.get(0).travelTime); - Assert.assertEquals("driverId is not as expected ",driverId_1,history.get(0).driverId); + Assertions.assertEquals(Double.valueOf(-3.6120000000000005),history.get(0).cost,"cost is not as expected "); + Assertions.assertEquals(Double.valueOf(6000.0),history.get(0).travelDistance,"travelDistance is not as expected "); + Assertions.assertEquals(Double.valueOf(-804.0),history.get(0).travelTime,"travelTime is not as expected "); + Assertions.assertEquals(driverId_1,history.get(0).driverId,"driverId is not as expected "); - Assert.assertEquals("cost is not as expected ",Double.valueOf(-6.622000000000001),history.get(1).cost); - Assert.assertEquals("travelDistance is not as expected ",Double.valueOf(7000.0),history.get(1).travelDistance); - Assert.assertEquals("travelTime is not as expected ",Double.valueOf(-1239.0),history.get(1).travelTime); - Assert.assertEquals("driverId is not as expected ",driverId_1,history.get(1).driverId); + Assertions.assertEquals(Double.valueOf(-6.622000000000001),history.get(1).cost,"cost is not as expected "); + Assertions.assertEquals(Double.valueOf(7000.0),history.get(1).travelDistance,"travelDistance is not as expected "); + Assertions.assertEquals(Double.valueOf(-1239.0),history.get(1).travelTime,"travelTime is not as expected "); + Assertions.assertEquals(driverId_1,history.get(1).driverId,"driverId is not as expected "); - Assert.assertEquals("cost is not as expected ",Double.valueOf(-8.428),history.get(2).cost); - Assert.assertEquals("travelDistance is not as expected ",Double.valueOf(10000.0),history.get(2).travelDistance); - Assert.assertEquals("travelTime is not as expected ",Double.valueOf(-1641.0),history.get(2).travelTime); - Assert.assertEquals("driverId is not as expected ",driverId_1,history.get(2).driverId); + Assertions.assertEquals(Double.valueOf(-8.428),history.get(2).cost,"cost is not as expected "); + Assertions.assertEquals(Double.valueOf(10000.0),history.get(2).travelDistance,"travelDistance is not as expected "); + Assertions.assertEquals(Double.valueOf(-1641.0),history.get(2).travelTime,"travelTime is not as expected "); + Assertions.assertEquals(driverId_1,history.get(2).driverId,"driverId is not as expected "); } } @@ -254,40 +254,40 @@ void runServiceTrackerTest(){ if(key.equals(carrierId)){ ServiceTracker.CarrierServiceTracker serviceTracker = carrierServiceTracker.get(key); System.out.println(serviceTracker.serviceTrackers.get(carrierServiceId1).calculatedArrival); - Assert.assertEquals("tourETA is not as expected ",Double.valueOf(24032.0),serviceTracker.serviceTrackers.get(carrierServiceId1).calculatedArrival); - Assert.assertEquals("arrivalTime is not as expected ",Double.valueOf(24405.0),serviceTracker.serviceTrackers.get(carrierServiceId1).arrivalTimeGuess); - Assert.assertEquals("driverId is not as expected ",person_0,serviceTracker.serviceTrackers.get(carrierServiceId1).driverIdGuess); - Assert.assertEquals("serviceETA is not as expected ", Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId1).expectedArrival)); - - Assert.assertEquals("tourETA is not as expected ",Double.valueOf(23766.0),serviceTracker.serviceTrackers.get(carrierServiceId11).calculatedArrival); - Assert.assertEquals("arrivalTime is not as expected ",Double.valueOf(23777.0),serviceTracker.serviceTrackers.get(carrierServiceId11).arrivalTimeGuess); - Assert.assertEquals("driverId is not as expected ",person_1,serviceTracker.serviceTrackers.get(carrierServiceId11).driverIdGuess); - Assert.assertEquals("serviceETA is not as expected ", Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId11).expectedArrival)); - - Assert.assertEquals("tourETA is not as expected ",Double.valueOf(25566.0),serviceTracker.serviceTrackers.get(carrierServiceId12).calculatedArrival); - Assert.assertEquals("arrivalTime is not as expected ",Double.valueOf(25945.0),serviceTracker.serviceTrackers.get(carrierServiceId12).arrivalTimeGuess); - Assert.assertEquals("driverId is not as expected ",person_0,serviceTracker.serviceTrackers.get(carrierServiceId12).driverIdGuess); - Assert.assertEquals("serviceETA is not as expected ", Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId12).expectedArrival)); - - Assert.assertEquals("tourETA is not as expected ",Double.valueOf(22533.0),serviceTracker.serviceTrackers.get(carrierServiceId13).calculatedArrival); - Assert.assertEquals("arrivalTime is not as expected ",Double.valueOf(22538.0),serviceTracker.serviceTrackers.get(carrierServiceId13).arrivalTimeGuess); - Assert.assertEquals("driverId is not as expected ",person_1,serviceTracker.serviceTrackers.get(carrierServiceId13).driverIdGuess); - Assert.assertEquals("serviceETA is not as expected ", Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId13).expectedArrival)); - - Assert.assertEquals("tourETA is not as expected ",Double.valueOf(23066.0),serviceTracker.serviceTrackers.get(carrierServiceId14).calculatedArrival); - Assert.assertEquals("arrivalTime is not as expected ",Double.valueOf(23434.0),serviceTracker.serviceTrackers.get(carrierServiceId14).arrivalTimeGuess); - Assert.assertEquals("driverId is not as expected ",person_0,serviceTracker.serviceTrackers.get(carrierServiceId14).driverIdGuess); - Assert.assertEquals("serviceETA is not as expected ", Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId14).expectedArrival)); - - Assert.assertEquals("tourETA is not as expected ",Double.valueOf(26399.0),serviceTracker.serviceTrackers.get(carrierServiceId15).calculatedArrival); - Assert.assertEquals("arrivalTime is not as expected ",Double.valueOf(26782.0),serviceTracker.serviceTrackers.get(carrierServiceId15).arrivalTimeGuess); - Assert.assertEquals("driverId is not as expected ",person_0,serviceTracker.serviceTrackers.get(carrierServiceId15).driverIdGuess); - Assert.assertEquals("serviceETA is not as expected ", Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId15).expectedArrival)); - - Assert.assertEquals("tourETA is not as expected ",Double.valueOf(24732.0),serviceTracker.serviceTrackers.get(carrierServiceId16).calculatedArrival); - Assert.assertEquals("arrivalTime is not as expected ",Double.valueOf(25108.0),serviceTracker.serviceTrackers.get(carrierServiceId16).arrivalTimeGuess); - Assert.assertEquals("driverId is not as expected ",person_0,serviceTracker.serviceTrackers.get(carrierServiceId16).driverIdGuess); - Assert.assertEquals("serviceETA is not as expected ", Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId16).expectedArrival)); + Assertions.assertEquals(Double.valueOf(24032.0),serviceTracker.serviceTrackers.get(carrierServiceId1).calculatedArrival,"tourETA is not as expected "); + Assertions.assertEquals(Double.valueOf(24405.0),serviceTracker.serviceTrackers.get(carrierServiceId1).arrivalTimeGuess,"arrivalTime is not as expected "); + Assertions.assertEquals(person_0,serviceTracker.serviceTrackers.get(carrierServiceId1).driverIdGuess,"driverId is not as expected "); + Assertions.assertEquals(Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId1).expectedArrival), "serviceETA is not as expected "); + + Assertions.assertEquals(Double.valueOf(23766.0),serviceTracker.serviceTrackers.get(carrierServiceId11).calculatedArrival,"tourETA is not as expected "); + Assertions.assertEquals(Double.valueOf(23777.0),serviceTracker.serviceTrackers.get(carrierServiceId11).arrivalTimeGuess,"arrivalTime is not as expected "); + Assertions.assertEquals(person_1,serviceTracker.serviceTrackers.get(carrierServiceId11).driverIdGuess,"driverId is not as expected "); + Assertions.assertEquals(Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId11).expectedArrival), "serviceETA is not as expected "); + + Assertions.assertEquals(Double.valueOf(25566.0),serviceTracker.serviceTrackers.get(carrierServiceId12).calculatedArrival,"tourETA is not as expected "); + Assertions.assertEquals(Double.valueOf(25945.0),serviceTracker.serviceTrackers.get(carrierServiceId12).arrivalTimeGuess,"arrivalTime is not as expected "); + Assertions.assertEquals(person_0,serviceTracker.serviceTrackers.get(carrierServiceId12).driverIdGuess,"driverId is not as expected "); + Assertions.assertEquals(Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId12).expectedArrival), "serviceETA is not as expected "); + + Assertions.assertEquals(Double.valueOf(22533.0),serviceTracker.serviceTrackers.get(carrierServiceId13).calculatedArrival,"tourETA is not as expected "); + Assertions.assertEquals(Double.valueOf(22538.0),serviceTracker.serviceTrackers.get(carrierServiceId13).arrivalTimeGuess,"arrivalTime is not as expected "); + Assertions.assertEquals(person_1,serviceTracker.serviceTrackers.get(carrierServiceId13).driverIdGuess,"driverId is not as expected "); + Assertions.assertEquals(Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId13).expectedArrival), "serviceETA is not as expected "); + + Assertions.assertEquals(Double.valueOf(23066.0),serviceTracker.serviceTrackers.get(carrierServiceId14).calculatedArrival,"tourETA is not as expected "); + Assertions.assertEquals(Double.valueOf(23434.0),serviceTracker.serviceTrackers.get(carrierServiceId14).arrivalTimeGuess,"arrivalTime is not as expected "); + Assertions.assertEquals(person_0,serviceTracker.serviceTrackers.get(carrierServiceId14).driverIdGuess,"driverId is not as expected "); + Assertions.assertEquals(Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId14).expectedArrival), "serviceETA is not as expected "); + + Assertions.assertEquals(Double.valueOf(26399.0),serviceTracker.serviceTrackers.get(carrierServiceId15).calculatedArrival,"tourETA is not as expected "); + Assertions.assertEquals(Double.valueOf(26782.0),serviceTracker.serviceTrackers.get(carrierServiceId15).arrivalTimeGuess,"arrivalTime is not as expected "); + Assertions.assertEquals(person_0,serviceTracker.serviceTrackers.get(carrierServiceId15).driverIdGuess,"driverId is not as expected "); + Assertions.assertEquals(Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId15).expectedArrival), "serviceETA is not as expected "); + + Assertions.assertEquals(Double.valueOf(24732.0),serviceTracker.serviceTrackers.get(carrierServiceId16).calculatedArrival,"tourETA is not as expected "); + Assertions.assertEquals(Double.valueOf(25108.0),serviceTracker.serviceTrackers.get(carrierServiceId16).arrivalTimeGuess,"arrivalTime is not as expected "); + Assertions.assertEquals(person_0,serviceTracker.serviceTrackers.get(carrierServiceId16).driverIdGuess,"driverId is not as expected "); + Assertions.assertEquals(Double.valueOf(0.0), Double.valueOf(serviceTracker.serviceTrackers.get(carrierServiceId16).expectedArrival), "serviceETA is not as expected "); } } } diff --git a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java index c96930e1f1f..45ec87629d4 100644 --- a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java +++ b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisWithShipmentTest.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers.analysis; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -93,12 +93,12 @@ void runShipmentTrackerTest(){ System.out.println("from "+fromLinkId+" to "+toLinkId+" distance is "+dist); } - Assert.assertEquals("Beeline distance is not as expected for shipment 1",Double.valueOf(10816.653826391968),beelineDistance.get(Id.create( "1", CarrierShipment.class ))); - Assert.assertEquals("Beeline distance is not as expected for shipment 11",Double.valueOf(6000.0),beelineDistance.get(Id.create( "11", CarrierShipment.class ))); - Assert.assertEquals("Beeline distance is not as expected for shipment 12",Double.valueOf(7106.335201775948),beelineDistance.get(Id.create( "12", CarrierShipment.class ))); - Assert.assertEquals("Beeline distance is not as expected for shipment 13",Double.valueOf(4123.105625617661),beelineDistance.get(Id.create( "13", CarrierShipment.class ))); - Assert.assertEquals("Beeline distance is not as expected for shipment 14",Double.valueOf(9055.385138137417),beelineDistance.get(Id.create( "14", CarrierShipment.class ))); - Assert.assertEquals("Beeline distance is not as expected for shipment 15",Double.valueOf(6964.19413859206),beelineDistance.get(Id.create( "15", CarrierShipment.class ))); - Assert.assertEquals("Beeline distance is not as expected for shipment 16",Double.valueOf(9192.388155425118),beelineDistance.get(Id.create( "16", CarrierShipment.class ))); + Assertions.assertEquals(Double.valueOf(10816.653826391968),beelineDistance.get(Id.create( "1", CarrierShipment.class )),"Beeline distance is not as expected for shipment 1"); + Assertions.assertEquals(Double.valueOf(6000.0),beelineDistance.get(Id.create( "11", CarrierShipment.class )),"Beeline distance is not as expected for shipment 11"); + Assertions.assertEquals(Double.valueOf(7106.335201775948),beelineDistance.get(Id.create( "12", CarrierShipment.class )),"Beeline distance is not as expected for shipment 12"); + Assertions.assertEquals(Double.valueOf(4123.105625617661),beelineDistance.get(Id.create( "13", CarrierShipment.class )),"Beeline distance is not as expected for shipment 13"); + Assertions.assertEquals(Double.valueOf(9055.385138137417),beelineDistance.get(Id.create( "14", CarrierShipment.class )),"Beeline distance is not as expected for shipment 14"); + Assertions.assertEquals(Double.valueOf(6964.19413859206),beelineDistance.get(Id.create( "15", CarrierShipment.class )),"Beeline distance is not as expected for shipment 15"); + Assertions.assertEquals(Double.valueOf(9192.388155425118),beelineDistance.get(Id.create( "16", CarrierShipment.class )),"Beeline distance is not as expected for shipment 16"); } } diff --git a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java index 8bd5209f135..89d9446b529 100644 --- a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java +++ b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java @@ -9,8 +9,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -469,9 +469,9 @@ public void install() { .filter(pe -> pe instanceof Leg) .map(pe -> (Leg)pe) .collect(toList()); - Assert.assertTrue("Incorrect Mode, case 1", planLegCase1.get(0).getMode().contains("walk")); - Assert.assertTrue("Incorrect Mode, case 1", planLegCase1.get(1).getMode().equals("pt")); - Assert.assertTrue("Incorrect Mode, case 1", planLegCase1.get(2).getMode().contains("walk")); + Assertions.assertTrue(planLegCase1.get(0).getMode().contains("walk"), "Incorrect Mode, case 1"); + Assertions.assertTrue(planLegCase1.get(1).getMode().equals("pt"), "Incorrect Mode, case 1"); + Assertions.assertTrue(planLegCase1.get(2).getMode().contains("walk"), "Incorrect Mode, case 1"); /** * Case 2a: Agent starts at Link "50-51". This is within the drt service area. Agent is expected use drt as @@ -488,11 +488,11 @@ public void install() { .filter(pe -> pe instanceof Leg) .map(pe -> (Leg)pe) .collect(toList()); - Assert.assertTrue("Incorrect Mode, case 2a", planLegCase2a.get(0).getMode().contains("walk")); - Assert.assertTrue("Incorrect Mode, case 2a", planLegCase2a.get(1).getMode().equals("drt")); - Assert.assertTrue("Incorrect Mode, case 2a", planLegCase2a.get(2).getMode().contains("walk")); - Assert.assertTrue("Incorrect Mode, case 2a", planLegCase2a.get(3).getMode().equals("pt")); - Assert.assertTrue("Incorrect Mode, case 2a", planLegCase2a.get(4).getMode().contains("walk")); + Assertions.assertTrue(planLegCase2a.get(0).getMode().contains("walk"), "Incorrect Mode, case 2a"); + Assertions.assertTrue(planLegCase2a.get(1).getMode().equals("drt"), "Incorrect Mode, case 2a"); + Assertions.assertTrue(planLegCase2a.get(2).getMode().contains("walk"), "Incorrect Mode, case 2a"); + Assertions.assertTrue(planLegCase2a.get(3).getMode().equals("pt"), "Incorrect Mode, case 2a"); + Assertions.assertTrue(planLegCase2a.get(4).getMode().contains("walk"), "Incorrect Mode, case 2a"); /** * Case 2b: Agent starts at Link "300-301". This is within the drt service area. Agent is expected use drt as @@ -508,11 +508,11 @@ public void install() { .filter(pe -> pe instanceof Leg) .map(pe -> (Leg)pe) .collect(toList()); - Assert.assertTrue("Incorrect Mode, case 2b", planLegCase2b.get(0).getMode().contains("walk")); - Assert.assertTrue("Incorrect Mode, case 2b", planLegCase2b.get(1).getMode().equals("drt")); - Assert.assertTrue("Incorrect Mode, case 2b", planLegCase2b.get(2).getMode().contains("walk")); - Assert.assertTrue("Incorrect Mode, case 2b", planLegCase2b.get(3).getMode().equals("pt")); - Assert.assertTrue("Incorrect Mode, case 2b", planLegCase2b.get(4).getMode().contains("walk")); + Assertions.assertTrue(planLegCase2b.get(0).getMode().contains("walk"), "Incorrect Mode, case 2b"); + Assertions.assertTrue(planLegCase2b.get(1).getMode().equals("drt"), "Incorrect Mode, case 2b"); + Assertions.assertTrue(planLegCase2b.get(2).getMode().contains("walk"), "Incorrect Mode, case 2b"); + Assertions.assertTrue(planLegCase2b.get(3).getMode().equals("pt"), "Incorrect Mode, case 2b"); + Assertions.assertTrue(planLegCase2b.get(4).getMode().contains("walk"), "Incorrect Mode, case 2b"); /** * Case 2c: Agent starts at Link "550-551". This is within the drt3 service area. Agent is expected use drt3 as @@ -528,11 +528,11 @@ public void install() { .filter(pe -> pe instanceof Leg) .map(pe -> (Leg)pe) .collect(toList()); - Assert.assertTrue("Incorrect Mode, case 2c", planLegCase2c.get(0).getMode().contains("walk")); - Assert.assertTrue("Incorrect Mode, case 2c", planLegCase2c.get(1).getMode().equals("drt3")); - Assert.assertTrue("Incorrect Mode, case 2c", planLegCase2c.get(2).getMode().contains("walk")); - Assert.assertTrue("Incorrect Mode, case 2c", planLegCase2c.get(3).getMode().equals("pt")); - Assert.assertTrue("Incorrect Mode, case 2c", planLegCase2c.get(4).getMode().contains("walk")); + Assertions.assertTrue(planLegCase2c.get(0).getMode().contains("walk"), "Incorrect Mode, case 2c"); + Assertions.assertTrue(planLegCase2c.get(1).getMode().equals("drt3"), "Incorrect Mode, case 2c"); + Assertions.assertTrue(planLegCase2c.get(2).getMode().contains("walk"), "Incorrect Mode, case 2c"); + Assertions.assertTrue(planLegCase2c.get(3).getMode().equals("pt"), "Incorrect Mode, case 2c"); + Assertions.assertTrue(planLegCase2c.get(4).getMode().contains("walk"), "Incorrect Mode, case 2c"); /** * Case 3a: Agent starts at Link "690-691". This is not within any drt service areas. Agent is expected to use @@ -548,7 +548,7 @@ public void install() { .filter(pe -> pe instanceof Leg) .map(pe -> (Leg)pe) .collect(toList()); - Assert.assertTrue("Incorrect Mode, case 3a", planLegCase3a.get(0).getMode().equals("walk")); + Assertions.assertTrue(planLegCase3a.get(0).getMode().equals("walk"), "Incorrect Mode, case 3a"); /** * Case 3b: Agent starts at Link "800-801". This is within the drt2 service area. Agent is NOT expected to utilize @@ -565,7 +565,7 @@ public void install() { .filter(pe -> pe instanceof Leg) .map(pe -> (Leg)pe) .collect(toList()); - Assert.assertTrue("Incorrect Mode, case 3b", planLegCase3b.get(0).getMode().equals("walk")); + Assertions.assertTrue(planLegCase3b.get(0).getMode().equals("walk"), "Incorrect Mode, case 3b"); } @@ -727,7 +727,7 @@ public void notifyIterationEnds(IterationEndsEvent event) { break; } } - Assert.assertFalse(problem); + Assertions.assertFalse(problem); } } diff --git a/contribs/vsp/src/test/java/playground/vsp/airPollution/flatEmissions/EmissionCostFactorsTest.java b/contribs/vsp/src/test/java/playground/vsp/airPollution/flatEmissions/EmissionCostFactorsTest.java index ed62c664a9f..f81f2ac9990 100644 --- a/contribs/vsp/src/test/java/playground/vsp/airPollution/flatEmissions/EmissionCostFactorsTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/airPollution/flatEmissions/EmissionCostFactorsTest.java @@ -1,7 +1,7 @@ package playground.vsp.airPollution.flatEmissions; -import static org.junit.Assert.fail; import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.fail; import static playground.vsp.airPollution.flatEmissions.EmissionCostFactors.NOx; import org.junit.jupiter.api.Test; diff --git a/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestColdEmissionHandler.java b/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestColdEmissionHandler.java index a0c00826bc0..b3b4eca91ca 100644 --- a/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestColdEmissionHandler.java +++ b/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestColdEmissionHandler.java @@ -23,7 +23,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -112,20 +112,18 @@ final void testEmissionPerPersonColdEventHandler(){ actualPM2 = cepp.get( Id.create("v2", Person.class ) ).get( Pollutant.PM ); // assert that values were set correctly - Assert.assertEquals("CO of vehicle 1 should be 17.1 but was "+actualCO1, new Double(17.1), actualCO1, MatsimTestUtils.EPSILON); - Assert.assertEquals("NOx of vehicle 1 should be 44.1 but was "+actualNOx1, new Double(44.1), actualNOx1, MatsimTestUtils.EPSILON); - Assert.assertEquals("PM of vehicle 1 should be 0 but was " +actualPM1, new Double(0.0), actualPM1, MatsimTestUtils.EPSILON); - Assert.assertEquals("CO of vehicle 2 should be 23.9 but was " +actualCO2, new Double(23.9), actualCO2, MatsimTestUtils.EPSILON); - Assert.assertEquals("NOx of vehicle 2 should be 0 but was " +actualNOx2 , new Double(0.0), actualNOx2, MatsimTestUtils.EPSILON); - Assert.assertEquals("PM of vehicle 2 should be 18.1 but was " +actualPM2, new Double(18.1), actualPM2, MatsimTestUtils.EPSILON); + Assertions.assertEquals(new Double(17.1), actualCO1, MatsimTestUtils.EPSILON, "CO of vehicle 1 should be 17.1 but was "+actualCO1); + Assertions.assertEquals(new Double(44.1), actualNOx1, MatsimTestUtils.EPSILON, "NOx of vehicle 1 should be 44.1 but was "+actualNOx1); + Assertions.assertEquals(new Double(0.0), actualPM1, MatsimTestUtils.EPSILON, "PM of vehicle 1 should be 0 but was " +actualPM1); + Assertions.assertEquals(new Double(23.9), actualCO2, MatsimTestUtils.EPSILON, "CO of vehicle 2 should be 23.9 but was " +actualCO2); + Assertions.assertEquals(new Double(0.0), actualNOx2, MatsimTestUtils.EPSILON, "NOx of vehicle 2 should be 0 but was " +actualNOx2); + Assertions.assertEquals(new Double(18.1), actualPM2, MatsimTestUtils.EPSILON, "PM of vehicle 2 should be 18.1 but was " +actualPM2); // nothing else in the map - Assert.assertEquals("There should be two types of emissions in this map but " + - "there were " + cepp.get(Id.create("v1", Person.class)).size()+".", - 2, cepp.get(Id.create("v1", Person.class)).keySet().size()); - Assert.assertEquals("There should be two types of emissions in this map but " + - "there were " + cepp.get(Id.create("v2", Person.class)).size()+".", - 2, cepp.get(Id.create("v2", Person.class)).keySet().size()); + Assertions.assertEquals(2, cepp.get(Id.create("v1", Person.class)).keySet().size(), "There should be two types of emissions in this map but " + + "there were " + cepp.get(Id.create("v1", Person.class)).size()+"."); + Assertions.assertEquals(2, cepp.get(Id.create("v2", Person.class)).keySet().size(), "There should be two types of emissions in this map but " + + "there were " + cepp.get(Id.create("v2", Person.class)).size()+"."); } } diff --git a/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestWarmEmissionHandler.java b/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestWarmEmissionHandler.java index de5e284c121..e09f1e3642b 100644 --- a/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestWarmEmissionHandler.java +++ b/contribs/vsp/src/test/java/playground/vsp/analysis/modules/emissions/TestWarmEmissionHandler.java @@ -23,7 +23,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -107,56 +107,56 @@ final void testEmissionPerPersonWarmEventHandler(){ if(wepp.get(Id.create("v1", Person.class)).containsKey( Pollutant.CO )){ // return key; Double actualCO1 = wepp.get(Id.create("v1", Person.class)).get( Pollutant.CO ); - Assert.assertEquals("CO of vehicle 1 should be 17.1 but was "+actualCO1, 17.1, actualCO1, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(17.1, actualCO1, MatsimTestUtils.EPSILON, "CO of vehicle 1 should be 17.1 but was "+actualCO1 ); }else{ - Assert.fail("No CO values for car 1 found."); + Assertions.fail("No CO values for car 1 found."); } //NOx vehicle 1 // return key; if(wepp.get(Id.create("v1", Person.class)).containsKey( Pollutant.NOx )){ // return key; Double actualNOx1 = wepp.get(Id.create("v1", Person.class)).get( Pollutant.NOx ); - Assert.assertEquals("NOx of vehicle 1 should be 44.1 but was "+actualNOx1, 44.1, actualNOx1, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(44.1, actualNOx1, MatsimTestUtils.EPSILON, "NOx of vehicle 1 should be 44.1 but was "+actualNOx1 ); }else{ - Assert.fail("No NOx values for car 1 found."); + Assertions.fail("No NOx values for car 1 found."); } //PM vehicle 1 // return key; if(wepp.get(Id.create("v1", Person.class)).containsKey( Pollutant.PM )){ - Assert.fail("There should be no PM values for car 1."); + Assertions.fail("There should be no PM values for car 1."); }else{ // return key; - Assert.assertNull("PM of vehicle 1 should be null.",wepp.get(Id.create("v1", Person.class)).get( Pollutant.PM ) ); + Assertions.assertNull(wepp.get(Id.create("v1", Person.class)).get( Pollutant.PM ),"PM of vehicle 1 should be null." ); } //CO vehicle 2 // return key; if(wepp.get(Id.create("v2", Person.class)).containsKey( Pollutant.CO )){ // return key; Double actualCO2 = wepp.get(Id.create("v2", Person.class)).get( Pollutant.CO ); - Assert.assertEquals("CO of vehicle 2 should be 23.9", 23.9, actualCO2, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(23.9, actualCO2, MatsimTestUtils.EPSILON, "CO of vehicle 2 should be 23.9" ); }else{ - Assert.fail("No CO values for car 2 found."); + Assertions.fail("No CO values for car 2 found."); } //NOx vehicle 2 // return key; if(wepp.get(Id.create("v2", Person.class)).containsKey( Pollutant.NOx )){ - Assert.fail("There should be no NOx values for car 2."); + Assertions.fail("There should be no NOx values for car 2."); }else{ // return key; - Assert.assertNull(wepp.get(Id.create("v2", Person.class)).get( Pollutant.NOx ) ); + Assertions.assertNull(wepp.get(Id.create("v2", Person.class)).get( Pollutant.NOx ) ); } //PM vehicle 2 // return key; if(wepp.get(Id.create("v2", Person.class)).containsKey( Pollutant.PM )){ // return key; Double actualPM2 = wepp.get(Id.create("v2", Person.class)).get( Pollutant.PM ); - Assert.assertEquals("PM of vehicle 2 should be 18.1", 18.1, actualPM2, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(18.1, actualPM2, MatsimTestUtils.EPSILON, "PM of vehicle 2 should be 18.1" ); }else{ - Assert.fail("No PM values for car 2 found."); + Assertions.fail("No PM values for car 2 found."); } //FC // return key; - Assert.assertNull(wepp.get(Id.create("v1", Person.class)).get( Pollutant.FC ) ); + Assertions.assertNull(wepp.get(Id.create("v1", Person.class)).get( Pollutant.FC ) ); } } diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapDataTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapDataTest.java index f63bcbb2fd4..f76c55e41b6 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapDataTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapDataTest.java @@ -1,6 +1,6 @@ package playground.vsp.andreas.bvgAna.level1; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -36,8 +36,8 @@ void testAgentId2DepartureDelayAtStopMapData() { // run tests for 1 event each, can be expanded later if needed - Assert.assertEquals((Double)event3.getTime(), data.getAgentDepartsPTInteraction().get(0)); - Assert.assertEquals((Double)event1.getTime(), data.getAgentEntersVehicle().get(0)); + Assertions.assertEquals((Double)event3.getTime(), data.getAgentDepartsPTInteraction().get(0)); + Assertions.assertEquals((Double)event1.getTime(), data.getAgentEntersVehicle().get(0)); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapTest.java index c50c5e0c285..cab543e4e4a 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2DepartureDelayAtStopMapTest.java @@ -3,7 +3,7 @@ import java.util.Set; import java.util.TreeSet; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -49,11 +49,11 @@ void testAgentId2DepartureDelayAtStopMap() { // run tests - Assert.assertTrue(handler.getStopId2DelayAtStopMap().containsKey(persId1)); - Assert.assertEquals(event3.getTime(), handler.getStopId2DelayAtStopMap().get(persId1).getAgentEntersVehicle().get(0), 0); + Assertions.assertTrue(handler.getStopId2DelayAtStopMap().containsKey(persId1)); + Assertions.assertEquals(event3.getTime(), handler.getStopId2DelayAtStopMap().get(persId1).getAgentEntersVehicle().get(0), 0); - Assert.assertTrue(handler.getStopId2DelayAtStopMap().containsKey(persId2)); - Assert.assertEquals(event4.getTime(), handler.getStopId2DelayAtStopMap().get(persId2).getAgentEntersVehicle().get(0), 0); + Assertions.assertTrue(handler.getStopId2DelayAtStopMap().containsKey(persId2)); + Assertions.assertEquals(event4.getTime(), handler.getStopId2DelayAtStopMap().get(persId2).getAgentEntersVehicle().get(0), 0); } diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2EnterLeaveVehicleEventHandlerTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2EnterLeaveVehicleEventHandlerTest.java index e82f75ca5ec..bab302aa082 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2EnterLeaveVehicleEventHandlerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2EnterLeaveVehicleEventHandlerTest.java @@ -3,7 +3,7 @@ import java.util.Set; import java.util.TreeSet; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonEntersVehicleEvent; @@ -55,12 +55,12 @@ void testAgentId2EnterLeaveVehicleEventHandler() { // run tests - Assert.assertSame(event1, handler.getAgentId2EnterEventMap().get(persId1).get(0)); - Assert.assertSame(event2, handler.getAgentId2EnterEventMap().get(persId2).get(0)); - Assert.assertSame(event3, handler.getAgentId2EnterEventMap().get(persId3).get(0)); - Assert.assertSame(event4, handler.getAgentId2LeaveEventMap().get(persId1).get(0)); - Assert.assertSame(event5, handler.getAgentId2LeaveEventMap().get(persId2).get(0)); - Assert.assertSame(event6, handler.getAgentId2LeaveEventMap().get(persId3).get(0)); + Assertions.assertSame(event1, handler.getAgentId2EnterEventMap().get(persId1).get(0)); + Assertions.assertSame(event2, handler.getAgentId2EnterEventMap().get(persId2).get(0)); + Assertions.assertSame(event3, handler.getAgentId2EnterEventMap().get(persId3).get(0)); + Assertions.assertSame(event4, handler.getAgentId2LeaveEventMap().get(persId1).get(0)); + Assertions.assertSame(event5, handler.getAgentId2LeaveEventMap().get(persId2).get(0)); + Assertions.assertSame(event6, handler.getAgentId2LeaveEventMap().get(persId3).get(0)); } diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapDataTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapDataTest.java index 3559c2d3082..6930924b935 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapDataTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapDataTest.java @@ -22,7 +22,7 @@ import java.util.Set; import java.util.TreeSet; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -71,9 +71,9 @@ void testAgentId2PtTripTravelTimeMapData() { System.out.println("Number of Transfers should be: 1 and are: "+test.getNumberOfTransfers()); System.out.println("Total travel time should be: "+(event6.getTime()-event5.getTime()+event4.getTime()-event3.getTime())+" and is: "+test.getTotalTripTravelTime()); - Assert.assertEquals(event6.getTime()-event5.getTime()+event4.getTime()-event3.getTime(), test.getTotalTripTravelTime(), 0.); + Assertions.assertEquals(event6.getTime()-event5.getTime()+event4.getTime()-event3.getTime(), test.getTotalTripTravelTime(), 0.); - Assert.assertEquals(1, test.getNumberOfTransfers()); + Assertions.assertEquals(1, test.getNumberOfTransfers()); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapTest.java index 2adbd8450ef..579a4684a1f 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/AgentId2PtTripTravelTimeMapTest.java @@ -5,7 +5,7 @@ import java.util.TreeMap; import java.util.TreeSet; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -68,7 +68,7 @@ void testAgentId2PtTripTravelTimeMap() { // first tests, this works - Assert.assertEquals(event4.getTime()-event3.getTime(), test.getAgentId2PtTripTravelTimeMap().get(agentId1).get(0).getTotalTripTravelTime(), 0.); + Assertions.assertEquals(event4.getTime()-event3.getTime(), test.getAgentId2PtTripTravelTimeMap().get(agentId1).get(0).getTotalTripTravelTime(), 0.); } diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/PersonEnterLeaveVehicle2ActivityHandlerTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/PersonEnterLeaveVehicle2ActivityHandlerTest.java index 58f13965d0d..cfd4af07243 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/PersonEnterLeaveVehicle2ActivityHandlerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/PersonEnterLeaveVehicle2ActivityHandlerTest.java @@ -3,7 +3,7 @@ import java.util.Set; import java.util.TreeSet; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; import org.matsim.api.core.v01.events.ActivityStartEvent; @@ -56,7 +56,7 @@ public void testPersonEnterLeaveVehicle2ActivityHandler() { test.handleEvent(event6); test.handleEvent(event7); - Assert.assertEquals(event0, test.getPersonEntersVehicleEvent2ActivityEndEvent().get(event1)); + Assertions.assertEquals(event0, test.getPersonEntersVehicleEvent2ActivityEndEvent().get(event1)); System.out.println(test.getPersonEntersVehicleEvent2ActivityEndEvent().toString()); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java index 5160fbce497..1b4a71190da 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java @@ -1,7 +1,7 @@ package playground.vsp.andreas.bvgAna.level1; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; @@ -57,7 +57,7 @@ void testStopId2LineId2Pulk() { * */ - Assert.assertEquals(event2, test.getStopId2LineId2PulkDataList().get(event2.getFacilityId()).get(event2.getVehicleId())); + Assertions.assertEquals(event2, test.getStopId2LineId2PulkDataList().get(event2.getFacilityId()).get(event2.getVehicleId())); System.out.println(test.getStopId2LineId2PulkDataList().get(event2.getFacilityId()).get(event2.getVehicleId())); System.out.println(event2.getVehicleId()); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2RouteId2DelayAtStopMapTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2RouteId2DelayAtStopMapTest.java index 6205ab72888..0fed35941f5 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2RouteId2DelayAtStopMapTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2RouteId2DelayAtStopMapTest.java @@ -1,6 +1,6 @@ package playground.vsp.andreas.bvgAna.level1; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; @@ -57,11 +57,11 @@ void testStopId2RouteId2DelayAtStopMap() { // // System.out.println(test.getStopId2RouteId2DelayAtStopMap().get(event1.getFacilityId()).get(transitRouteId1).getLineId()); - Assert.assertEquals(transitLineId1, test.getStopId2RouteId2DelayAtStopMap().get(event1.getFacilityId()).get(transitRouteId1).getLineId()); + Assertions.assertEquals(transitLineId1, test.getStopId2RouteId2DelayAtStopMap().get(event1.getFacilityId()).get(transitRouteId1).getLineId()); - Assert.assertEquals(transitRouteId1, test.getStopId2RouteId2DelayAtStopMap().get(event1.getFacilityId()).get(transitRouteId1).getRouteId()); + Assertions.assertEquals(transitRouteId1, test.getStopId2RouteId2DelayAtStopMap().get(event1.getFacilityId()).get(transitRouteId1).getRouteId()); - Assert.assertEquals(1, test.getStopId2RouteId2DelayAtStopMap().get(event1.getFacilityId()).get(transitRouteId1).getRealizedDepartures().size()); + Assertions.assertEquals(1, test.getStopId2RouteId2DelayAtStopMap().get(event1.getFacilityId()).get(transitRouteId1).getRealizedDepartures().size()); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapDataTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapDataTest.java index 720bf61b615..878dd29fa66 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapDataTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapDataTest.java @@ -1,6 +1,6 @@ package playground.vsp.andreas.bvgAna.level1; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; @@ -39,7 +39,7 @@ void testVehId2DelayAtStopMapData() { // testing - Assert.assertNotNull(mapData); + Assertions.assertNotNull(mapData); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapTest.java index 3621a8081cd..83c89e0e04b 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2DelayAtStopMapTest.java @@ -3,7 +3,7 @@ import java.util.LinkedList; import java.util.TreeMap; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; @@ -92,11 +92,11 @@ void testVehId2DelayAtStopMap() { // testing if first and last entries match - Assert.assertEquals(data.get(vehId1).getFirst().toString(), testMap.getVehId2DelayAtStopMap().get(vehId1).getFirst().toString()); - Assert.assertEquals(data.get(vehId2).getFirst().toString(), testMap.getVehId2DelayAtStopMap().get(vehId2).getFirst().toString()); + Assertions.assertEquals(data.get(vehId1).getFirst().toString(), testMap.getVehId2DelayAtStopMap().get(vehId1).getFirst().toString()); + Assertions.assertEquals(data.get(vehId2).getFirst().toString(), testMap.getVehId2DelayAtStopMap().get(vehId2).getFirst().toString()); - Assert.assertEquals(data.get(vehId1).getLast().toString(), testMap.getVehId2DelayAtStopMap().get(vehId1).getLast().toString()); - Assert.assertEquals(data.get(vehId2).getLast().toString(), testMap.getVehId2DelayAtStopMap().get(vehId2).getLast().toString()); + Assertions.assertEquals(data.get(vehId1).getLast().toString(), testMap.getVehId2DelayAtStopMap().get(vehId1).getLast().toString()); + Assertions.assertEquals(data.get(vehId2).getLast().toString(), testMap.getVehId2DelayAtStopMap().get(vehId2).getLast().toString()); } diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2OccupancyHandlerTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2OccupancyHandlerTest.java index de708843b22..2b368ad22be 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2OccupancyHandlerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2OccupancyHandlerTest.java @@ -1,8 +1,8 @@ package playground.vsp.andreas.bvgAna.level1; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import playground.vsp.andreas.bvgAna.level1.VehId2OccupancyHandler; @@ -15,7 +15,7 @@ void testVehId2OccupancyHandler() { // to be implemented - Assert.assertNotNull(test); + Assertions.assertNotNull(test); } diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2PersonEnterLeaveVehicleMapTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2PersonEnterLeaveVehicleMapTest.java index 26a36b3e80b..4a2fcc748bd 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2PersonEnterLeaveVehicleMapTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/VehId2PersonEnterLeaveVehicleMapTest.java @@ -3,7 +3,7 @@ import java.util.ArrayList; import java.util.TreeMap; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.PersonEntersVehicleEvent; @@ -59,17 +59,17 @@ void testVehId2PersonEnterLeaveVehicleMap() { // test // Assert.assertEquals(enter.get(vehId1).get(0), test.getVehId2PersonEnterEventMap().get(vehId1).get(0)); - Assert.assertEquals(event1.getTime(), test.getVehId2PersonEnterEventMap().get(vehId1).get(0).getTime(), 0.); + Assertions.assertEquals(event1.getTime(), test.getVehId2PersonEnterEventMap().get(vehId1).get(0).getTime(), 0.); // Assert.assertEquals(enter.get(vehId1).get(1), test.getVehId2PersonEnterEventMap().get(vehId1).get(1)); - Assert.assertEquals(event2.getTime(), test.getVehId2PersonEnterEventMap().get(vehId1).get(1).getTime(), 0.); + Assertions.assertEquals(event2.getTime(), test.getVehId2PersonEnterEventMap().get(vehId1).get(1).getTime(), 0.); // Assert.assertEquals(leave.get(vehId2).get(0), test.getVehId2PersonLeaveEventMap().get(vehId2).get(0)); - Assert.assertEquals(event3.getTime(), test.getVehId2PersonLeaveEventMap().get(vehId2).get(0).getTime(), 0.); + Assertions.assertEquals(event3.getTime(), test.getVehId2PersonLeaveEventMap().get(vehId2).get(0).getTime(), 0.); // Assert.assertEquals(leave.get(vehId2).get(1), test.getVehId2PersonLeaveEventMap().get(vehId2).get(1)); - Assert.assertEquals(event4.getTime(), test.getVehId2PersonLeaveEventMap().get(vehId2).get(1).getTime(), 0.); + Assertions.assertEquals(event4.getTime(), test.getVehId2PersonLeaveEventMap().get(vehId2).get(1).getTime(), 0.); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java index e2eb11c4d0b..d93292adc2e 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/osmBB/PTCountsNetworkSimplifierTest.java @@ -23,7 +23,7 @@ import java.util.Set; import java.util.TreeSet; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -74,11 +74,11 @@ void testSimplifyEmptyNetwork(){ Network network = scenario.getNetwork(); new MatsimNetworkReader(scenario.getNetwork()).readFile(outNetwork); - Assert.assertEquals(21, network.getLinks().size()); - Assert.assertEquals(10, network.getNodes().size()); + Assertions.assertEquals(21, network.getLinks().size()); + Assertions.assertEquals(10, network.getNodes().size()); - Assert.assertNull(network.getLinks().get(Id.create("1201_1202", Link.class))); - Assert.assertNull(network.getNodes().get(Id.create("1101", Node.class))); + Assertions.assertNull(network.getLinks().get(Id.create("1201_1202", Link.class))); + Assertions.assertNull(network.getNodes().get(Id.create("1101", Node.class))); } /** @@ -114,15 +114,15 @@ void testSimplifyPTNetwork(){ Network network = scenario.getNetwork(); new MatsimNetworkReader(scenario.getNetwork()).readFile(outNetwork); - Assert.assertEquals(26, network.getLinks().size()); - Assert.assertEquals(14, network.getNodes().size()); + Assertions.assertEquals(26, network.getLinks().size()); + Assertions.assertEquals(14, network.getNodes().size()); - Assert.assertNotNull(network.getLinks().get(Id.create("1103_1104", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1203_1204", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1303_1304", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1103_1104", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1203_1204", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1303_1304", Link.class))); - Assert.assertNull(network.getLinks().get(Id.create("1201_1202", Link.class))); - Assert.assertNull(network.getNodes().get(Id.create("1101", Node.class))); + Assertions.assertNull(network.getLinks().get(Id.create("1201_1202", Link.class))); + Assertions.assertNull(network.getNodes().get(Id.create("1101", Node.class))); } /** @@ -162,13 +162,13 @@ void testSimplifyCountsNetwork(){ Network network = scenario.getNetwork(); new MatsimNetworkReader(scenario.getNetwork()).readFile(outNetwork); - Assert.assertEquals(23, network.getLinks().size()); - Assert.assertEquals(12, network.getNodes().size()); + Assertions.assertEquals(23, network.getLinks().size()); + Assertions.assertEquals(12, network.getNodes().size()); - Assert.assertNotNull(network.getLinks().get(Id.create("1101_1102", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1101_1102", Link.class))); - Assert.assertNull(network.getLinks().get(Id.create("1103_1104", Link.class))); - Assert.assertNull(network.getNodes().get(Id.create("1103", Node.class))); + Assertions.assertNull(network.getLinks().get(Id.create("1103_1104", Link.class))); + Assertions.assertNull(network.getNodes().get(Id.create("1103", Node.class))); } /** @@ -208,16 +208,16 @@ void testSimplifyPTCountsNetwork(){ Network network = scenario.getNetwork(); new MatsimNetworkReader(scenario.getNetwork()).readFile(outNetwork); - Assert.assertEquals(28, network.getLinks().size()); - Assert.assertEquals(16, network.getNodes().size()); + Assertions.assertEquals(28, network.getLinks().size()); + Assertions.assertEquals(16, network.getNodes().size()); - Assert.assertNotNull(network.getLinks().get(Id.create("1101_1102", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1103_1104", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1203_1204", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1303_1304", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1101_1102", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1103_1104", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1203_1204", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1303_1304", Link.class))); - Assert.assertNull(network.getLinks().get(Id.create("1201_1202", Link.class))); - Assert.assertNull(network.getNodes().get(Id.create("1201", Node.class))); + Assertions.assertNull(network.getLinks().get(Id.create("1201_1202", Link.class))); + Assertions.assertNull(network.getNodes().get(Id.create("1201", Node.class))); } /** @@ -259,17 +259,17 @@ void testSimplifyElseNetwork(){ Network network = scenario.getNetwork(); new MatsimNetworkReader(scenario.getNetwork()).readFile(outNetwork); - Assert.assertEquals(29, network.getLinks().size()); - Assert.assertEquals(16, network.getNodes().size()); + Assertions.assertEquals(29, network.getLinks().size()); + Assertions.assertEquals(16, network.getNodes().size()); - Assert.assertNotNull(network.getLinks().get(Id.create("1101_1102", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1201_1202", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1301_1302", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1204_1203", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1314_1313", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1101_1102", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1201_1202", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1301_1302", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1204_1203", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1314_1313", Link.class))); - Assert.assertNull(network.getLinks().get(Id.create("1103_1104", Link.class))); - Assert.assertNull(network.getNodes().get(Id.create("1103", Node.class))); + Assertions.assertNull(network.getLinks().get(Id.create("1103_1104", Link.class))); + Assertions.assertNull(network.getNodes().get(Id.create("1103", Node.class))); } @@ -315,21 +315,21 @@ void testSimplifyAllNetwork(){ Network network = scenario.getNetwork(); new MatsimNetworkReader(scenario.getNetwork()).readFile(outNetwork); - Assert.assertEquals(32, network.getLinks().size()); - Assert.assertEquals(18, network.getNodes().size()); + Assertions.assertEquals(32, network.getLinks().size()); + Assertions.assertEquals(18, network.getNodes().size()); - Assert.assertNotNull(network.getLinks().get(Id.create("1101_1102", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1103_1104", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1203_1204", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1303_1304", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1101_1102", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1103_1104", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1203_1204", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1303_1304", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1101_1102", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1201_1202", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1301_1302", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1204_1203", Link.class))); - Assert.assertNotNull(network.getLinks().get(Id.create("1314_1313", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1101_1102", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1201_1202", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1301_1302", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1204_1203", Link.class))); + Assertions.assertNotNull(network.getLinks().get(Id.create("1314_1313", Link.class))); - Assert.assertNull(network.getLinks().get(Id.create("1202_1201", Link.class))); + Assertions.assertNull(network.getLinks().get(Id.create("1202_1201", Link.class))); } } diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java index 104fcd8f336..64755202e05 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java @@ -38,8 +38,8 @@ import jakarta.inject.Inject; import java.util.*; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; @RunWith(Parameterized.class) public class ModalDistanceAndCountsCadytsIT { @@ -349,8 +349,8 @@ public ScoringFunction createNewScoringFunction(Person person) { assertEquals(400, modalDistanceCount.get("bike_2050.0"), 80); assertEquals(400, modalDistanceCount.get("bike_2150.0"), 80); } else if (this.modalDistanceWeight == 0 && this.countsWeight > 0) { - assertTrue("expected more than 500 car trips on the long route but the number of trips was " + modalDistanceCount.get("car_2250.0"), - modalDistanceCount.get("car_2250.0") > 500); // don't know. one would assume a stronger impact when only running the cadyts count correction but there isn't + assertTrue(modalDistanceCount.get("car_2250.0") > 500, + "expected more than 500 car trips on the long route but the number of trips was " + modalDistanceCount.get("car_2250.0")); // don't know. one would assume a stronger impact when only running the cadyts count correction but there isn't } else if (this.modalDistanceWeight > 0 && this.countsWeight > 0) { /* This assumes that counts have a higher impact than distance distributions * (because counts request 1000 on car_2250 and the distance distribution requests 100 on car_2050 and car_2150 but 0 on car_2250). diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java index 90a70f545a2..796380440ad 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsMultipleDistancesIT.java @@ -34,13 +34,13 @@ import org.matsim.vehicles.VehicleType; import jakarta.inject.Inject; + +import static org.junit.jupiter.api.Assertions.assertEquals; import java.util.Arrays; import java.util.HashMap; import java.util.HashSet; import java.util.Map; -import static org.junit.Assert.assertEquals; - public class ModalDistanceCadytsMultipleDistancesIT { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java index c2dfaf70610..2a7f0fdc897 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceCadytsSingleDistanceIT.java @@ -48,13 +48,13 @@ import org.matsim.vehicles.VehicleType; import jakarta.inject.Inject; + +import static org.junit.jupiter.api.Assertions.assertEquals; import java.util.Arrays; import java.util.HashSet; import java.util.Map; import java.util.stream.Collectors; -import static org.junit.Assert.assertEquals; - public class ModalDistanceCadytsSingleDistanceIT { @RegisterExtension diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java index 8cccb793c66..70ee30d5232 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/TripEventHandlerTest.java @@ -23,8 +23,8 @@ import java.util.List; import java.util.Map; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertFalse; public class TripEventHandlerTest { diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java b/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java index 12089da0739..23a66584d87 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/AdvancedMarginalCongestionPricingIT.java @@ -27,8 +27,7 @@ import jakarta.inject.Inject; import jakarta.inject.Provider; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -104,7 +103,7 @@ final void test0a(){ activity1.setEndTime(16 * 3600.); double delay1 = 0 * 3600.; double activityDelayDisutility1 = marginaSumScoringFunction.getNormalActivityDelayDisutility(activity1, delay1); - Assert.assertEquals("Wrong disutility from starting an activity with a delay (arriving later at the activity location).", 0., activityDelayDisutility1, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., activityDelayDisutility1, MatsimTestUtils.EPSILON, "Wrong disutility from starting an activity with a delay (arriving later at the activity location)."); // test if a delay results in zero activity delay disutility if the agent would have arrived to late at the activity location anyway Activity activity2 = PopulationUtils.createActivityFromLinkId("work", linkId); @@ -112,7 +111,7 @@ final void test0a(){ activity2.setEndTime(20 * 3600.); double delay2 = 0.5 * 3600.; double activityDelayDisutility2 = marginaSumScoringFunction.getNormalActivityDelayDisutility(activity2, delay2); - Assert.assertEquals("Wrong disutility from starting an activity with a delay (arriving later at the activity location).", 0., activityDelayDisutility2, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., activityDelayDisutility2, MatsimTestUtils.EPSILON, "Wrong disutility from starting an activity with a delay (arriving later at the activity location)."); // test if a delay results in zero activity delay disutility if the agent would have arrived to early at the activity location anyway Activity activity3 = PopulationUtils.createActivityFromLinkId("work", linkId); @@ -120,7 +119,7 @@ final void test0a(){ activity3.setEndTime(5 * 3600.); double delay3 = 0.5 * 3600.; double activityDelayDisutility3 = marginaSumScoringFunction.getNormalActivityDelayDisutility(activity3, delay3); - Assert.assertEquals("Wrong disutility from starting an activity with a delay (arriving later at the activity location).", 0., activityDelayDisutility3, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., activityDelayDisutility3, MatsimTestUtils.EPSILON, "Wrong disutility from starting an activity with a delay (arriving later at the activity location)."); // test if a delay results in the right activity delay disutility if the agent would have had more time to perform the activity Activity activity4 = PopulationUtils.createActivityFromLinkId("work", linkId); @@ -130,13 +129,13 @@ final void test0a(){ double activityDelayDisutility4 = marginaSumScoringFunction.getNormalActivityDelayDisutility(activity4, delay4); // 6 hours --> 65.549424473781 utils // 5 hours --> 60 utils - Assert.assertEquals("Wrong disutility from starting an activity with a delay (arriving later at the activity location).", 5.549424473781310, activityDelayDisutility4, MatsimTestUtils.EPSILON); + Assertions.assertEquals(5.549424473781310, activityDelayDisutility4, MatsimTestUtils.EPSILON, "Wrong disutility from starting an activity with a delay (arriving later at the activity location)."); // repeat the previous test: test if a delay results in the right activity delay disutility if the agent would have had more time to perform the activity double activityDelayDisutility4b = marginaSumScoringFunction.getNormalActivityDelayDisutility(activity4, delay4); // 6 hours --> 65.549424473781 utils // 5 hours --> 60 utils - Assert.assertEquals("Wrong disutility from starting an activity with a delay (arriving later at the activity location).", 5.549424473781310, activityDelayDisutility4b, MatsimTestUtils.EPSILON); + Assertions.assertEquals(5.549424473781310, activityDelayDisutility4b, MatsimTestUtils.EPSILON, "Wrong disutility from starting an activity with a delay (arriving later at the activity location)."); } // test overnight activities with first and last activity of the same type @@ -171,20 +170,20 @@ final void test0b(){ double activityDelayDisutility1 = marginaSumScoringFunction.getOvernightActivityDelayDisutility(activity1, activity2, delay1); // 6 + 7 hours --> 65.763074952494600 utils // 6 + 7 hours --> 65.763074952494600 utils - Assert.assertEquals("Wrong disutility from starting an activity with a delay (arriving later at the activity location).", 0., activityDelayDisutility1, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., activityDelayDisutility1, MatsimTestUtils.EPSILON, "Wrong disutility from starting an activity with a delay (arriving later at the activity location)."); // test if a delay results in the right activity delay disutility double delay2 = 1 * 3600.; double activityDelayDisutility2 = marginaSumScoringFunction.getOvernightActivityDelayDisutility(activity1, activity2, delay2); // 6 + 7 hours --> 65.763074952494600 utils // 7 + 7 hours --> 71.098848947562600 utils - Assert.assertEquals("Wrong disutility from starting an activity with a delay (arriving later at the activity location).", 5.335773995067980, activityDelayDisutility2, MatsimTestUtils.EPSILON); + Assertions.assertEquals(5.335773995067980, activityDelayDisutility2, MatsimTestUtils.EPSILON, "Wrong disutility from starting an activity with a delay (arriving later at the activity location)."); // repeat the previous test: test if a delay results in the right activity delay disutility double activityDelayDisutility2b = marginaSumScoringFunction.getOvernightActivityDelayDisutility(activity1, activity2, delay2); // 6 + 7 hours --> 65.763074952494600 utils // 7 + 7 hours --> 71.098848947562600 utils - Assert.assertEquals("Wrong disutility from starting an activity with a delay (arriving later at the activity location).", 5.335773995067980, activityDelayDisutility2b, MatsimTestUtils.EPSILON); + Assertions.assertEquals(5.335773995067980, activityDelayDisutility2b, MatsimTestUtils.EPSILON, "Wrong disutility from starting an activity with a delay (arriving later at the activity location)."); } // test overnight activities with first and last activity of different types @@ -224,14 +223,14 @@ final void test0c(){ double activityDelayDisutility1 = marginaSumScoringFunction.getOvernightActivityDelayDisutility(activity1, activity2, delay1); // 6 --> 10.0934029996839 utils + 7 --> 21.1922519472465 utils = 31.285654946930 utils // 6 --> 10.0934029996839 utils + 7 --> 21.1922519472465 utils = 31.285654946930 utils - Assert.assertEquals("Wrong disutility from starting an activity with a delay (arriving later at the activity location).", 0., activityDelayDisutility1, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0., activityDelayDisutility1, MatsimTestUtils.EPSILON, "Wrong disutility from starting an activity with a delay (arriving later at the activity location)."); // test if a delay results in the right activity delay disutility double delay2 = 1 * 3600.; double activityDelayDisutility2 = marginaSumScoringFunction.getOvernightActivityDelayDisutility(activity1, activity2, delay2); // 6 --> 10.0934029996839 utils + 7 --> 21.1922519472465 utils = 31.285654946930 utils // 7 --> 21.1922519472465 utils + 7 --> 21.1922519472465 utils = 42.3845038944931 utils - Assert.assertEquals("Wrong disutility from starting an activity with a delay (arriving later at the activity location).", 11.0988489475631, activityDelayDisutility2, MatsimTestUtils.EPSILON); + Assertions.assertEquals(11.0988489475631, activityDelayDisutility2, MatsimTestUtils.EPSILON, "Wrong disutility from starting an activity with a delay (arriving later at the activity location)."); } // test if the delayed arrival at a normal activity (not the first or last activity) results in the right monetary amount @@ -300,12 +299,12 @@ public ControlerListener get() { controler.run(); // test if there is only one congestion event and only one money event - Assert.assertEquals("Wrong number of congestion events.", 1, congestionEvents.size()); - Assert.assertEquals("Wrong number of money events.", 1, moneyEvents.size()); + Assertions.assertEquals(1, congestionEvents.size(), "Wrong number of congestion events."); + Assertions.assertEquals(1, moneyEvents.size(), "Wrong number of money events."); // test if the delay is 2 seconds double delay = congestionEvents.get(0).getDelay(); - Assert.assertEquals("Wrong delay.", 2.0, delay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, delay, MatsimTestUtils.EPSILON, "Wrong delay."); double amountFromEvent = moneyEvents.get(0).getAmount(); double tripDelayDisutility = delay / 3600. * controler.getConfig().scoring().getModes().get(TransportMode.car).getMarginalUtilityOfTraveling() * (-1); @@ -313,7 +312,7 @@ public ControlerListener get() { // without delay --> 70.573360291244900 double activityDelayDisutility = 70.573360291244900 - 70.570685898554200; double amount = (-1) * (activityDelayDisutility + tripDelayDisutility) / controler.getConfig().scoring().getMarginalUtilityOfMoney(); - Assert.assertEquals("Wrong amount.", amount, amountFromEvent, MatsimTestUtils.EPSILON); + Assertions.assertEquals(amount, amountFromEvent, MatsimTestUtils.EPSILON, "Wrong amount."); } // test if a delayed arrival at the last activity results in the right monetary amount @@ -380,12 +379,12 @@ public ControlerListener get() { controler.run(); // test if there is only one congestion event and only one money event - Assert.assertEquals("Wrong number of congestion events.", 1, congestionEvents.size()); - Assert.assertEquals("Wrong number of money events.", 1, moneyEvents.size()); + Assertions.assertEquals(1, congestionEvents.size(), "Wrong number of congestion events."); + Assertions.assertEquals(1, moneyEvents.size(), "Wrong number of money events."); // test if the delay is 2 seconds double delay = congestionEvents.get(0).getDelay(); - Assert.assertEquals("Wrong delay.", 2.0, delay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, delay, MatsimTestUtils.EPSILON, "Wrong delay."); double amountFromEvent = moneyEvents.get(0).getAmount(); double tripDelayDisutility = delay / 3600. * controler.getConfig().scoring().getModes().get(TransportMode.car).getMarginalUtilityOfTraveling() * (-1); @@ -399,7 +398,7 @@ public ControlerListener get() { double activityDelayDisutility = 80.584243964094500 - 80.581739442040600; double amount = (-1) * (activityDelayDisutility + tripDelayDisutility) / controler.getConfig().scoring().getMarginalUtilityOfMoney(); - Assert.assertEquals("Wrong amount.", amount, amountFromEvent, MatsimTestUtils.EPSILON); + Assertions.assertEquals(amount, amountFromEvent, MatsimTestUtils.EPSILON, "Wrong amount."); } // test if the right number of money events are thrown @@ -466,8 +465,8 @@ public ControlerListener get() { controler.run(); // test if there are three congestion events and three money events - Assert.assertEquals("Wrong number of congestion events.", 3, congestionEvents.size()); - Assert.assertEquals("Wrong number of money events.", 3, moneyEvents.size()); + Assertions.assertEquals(3, congestionEvents.size(), "Wrong number of congestion events."); + Assertions.assertEquals(3, moneyEvents.size(), "Wrong number of money events."); } // test if the right number of money events are thrown @@ -534,7 +533,7 @@ public ControlerListener get() { controler.run(); // test if there are three congestion events and three money events - Assert.assertEquals("Wrong number of congestion events.", 3, congestionEvents.size()); - Assert.assertEquals("Wrong number of money events.", 3, moneyEvents.size()); + Assertions.assertEquals(3, congestionEvents.size(), "Wrong number of congestion events."); + Assertions.assertEquals(3, moneyEvents.size(), "Wrong number of money events."); } } diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java index a7406ecae28..755df67d97d 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/CombinedFlowAndStorageDelayTest.java @@ -21,7 +21,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -85,12 +85,12 @@ final void implV4Test(){ for(CongestionEvent e : congestionEvents){ if(e.getAffectedAgentId().equals(Id.createPersonId("2")) && e.getCausingAgentId().equals(Id.createPersonId("1"))){ - Assert.assertEquals("Delay caused by agent 2 is not correct.", 100, e.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(100, e.getDelay(), MatsimTestUtils.EPSILON, "Delay caused by agent 2 is not correct."); // this is not captured by only leaving agents list. } } - Assert.assertEquals("Number of congestion events are not correct.", 4, congestionEvents.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, congestionEvents.size(), MatsimTestUtils.EPSILON, "Number of congestion events are not correct."); } // @Test @@ -104,11 +104,11 @@ public final void implV6Test(){ for(CongestionEvent e : congestionEvents){ if(e.getAffectedAgentId().equals(Id.createPersonId("2")) && e.getLinkId().equals(Id.createLinkId("2"))){ - Assert.assertEquals("Wrong causing agent", Id.createPersonId("1"), e.getCausingAgentId()); + Assertions.assertEquals(Id.createPersonId("1"), e.getCausingAgentId(), "Wrong causing agent"); // this is not captured by only leaving agents list. } } - Assert.assertEquals("Number of congestion events are not correct.", 3, congestionEvents.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, congestionEvents.size(), MatsimTestUtils.EPSILON, "Number of congestion events are not correct."); } private List getAffectedPersonId2Delays(String congestionPricingImpl){ diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/CorridorNetworkTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/CorridorNetworkTest.java index e583e5441de..ae8f04f18a4 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/CorridorNetworkTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/CorridorNetworkTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -71,24 +71,24 @@ void v3Test(){ List v3_events = getCongestionEvents("v3", sc); - Assert.assertEquals("wrong number of congestion events", 6, v3_events.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, v3_events.size(), MatsimTestUtils.EPSILON, "wrong number of congestion events"); for ( CongestionEvent event : v3_events ){ if(event.getAffectedAgentId().equals(Id.createPersonId(2))){ // agent 2 is delayed on link 2 (bottleneck link) due to agent 1 - Assert.assertEquals("wrong causing agent", "1", event.getCausingAgentId().toString()); - Assert.assertEquals("wrong delay", 3, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals("1", event.getCausingAgentId().toString(), "wrong causing agent"); + Assertions.assertEquals(3, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } else if ( event.getAffectedAgentId().equals(Id.createPersonId(3)) ) { // agent 3 is delayed on link 2 due to agent 2, 1 if(event.getCausingAgentId().equals(Id.createPersonId(2))) { - Assert.assertEquals("wrong delay", 4, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } else { - Assert.assertEquals("wrong delay", 2, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } @@ -96,16 +96,16 @@ void v3Test(){ if(event.getCausingAgentId().equals(Id.createPersonId(3))){ - Assert.assertEquals("wrong delay", 4, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } else if (event.getCausingAgentId().equals(Id.createPersonId(2))){ - Assert.assertEquals("wrong delay", 4, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } else { - Assert.assertEquals("wrong causing agent", "1", event.getCausingAgentId().toString()); - Assert.assertEquals("wrong delay", 1, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals("1", event.getCausingAgentId().toString(), "wrong causing agent"); + Assertions.assertEquals(1, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } } } @@ -118,24 +118,24 @@ void v4Test(){ List v4_events = getCongestionEvents("v4", sc); - Assert.assertEquals("wrong number of congestion events", 6, v4_events.size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, v4_events.size(), MatsimTestUtils.EPSILON, "wrong number of congestion events"); for ( CongestionEvent event : v4_events ){ if(event.getAffectedAgentId().equals(Id.createPersonId(2))){ // agent 2 is delayed on link 2 (bottleneck link) due to agent 1 - Assert.assertEquals("wrong causing agent", "1", event.getCausingAgentId().toString()); - Assert.assertEquals("wrong delay", 3, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals("1", event.getCausingAgentId().toString(), "wrong causing agent"); + Assertions.assertEquals(3, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } else if ( event.getAffectedAgentId().equals(Id.createPersonId(3)) ) { // agent 3 is delayed on link 2 due to agent 2, 1 if(event.getCausingAgentId().equals(Id.createPersonId(2))) { - Assert.assertEquals("wrong delay", 4, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } else { - Assert.assertEquals("wrong delay", 2, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } @@ -144,19 +144,19 @@ void v4Test(){ if(event.getCausingAgentId().equals(Id.createPersonId(3)) ){ if ( event.getTime() == 10.0 ) { - Assert.assertEquals("wrong delay", 3, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } else { - Assert.assertEquals("wrong congestion event time", 18.0, event.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong delay", 4, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(18.0, event.getTime(), MatsimTestUtils.EPSILON, "wrong congestion event time"); + Assertions.assertEquals(4, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } } else { - Assert.assertEquals("wrong causing agent", "2", event.getCausingAgentId().toString()); - Assert.assertEquals("wrong delay", 2, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals("2", event.getCausingAgentId().toString(), "wrong causing agent"); + Assertions.assertEquals(2, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } } diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java index b34e2adbf6d..94c1f09f388 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowQueueQsimTest.java @@ -27,7 +27,7 @@ import java.util.List; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -128,11 +128,11 @@ public void handleEvent(CongestionEvent event) { sim.run(); for (CongestionEvent event : congestionEvents) { - Assert.assertEquals("here the delay should be equal to the inverse of the flow capacity", 3., event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3., event.getDelay(), MatsimTestUtils.EPSILON, "here the delay should be equal to the inverse of the flow capacity"); } - Assert.assertEquals("wrong total delay", 9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong total internalized delay", 9., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON, "wrong total delay"); + Assertions.assertEquals(9., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON, "wrong total internalized delay"); } @@ -168,23 +168,23 @@ public void handleEvent(CongestionEvent event) { for (CongestionEvent event : congestionEvents) { if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentB")) { - Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3., event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentA")) { - Assert.assertEquals("wrong delay", 6., event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6., event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } if (event.getCausingAgentId().toString().equals("agentB") && event.getAffectedAgentId().toString().equals("agentA")) { - Assert.assertEquals("wrong delay", 6., event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6., event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } } - Assert.assertEquals("wrong total delay", 9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON, "wrong total delay"); // the second agent is 3 sec delayed and charges the first agent with these 3 sec // the third agent is 6 sec delayed and charges the first and the second agent with each 6 sec - Assert.assertEquals("wrong total internalized delay", 15., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(15., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON, "wrong total internalized delay"); } /** @@ -219,23 +219,23 @@ public void handleEvent(CongestionEvent event) { for (CongestionEvent event : congestionEvents) { if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentB")) { - Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3., event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } if (event.getCausingAgentId().toString().equals("agentC") && event.getAffectedAgentId().toString().equals("agentA")) { - Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3., event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } if (event.getCausingAgentId().toString().equals("agentB") && event.getAffectedAgentId().toString().equals("agentA")) { - Assert.assertEquals("wrong delay", 3., event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3., event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay"); } } - Assert.assertEquals("wrong total delay", 9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9., congestionHandler.getTotalDelay(), MatsimTestUtils.EPSILON, "wrong total delay"); // the second agent is 3 sec delayed and charges the first agent with these 3 sec // the third agent is 6 sec delayed and charges the first and the second agent with each 6 sec - Assert.assertEquals("wrong total internalized delay", 9., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9., congestionHandler.getTotalInternalizedDelay(), MatsimTestUtils.EPSILON, "wrong total internalized delay"); } private void setPopulation1(Scenario scenario) { diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java index 3029eda9921..c2f58a3cc25 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java @@ -32,8 +32,8 @@ import jakarta.inject.Inject; import jakarta.inject.Provider; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -162,11 +162,11 @@ public void handleEvent(CongestionEvent event) { System.out.println(event.toString()); if (event.getCausingAgentId().toString().equals(this.testAgent1.toString()) && event.getAffectedAgentId().toString().equals(this.testAgent2.toString())) { - Assert.assertEquals("wrong delay.", 10.0, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10.0, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); } else if ((event.getCausingAgentId().toString().equals(this.testAgent2.toString())) && (event.getAffectedAgentId().toString().equals(this.testAgent3.toString())) && (event.getTime() == 116.0)) { - Assert.assertEquals("wrong delay.", 10.0, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10.0, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); } else if ((event.getCausingAgentId().toString().equals(this.testAgent1.toString())) && (event.getAffectedAgentId().toString().equals(this.testAgent3.toString())) && (event.getTime() == 126.0)) { - Assert.assertEquals("wrong delay.", 9.0, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9.0, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); } } @@ -210,7 +210,7 @@ public void handleEvent(CongestionEvent event) { System.out.println(event.toString()); totalDelay += event.getDelay(); } - Assert.assertEquals("wrong total delay.", 50.0, totalDelay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(50.0, totalDelay, MatsimTestUtils.EPSILON, "wrong total delay."); } @@ -251,7 +251,7 @@ public void handleEvent(CongestionEvent event) { System.out.println(event.toString()); totalDelay += event.getDelay(); } - Assert.assertEquals("wrong total delay.", 30.0, totalDelay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(30.0, totalDelay, MatsimTestUtils.EPSILON, "wrong total delay."); } @@ -292,7 +292,7 @@ public void handleEvent(CongestionEvent event) { System.out.println(event.toString()); totalDelay += event.getDelay(); } - Assert.assertEquals("wrong total delay.", 32.0, totalDelay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(32.0, totalDelay, MatsimTestUtils.EPSILON, "wrong total delay."); } @@ -424,10 +424,10 @@ else if(((event.getServices().getConfig().controller().getLastIteration())-(even controler.run(); { // controlling and showing the conditions of the test: - Assert.assertEquals("entering agents in timeBin1.", 3.0, enterCounter.get(timeBin1), MatsimTestUtils.EPSILON); - Assert.assertEquals("entering agents in timeBin2.", 3.0, enterCounter.get(timeBin2), MatsimTestUtils.EPSILON); - Assert.assertEquals("leaving agents in timeBin1.", 1.0, leaveCounter.get(timeBin1), MatsimTestUtils.EPSILON); - Assert.assertEquals("leaving agents in timeBin1.", 5.0, leaveCounter.get(timeBin2), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.0, enterCounter.get(timeBin1), MatsimTestUtils.EPSILON, "entering agents in timeBin1."); + Assertions.assertEquals(3.0, enterCounter.get(timeBin2), MatsimTestUtils.EPSILON, "entering agents in timeBin2."); + Assertions.assertEquals(1.0, leaveCounter.get(timeBin1), MatsimTestUtils.EPSILON, "leaving agents in timeBin1."); + Assertions.assertEquals(5.0, leaveCounter.get(timeBin2), MatsimTestUtils.EPSILON, "leaving agents in timeBin1."); } // for both time-bins ("28800-29700" and "29700-30600") @@ -436,15 +436,15 @@ else if(((event.getServices().getConfig().controller().getLastIteration())-(even // the congestion effects of each 3 cars are the same, // the fact that 2 of the first 3 cars leave the link in the next time-bin should be irrelevant - Assert.assertEquals("avgValue1 == avgValue2", avgValue1, avgValue2, MatsimTestUtils.EPSILON); - Assert.assertEquals("avgValue3 == avgValue3", avgValue3, avgValue4, MatsimTestUtils.EPSILON); - Assert.assertEquals("avgValue1 == avgValue3", avgValue1, avgValue3, MatsimTestUtils.EPSILON); + Assertions.assertEquals(avgValue1, avgValue2, MatsimTestUtils.EPSILON, "avgValue1 == avgValue2"); + Assertions.assertEquals(avgValue3, avgValue4, MatsimTestUtils.EPSILON, "avgValue3 == avgValue3"); + Assertions.assertEquals(avgValue1, avgValue3, MatsimTestUtils.EPSILON, "avgValue1 == avgValue3"); - Assert.assertEquals("avgOldValue1 == avgOldValue2", avgOldValue1, avgOldValue2, MatsimTestUtils.EPSILON); - Assert.assertEquals("avgOldValue3 == avgOldValue3", avgOldValue3, avgOldValue4, MatsimTestUtils.EPSILON); - Assert.assertEquals("avgOldValue1 == avgOldValue3", avgOldValue1, avgOldValue3, MatsimTestUtils.EPSILON); + Assertions.assertEquals(avgOldValue1, avgOldValue2, MatsimTestUtils.EPSILON, "avgOldValue1 == avgOldValue2"); + Assertions.assertEquals(avgOldValue3, avgOldValue4, MatsimTestUtils.EPSILON, "avgOldValue3 == avgOldValue3"); + Assertions.assertEquals(avgOldValue1, avgOldValue3, MatsimTestUtils.EPSILON, "avgOldValue1 == avgOldValue3"); - Assert.assertEquals("avgValue1 == avgOldValue1", avgValue1, avgOldValue1, MatsimTestUtils.EPSILON); + Assertions.assertEquals(avgValue1, avgOldValue1, MatsimTestUtils.EPSILON, "avgValue1 == avgOldValue1"); } @@ -493,15 +493,15 @@ public void handleEvent(LinkLeaveEvent event) { } - Assert.assertEquals("numberOfCongestionEvents", congestionEvents.size(), 3, MatsimTestUtils.EPSILON); + Assertions.assertEquals(congestionEvents.size(), 3, MatsimTestUtils.EPSILON, "numberOfCongestionEvents"); for(CongestionEvent mce : congestionEvents){ if((mce.getCausingAgentId().equals(testAgent1))&&(mce.getAffectedAgentId().equals(testAgent2))){ - Assert.assertEquals("delay", 10., mce.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10., mce.getDelay(), MatsimTestUtils.EPSILON, "delay"); }else if((mce.getCausingAgentId().equals(testAgent2))&&(mce.getAffectedAgentId().equals(testAgent3))){ - Assert.assertEquals("delay", 10., mce.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10., mce.getDelay(), MatsimTestUtils.EPSILON, "delay"); }else if((mce.getCausingAgentId().equals(testAgent1))&&(mce.getAffectedAgentId().equals(testAgent3))){ - Assert.assertEquals("delay", 4., mce.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4., mce.getDelay(), MatsimTestUtils.EPSILON, "delay"); } } } @@ -552,15 +552,15 @@ public void handleEvent(LinkLeaveEvent event) { } - Assert.assertEquals("numberOfCongestionEvents", congestionEvents.size(), 3, MatsimTestUtils.EPSILON); + Assertions.assertEquals(congestionEvents.size(), 3, MatsimTestUtils.EPSILON, "numberOfCongestionEvents"); for(CongestionEvent mce : congestionEvents){ if((mce.getCausingAgentId().equals(testAgent1))&&(mce.getAffectedAgentId().equals(testAgent3))){ - Assert.assertEquals("delay", 4., mce.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4., mce.getDelay(), MatsimTestUtils.EPSILON, "delay"); }else if((mce.getCausingAgentId().equals(testAgent3))&&(mce.getAffectedAgentId().equals(testAgent2))){ - Assert.assertEquals("delay", 10., mce.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10., mce.getDelay(), MatsimTestUtils.EPSILON, "delay"); }else if((mce.getCausingAgentId().equals(testAgent1))&&(mce.getAffectedAgentId().equals(testAgent2))){ - Assert.assertEquals("delay", 10., mce.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10., mce.getDelay(), MatsimTestUtils.EPSILON, "delay"); } } @@ -613,15 +613,15 @@ public void handleEvent(LinkLeaveEvent event) { } - Assert.assertEquals("numberOfCongestionEvents", congestionEvents.size(), 3, MatsimTestUtils.EPSILON); + Assertions.assertEquals(congestionEvents.size(), 3, MatsimTestUtils.EPSILON, "numberOfCongestionEvents"); for(CongestionEvent mce : congestionEvents){ if((mce.getCausingAgentId().equals(testAgent1))&&(mce.getAffectedAgentId().equals(testAgent2))){ - Assert.assertEquals("delay", 5., mce.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5., mce.getDelay(), MatsimTestUtils.EPSILON, "delay"); }else if((mce.getCausingAgentId().equals(testAgent2))&&(mce.getAffectedAgentId().equals(testAgent3))){ - Assert.assertEquals("delay", 10., mce.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10., mce.getDelay(), MatsimTestUtils.EPSILON, "delay"); }else if((mce.getCausingAgentId().equals(testAgent1))&&(mce.getAffectedAgentId().equals(testAgent3))){ - Assert.assertEquals("delay", 8., mce.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8., mce.getDelay(), MatsimTestUtils.EPSILON, "delay"); } } @@ -682,11 +682,11 @@ public void handleEvent(LinkEnterEvent event) { System.out.println(event.toString()); if (event.getCausingAgentId().toString().equals(this.testAgent1.toString()) && event.getAffectedAgentId().toString().equals(this.testAgent2.toString())) { - Assert.assertEquals("wrong delay.", 10.0, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10.0, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); } else if ((event.getCausingAgentId().toString().equals(this.testAgent2.toString())) && (event.getAffectedAgentId().toString().equals(this.testAgent3.toString())) && (event.getTime() == 116.0)) { - Assert.assertEquals("wrong delay.", 10.0, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10.0, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); } else if ((event.getCausingAgentId().toString().equals(this.testAgent1.toString())) && (event.getAffectedAgentId().toString().equals(this.testAgent3.toString())) && (event.getTime() == 126.0)) { - Assert.assertEquals("wrong delay.", 9.0, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9.0, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); } } diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java index c43f9c44301..1f70380e3de 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerV3Test.java @@ -29,8 +29,7 @@ import jakarta.inject.Inject; import jakarta.inject.Provider; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -138,11 +137,11 @@ public void install() { double outflowRate = 3.; // 1200 veh / h --> 1 veh every 3 sec double inflowRate = 1.; // 1 veh every 1 sec int demand = 20; - Assert.assertEquals("wrong total delay", (outflowRate - inflowRate) * (demand * demand - demand) / 2, totalDelay, MatsimTestUtils.EPSILON); + Assertions.assertEquals((outflowRate - inflowRate) * (demand * demand - demand) / 2, totalDelay, MatsimTestUtils.EPSILON, "wrong total delay"); // assert - Assert.assertEquals("wrong values for testAgent7", 38.0, personId2causedDelay.get(Id.create("testAgent7", Person.class)), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong values for testAgent7", 12.0, personId2affectedDelay.get(Id.create("testAgent7", Person.class)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(38.0, personId2causedDelay.get(Id.create("testAgent7", Person.class)), MatsimTestUtils.EPSILON, "wrong values for testAgent7"); + Assertions.assertEquals(12.0, personId2affectedDelay.get(Id.create("testAgent7", Person.class)), MatsimTestUtils.EPSILON, "wrong values for testAgent7"); // ... } } diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java index ae8e105e244..a398d462e77 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionPricingTest.java @@ -23,7 +23,7 @@ import java.util.List; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -104,7 +104,7 @@ public void handleEvent(CongestionEvent event) { PrepareForSimUtils.createDefaultPrepareForSim(sc).run(); new QSimBuilder(sc.getConfig()).useDefaults().build(sc, events).run(); - Assert.assertEquals("wrong number of congestion events" , 15, congestionEvents.size()); + Assertions.assertEquals(15, congestionEvents.size(), "wrong number of congestion events"); Set affectedPersons = new HashSet<>(); Set causingPersons = new HashSet<>(); @@ -127,33 +127,33 @@ public void handleEvent(CongestionEvent event) { if(event.getLinkId().equals(Id.createLinkId("3"))){ if (event.getCausingAgentId().toString().equals("0") && event.getAffectedAgentId().toString().equals("2")) { - Assert.assertEquals("wrong delay.", 8, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); // Assert.assertEquals("wrong delay.", 9, event.getDelay(), MatsimTestUtils.EPSILON);//1 sec change is caused due to the change in the flow accumulation approach (can go to -ive). Amit Jan 17 link3Delays++; } else if (event.getCausingAgentId().toString().equals("2") && event.getAffectedAgentId().toString().equals("4")) { - Assert.assertEquals("wrong delay.", 10, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); link3Delays++; } else if (event.getCausingAgentId().toString().equals("0") && event.getAffectedAgentId().toString().equals("4")) { - Assert.assertEquals("wrong delay.", 6, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(6, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); // Assert.assertEquals("wrong delay.", 7, event.getDelay(), MatsimTestUtils.EPSILON); link3Delays++; } else if (event.getCausingAgentId().toString().equals("4") && event.getAffectedAgentId().toString().equals("6")) { // delays 10,5 person6Delay+=event.getDelay(); if(repetationPerson6Count>0){ - Assert.assertEquals("wrong delay.", 15, person6Delay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(15, person6Delay, MatsimTestUtils.EPSILON, "wrong delay."); // Assert.assertEquals("wrong delay.", 16, person6Delay, MatsimTestUtils.EPSILON); } repetationPerson6Count++; link3Delays++; } else if (event.getCausingAgentId().toString().equals("2") && event.getAffectedAgentId().toString().equals("6")) { - Assert.assertEquals("wrong delay.", 9, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); link3Delays++; } else if (event.getCausingAgentId().toString().equals("6") && event.getAffectedAgentId().toString().equals("8")) { // delays are 10, 10 person8_6Delay+=event.getDelay(); if(repetationPerson8_6Count>0){ - Assert.assertEquals("wrong delay.", 20, person8_6Delay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(20, person8_6Delay, MatsimTestUtils.EPSILON, "wrong delay."); } repetationPerson8_6Count++; link3Delays++; @@ -161,20 +161,20 @@ public void handleEvent(CongestionEvent event) { // delays are 3,9 person8_4Delay+=event.getDelay(); if(repetationPerson8_4Count>0){ - Assert.assertEquals("wrong delay.", 12, person8_4Delay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(12, person8_4Delay, MatsimTestUtils.EPSILON, "wrong delay."); // Assert.assertEquals("wrong delay.", 13, person8_4Delay, MatsimTestUtils.EPSILON); } repetationPerson8_4Count++; link3Delays++; } else if (event.getCausingAgentId().toString().equals("6") && event.getAffectedAgentId().toString().equals("9")) { - Assert.assertEquals("wrong delay.", 2, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); // Assert.assertEquals("wrong delay.", 3, event.getDelay(), MatsimTestUtils.EPSILON); link3Delays++; } else if (event.getCausingAgentId().toString().equals("8") && event.getAffectedAgentId().toString().equals("9")) { - Assert.assertEquals("wrong delay.", 10, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); link3Delays++; } else if (event.getCausingAgentId().toString().equals("6") && event.getAffectedAgentId().toString().equals("7")) { - Assert.assertEquals("wrong delay.", 4, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); // Assert.assertEquals("wrong delay.", 5, event.getDelay(), MatsimTestUtils.EPSILON); //1 sec change is caused due to the change in the flow accumulation approach (can go to -ive). Amit Jan 17 link3Delays++; } @@ -182,10 +182,10 @@ public void handleEvent(CongestionEvent event) { } else if(event.getLinkId().equals(Id.createLinkId("2"))){ if (event.getCausingAgentId().toString().equals("6") && event.getAffectedAgentId().toString().equals("7")) { - Assert.assertEquals("wrong delay.", 1, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); link2Delays++; } else if (event.getCausingAgentId().toString().equals("8") && event.getAffectedAgentId().toString().equals("9")) { - Assert.assertEquals("wrong delay.", 1, event.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, event.getDelay(), MatsimTestUtils.EPSILON, "wrong delay."); link2Delays++; } @@ -193,15 +193,15 @@ public void handleEvent(CongestionEvent event) { } // affected persons are 2,4,6,8 on link3 and 6,7,8,9 on link 2. - Assert.assertEquals("wrong number of affected persons" , 6, affectedPersons.size()); + Assertions.assertEquals(6, affectedPersons.size(), "wrong number of affected persons"); //causing agents set should not have any one from 1,3,5,7,9 for(int id :causingPersons){ - Assert.assertEquals("Wrong causing person", 0, id%2); + Assertions.assertEquals(0, id%2, "Wrong causing person"); } - Assert.assertEquals("some events are not checked on link 2" , 2, link2Delays); - Assert.assertEquals("some events are not checked on link 3" , 13, link3Delays); + Assertions.assertEquals(2, link2Delays, "some events are not checked on link 2"); + Assertions.assertEquals(13, link3Delays, "some events are not checked on link 3"); } /** diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java index ff9518ca966..5ddadecf44c 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MultipleSpillbackCausingLinksTest.java @@ -21,7 +21,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -87,7 +87,7 @@ final void multipleSpillBackTest(){ for(CongestionEvent e : congestionEvents){ if(e.getAffectedAgentId().equals(Id.createPersonId("2"))&&e.getLinkId().equals(Id.createLinkId("2")) && index ==1){ // first next link in the route is link 2 - Assert.assertEquals("Delay on first next link in the route is not correct.", 9.0, e.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(9.0, e.getDelay(), MatsimTestUtils.EPSILON, "Delay on first next link in the route is not correct."); // Assert.assertEquals("Delay on first next link in the route is not correct.", 10.0, e.getDelay(), MatsimTestUtils.EPSILON); //1 sec change (1 time on link2) is caused due to the change in the flow accumulation approach (can go to -ive). Amit Jan 17 eventTimes.add(e.getTime()); index ++; @@ -98,9 +98,9 @@ final void multipleSpillBackTest(){ // route is link 6 // agent 3 and 4 leave prior to agent 2 during home work (trip3) if(e.getCausingAgentId().equals(Id.createPersonId("3"))){ - Assert.assertEquals("Delay on second next link in the route is not correct.", 10.0, e.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10.0, e.getDelay(), MatsimTestUtils.EPSILON, "Delay on second next link in the route is not correct."); } else if (e.getCausingAgentId().equals(Id.createPersonId("4"))){ - Assert.assertEquals("Delay on second next link in the route is not correct.", 10.0, e.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10.0, e.getDelay(), MatsimTestUtils.EPSILON, "Delay on second next link in the route is not correct."); } eventTimes.add(e.getTime()); index ++; @@ -109,7 +109,7 @@ final void multipleSpillBackTest(){ if(e.getAffectedAgentId().equals(Id.createPersonId("2"))&&e.getLinkId().equals(Id.createLinkId("2")) && index ==4){ // first next link in the route is link 2 // multiple spill back causing link - Assert.assertEquals("Delay on first next link in the route due to multiple spill back is not correct.", 4.0, e.getDelay(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4.0, e.getDelay(), MatsimTestUtils.EPSILON, "Delay on first next link in the route due to multiple spill back is not correct."); // Assert.assertEquals("Delay on first next link in the route due to multiple spill back is not correct.", 6.0, e.getDelay(), MatsimTestUtils.EPSILON); //1 sec change (two times on link2 and link6) is caused due to the change in the flow accumulation approach (can go to -ive). Amit Jan 17 eventTimes.add(e.getTime()); index ++; @@ -117,10 +117,10 @@ final void multipleSpillBackTest(){ } // now check, for agent 2, first link in the route (trip1) is occur first and rest later time i.e. during index ==1. - Assert.assertFalse("Congestion event for first next link in the route should occur first.", eventTimes.get(0) > eventTimes.get(1)); + Assertions.assertFalse(eventTimes.get(0) > eventTimes.get(1), "Congestion event for first next link in the route should occur first."); // all other congestion event for agent 2 while leaving link 1 should occur at the same time. - Assert.assertFalse("Congestion event for multiple spill back causing links should occur at the same time.", eventTimes.get(1) == eventTimes.get(2) && eventTimes.get(2) == eventTimes.get(3)); + Assertions.assertFalse(eventTimes.get(1) == eventTimes.get(2) && eventTimes.get(2) == eventTimes.get(3), "Congestion event for multiple spill back causing links should occur at the same time."); } diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java b/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java index 46cbb7a5ebc..9cdfa5b37b1 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/TestForEmergenceTime.java @@ -21,7 +21,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -72,8 +72,8 @@ final void emergenceTimeTest_v4(){ List congestionEvents = getAffectedPersonId2Delays(impl); for(CongestionEvent event : congestionEvents){ if(event.getCausingAgentId().equals(Id.createPersonId("21"))){ - Assert.assertEquals("wrong emergence time", 8*3600+55, event.getEmergenceTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong linkId", Id.createLinkId("3"), event.getLinkId()); + Assertions.assertEquals(8*3600+55, event.getEmergenceTime(), MatsimTestUtils.EPSILON, "wrong emergence time"); + Assertions.assertEquals(Id.createLinkId("3"), event.getLinkId(), "wrong linkId"); } } } diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java b/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java index 28fca80e271..71039834a90 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/TransferFinalSocToNextIterTest.java @@ -23,7 +23,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -63,18 +63,18 @@ void test() { controler.run(); // testInitialEnergyInIter0 - Assert.assertEquals(INITIAL_SOC, handler.iterationInitialSOC.get(0), 0.0); + Assertions.assertEquals(INITIAL_SOC, handler.iterationInitialSOC.get(0), 0.0); // testSOCIsDumpedIntoVehicleType //agent has driven the car so SOC should have changed and should be dumped into the vehicle type var vehicle = scenario.getVehicles().getVehicles().get(Id.create("Triple Charger_car", Vehicle.class)); var evSpec = ElectricFleetUtils.createElectricVehicleSpecificationDefaultImpl(vehicle ); - Assert.assertNotEquals(evSpec.getInitialSoc(), INITIAL_SOC); - Assert.assertEquals(0.7273605127621898, evSpec.getInitialSoc(), MatsimTestUtils.EPSILON); //should not be fully charged + Assertions.assertNotEquals(evSpec.getInitialSoc(), INITIAL_SOC); + Assertions.assertEquals(0.7273605127621898, evSpec.getInitialSoc(), MatsimTestUtils.EPSILON); //should not be fully charged // testSOCisTransferredToNextIteration for (int i = 0; i < LAST_ITERATION; i++) { - Assert.assertEquals(handler.iterationEndSOC.get(i), handler.iterationInitialSOC.get(i + 1)); + Assertions.assertEquals(handler.iterationEndSOC.get(i), handler.iterationInitialSOC.get(i + 1)); } } diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java index c267b09bb17..9f470684027 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVIT.java @@ -1,7 +1,7 @@ package playground.vsp.ev; import org.apache.logging.log4j.LogManager; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.population.Population; @@ -37,20 +37,20 @@ void run() { PopulationUtils.readPopulation( actual, utils.getOutputDirectory() + "/output_plans.xml.gz" ); boolean result = PopulationUtils.comparePopulations( expected, actual ); - Assert.assertTrue( result ); + Assertions.assertTrue( result ); } { String expected = utils.getInputDirectory() + "/output_events.xml.gz" ; String actual = utils.getOutputDirectory() + "/output_events.xml.gz" ; EventsFileComparator.Result result = EventsUtils.compareEventsFiles( expected, actual ); - Assert.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result ); + Assertions.assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, result ); } } catch ( Exception ee ) { LogManager.getLogger(this.getClass() ).fatal("there was an exception: \n" + ee ) ; // if one catches an exception, then one needs to explicitly fail the test: - Assert.fail(); + Assertions.fail(); } diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java index 2611efa158e..15bd18ad185 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java @@ -6,8 +6,8 @@ import java.util.Map; import java.util.stream.Collectors; -import org.junit.Assert; import org.junit.BeforeClass; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -118,71 +118,71 @@ void testAgentsExecuteSameNumberOfActsAsPlanned() { + " activities"; } } - Assert.assertFalse("the following persons do not execute the same amount of activities as they plan to:" + personsWithDifferingActCount, - fail); + Assertions.assertFalse(fail, + "the following persons do not execute the same amount of activities as they plan to:" + personsWithDifferingActCount); } @Test void testCarAndBikeAgent() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Charge during leisure + bike"), List.of()); - Assert.assertEquals(1, plugins.size(), 0); + Assertions.assertEquals(1, plugins.size(), 0); //charges at during leisure(12)-bike-leisure(13)-bike-leisure(14) ActivityStartEvent pluginActStart2 = plugins.get(0); //agent travels 5 links between precedent work activity which end at 11. each link takes 99 seconds - Assert.assertEquals("wrong charging start time", 11 * 3600 + 5 * 99, pluginActStart2.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "90", pluginActStart2.getLinkId().toString()); + Assertions.assertEquals(11 * 3600 + 5 * 99, pluginActStart2.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("90", pluginActStart2.getLinkId().toString(), "wrong charging start location"); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("Charge during leisure + bike"), List.of()); - Assert.assertEquals(1, plugouts.size(), 0); + Assertions.assertEquals(1, plugouts.size(), 0); ActivityEndEvent plugoutActStart = plugouts.get(0); - Assert.assertEquals("wrong charging end time", 14 * 3600, plugoutActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging end location", "90", plugoutActStart.getLinkId().toString()); + Assertions.assertEquals(14 * 3600, plugoutActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging end time"); + Assertions.assertEquals("90", plugoutActStart.getLinkId().toString(), "wrong charging end location"); } @Test void testTripleCharger() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Triple Charger"), List.of()); - Assert.assertEquals(plugins.size(), 3., 0); + Assertions.assertEquals(plugins.size(), 3., 0); ActivityStartEvent pluginActStart = plugins.get(0); - Assert.assertEquals("wrong charging start time", 1490d, pluginActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "90", pluginActStart.getLinkId().toString()); + Assertions.assertEquals(1490d, pluginActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("90", pluginActStart.getLinkId().toString(), "wrong charging start location"); ActivityStartEvent pluginActStart2 = plugins.get(1); - Assert.assertEquals("wrong charging start time", 25580d, pluginActStart2.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "90", pluginActStart2.getLinkId().toString()); + Assertions.assertEquals(25580d, pluginActStart2.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("90", pluginActStart2.getLinkId().toString(), "wrong charging start location"); ActivityStartEvent pluginActStart3 = plugins.get(2); - Assert.assertEquals("wrong charging start time", 45724d, pluginActStart3.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "95", pluginActStart3.getLinkId().toString()); + Assertions.assertEquals(45724d, pluginActStart3.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("95", pluginActStart3.getLinkId().toString(), "wrong charging start location"); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("Triple Charger"), List.of()); - Assert.assertEquals(plugouts.size(), 2, 0); + Assertions.assertEquals(plugouts.size(), 2, 0); ActivityEndEvent plugoutActStart = plugouts.get(0); - Assert.assertEquals("wrong charging end time", 3179d, plugoutActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging end location", "90", plugoutActStart.getLinkId().toString()); + Assertions.assertEquals(3179d, plugoutActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging end time"); + Assertions.assertEquals("90", plugoutActStart.getLinkId().toString(), "wrong charging end location"); ActivityEndEvent plugoutActStart2 = plugouts.get(1); - Assert.assertEquals("wrong charging end time", 26608d, plugoutActStart2.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging end location", "90", plugoutActStart2.getLinkId().toString()); + Assertions.assertEquals(26608d, plugoutActStart2.getTime(), MatsimTestUtils.EPSILON, "wrong charging end time"); + Assertions.assertEquals("90", plugoutActStart2.getLinkId().toString(), "wrong charging end location"); } @Test void testChargerSelectionShopping() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Charging during shopping"), List.of()); - Assert.assertEquals(1, plugins.size(), 0); + Assertions.assertEquals(1, plugins.size(), 0); ActivityStartEvent pluginActStart = plugins.get(0); //starts at 10am at work and travels 8 links à 99s - Assert.assertEquals("wrong charging start time", 10 * 3600 + 8 * 99, pluginActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "172", pluginActStart.getLinkId().toString()); + Assertions.assertEquals(10 * 3600 + 8 * 99, pluginActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("172", pluginActStart.getLinkId().toString(), "wrong charging start location"); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("Charging during shopping"), List.of()); - Assert.assertEquals(1, plugouts.size(), 0); + Assertions.assertEquals(1, plugouts.size(), 0); ActivityEndEvent plugoutActStart = plugouts.get(0); - Assert.assertEquals("wrong charging end time", 11 * 3600 + 23 * 60 + 27, plugoutActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging end location", "172", plugoutActStart.getLinkId().toString()); + Assertions.assertEquals(11 * 3600 + 23 * 60 + 27, plugoutActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging end time"); + Assertions.assertEquals("172", plugoutActStart.getLinkId().toString(), "wrong charging end location"); } @@ -190,66 +190,66 @@ void testChargerSelectionShopping() { void testLongDistance() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Charger Selection long distance leg"), List.of()); - Assert.assertEquals(1, plugins.size(), 0); + Assertions.assertEquals(1, plugins.size(), 0); ActivityStartEvent pluginActStart = plugins.get(0); //starts at 8 am and travels 19 links à 99s + 3s waiting time to enter traffic - Assert.assertEquals("wrong charging start time", 8 * 3600 + 19 * 99 + 3, pluginActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "89", pluginActStart.getLinkId().toString()); + Assertions.assertEquals(8 * 3600 + 19 * 99 + 3, pluginActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("89", pluginActStart.getLinkId().toString(), "wrong charging start location"); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("Charger Selection long distance leg"), List.of()); - Assert.assertEquals(1, plugouts.size(), 0); + Assertions.assertEquals(1, plugouts.size(), 0); ActivityEndEvent plugoutActStart = plugouts.get(0); //needs to walk for 26 minutes - Assert.assertEquals("wrong charging end time", 10 * 3600 + 26 * 60, plugoutActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging end location", "89", plugoutActStart.getLinkId().toString()); + Assertions.assertEquals(10 * 3600 + 26 * 60, plugoutActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging end time"); + Assertions.assertEquals("89", plugoutActStart.getLinkId().toString(), "wrong charging end location"); } @Test void testTwin() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Charger Selection long distance twin"), List.of()); - Assert.assertEquals(1, plugins.size(), 0); + Assertions.assertEquals(1, plugins.size(), 0); ActivityStartEvent pluginActStart = plugins.get(0); //starts at 8:00:40 am and travels 19 links à 99s - Assert.assertEquals("wrong charging start time", 8 * 3605 + 19 * 99, pluginActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "89", pluginActStart.getLinkId().toString()); + Assertions.assertEquals(8 * 3605 + 19 * 99, pluginActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("89", pluginActStart.getLinkId().toString(), "wrong charging start location"); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("Charger Selection long distance twin"), List.of()); - Assert.assertEquals(1, plugouts.size(), 0); + Assertions.assertEquals(1, plugouts.size(), 0); ActivityEndEvent plugoutActStart = plugouts.get(0); - Assert.assertEquals("wrong charging end time", 10 * 3600, plugoutActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging end location", "89", plugoutActStart.getLinkId().toString()); + Assertions.assertEquals(10 * 3600, plugoutActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging end time"); + Assertions.assertEquals("89", plugoutActStart.getLinkId().toString(), "wrong charging end location"); } @Test void testDoubleCharger() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Double Charger"), List.of()); - Assert.assertEquals(1, plugins.size(), 0); + Assertions.assertEquals(1, plugins.size(), 0); ActivityStartEvent pluginActStart = plugins.get(0); //starts at 6 am and travels 17 links à 99s - Assert.assertEquals("wrong charging start time", 6 * 3600 + 17 * 99, pluginActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "90", pluginActStart.getLinkId().toString()); + Assertions.assertEquals(6 * 3600 + 17 * 99, pluginActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("90", pluginActStart.getLinkId().toString(), "wrong charging start location"); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("Double Charger"), List.of()); - Assert.assertEquals(1, plugouts.size(), 0); + Assertions.assertEquals(1, plugouts.size(), 0); ActivityEndEvent plugoutActStart = plugouts.get(0); - Assert.assertEquals("wrong charging end time", 28783d, plugoutActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging end location", "90", plugoutActStart.getLinkId().toString()); + Assertions.assertEquals(28783d, plugoutActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging end time"); + Assertions.assertEquals("90", plugoutActStart.getLinkId().toString(), "wrong charging end location"); } @Test void testNotEnoughTimeCharger() { //TODO this test succeeds if the corresponding agents is deleted List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Not enough time so no charge"), List.of()); - Assert.assertTrue(plugins.isEmpty()); + Assertions.assertTrue(plugins.isEmpty()); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("Not enough time so no charge"), List.of()); - Assert.assertTrue(plugins.isEmpty()); + Assertions.assertTrue(plugins.isEmpty()); } @Test @@ -258,33 +258,33 @@ void testEarlyCharger() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Not enough time so charging early"), List.of()); - Assert.assertEquals(1, plugins.size(), 0); + Assertions.assertEquals(1, plugins.size(), 0); ActivityStartEvent pluginActStart = plugins.get(0); //starts at 6 am and travels 18 links à 99s + 3s waiting time to enter traffic - Assert.assertEquals("wrong charging start time", 6 * 3600 + 18 * 99 + 3, pluginActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "90", pluginActStart.getLinkId().toString()); + Assertions.assertEquals(6 * 3600 + 18 * 99 + 3, pluginActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("90", pluginActStart.getLinkId().toString(), "wrong charging start location"); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("Not enough time so charging early"), List.of()); - Assert.assertEquals(1, plugouts.size(), 0); + Assertions.assertEquals(1, plugouts.size(), 0); ActivityEndEvent plugoutActStart = plugouts.get(0); - Assert.assertEquals("wrong charging end time", 7 * 3600 + 27 * 60 + 49, plugoutActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging end location", "90", plugoutActStart.getLinkId().toString()); + Assertions.assertEquals(7 * 3600 + 27 * 60 + 49, plugoutActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging end time"); + Assertions.assertEquals("90", plugoutActStart.getLinkId().toString(), "wrong charging end location"); } @Test void testHomeCharger() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Home Charger"), List.of()); - Assert.assertEquals(1, plugins.size(), 0); + Assertions.assertEquals(1, plugins.size(), 0); ActivityStartEvent pluginActStart = plugins.get(0); //starts return to home trip at 8am and travels 10 links à 99s + 3s waiting time - Assert.assertEquals("wrong charging start time", 8 * 3600 + 10 * 99, pluginActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", pluginActStart.getLinkId().toString(), "95"); + Assertions.assertEquals(8 * 3600 + 10 * 99, pluginActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals(pluginActStart.getLinkId().toString(), "95", "wrong charging start location"); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("Home Charger"), List.of()); - Assert.assertTrue("Home charger should not have a plug out interaction", plugouts.isEmpty()); + Assertions.assertTrue(plugouts.isEmpty(), "Home charger should not have a plug out interaction"); } @Test @@ -293,31 +293,31 @@ void testNoRoundTripSoNoHomeCharge() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("No Round Trip So No Home Charge"), List.of()); - Assert.assertTrue(plugins.isEmpty()); + Assertions.assertTrue(plugins.isEmpty()); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("No Round Trip So No Home Charge"), List.of()); - Assert.assertTrue("Home charger should not have a plug out interaction", plugouts.isEmpty()); + Assertions.assertTrue(plugouts.isEmpty(), "Home charger should not have a plug out interaction"); } @Test void testDoubleChargerHomeCharger() { List plugins = this.handler.plugInCntPerPerson.getOrDefault(Id.createPersonId("Double Charger Home Charger"), List.of()); - Assert.assertEquals(plugins.size(), 2, 0); + Assertions.assertEquals(plugins.size(), 2, 0); ActivityStartEvent pluginActStart = plugins.get(0); - Assert.assertEquals("wrong charging start time", 5 * 3600 + 13 * 99, pluginActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "95", pluginActStart.getLinkId().toString()); + Assertions.assertEquals(5 * 3600 + 13 * 99, pluginActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("95", pluginActStart.getLinkId().toString(), "wrong charging start location"); //drives back home at 17 pm and travels 18 links ActivityStartEvent pluginActStart2 = plugins.get(1); - Assert.assertEquals("wrong charging start time", 17 * 3600 + 18 * 99, pluginActStart2.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging start location", "90", pluginActStart2.getLinkId().toString()); + Assertions.assertEquals(17 * 3600 + 18 * 99, pluginActStart2.getTime(), MatsimTestUtils.EPSILON, "wrong charging start time"); + Assertions.assertEquals("90", pluginActStart2.getLinkId().toString(), "wrong charging start location"); List plugouts = this.handler.plugOutCntPerPerson.getOrDefault(Id.createPersonId("Double Charger Home Charger"), List.of()); ActivityEndEvent plugoutActStart = plugouts.get(0); - Assert.assertEquals("wrong charging end time", 33242d, plugoutActStart.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong charging end location", "95", plugoutActStart.getLinkId().toString()); - Assert.assertEquals("Should plug out exactly once (as second plugin is for home charge)", 1, plugouts.size()); + Assertions.assertEquals(33242d, plugoutActStart.getTime(), MatsimTestUtils.EPSILON, "wrong charging end time"); + Assertions.assertEquals("95", plugoutActStart.getLinkId().toString(), "wrong charging end location"); + Assertions.assertEquals(1, plugouts.size(), "Should plug out exactly once (as second plugin is for home charge)"); } private static void overridePopulation(Scenario scenario) { @@ -924,8 +924,9 @@ public void handleEvent(ActivityEndEvent event) { ActivityStartEvent correspondingPlugin = this.plugInCntPerPerson.get(event.getPersonId()) .get(this.plugInCntPerPerson.get(event.getPersonId()).size() - 1); - Assert.assertEquals("plugin and plugout location seem not to match. event=" + event, correspondingPlugin.getLinkId(), - event.getLinkId()); + Assertions.assertEquals(correspondingPlugin.getLinkId(), + event.getLinkId(), + "plugin and plugout location seem not to match. event=" + event); } } @@ -959,8 +960,7 @@ public void handleEvent(ChargingEndEvent event) { ChargingStartEvent correspondingStart = this.chargingStarts.get(event.getVehicleId()) .get(this.chargingStarts.get(event.getVehicleId()).size() - 1); - Assert.assertEquals("chargingEnd and chargingStart do not seem not to take place at the same charger. event=" + event, - correspondingStart.getChargerId(), event.getChargerId()); + Assertions.assertEquals(correspondingStart.getChargerId(), event.getChargerId(), "chargingEnd and chargingStart do not seem not to take place at the same charger. event=" + event); } @Override diff --git a/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java b/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java index 07a9345c92c..2eeae6af2fe 100644 --- a/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java @@ -1,8 +1,8 @@ package playground.vsp.flowEfficiency; import com.google.inject.Provides; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -68,17 +68,17 @@ public class HierarchicalFLowEfficiencyCalculatorTest { @Test void testThatDrtAVMoveFaster(){ - Assert.assertTrue(handler.lastArrivalsPerLink.get(Id.createLinkId(258)) > handler.lastArrivalsPerLink.get(Id.createLinkId(259))); - Assert.assertTrue(handler.lastArrivalsPerLink.get(Id.createLinkId(258)) > handler.lastArrivalsPerLink.get(Id.createLinkId(260))); - Assert.assertTrue(handler.lastArrivalsPerLink.get(Id.createLinkId(260)) > handler.lastArrivalsPerLink.get(Id.createLinkId(259))); + Assertions.assertTrue(handler.lastArrivalsPerLink.get(Id.createLinkId(258)) > handler.lastArrivalsPerLink.get(Id.createLinkId(259))); + Assertions.assertTrue(handler.lastArrivalsPerLink.get(Id.createLinkId(258)) > handler.lastArrivalsPerLink.get(Id.createLinkId(260))); + Assertions.assertTrue(handler.lastArrivalsPerLink.get(Id.createLinkId(260)) > handler.lastArrivalsPerLink.get(Id.createLinkId(259))); - Assert.assertEquals(7238, handler.lastArrivalsPerLink.get(Id.createLinkId(258)), MatsimTestUtils.EPSILON); //car drivers - Assert.assertEquals(1845, handler.lastArrivalsPerLink.get(Id.createLinkId(259)), MatsimTestUtils.EPSILON); //drt drivers - Assert.assertEquals(5440, handler.lastArrivalsPerLink.get(Id.createLinkId(260)), MatsimTestUtils.EPSILON); //mixed (car - drt -car - drt - ....) + Assertions.assertEquals(7238, handler.lastArrivalsPerLink.get(Id.createLinkId(258)), MatsimTestUtils.EPSILON); //car drivers + Assertions.assertEquals(1845, handler.lastArrivalsPerLink.get(Id.createLinkId(259)), MatsimTestUtils.EPSILON); //drt drivers + Assertions.assertEquals(5440, handler.lastArrivalsPerLink.get(Id.createLinkId(260)), MatsimTestUtils.EPSILON); //mixed (car - drt -car - drt - ....) - Assert.assertEquals(1800, handler.nrOfArrivalsPerLink.get(Id.createLinkId(258)), MatsimTestUtils.EPSILON); - Assert.assertEquals(1800, handler.nrOfArrivalsPerLink.get(Id.createLinkId(259)), MatsimTestUtils.EPSILON); - Assert.assertEquals(1800, handler.nrOfArrivalsPerLink.get(Id.createLinkId(260)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1800, handler.nrOfArrivalsPerLink.get(Id.createLinkId(258)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1800, handler.nrOfArrivalsPerLink.get(Id.createLinkId(259)), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1800, handler.nrOfArrivalsPerLink.get(Id.createLinkId(260)), MatsimTestUtils.EPSILON); } diff --git a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java index 56816559ba1..7d115d579a6 100644 --- a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/cemdap/input/SynPopCreatorTest.java @@ -1,6 +1,6 @@ package playground.vsp.openberlinscenario.cemdap.input; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.population.Person; @@ -93,9 +93,9 @@ void TestGenerateDemand() { //assert // Assert.assertEquals("Wrong municipality", "12060034", householdId.toString().substring(0,8)); if (!employed) { - Assert.assertEquals("Wrong locationOfWork", "-99", locationOfWork); + Assertions.assertEquals("-99", locationOfWork, "Wrong locationOfWork"); } else if (locationOfWork.length() != 6) { - Assert.assertTrue("Wrong locationOfWork", possibleLocationsOfWork.contains(locationOfWork)); + Assertions.assertTrue(possibleLocationsOfWork.contains(locationOfWork), "Wrong locationOfWork"); } if (gender == Gender.male) { if (isBetween(age, 18, 24)) male18_24++; @@ -113,27 +113,27 @@ void TestGenerateDemand() { if (isBetween(age, 50, 64)) female50_64++; if (isBetween(age, 65, 74)) female65_74++; if (age > 74) female75Plus++; - } else Assert.fail("Wrong gender"); + } else Assertions.fail("Wrong gender"); } //System.out.println("Persons size: " + pop.getPersons().values().size()); - Assert.assertEquals("Wrong male18_24 count", male18_24Ref, male18_24); - Assert.assertEquals("Wrong male25_29 count", male25_29Ref, male25_29); - Assert.assertEquals("Wrong male30_39 count", male30_39Ref, male30_39); - Assert.assertEquals("Wrong male40_49 count", male40_49Ref, male40_49); - Assert.assertEquals("Wrong male50_64 count", male50_64Ref, male50_64); - Assert.assertEquals("Wrong male75Plus count", male75PlusRef, male75Plus); - Assert.assertEquals("Wrong female18_24 count", female18_24Ref, female18_24); - Assert.assertEquals("Wrong female25_29 count", female25_29Ref, female25_29); - Assert.assertEquals("Wrong female30_39 count", female30_39Ref, female30_39); - Assert.assertEquals("Wrong female40_49 count", female40_49Ref, female40_49); - Assert.assertEquals("Wrong female50_64 count", female50_64Ref, female50_64); - Assert.assertEquals("Wrong female65_74 count", female65_74Ref, female65_74); - Assert.assertEquals("Wrong female75Plus count", female75PlusRef, female75Plus); - Assert.assertEquals("Wrong male65_74 count", male65_74Ref, male65_74); - - Assert.assertTrue("", new File(utils.getOutputDirectory() + "persons1.dat.gz").exists()); + Assertions.assertEquals(male18_24Ref, male18_24, "Wrong male18_24 count"); + Assertions.assertEquals(male25_29Ref, male25_29, "Wrong male25_29 count"); + Assertions.assertEquals(male30_39Ref, male30_39, "Wrong male30_39 count"); + Assertions.assertEquals(male40_49Ref, male40_49, "Wrong male40_49 count"); + Assertions.assertEquals(male50_64Ref, male50_64, "Wrong male50_64 count"); + Assertions.assertEquals(male75PlusRef, male75Plus, "Wrong male75Plus count"); + Assertions.assertEquals(female18_24Ref, female18_24, "Wrong female18_24 count"); + Assertions.assertEquals(female25_29Ref, female25_29, "Wrong female25_29 count"); + Assertions.assertEquals(female30_39Ref, female30_39, "Wrong female30_39 count"); + Assertions.assertEquals(female40_49Ref, female40_49, "Wrong female40_49 count"); + Assertions.assertEquals(female50_64Ref, female50_64, "Wrong female50_64 count"); + Assertions.assertEquals(female65_74Ref, female65_74, "Wrong female65_74 count"); + Assertions.assertEquals(female75PlusRef, female75Plus, "Wrong female75Plus count"); + Assertions.assertEquals(male65_74Ref, male65_74, "Wrong male65_74 count"); + + Assertions.assertTrue(new File(utils.getOutputDirectory() + "persons1.dat.gz").exists(), ""); } diff --git a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java index 7f96e4d5879..d6d72219e1d 100644 --- a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java @@ -2,8 +2,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -67,9 +67,9 @@ void testSelectionProbability() { LOG.info("selection probability: " + SELECTION_PROBABILITY); LOG.info("real selection probability: " + ((double)modifiedPopulationCase1.getPersons().size()/ originalPopulationCase.getPersons().size())); - Assert.assertEquals("Selection probability was not correctly applied", - 11, modifiedPopulationCase1.getPersons().size(), - MatsimTestUtils.EPSILON); + Assertions.assertEquals(11, modifiedPopulationCase1.getPersons().size(), + MatsimTestUtils.EPSILON, + "Selection probability was not correctly applied"); } @Test @@ -77,8 +77,8 @@ void testEveryPersonCopiedExistsInOriginal() { for (Person copy : modifiedPopulationCase1.getPersons().values()) { Person original = originalPopulationCase.getPersons().get(copy.getId()); - Assert.assertTrue("Person " + copy.getId() + " does not exist in the original file", - original != null); + Assertions.assertTrue(original != null, + "Person " + copy.getId() + " does not exist in the original file"); } } @@ -87,7 +87,7 @@ void testOnlyTransferSelectedPlan() { for (Person copy : modifiedPopulationCase2.getPersons().values()) { Person original = originalPopulationCase.getPersons().get(copy.getId()); - Assert.assertEquals("More than 1 plan", 1, copy.getPlans().size()); + Assertions.assertEquals(1, copy.getPlans().size(), "More than 1 plan"); comparePlansWithoutRoutes(original.getSelectedPlan(), copy.getSelectedPlan()); } } @@ -98,8 +98,7 @@ void testNotOnlyTransferSelectedPlan() { for (Person copy : modifiedPopulationCase1.getPersons().values()) { Person original = originalPopulationCase.getPersons().get(copy.getId()); - Assert.assertEquals("Not the same amount of plans", - original.getPlans().size(), copy.getPlans().size()); + Assertions.assertEquals(original.getPlans().size(), copy.getPlans().size(), "Not the same amount of plans"); comparePlans(original.getSelectedPlan(), copy.getSelectedPlan()); for (int i = 0; i < original.getPlans().size(); i++) { Plan originalPlan = original.getPlans().get(i); @@ -117,15 +116,15 @@ void testConsiderHomeStayingAgents() { if (copy.getSelectedPlan().getPlanElements().size() == 1) atLeastOneHomeStayingPerson = true; } - Assert.assertTrue("No home staying person found", atLeastOneHomeStayingPerson); + Assertions.assertTrue(atLeastOneHomeStayingPerson, "No home staying person found"); } @Test void testNotConsiderHomeStayingAgents() { for (Person copy : modifiedPopulationCase1.getPersons().values()) { - Assert.assertTrue("No home staying agents allowed", - copy.getSelectedPlan().getPlanElements().size() > 1); + Assertions.assertTrue(copy.getSelectedPlan().getPlanElements().size() > 1, + "No home staying agents allowed"); } } @@ -138,7 +137,7 @@ void testIncludeStayHomePlans() { if (plan.getPlanElements().size() <= 1) atLeastOneHomeStayingPlan = true; } - Assert.assertTrue("No home staying plan found", atLeastOneHomeStayingPlan); + Assertions.assertTrue(atLeastOneHomeStayingPlan, "No home staying plan found"); } @Test @@ -147,8 +146,8 @@ void testNotIncludeStayHomePlans() { for (Person copy : modifiedPopulationCase2.getPersons().values()) { for (Plan plan : copy.getPlans()) if (!plan.equals(copy.getSelectedPlan())) - Assert.assertTrue("No home staying plans allowed", - plan.getPlanElements().size() > 1); + Assertions.assertTrue(plan.getPlanElements().size() > 1, + "No home staying plans allowed"); } } @@ -159,8 +158,8 @@ void testOnlyConsiderPeopleAlwaysGoingByCar() { for (Plan plan : copy.getPlans()) for (PlanElement planElement : plan.getPlanElements()) { if (planElement instanceof Leg) { - Assert.assertTrue("No other mode than car allowed", - (((Leg) planElement).getMode().equals(TransportMode.car))); + Assertions.assertTrue((((Leg) planElement).getMode().equals(TransportMode.car)), + "No other mode than car allowed"); } } } @@ -178,7 +177,7 @@ void testNotOnlyConsiderPeopleAlwaysGoingByCar() { } } } - Assert.assertTrue("There should be other modes than car", otherModeThanCarConsidered); + Assertions.assertTrue(otherModeThanCarConsidered, "There should be other modes than car"); } @Test @@ -188,8 +187,8 @@ void testRemoveLinksAndRoutes() { for (Plan plan : copy.getPlans()) for (PlanElement planElement : plan.getPlanElements()) { if (planElement instanceof Leg) { - Assert.assertTrue("There should not be a route left", - (((Leg) planElement).getRoute() == null)); + Assertions.assertTrue((((Leg) planElement).getRoute() == null), + "There should not be a route left"); } } } @@ -207,21 +206,22 @@ void testNotRemoveLinksAndRoutes() { } } } - Assert.assertTrue("There should be at minimum one route left", routeFound); + Assertions.assertTrue(routeFound, "There should be at minimum one route left"); } private void comparePlans(Plan original, Plan copy) { - Assert.assertEquals("Plans are not the same", original.toString(), copy.toString()); + Assertions.assertEquals(original.toString(), copy.toString(), "Plans are not the same"); for (int i = 0; i < original.getPlanElements().size(); i++) { - Assert.assertEquals("PlanElements are not the same", original.getPlanElements().get(i).toString(), - copy.getPlanElements().get(i).toString()); + Assertions.assertEquals(original.getPlanElements().get(i).toString(), + copy.getPlanElements().get(i).toString(), + "PlanElements are not the same"); } } private void comparePlansWithoutRoutes(Plan original, Plan copy) { - Assert.assertEquals("Plans are not the same", original.toString(), copy.toString()); + Assertions.assertEquals(original.toString(), copy.toString(), "Plans are not the same"); } private static Population readPopulationFromFile(String populationFile) { diff --git a/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java b/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java index 8ea37d7d2df..4678d019243 100644 --- a/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/pt/ptdisturbances/EditTripsTest.java @@ -21,8 +21,8 @@ package playground.vsp.pt.ptdisturbances; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.net.URL; import java.util.ArrayList; @@ -133,16 +133,16 @@ void testAgentStaysAtStop() { double travelTime = arrivalTimes.get(person.getId()) - activityEndTime; List trip = trips.get(person.getId()); - assertEquals("Travel time has changed", 1490.0, travelTime, MatsimTestUtils.EPSILON); - assertEquals("Number of trip elements has changed", 7 ,trip.size()); + assertEquals(1490.0, travelTime, MatsimTestUtils.EPSILON, "Travel time has changed"); + assertEquals(7 ,trip.size(),"Number of trip elements has changed"); - assertEquals("Trip element has changed", "dummy@car_17bOut", trip.get(0)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(1)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(2)); - assertEquals("Trip element has changed", "tr_334", trip.get(3)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(4)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(5)); - assertEquals("Trip element has changed", "dummy@work0", trip.get(6)); + assertEquals("dummy@car_17bOut", trip.get(0), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(1), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(2), "Trip element has changed"); + assertEquals("tr_334", trip.get(3), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(4), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(5), "Trip element has changed"); + assertEquals("dummy@work0", trip.get(6), "Trip element has changed"); } @@ -169,16 +169,16 @@ void testAgentLeavesStop() { double travelTime = arrivalTimes.get(person.getId()) - activityEndTime; List trip = trips.get(person.getId()); - assertEquals("Travel time has changed", 1344.0, travelTime, MatsimTestUtils.EPSILON); - assertEquals("Number of trip elements has changed", 7 ,trip.size()); + assertEquals(1344.0, travelTime, MatsimTestUtils.EPSILON, "Travel time has changed"); + assertEquals(7 ,trip.size(),"Number of trip elements has changed"); - assertEquals("Trip element has changed", "dummy@car_17bOut", trip.get(0)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(1)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(2)); - assertEquals("Trip element has changed", "tr_333", trip.get(3)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(4)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(5)); - assertEquals("Trip element has changed", "dummy@work0", trip.get(6)); + assertEquals("dummy@car_17bOut", trip.get(0), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(1), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(2), "Trip element has changed"); + assertEquals("tr_333", trip.get(3), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(4), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(5), "Trip element has changed"); + assertEquals("dummy@work0", trip.get(6), "Trip element has changed"); } @@ -205,16 +205,16 @@ void testAgentStaysInVehicle() { double travelTime = arrivalTimes.get(person.getId()) - activityEndTime; List trip = trips.get(person.getId()); - assertEquals("Travel time has changed", 1044.0, travelTime, MatsimTestUtils.EPSILON); - assertEquals("Number of trip elements has changed", 7 ,trip.size()); + assertEquals(1044.0, travelTime, MatsimTestUtils.EPSILON, "Travel time has changed"); + assertEquals(7 ,trip.size(),"Number of trip elements has changed"); - assertEquals("Trip element has changed", "dummy@car_17bOut", trip.get(0)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(1)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(2)); - assertEquals("Trip element has changed", "tr_332", trip.get(3)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(4)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(5)); - assertEquals("Trip element has changed", "dummy@work0", trip.get(6)); + assertEquals("dummy@car_17bOut", trip.get(0), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(1), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(2), "Trip element has changed"); + assertEquals("tr_332", trip.get(3), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(4), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(5), "Trip element has changed"); + assertEquals("dummy@work0", trip.get(6), "Trip element has changed"); } @@ -241,21 +241,21 @@ void testAgentLeavesVehicleAtNextStop() { double travelTime = arrivalTimes.get(person.getId()) - activityEndTime; List trip = trips.get(person.getId()); - assertEquals("Travel time has changed", 1077.0, travelTime, MatsimTestUtils.EPSILON); - assertEquals("Number of trip elements has changed", 12 ,trip.size()); + assertEquals(1077.0, travelTime, MatsimTestUtils.EPSILON, "Travel time has changed"); + assertEquals(12 ,trip.size(),"Number of trip elements has changed"); - assertEquals("Trip element has changed", "dummy@car_17bOut", trip.get(0)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(1)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(2)); - assertEquals("Trip element has changed", "tr_333", trip.get(3)); - assertEquals("Trip element has changed", "pt interaction@pt7", trip.get(4)); - assertEquals("Trip element has changed", "pt interaction@pt7", trip.get(5)); - assertEquals("Trip element has changed", "pt interaction@pt1", trip.get(6)); - assertEquals("Trip element has changed", "pt interaction@pt1", trip.get(7)); - assertEquals("Trip element has changed", "tr_45", trip.get(8)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(9)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(10)); - assertEquals("Trip element has changed", "dummy@work0", trip.get(11)); + assertEquals("dummy@car_17bOut", trip.get(0), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(1), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(2), "Trip element has changed"); + assertEquals("tr_333", trip.get(3), "Trip element has changed"); + assertEquals("pt interaction@pt7", trip.get(4), "Trip element has changed"); + assertEquals("pt interaction@pt7", trip.get(5), "Trip element has changed"); + assertEquals("pt interaction@pt1", trip.get(6), "Trip element has changed"); + assertEquals("pt interaction@pt1", trip.get(7), "Trip element has changed"); + assertEquals("tr_45", trip.get(8), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(9), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(10), "Trip element has changed"); + assertEquals("dummy@work0", trip.get(11), "Trip element has changed"); } @@ -283,18 +283,18 @@ void testAgentIsAtTeleportLegAndLeavesStop() { double travelTime = arrivalTimes.get(person.getId()) - activityEndTime; List trip = trips.get(person.getId()); - assertEquals("Travel time has changed", 2570.0, travelTime, MatsimTestUtils.EPSILON); - assertEquals("Number of trip elements has changed", 9 ,trip.size()); + assertEquals(2570.0, travelTime, MatsimTestUtils.EPSILON, "Travel time has changed"); + assertEquals(9 ,trip.size(),"Number of trip elements has changed"); - assertEquals("Trip element has changed", "dummy@car_17bOut", trip.get(0)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(1)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(2)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(3)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(4)); - assertEquals("Trip element has changed", "tr_334", trip.get(5)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(6)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(7)); - assertEquals("Trip element has changed", "dummy@work0", trip.get(8)); + assertEquals("dummy@car_17bOut", trip.get(0), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(1), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(2), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(3), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(4), "Trip element has changed"); + assertEquals("tr_334", trip.get(5), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(6), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(7), "Trip element has changed"); + assertEquals("dummy@work0", trip.get(8), "Trip element has changed"); } @@ -325,18 +325,18 @@ void testAgentIsAtTeleportLegAndWaitsAtStop_walkUnattractive() { double travelTime = arrivalTimes.get(person.getId()) - activityEndTime; List trip = trips.get(person.getId()); - assertEquals("Travel time has changed", 2570.0, travelTime, MatsimTestUtils.EPSILON); - assertEquals("Number of trip elements has changed", 9 ,trip.size()); + assertEquals(2570.0, travelTime, MatsimTestUtils.EPSILON, "Travel time has changed"); + assertEquals(9 ,trip.size(),"Number of trip elements has changed"); - assertEquals("Trip element has changed", "dummy@car_17bOut", trip.get(0)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(1)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(2)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(3)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(4)); - assertEquals("Trip element has changed", "tr_334", trip.get(5)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(6)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(7)); - assertEquals("Trip element has changed", "dummy@work0", trip.get(8)); + assertEquals("dummy@car_17bOut", trip.get(0), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(1), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(2), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(3), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(4), "Trip element has changed"); + assertEquals("tr_334", trip.get(5), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(6), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(7), "Trip element has changed"); + assertEquals("dummy@work0", trip.get(8), "Trip element has changed"); } @@ -361,18 +361,18 @@ void testAgentIsAtTeleportLegAndWaitsAtStop() { double travelTime = arrivalTimes.get(person.getId()) - activityEndTime; List trip = trips.get(person.getId()); - assertEquals("Travel time has changed", 2570.0, travelTime, MatsimTestUtils.EPSILON); - assertEquals("Number of trip elements has changed", 9 ,trip.size()); + assertEquals(2570.0, travelTime, MatsimTestUtils.EPSILON, "Travel time has changed"); + assertEquals(9 ,trip.size(),"Number of trip elements has changed"); - assertEquals("Trip element has changed", "dummy@car_17bOut", trip.get(0)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(1)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(2)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(3)); - assertEquals("Trip element has changed", "pt interaction@pt6c", trip.get(4)); - assertEquals("Trip element has changed", "tr_334", trip.get(5)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(6)); - assertEquals("Trip element has changed", "pt interaction@pt8", trip.get(7)); - assertEquals("Trip element has changed", "dummy@work0", trip.get(8)); + assertEquals("dummy@car_17bOut", trip.get(0), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(1), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(2), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(3), "Trip element has changed"); + assertEquals("pt interaction@pt6c", trip.get(4), "Trip element has changed"); + assertEquals("tr_334", trip.get(5), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(6), "Trip element has changed"); + assertEquals("pt interaction@pt8", trip.get(7), "Trip element has changed"); + assertEquals("dummy@work0", trip.get(8), "Trip element has changed"); } @@ -411,7 +411,7 @@ void testOneAgentEveryFourSeconds() { numberOfUsedLines++; } } - assertTrue("Number of used lines ist not plausible", numberOfUsedLines == 1 || numberOfUsedLines == 2); + assertTrue(numberOfUsedLines == 1 || numberOfUsedLines == 2, "Number of used lines ist not plausible"); } System.out.println(config.controller().getOutputDirectory()); } diff --git a/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java b/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java index def2f9bebad..81bd2b2b013 100644 --- a/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java @@ -21,8 +21,8 @@ package playground.vsp.pt.transitRouteTrimmer; import javafx.util.Pair; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.prep.PreparedGeometry; import org.matsim.api.core.v01.Id; @@ -45,7 +45,7 @@ import java.util.*; import java.util.stream.Collectors; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; /** * TODO: reduce size of input files: either cut files to only include relevant TransitLines or use different scenario @@ -118,8 +118,8 @@ void test_AllIn() { } } - assertEquals("There should be no stops outside of zone", 0, stopsOutsideZoneCnt); - assertEquals("All stops should be inside the zone", stopsTotal, stopsInZoneCnt); + assertEquals(0, stopsOutsideZoneCnt, "There should be no stops outside of zone"); + assertEquals(stopsTotal, stopsInZoneCnt, "All stops should be inside the zone"); } /** @@ -143,8 +143,8 @@ void test_HalfIn() { Id firstStopId = transitRoute.getStops().get(0).getStopFacility().getId(); Id lastStopId = transitRoute.getStops().get(sizeOld - 1).getStopFacility().getId(); - assertNotEquals("The Route should not be entirely inside of the zone", sizeOld, inCnt); - assertNotEquals("The Route should not be entirely outside of the zone", sizeOld, outCnt); + assertNotEquals(sizeOld, inCnt, "The Route should not be entirely inside of the zone"); + assertNotEquals(sizeOld, outCnt, "The Route should not be entirely outside of the zone"); assertFalse(stopsInZone.contains(firstStopId)); assertTrue(stopsInZone.contains(lastStopId)); @@ -171,8 +171,8 @@ void test_MiddleIn() { Id firstStopId = transitRoute.getStops().get(0).getStopFacility().getId(); Id lastStopId = transitRoute.getStops().get(sizeOld - 1).getStopFacility().getId(); - assertNotEquals("The Route should not be entirely inside of the zone", sizeOld, inCnt); - assertNotEquals("The Route should not be entirely outside of the zone", sizeOld, outCnt); + assertNotEquals(sizeOld, inCnt, "The Route should not be entirely inside of the zone"); + assertNotEquals(sizeOld, outCnt, "The Route should not be entirely outside of the zone"); assertFalse(stopsInZone.contains(firstStopId)); assertFalse(stopsInZone.contains(lastStopId)); @@ -205,16 +205,15 @@ void testDeleteRoutesEntirelyInsideZone_AllIn() { // After Trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("Schedule should include empty transit line", - transitScheduleNew.getTransitLines().containsKey(transitLineId)); - assertEquals("transitLine should no longer contain any routes", - transitScheduleNew.getTransitLines().get(transitLineId).getRoutes().size(), 0); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), + "Schedule should include empty transit line"); + assertEquals(transitScheduleNew.getTransitLines().get(transitLineId).getRoutes().size(), 0, "transitLine should no longer contain any routes"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } @@ -246,23 +245,22 @@ void testDeleteRoutesEntirelyInsideZone_HalfIn() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("Schedule should include transit line", - transitScheduleNew.getTransitLines().containsKey(transitLineId)); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), + "Schedule should include transit line"); TransitLine transitLine = transitScheduleNew.getTransitLines().get(transitLineId); - assertTrue("Schedule should include transit route", - transitLine.getRoutes().containsKey(transitRouteId)); + assertTrue(transitLine.getRoutes().containsKey(transitRouteId), + "Schedule should include transit route"); TransitRoute transitRoute = transitLine.getRoutes().get(transitRouteId); int stopCntNew = transitRoute.getStops().size(); - assertEquals("transitRoute should contain same number of stops as before modification", - stopCntOld, stopCntNew); + assertEquals(stopCntOld, stopCntNew, "transitRoute should contain same number of stops as before modification"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } @@ -294,23 +292,22 @@ void testDeleteRoutesEntirelyInsideZone_MiddleIn() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("Schedule should include transit line", - transitScheduleNew.getTransitLines().containsKey(transitLineId)); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), + "Schedule should include transit line"); TransitLine transitLine = transitScheduleNew.getTransitLines().get(transitLineId); - assertTrue("Schedule should include transit route", - transitLine.getRoutes().containsKey(transitRouteId)); + assertTrue(transitLine.getRoutes().containsKey(transitRouteId), + "Schedule should include transit route"); TransitRoute transitRoute = transitLine.getRoutes().get(transitRouteId); int stopCntNew = transitRoute.getStops().size(); - assertEquals("transitRoute should contain same number of stops as before modification", - stopCntOld, stopCntNew); + assertEquals(stopCntOld, stopCntNew, "transitRoute should contain same number of stops as before modification"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } @@ -336,16 +333,15 @@ void testTrimEnds_AllIn() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("schedule should include empty transit line", - transitScheduleNew.getTransitLines().containsKey(transitLineId)); - assertEquals("transitLine should no longer contain any routes", - transitScheduleNew.getTransitLines().get(transitLineId).getRoutes().size(), 0); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), + "schedule should include empty transit line"); + assertEquals(transitScheduleNew.getTransitLines().get(transitLineId).getRoutes().size(), 0, "transitLine should no longer contain any routes"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } @@ -388,22 +384,18 @@ void testTrimEnds_HalfIn() { Id firstStopNew = transitRouteNew.getStops().get(0).getStopFacility().getId(); Id lastStopNew = transitRouteNew.getStops().get(sizeNew - 1).getStopFacility().getId(); - Assert.assertTrue("modified route should have less stops as original route", - sizeOld > sizeNew); - assertEquals("there should be no stops within the zone", - 0, inCntNew); - assertEquals("number of stops outside of zone should remain same", - outCntOld, outCntNew); - assertEquals("first stop of old and new route should be same", - firstStopOld, firstStopNew); - assertNotEquals("last stop of old and new route should be different", - lastStopOld, lastStopNew); + Assertions.assertTrue(sizeOld > sizeNew, + "modified route should have less stops as original route"); + assertEquals(0, inCntNew, "there should be no stops within the zone"); + assertEquals(outCntOld, outCntNew, "number of stops outside of zone should remain same"); + assertEquals(firstStopOld, firstStopNew, "first stop of old and new route should be same"); + assertNotEquals(lastStopOld, lastStopNew, "last stop of old and new route should be different"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } /** @@ -439,18 +431,16 @@ void testTrimEnds_MiddleIn() { int numStopsNew = routeNew.getStops().size(); int numLinksNew = routeNew.getRoute().getLinkIds().size(); - Assert.assertTrue("line should still exist", - transitScheduleNew.getTransitLines().containsKey(transitLineId)); - Assert.assertEquals("new route should contain same number of stops as old one", - numStopsOld, numStopsNew); - Assert.assertEquals("new route should contain same number of links as old one", - numLinksOld, numLinksNew); + Assertions.assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), + "line should still exist"); + Assertions.assertEquals(numStopsOld, numStopsNew, "new route should contain same number of stops as old one"); + Assertions.assertEquals(numLinksOld, numLinksNew, "new route should contain same number of links as old one"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } @@ -475,14 +465,14 @@ void testSkipStops_AllIn() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("sched should include empty transit line", transitScheduleNew.getTransitLines().containsKey(transitLineId)); - assertEquals("transitLine should not longer contain any routes", transitScheduleNew.getTransitLines().get(transitLineId).getRoutes().size(), 0); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), "sched should include empty transit line"); + assertEquals(transitScheduleNew.getTransitLines().get(transitLineId).getRoutes().size(), 0, "transitLine should not longer contain any routes"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } @@ -520,20 +510,18 @@ void testSkipStops_HalfIn() { int outCntNew = countStopsOutsideZone(transitRouteNew, stopsInZone); int numLinksNew = transitRouteNew.getRoute().getLinkIds().size(); - Assert.assertTrue("there should be less stops after the modification", - sizeOld > sizeNew); - assertTrue("new route should have less links than old route", - numLinksNew < numLinksOld); - assertEquals("there should only be one stop within the zone", - 1, inCntNew); - assertEquals("the number of stops outside of zone should remain same", - outCntOld, outCntNew); + Assertions.assertTrue(sizeOld > sizeNew, + "there should be less stops after the modification"); + assertTrue(numLinksNew < numLinksOld, + "new route should have less links than old route"); + assertEquals(1, inCntNew, "there should only be one stop within the zone"); + assertEquals(outCntOld, outCntNew, "the number of stops outside of zone should remain same"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } @@ -571,21 +559,18 @@ void testSkipStops_MiddleIn() { int numLinksNew = transitRouteNew.getRoute().getLinkIds().size(); int inCntNew = countStopsInZone(transitRouteNew, stopsInZone); - Assert.assertTrue("line should still exist", - transitScheduleNew.getTransitLines().containsKey(transitLineId)); - Assert.assertNotEquals("new route should NOT contain same number of stops as old one", - numStopsOld, numStopsNew); - Assert.assertEquals("new route should contain same number of links as old one", - numLinksOld, numLinksNew); - Assert.assertEquals("new route should only have two stops within zone, one per zone entrance/exit", - 2, inCntNew); + Assertions.assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), + "line should still exist"); + Assertions.assertNotEquals(numStopsOld, numStopsNew, "new route should NOT contain same number of stops as old one"); + Assertions.assertEquals(numLinksOld, numLinksNew, "new route should contain same number of links as old one"); + Assertions.assertEquals(2, inCntNew, "new route should only have two stops within zone, one per zone entrance/exit"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } /** @@ -611,16 +596,15 @@ void testSplitRoutes_AllIn() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("schedule should include empty transit line", - transitScheduleNew.getTransitLines().containsKey(transitLineId)); - assertEquals("transitLine should not longer contain any routes", - 0, transitScheduleNew.getTransitLines().get(transitLineId).getRoutes().size()); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), + "schedule should include empty transit line"); + assertEquals(0, transitScheduleNew.getTransitLines().get(transitLineId).getRoutes().size(), "transitLine should not longer contain any routes"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } /** @@ -660,18 +644,16 @@ void testSplitRoutes_HalfIn() { int inCntNew = countStopsInZone(transitRouteNew, stopsInZone); int outCntNew = countStopsOutsideZone(transitRouteNew, stopsInZone); - assertTrue("new route should have less stops than old route", - sizeOld > sizeNew); - assertEquals("there should only be one stop within the zone", - 1, inCntNew); - assertEquals("# of stops outside of zone should remain same", - outCntOld, outCntNew); + assertTrue(sizeOld > sizeNew, + "new route should have less stops than old route"); + assertEquals(1, inCntNew, "there should only be one stop within the zone"); + assertEquals(outCntOld, outCntNew, "# of stops outside of zone should remain same"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } /** @@ -701,7 +683,7 @@ void testSplitRoutes_MiddleIn() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("line should still exist", transitScheduleNew.getTransitLines().containsKey(transitLineId)); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), "line should still exist"); TransitLine transitLineNew = transitScheduleNew.getTransitLines().get(transitLineId); assertTrue(transitLineNew.getRoutes().containsKey(Id.create("161---17326_700_22_split1", TransitRoute.class))); @@ -720,14 +702,14 @@ void testSplitRoutes_MiddleIn() { int inCntNew1 = countStopsInZone(transitRouteNew1, stopsInZone); int inCntNew2 = countStopsInZone(transitRouteNew2, stopsInZone); - Assert.assertEquals("new route #1 should only have one stop within zone", 1, inCntNew1); - Assert.assertEquals("new route #2 should only have one stop within zone", 1, inCntNew2); + Assertions.assertEquals(1, inCntNew1, "new route #1 should only have one stop within zone"); + Assertions.assertEquals(1, inCntNew2, "new route #2 should only have one stop within zone"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } @@ -779,7 +761,7 @@ void testSplitRoutes_MiddleIn_Hub_ValidateReach() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("line should still exist", transitScheduleNew.getTransitLines().containsKey(transitLineId)); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), "line should still exist"); TransitLine transitLineNew = transitScheduleNew.getTransitLines().get(transitLineId); assertTrue(transitLineNew.getRoutes().containsKey(Id.create("161---17326_700_22_split1", TransitRoute.class))); @@ -798,14 +780,14 @@ void testSplitRoutes_MiddleIn_Hub_ValidateReach() { int inCntNew1 = countStopsInZone(transitRouteNew1, stopsInZone); int inCntNew2 = countStopsInZone(transitRouteNew2, stopsInZone); - assertEquals("new route #1 should have three stop within zone", 3, inCntNew1); - assertEquals("new route #2 should have one stop within zone", 1, inCntNew2); + assertEquals(3, inCntNew1, "new route #1 should have three stop within zone"); + assertEquals(1, inCntNew2, "new route #2 should have one stop within zone"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } /** @@ -847,7 +829,7 @@ void testSplitRoutes_MiddleIn_Hub_IncludeFirstHubInZone() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("line should still exist", transitScheduleNew.getTransitLines().containsKey(transitLineId)); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), "line should still exist"); TransitLine transitLineNew = transitScheduleNew.getTransitLines().get(transitLineId); assertTrue(transitLineNew.getRoutes().containsKey(Id.create("161---17326_700_22_split1", TransitRoute.class))); @@ -867,23 +849,19 @@ void testSplitRoutes_MiddleIn_Hub_IncludeFirstHubInZone() { int inCntNew2 = countStopsInZone(transitRouteNew2, stopsInZone); - assertEquals("new route #1 should have three stops within zone", - 3, inCntNew1); - assertEquals("new route #2 should have four stops within zone", - 4, inCntNew2); + assertEquals(3, inCntNew1, "new route #1 should have three stops within zone"); + assertEquals(4, inCntNew2, "new route #2 should have four stops within zone"); Id idRoute1 = transitRouteNew1.getStops().get(transitRouteNew1.getStops().size() - 1).getStopFacility().getId(); - assertEquals("last stop of route #1 should be the left hub", - facIdLeft, idRoute1); + assertEquals(facIdLeft, idRoute1, "last stop of route #1 should be the left hub"); Id idRoute2 = transitRouteNew2.getStops().get(0).getStopFacility().getId(); - assertEquals("first stop of route #2 should be the right hub", - facIdRight, idRoute2); + assertEquals(facIdRight, idRoute2, "first stop of route #2 should be the right hub"); // Test vehicles Set> vehiclesUsedInTransitSchedule = getVehiclesUsedInTransitSchedule(transitScheduleNew); Set> vehiclesInVehiclesNew = results.getValue().getVehicles().keySet(); - Assert.assertTrue("TransitVehicles should contain all vehicles used in new TransitSchedule", - vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule)); + Assertions.assertTrue(vehiclesInVehiclesNew.containsAll(vehiclesUsedInTransitSchedule), + "TransitVehicles should contain all vehicles used in new TransitSchedule"); } /** @@ -930,7 +908,7 @@ void testSplitRoutes_MiddleIn_Hub_MultipleHubs() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("line should still exist", transitScheduleNew.getTransitLines().containsKey(transitLineId)); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), "line should still exist"); TransitLine transitLineNew = transitScheduleNew.getTransitLines().get(transitLineId); assertTrue(transitLineNew.getRoutes().containsKey(Id.create("161---17326_700_22_split1", TransitRoute.class))); @@ -949,8 +927,8 @@ void testSplitRoutes_MiddleIn_Hub_MultipleHubs() { int inCntNew1 = countStopsInZone(transitRouteNew1, stopsInZone); int inCntNew2 = countStopsInZone(transitRouteNew2, stopsInZone); - assertEquals("new route #1 should have five stop within zone", 5, inCntNew1); - assertEquals("new route #2 should have one stop within zone", 1, inCntNew2); + assertEquals(5, inCntNew1, "new route #1 should have five stop within zone"); + assertEquals(1, inCntNew2, "new route #2 should have one stop within zone"); } @@ -987,7 +965,7 @@ void testSplitRoutes_MiddleIn_Hub_OverlapRoutes() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("line should still exist", transitScheduleNew.getTransitLines().containsKey(transitLineId)); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), "line should still exist"); TransitLine transitLineNew = transitScheduleNew.getTransitLines().get(transitLineId); assertTrue(transitLineNew.getRoutes().containsKey(Id.create("161---17326_700_22_split1", TransitRoute.class))); @@ -1001,7 +979,7 @@ void testSplitRoutes_MiddleIn_Hub_OverlapRoutes() { assertEquals(transitRouteOld.getStops().size(), transitRouteNew1.getStops().size()); int inCntNew1 = countStopsInZone(transitRouteNew1, stopsInZone); - assertEquals("new route #1 should have 19 stops within zone", 19, inCntNew1); + assertEquals(19, inCntNew1, "new route #1 should have 19 stops within zone"); } @@ -1038,7 +1016,7 @@ void testSplitRoutes_MiddleIn_AllowableStopsWithin() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("line should still exist", transitScheduleNew.getTransitLines().containsKey(transitLineId)); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), "line should still exist"); TransitLine transitLineNew = transitScheduleNew.getTransitLines().get(transitLineId); assertTrue(transitLineNew.getRoutes().containsKey(Id.create("161---17326_700_22_split1", TransitRoute.class))); @@ -1054,7 +1032,7 @@ void testSplitRoutes_MiddleIn_AllowableStopsWithin() { int inCntNew1 = countStopsInZone(routeNew1, stopsInZone); - assertEquals("new route #1 should have 19 stops within zone", 19, inCntNew1); + assertEquals(19, inCntNew1, "new route #1 should have 19 stops within zone"); } @@ -1085,7 +1063,7 @@ void testDeparturesAndOffsetsAndDescription() { // After trim TransitSchedule transitScheduleNew = results.getKey(); - assertTrue("line should still exist", transitScheduleNew.getTransitLines().containsKey(transitLineId)); + assertTrue(transitScheduleNew.getTransitLines().containsKey(transitLineId), "line should still exist"); TransitLine transitLineNew = transitScheduleNew.getTransitLines().get(transitLineId); assertTrue(transitLineNew.getRoutes().containsKey(Id.create("161---17326_700_22_split1", TransitRoute.class))); @@ -1102,15 +1080,15 @@ void testDeparturesAndOffsetsAndDescription() { //Start of left route TransitRouteStop routeNew1Start = transitRouteNew1.getStops().get(0); - Assert.assertEquals(0., routeNew1Start.getDepartureOffset().seconds(),0.); - Assert.assertEquals(0., routeNew1Start.getArrivalOffset().seconds(), 0.); + Assertions.assertEquals(0., routeNew1Start.getDepartureOffset().seconds(),0.); + Assertions.assertEquals(0., routeNew1Start.getArrivalOffset().seconds(), 0.); //End of first route TransitRouteStop routeNew1End = transitRouteNew1.getStops().get(routeNew1size - 1); TransitRouteStop routeOld1End = transitRouteOld.getStops().get(routeNew1size - 1); - Assert.assertEquals(routeOld1End.getDepartureOffset(), routeNew1End.getDepartureOffset()); - Assert.assertEquals(routeOld1End.getArrivalOffset(), routeNew1End.getArrivalOffset()); + Assertions.assertEquals(routeOld1End.getDepartureOffset(), routeNew1End.getDepartureOffset()); + Assertions.assertEquals(routeOld1End.getArrivalOffset(), routeNew1End.getArrivalOffset()); //Start of second route TransitRouteStop routeNew2Start = transitRouteNew2.getStops().get(0); @@ -1118,44 +1096,44 @@ void testDeparturesAndOffsetsAndDescription() { double deltaSeconds = routeOld2Start.getArrivalOffset().seconds(); - Assert.assertEquals(0., routeNew2Start.getDepartureOffset().seconds(), 0.); - Assert.assertEquals(0., routeNew2Start.getArrivalOffset().seconds(), 0.); + Assertions.assertEquals(0., routeNew2Start.getDepartureOffset().seconds(), 0.); + Assertions.assertEquals(0., routeNew2Start.getArrivalOffset().seconds(), 0.); //End of second route TransitRouteStop routeNew2End = transitRouteNew2.getStops().get(routeNew2Size - 1); TransitRouteStop routeOld2End = transitRouteOld.getStops().get(routeOldSize - 1); - Assert.assertEquals(routeOld2End.getDepartureOffset().seconds() - deltaSeconds, routeNew2End.getDepartureOffset().seconds(), 0.); - Assert.assertEquals(routeOld2End.getArrivalOffset().seconds() - deltaSeconds, routeNew2End.getArrivalOffset().seconds(), 0.); + Assertions.assertEquals(routeOld2End.getDepartureOffset().seconds() - deltaSeconds, routeNew2End.getDepartureOffset().seconds(), 0.); + Assertions.assertEquals(routeOld2End.getArrivalOffset().seconds() - deltaSeconds, routeNew2End.getArrivalOffset().seconds(), 0.); // Check Departures - Assert.assertEquals(transitRouteOld.getDepartures().size(), transitRouteNew1.getDepartures().size()); - Assert.assertEquals(transitRouteOld.getDepartures().size(), transitRouteNew2.getDepartures().size()); + Assertions.assertEquals(transitRouteOld.getDepartures().size(), transitRouteNew1.getDepartures().size()); + Assertions.assertEquals(transitRouteOld.getDepartures().size(), transitRouteNew2.getDepartures().size()); for (Departure departureOld : transitRouteOld.getDepartures().values()) { Id idOld = departureOld.getId(); double departureTimeOld = departureOld.getDepartureTime(); Id vehicleIdOld = departureOld.getVehicleId(); Id idNew1 = Id.create(idOld.toString() + "_split1", Departure.class); - Assert.assertTrue(transitRouteNew1.getDepartures().containsKey(idNew1)); + Assertions.assertTrue(transitRouteNew1.getDepartures().containsKey(idNew1)); Departure departureNew1 = transitRouteNew1.getDepartures().get(idNew1); - Assert.assertEquals(vehicleIdOld.toString() + "_split1", departureNew1.getVehicleId().toString()); - Assert.assertEquals(departureTimeOld, departureNew1.getDepartureTime(), 0.); + Assertions.assertEquals(vehicleIdOld.toString() + "_split1", departureNew1.getVehicleId().toString()); + Assertions.assertEquals(departureTimeOld, departureNew1.getDepartureTime(), 0.); Id idNew2 = Id.create(idOld.toString() + "_split2", Departure.class); - Assert.assertTrue(transitRouteNew2.getDepartures().containsKey(idNew2)); + Assertions.assertTrue(transitRouteNew2.getDepartures().containsKey(idNew2)); Departure departureNew2 = transitRouteNew2.getDepartures().get(idNew2); - Assert.assertEquals(vehicleIdOld.toString() + "_split2", departureNew2.getVehicleId().toString()); - Assert.assertEquals(departureTimeOld + deltaSeconds, departureNew2.getDepartureTime(), 0.); + Assertions.assertEquals(vehicleIdOld.toString() + "_split2", departureNew2.getVehicleId().toString()); + Assertions.assertEquals(departureTimeOld + deltaSeconds, departureNew2.getDepartureTime(), 0.); } - Assert.assertEquals("test123", transitRouteNew1.getDescription()); - Assert.assertEquals("test123", transitRouteNew2.getDescription()); + Assertions.assertEquals("test123", transitRouteNew1.getDescription()); + Assertions.assertEquals("test123", transitRouteNew2.getDescription()); - Assert.assertEquals(transitRouteOld.getTransportMode(), transitRouteNew1.getTransportMode()); - Assert.assertEquals(transitRouteOld.getTransportMode(), transitRouteNew2.getTransportMode()); + Assertions.assertEquals(transitRouteOld.getTransportMode(), transitRouteNew1.getTransportMode()); + Assertions.assertEquals(transitRouteOld.getTransportMode(), transitRouteNew2.getTransportMode()); // transitScheduleNew.getAttributes(); diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java index ba7aac9976a..dc39db4c237 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java @@ -1,7 +1,7 @@ package playground.vsp.scoring; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -116,19 +116,19 @@ void testMoneyScore(){ ScoringParameters paramsRich = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("highIncome"))); CharyparNagelMoneyScoring moneyScoringRich = new CharyparNagelMoneyScoring(paramsRich); moneyScoringRich.addMoney(100); - Assert.assertEquals("for the rich person, 100 money units should be equal to a score of ", 20 * 1./1.5 * 100, moneyScoringRich.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(20 * 1./1.5 * 100, moneyScoringRich.getScore(), MatsimTestUtils.EPSILON, "for the rich person, 100 money units should be equal to a score of "); ScoringParameters paramsPoor = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("lowIncome"))); CharyparNagelMoneyScoring moneyScoringPoor = new CharyparNagelMoneyScoring(paramsPoor); moneyScoringPoor.addMoney(100); - Assert.assertEquals("for the poor person, 100 money units should be equal to a score of ", 20 * 1./0.5 * 100, moneyScoringPoor.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(20 * 1./0.5 * 100, moneyScoringPoor.getScore(), MatsimTestUtils.EPSILON, "for the poor person, 100 money units should be equal to a score of "); - Assert.assertTrue("100 money units should worth more for a poor person than for a rich person", moneyScoringPoor.getScore() > moneyScoringRich.getScore()); + Assertions.assertTrue(moneyScoringPoor.getScore() > moneyScoringRich.getScore(), "100 money units should worth more for a poor person than for a rich person"); } private void makeAssert(ScoringParameters params, double income, double marginalUtilityOfWaitingPt_s){ - Assert.assertEquals("marginalUtilityOfMoney is wrong", 20 * 1 / income , params.marginalUtilityOfMoney, 0.); - Assert.assertEquals("marginalUtilityOfWaitingPt_s is wrong", marginalUtilityOfWaitingPt_s , params.marginalUtilityOfWaitingPt_s, 0.); + Assertions.assertEquals(20 * 1 / income , params.marginalUtilityOfMoney, 0., "marginalUtilityOfMoney is wrong"); + Assertions.assertEquals(marginalUtilityOfWaitingPt_s , params.marginalUtilityOfWaitingPt_s, 0., "marginalUtilityOfWaitingPt_s is wrong"); } diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java index a6c9cdbb8d0..35fa3d927ba 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java @@ -1,7 +1,7 @@ package playground.vsp.scoring; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -156,19 +156,19 @@ void testMoneyScore(){ ScoringParameters paramsRich = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("highIncome"))); CharyparNagelMoneyScoring moneyScoringRich = new CharyparNagelMoneyScoring(paramsRich); moneyScoringRich.addMoney(100); - Assert.assertEquals("for the rich person, 100 money units should be equal to a score of 66.66", 1./1.5 * 100, moneyScoringRich.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1./1.5 * 100, moneyScoringRich.getScore(), MatsimTestUtils.EPSILON, "for the rich person, 100 money units should be equal to a score of 66.66"); ScoringParameters paramsPoor = personScoringParams.getScoringParameters(population.getPersons().get(Id.createPersonId("lowIncome"))); CharyparNagelMoneyScoring moneyScoringPoor = new CharyparNagelMoneyScoring(paramsPoor); moneyScoringPoor.addMoney(100); - Assert.assertEquals("for the poor person, 100 money units should be equal to a score of 200.00", 1./0.5 * 100, moneyScoringPoor.getScore(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1./0.5 * 100, moneyScoringPoor.getScore(), MatsimTestUtils.EPSILON, "for the poor person, 100 money units should be equal to a score of 200.00"); - Assert.assertTrue("100 money units should worth more for a poor person than for a rich person", moneyScoringPoor.getScore() > moneyScoringRich.getScore()); + Assertions.assertTrue(moneyScoringPoor.getScore() > moneyScoringRich.getScore(), "100 money units should worth more for a poor person than for a rich person"); } private void makeAssert(ScoringParameters params, double income, double marginalUtilityOfWaitingPt_s){ - Assert.assertEquals("marginalUtilityOfMoney is wrong", 1 / income , params.marginalUtilityOfMoney, 0.); - Assert.assertEquals("marginalUtilityOfWaitingPt_s is wrong", marginalUtilityOfWaitingPt_s , params.marginalUtilityOfWaitingPt_s, 0.); + Assertions.assertEquals(1 / income , params.marginalUtilityOfMoney, 0., "marginalUtilityOfMoney is wrong"); + Assertions.assertEquals(marginalUtilityOfWaitingPt_s , params.marginalUtilityOfWaitingPt_s, 0., "marginalUtilityOfWaitingPt_s is wrong"); } diff --git a/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java b/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java index eb432ad08a5..b9b49e15c95 100644 --- a/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java @@ -25,8 +25,8 @@ import ch.sbb.matsim.config.SwissRailRaptorConfigGroup.RouteSelectorParameterSet; import ch.sbb.matsim.routing.pt.raptor.RaptorStopFinder.Direction; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.Config; @@ -63,10 +63,10 @@ void testConfigIO_general() { SwissRailRaptorConfigGroup config2 = writeRead(config1); // do checks - Assert.assertTrue(config2.isUseRangeQuery()); - Assert.assertTrue(config2.isUseIntermodalAccessEgress()); - Assert.assertTrue(config2.isUseModeMappingForPassengers()); - Assert.assertEquals(0.0031 * 3600, config2.getTransferPenaltyCostPerTravelTimeHour(), 0.0); + Assertions.assertTrue(config2.isUseRangeQuery()); + Assertions.assertTrue(config2.isUseIntermodalAccessEgress()); + Assertions.assertTrue(config2.isUseModeMappingForPassengers()); + Assertions.assertEquals(0.0031 * 3600, config2.getTransferPenaltyCostPerTravelTimeHour(), 0.0); } @Test @@ -92,20 +92,20 @@ void testConfigIO_rangeQuery() { SwissRailRaptorConfigGroup config2 = writeRead(config1); // do checks - Assert.assertTrue(config2.isUseRangeQuery()); + Assertions.assertTrue(config2.isUseRangeQuery()); RangeQuerySettingsParameterSet range1 = config2.getRangeQuerySettings(null); - Assert.assertNotNull(range1); - Assert.assertEquals(0, range1.getSubpopulations().size()); - Assert.assertEquals(10*60, range1.getMaxEarlierDeparture()); - Assert.assertEquals(59*60, range1.getMaxLaterDeparture()); + Assertions.assertNotNull(range1); + Assertions.assertEquals(0, range1.getSubpopulations().size()); + Assertions.assertEquals(10*60, range1.getMaxEarlierDeparture()); + Assertions.assertEquals(59*60, range1.getMaxLaterDeparture()); RangeQuerySettingsParameterSet range2 = config2.getRangeQuerySettings("inflexible"); - Assert.assertNotNull(range2); - Assert.assertEquals(1, range2.getSubpopulations().size()); - Assert.assertEquals("inflexible", range2.getSubpopulations().iterator().next()); - Assert.assertEquals(60, range2.getMaxEarlierDeparture()); - Assert.assertEquals(15*60, range2.getMaxLaterDeparture()); + Assertions.assertNotNull(range2); + Assertions.assertEquals(1, range2.getSubpopulations().size()); + Assertions.assertEquals("inflexible", range2.getSubpopulations().iterator().next()); + Assertions.assertEquals(60, range2.getMaxEarlierDeparture()); + Assertions.assertEquals(15*60, range2.getMaxLaterDeparture()); } @Test @@ -133,21 +133,21 @@ void testConfigIO_routeSelector() { SwissRailRaptorConfigGroup config2 = writeRead(config1); // do checks - Assert.assertTrue(config2.isUseRangeQuery()); + Assertions.assertTrue(config2.isUseRangeQuery()); RouteSelectorParameterSet selector1 = config2.getRouteSelector(null); - Assert.assertNotNull(selector1); - Assert.assertEquals(0, selector1.getSubpopulations().size()); - Assert.assertEquals(600, selector1.getBetaTransfers(), 0.0); - Assert.assertEquals(1.6, selector1.getBetaDepartureTime(), 0.0); - Assert.assertEquals(1.3, selector1.getBetaTravelTime(), 0.0); + Assertions.assertNotNull(selector1); + Assertions.assertEquals(0, selector1.getSubpopulations().size()); + Assertions.assertEquals(600, selector1.getBetaTransfers(), 0.0); + Assertions.assertEquals(1.6, selector1.getBetaDepartureTime(), 0.0); + Assertions.assertEquals(1.3, selector1.getBetaTravelTime(), 0.0); RouteSelectorParameterSet selector2 = config2.getRouteSelector("inflexible"); - Assert.assertNotNull(selector2); - Assert.assertEquals(1, selector2.getSubpopulations().size()); - Assert.assertEquals(500, selector2.getBetaTransfers(), 0.0); - Assert.assertEquals(5, selector2.getBetaDepartureTime(), 0.0); - Assert.assertEquals(1.2, selector2.getBetaTravelTime(), 0.0); + Assertions.assertNotNull(selector2); + Assertions.assertEquals(1, selector2.getSubpopulations().size()); + Assertions.assertEquals(500, selector2.getBetaTransfers(), 0.0); + Assertions.assertEquals(5, selector2.getBetaDepartureTime(), 0.0); + Assertions.assertEquals(1.2, selector2.getBetaTravelTime(), 0.0); } @Test @@ -184,35 +184,35 @@ void testConfigIO_intermodalAccessEgress() { SwissRailRaptorConfigGroup config2 = writeRead(config1); // do checks - Assert.assertTrue(config2.isUseIntermodalAccessEgress()); + Assertions.assertTrue(config2.isUseIntermodalAccessEgress()); List parameterSets = config2.getIntermodalAccessEgressParameterSets(); - Assert.assertNotNull(parameterSets); - Assert.assertEquals("wrong number of parameter sets",2, parameterSets.size()); + Assertions.assertNotNull(parameterSets); + Assertions.assertEquals(2, parameterSets.size(), "wrong number of parameter sets"); IntermodalAccessEgressParameterSet paramSet1 = parameterSets.get(0); - Assert.assertEquals(TransportMode.bike, paramSet1.getMode()); - Assert.assertEquals(2000, paramSet1.getMaxRadius(), 0.0); - Assert.assertEquals(1500, paramSet1.getInitialSearchRadius(), 0.0); - Assert.assertEquals(1000, paramSet1.getSearchExtensionRadius(), 0.0); - Assert.assertEquals(0.01, paramSet1.getShareTripSearchRadius(), 0.0); - Assert.assertNull(paramSet1.getPersonFilterAttribute()); - Assert.assertNull(paramSet1.getPersonFilterValue()); - Assert.assertNull(paramSet1.getLinkIdAttribute()); - Assert.assertEquals("bikeAndRail", paramSet1.getStopFilterAttribute()); - Assert.assertEquals("true", paramSet1.getStopFilterValue()); + Assertions.assertEquals(TransportMode.bike, paramSet1.getMode()); + Assertions.assertEquals(2000, paramSet1.getMaxRadius(), 0.0); + Assertions.assertEquals(1500, paramSet1.getInitialSearchRadius(), 0.0); + Assertions.assertEquals(1000, paramSet1.getSearchExtensionRadius(), 0.0); + Assertions.assertEquals(0.01, paramSet1.getShareTripSearchRadius(), 0.0); + Assertions.assertNull(paramSet1.getPersonFilterAttribute()); + Assertions.assertNull(paramSet1.getPersonFilterValue()); + Assertions.assertNull(paramSet1.getLinkIdAttribute()); + Assertions.assertEquals("bikeAndRail", paramSet1.getStopFilterAttribute()); + Assertions.assertEquals("true", paramSet1.getStopFilterValue()); IntermodalAccessEgressParameterSet paramSet2 = parameterSets.get(1); - Assert.assertEquals("sff", paramSet2.getMode()); - Assert.assertEquals(5000, paramSet2.getMaxRadius(), 0.0); - Assert.assertEquals(3000, paramSet2.getInitialSearchRadius(), 0.0); - Assert.assertEquals(2000, paramSet2.getSearchExtensionRadius(), 0.0); - Assert.assertEquals(Double.POSITIVE_INFINITY, paramSet2.getShareTripSearchRadius(), 0.0); - Assert.assertEquals("sff_user", paramSet2.getPersonFilterAttribute()); - Assert.assertEquals("true", paramSet2.getPersonFilterValue()); - Assert.assertEquals("linkId_sff", paramSet2.getLinkIdAttribute()); - Assert.assertEquals("stop-type", paramSet2.getStopFilterAttribute()); - Assert.assertEquals("hub", paramSet2.getStopFilterValue()); + Assertions.assertEquals("sff", paramSet2.getMode()); + Assertions.assertEquals(5000, paramSet2.getMaxRadius(), 0.0); + Assertions.assertEquals(3000, paramSet2.getInitialSearchRadius(), 0.0); + Assertions.assertEquals(2000, paramSet2.getSearchExtensionRadius(), 0.0); + Assertions.assertEquals(Double.POSITIVE_INFINITY, paramSet2.getShareTripSearchRadius(), 0.0); + Assertions.assertEquals("sff_user", paramSet2.getPersonFilterAttribute()); + Assertions.assertEquals("true", paramSet2.getPersonFilterValue()); + Assertions.assertEquals("linkId_sff", paramSet2.getLinkIdAttribute()); + Assertions.assertEquals("stop-type", paramSet2.getStopFilterAttribute()); + Assertions.assertEquals("hub", paramSet2.getStopFilterValue()); } @Test @@ -241,25 +241,25 @@ void testConfigIO_modeMappings() { SwissRailRaptorConfigGroup config2 = writeRead(config1); // do checks - Assert.assertTrue(config2.isUseModeMappingForPassengers()); + Assertions.assertTrue(config2.isUseModeMappingForPassengers()); ModeMappingForPassengersParameterSet trainMapping = config2.getModeMappingForPassengersParameterSet("train"); - Assert.assertNotNull(trainMapping); - Assert.assertEquals("train", trainMapping.getRouteMode()); - Assert.assertEquals("rail", trainMapping.getPassengerMode()); + Assertions.assertNotNull(trainMapping); + Assertions.assertEquals("train", trainMapping.getRouteMode()); + Assertions.assertEquals("rail", trainMapping.getPassengerMode()); ModeMappingForPassengersParameterSet tramMapping = config2.getModeMappingForPassengersParameterSet("tram"); - Assert.assertNotNull(tramMapping); - Assert.assertEquals("tram", tramMapping.getRouteMode()); - Assert.assertEquals("rail", tramMapping.getPassengerMode()); + Assertions.assertNotNull(tramMapping); + Assertions.assertEquals("tram", tramMapping.getRouteMode()); + Assertions.assertEquals("rail", tramMapping.getPassengerMode()); ModeMappingForPassengersParameterSet busMapping = config2.getModeMappingForPassengersParameterSet("bus"); - Assert.assertNotNull(busMapping); - Assert.assertEquals("bus", busMapping.getRouteMode()); - Assert.assertEquals("road", busMapping.getPassengerMode()); + Assertions.assertNotNull(busMapping); + Assertions.assertEquals("bus", busMapping.getRouteMode()); + Assertions.assertEquals("road", busMapping.getPassengerMode()); - Assert.assertNull(config2.getModeMappingForPassengersParameterSet("road")); - Assert.assertNull(config2.getModeMappingForPassengersParameterSet("ship")); + Assertions.assertNull(config2.getModeMappingForPassengersParameterSet("road")); + Assertions.assertNull(config2.getModeMappingForPassengersParameterSet("ship")); } private SwissRailRaptorConfigGroup writeRead(SwissRailRaptorConfigGroup config) { diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/CapacityDependentScoringTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/CapacityDependentScoringTest.java index 0518b08dcf2..5ea67dc3642 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/CapacityDependentScoringTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/CapacityDependentScoringTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package ch.sbb.matsim.routing.pt.raptor; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -91,8 +91,8 @@ void testScoring() { // in the normal case, it's a 15min trips at full cost, so it should be -6 * (1/4) = -1.5 // in the capacity dependent case, the vehicle is empty plus the passenger => occupancy = 0.2, thus the cost should only be 0.8 * original cost => -1.2 - Assert.assertEquals(-1.5, normalScore, 1e-7); - Assert.assertEquals(-1.2, capDepScore, 1e-7); + Assertions.assertEquals(-1.5, normalScore, 1e-7); + Assertions.assertEquals(-1.2, capDepScore, 1e-7); } private double calcScore(Fixture f, boolean capacityDependent) { diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/OccupancyTrackerTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/OccupancyTrackerTest.java index 809f316a4bd..9e362705b7a 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/OccupancyTrackerTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/OccupancyTrackerTest.java @@ -20,7 +20,7 @@ package ch.sbb.matsim.routing.pt.raptor; import ch.sbb.matsim.routing.pt.raptor.OccupancyData.DepartureData; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -67,67 +67,67 @@ void testGetNextDeparture() { DepartureData data; data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("06:45:00")); // before there is any vehicle - Assert.assertEquals(f.dep0, data.departureId); + Assertions.assertEquals(f.dep0, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("06:55:00")); // before we have any pax observations - Assert.assertEquals(f.dep0, data.departureId); + Assertions.assertEquals(f.dep0, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:00:00")); - Assert.assertEquals(f.dep0, data.departureId); + Assertions.assertEquals(f.dep0, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:00:30")); - Assert.assertEquals(f.dep0, data.departureId); + Assertions.assertEquals(f.dep0, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:00:31")); - Assert.assertEquals(f.dep1, data.departureId); + Assertions.assertEquals(f.dep1, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:05:00")); - Assert.assertEquals(f.dep1, data.departureId); + Assertions.assertEquals(f.dep1, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:06:00")); - Assert.assertEquals(f.dep1, data.departureId); + Assertions.assertEquals(f.dep1, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:06:01")); - Assert.assertEquals(f.dep2, data.departureId); + Assertions.assertEquals(f.dep2, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:11:00")); - Assert.assertEquals(f.dep2, data.departureId); + Assertions.assertEquals(f.dep2, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:11:01")); - Assert.assertEquals(f.dep3, data.departureId); + Assertions.assertEquals(f.dep3, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:18:00")); - Assert.assertEquals(f.dep3, data.departureId); + Assertions.assertEquals(f.dep3, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:18:05")); - Assert.assertEquals(f.dep3, data.departureId); + Assertions.assertEquals(f.dep3, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:22:00")); - Assert.assertEquals(f.dep3, data.departureId); + Assertions.assertEquals(f.dep3, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:24:00")); - Assert.assertEquals(f.dep3, data.departureId); + Assertions.assertEquals(f.dep3, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:24:03")); - Assert.assertEquals(f.dep5, data.departureId); + Assertions.assertEquals(f.dep5, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:29:00")); - Assert.assertEquals(f.dep5, data.departureId); + Assertions.assertEquals(f.dep5, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:35:00")); - Assert.assertEquals(f.dep5, data.departureId); + Assertions.assertEquals(f.dep5, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:40:00")); - Assert.assertEquals(f.dep5, data.departureId); + Assertions.assertEquals(f.dep5, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:50:00")); - Assert.assertEquals(f.dep5, data.departureId); + Assertions.assertEquals(f.dep5, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:50:05")); - Assert.assertEquals(f.dep5, data.departureId); + Assertions.assertEquals(f.dep5, data.departureId); data = occData.getNextAvailableDeparture(f.line1, f.route1, f.stop1, Time.parseTime("07:50:30")); - Assert.assertNull(data); + Assertions.assertNull(data); } @Test @@ -144,22 +144,22 @@ void testGetDepartureData() { DepartureData data; data = occData.getDepartureData(f.line1, f.route1, f.stop1, f.dep0); - Assert.assertEquals(0, data.paxCountAtDeparture); + Assertions.assertEquals(0, data.paxCountAtDeparture); data = occData.getDepartureData(f.line1, f.route1, f.stop1, f.dep1); - Assert.assertEquals(2, data.paxCountAtDeparture); + Assertions.assertEquals(2, data.paxCountAtDeparture); data = occData.getDepartureData(f.line1, f.route1, f.stop1, f.dep2); - Assert.assertEquals(2, data.paxCountAtDeparture); + Assertions.assertEquals(2, data.paxCountAtDeparture); data = occData.getDepartureData(f.line1, f.route1, f.stop1, f.dep3); - Assert.assertEquals(3, data.paxCountAtDeparture); + Assertions.assertEquals(3, data.paxCountAtDeparture); data = occData.getDepartureData(f.line1, f.route1, f.stop1, f.dep4); - Assert.assertEquals(0, data.paxCountAtDeparture); + Assertions.assertEquals(0, data.paxCountAtDeparture); data = occData.getDepartureData(f.line1, f.route1, f.stop1, f.dep5); - Assert.assertEquals(1, data.paxCountAtDeparture); + Assertions.assertEquals(1, data.paxCountAtDeparture); } private static class Fixture { diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorStopFinderTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorStopFinderTest.java index 1fe325b7801..1fad2beca84 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorStopFinderTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorStopFinderTest.java @@ -20,7 +20,7 @@ package ch.sbb.matsim.routing.pt.raptor; import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -104,7 +104,7 @@ void testDefaultStopFinder_EmptyInitialSearchRadius() { List legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(this.fromFac, this.toFac, 7 * 3600, f0.dummyPerson)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } @@ -135,19 +135,19 @@ void testDefaultStopFinder_EmptyInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -179,19 +179,19 @@ void testDefaultStopFinder_EmptyInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } } @@ -233,7 +233,7 @@ void testDefaultStopFinder_EmptyInitialSearchRadius_StopFilterAttributes() { List legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(this.fromFac, this.toFac, 7 * 3600, f0.dummyPerson)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } @@ -270,19 +270,19 @@ void testDefaultStopFinder_EmptyInitialSearchRadius_StopFilterAttributes() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -321,19 +321,19 @@ void testDefaultStopFinder_EmptyInitialSearchRadius_StopFilterAttributes() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -376,19 +376,19 @@ Initial_Search_Radius includes B (not "walkAccessible") System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } } @@ -421,7 +421,7 @@ void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius() { List legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(this.fromFac, this.toFac, 7 * 3600, f0.dummyPerson)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } @@ -453,19 +453,19 @@ void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -497,19 +497,19 @@ void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } } @@ -551,7 +551,7 @@ void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius_StopFil List legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(this.fromFac, this.toFac, 7 * 3600, f0.dummyPerson)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } @@ -589,19 +589,19 @@ void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius_StopFil System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -641,19 +641,19 @@ void testRandomAccessEgressModeRaptorStopFinder_EmptyInitialSearchRadius_StopFil System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -697,19 +697,19 @@ Initial_Search_Radius includes B (not "walkAccessible") System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } } @@ -758,19 +758,19 @@ void testDefaultStopFinder_HalfFullInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -803,19 +803,19 @@ void testDefaultStopFinder_HalfFullInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -848,19 +848,19 @@ void testDefaultStopFinder_HalfFullInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } } @@ -902,19 +902,19 @@ void testDefaultStopFinder_HalfFullInitialSearchRadius_StopFilterAttributes() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -954,19 +954,19 @@ void testDefaultStopFinder_HalfFullInitialSearchRadius_StopFilterAttributes() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } } @@ -1002,19 +1002,19 @@ void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1048,19 +1048,19 @@ void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1094,19 +1094,19 @@ void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } } @@ -1149,19 +1149,19 @@ void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadius_Stop System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1202,19 +1202,19 @@ void testRandomAccessEgressModeRaptorStopFinder_HalfFullInitialSearchRadius_Stop System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } } @@ -1265,19 +1265,19 @@ void testDefaultStopFinder_FullInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1312,19 +1312,19 @@ void testDefaultStopFinder_FullInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } } @@ -1370,19 +1370,19 @@ void testDefaultStopFinder_FullInitialSearchRadius_StopFilterAttributes() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1425,19 +1425,19 @@ void testDefaultStopFinder_FullInitialSearchRadius_StopFilterAttributes() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1477,19 +1477,19 @@ void testRandomAccessEgressModeRaptorStopFinder_FullInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1525,19 +1525,19 @@ void testRandomAccessEgressModeRaptorStopFinder_FullInitialSearchRadius() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } } @@ -1584,19 +1584,19 @@ void testRandomAccessEgressModeRaptorStopFinder_FullInitialSearchRadius_StopFilt System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1640,19 +1640,19 @@ void testRandomAccessEgressModeRaptorStopFinder_FullInitialSearchRadius_StopFilt System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("CC", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1713,19 +1713,19 @@ void testDefaultStopFinder_testMultipleModes() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals("zoomer", leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals("zoomer", leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1779,19 +1779,19 @@ void testDefaultStopFinder_testMultipleModes() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals("zoomer", leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals("zoomer", leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("DD", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); } @@ -1841,15 +1841,15 @@ void testDefaultStopFinder_testMultipleModes() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("AA", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("BB", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("XX", Link.class), leg.getRoute().getEndLinkId()); // leg = legs.get(2); // Assert.assertEquals(TransportMode.bike, leg.getMode()); // Assert.assertEquals(Id.create("XX", Link.class), leg.getRoute().getStartLinkId()); diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java index d401ec3ba52..6033cbdfdbd 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java @@ -20,8 +20,8 @@ package ch.sbb.matsim.routing.pt.raptor; import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigGroup; @@ -63,24 +63,24 @@ void testConfigLoading() { // first checks ConfigGroup srrConfig2 = config2.getModules().get(SwissRailRaptorConfigGroup.GROUP); - Assert.assertNotNull(srrConfig2); - Assert.assertEquals(ConfigGroup.class, srrConfig2.getClass()); + Assertions.assertNotNull(srrConfig2); + Assertions.assertEquals(ConfigGroup.class, srrConfig2.getClass()); // create RaptorConfig, test if SwissRailRaptorConfigGroup got created RaptorParameters raptorParams = RaptorUtils.createParameters(config2); srrConfig2 = config2.getModules().get(SwissRailRaptorConfigGroup.GROUP); - Assert.assertNotNull(srrConfig2); - Assert.assertEquals(SwissRailRaptorConfigGroup.class, srrConfig2.getClass()); + Assertions.assertNotNull(srrConfig2); + Assertions.assertEquals(SwissRailRaptorConfigGroup.class, srrConfig2.getClass()); - Assert.assertNotNull(raptorParams.getConfig()); - Assert.assertEquals(srrConfig2, raptorParams.getConfig()); + Assertions.assertNotNull(raptorParams.getConfig()); + Assertions.assertEquals(srrConfig2, raptorParams.getConfig()); RaptorParameters raptorParams2 = RaptorUtils.createParameters(config2); - Assert.assertEquals("the same config object should be returned in subsequent calls.", srrConfig2, raptorParams2.getConfig()); + Assertions.assertEquals(srrConfig2, raptorParams2.getConfig(), "the same config object should be returned in subsequent calls."); // check that the config is actually what we configured - Assert.assertTrue(raptorParams2.getConfig().isUseRangeQuery()); - Assert.assertTrue(raptorParams2.getConfig().isUseIntermodalAccessEgress()); - Assert.assertFalse(raptorParams2.getConfig().isUseModeMappingForPassengers()); + Assertions.assertTrue(raptorParams2.getConfig().isUseRangeQuery()); + Assertions.assertTrue(raptorParams2.getConfig().isUseIntermodalAccessEgress()); + Assertions.assertFalse(raptorParams2.getConfig().isUseModeMappingForPassengers()); } } diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorCapacitiesTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorCapacitiesTest.java index eaa6c0ddfc6..7ad33007806 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorCapacitiesTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorCapacitiesTest.java @@ -20,7 +20,7 @@ package ch.sbb.matsim.routing.pt.raptor; import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -89,23 +89,23 @@ void testUseSlowerAlternative() { Facility toFacility = new FakeFacility(new Coord(7100, 1100), Id.create("cd", Link.class)); List route1 = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFacility, toFacility, Time.parseTime("07:00:00"), null)); - Assert.assertNotNull(route1); + Assertions.assertNotNull(route1); System.out.println("uncongested route:"); for (PlanElement leg : route1) { System.out.println(leg.toString() + " > " + ((Leg)leg).getRoute().getRouteDescription()); } - Assert.assertEquals(3, route1.size()); + Assertions.assertEquals(3, route1.size()); Leg leg1 = (Leg) route1.get(0); - Assert.assertEquals("walk", leg1.getMode()); + Assertions.assertEquals("walk", leg1.getMode()); Leg leg2 = (Leg) route1.get(1); - Assert.assertEquals("pt", leg2.getMode()); + Assertions.assertEquals("pt", leg2.getMode()); TransitPassengerRoute paxRoute1 = (TransitPassengerRoute) leg2.getRoute(); - Assert.assertEquals(f.fastLineId, paxRoute1.getLineId()); + Assertions.assertEquals(f.fastLineId, paxRoute1.getLineId()); Leg leg3 = (Leg) route1.get(2); - Assert.assertEquals("walk", leg3.getMode()); + Assertions.assertEquals("walk", leg3.getMode()); // with delays at entering @@ -192,23 +192,23 @@ void testUseSlowerAlternative() { tracker.handleEvent(new VehicleDepartsAtFacilityEvent(Time.parseTime("07:20:30"), vehicle3, f.stopAId, 0)); List route2 = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFacility, toFacility, Time.parseTime("07:00:00"), null)); - Assert.assertNotNull(route2); + Assertions.assertNotNull(route2); System.out.println("congested route:"); for (PlanElement leg : route2) { System.out.println(leg.toString() + " > " + ((Leg)leg).getRoute().getRouteDescription()); } - Assert.assertEquals(3, route2.size()); + Assertions.assertEquals(3, route2.size()); leg1 = (Leg) route2.get(0); - Assert.assertEquals("walk", leg1.getMode()); + Assertions.assertEquals("walk", leg1.getMode()); leg2 = (Leg) route2.get(1); - Assert.assertEquals("pt", leg2.getMode()); + Assertions.assertEquals("pt", leg2.getMode()); TransitPassengerRoute paxRoute2 = (TransitPassengerRoute) leg2.getRoute(); - Assert.assertEquals(f.slowLineId, paxRoute2.getLineId()); + Assertions.assertEquals(f.slowLineId, paxRoute2.getLineId()); leg3 = (Leg) route2.get(2); - Assert.assertEquals("walk", leg3.getMode()); + Assertions.assertEquals("walk", leg3.getMode()); } private static class Fixture { diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorDataTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorDataTest.java index 6fbd90145a8..e28bd02ea2f 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorDataTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorDataTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package ch.sbb.matsim.routing.pt.raptor; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.pt.transitSchedule.api.TransitStopFacility; @@ -47,7 +47,7 @@ void testTransfersFromSchedule() { TransitStopFacility fromStop = data.routeStops[t.fromRouteStop].routeStop.getStopFacility(); TransitStopFacility toStop = data.routeStops[t.toRouteStop].routeStop.getStopFacility(); if (fromStop.getId().equals(stopId19) && toStop.getId().equals(stopId9)) { - Assert.fail("There should not be any transfer between stop facilities 19 and 9."); + Assertions.fail("There should not be any transfer between stop facilities 19 and 9."); } } @@ -63,8 +63,8 @@ void testTransfersFromSchedule() { foundTransferCount++; } } - Assert.assertEquals("wrong number of transfers between stop facilities 19 and 9.", 1, foundTransferCount); - Assert.assertEquals("number of transfers should have incrased.", data.transfers.length + 1, data2.transfers.length); + Assertions.assertEquals(1, foundTransferCount, "wrong number of transfers between stop facilities 19 and 9."); + Assertions.assertEquals(data.transfers.length + 1, data2.transfers.length, "number of transfers should have incrased."); // assign a high transfer time to a "default" transfer f.schedule.getMinimalTransferTimes().set(stopId5, stopId18, 456); @@ -74,12 +74,12 @@ void testTransfersFromSchedule() { TransitStopFacility fromStop = data3.routeStops[t.fromRouteStop].routeStop.getStopFacility(); TransitStopFacility toStop = data3.routeStops[t.toRouteStop].routeStop.getStopFacility(); if (fromStop.getId().equals(stopId5) && toStop.getId().equals(stopId18)) { - Assert.assertEquals("transfer has wrong transfer time.", 456, t.transferTime); + Assertions.assertEquals(456, t.transferTime, "transfer has wrong transfer time."); foundCorrectTransfer = true; } } - Assert.assertTrue("did not find overwritten transfer", foundCorrectTransfer); - Assert.assertEquals("number of transfers should have stayed the same.", data2.transfers.length, data3.transfers.length); + Assertions.assertTrue(foundCorrectTransfer, "did not find overwritten transfer"); + Assertions.assertEquals(data2.transfers.length, data3.transfers.length, "number of transfers should have stayed the same."); // assign a low transfer time to a "default" transfer f.schedule.getMinimalTransferTimes().set(stopId5, stopId18, 0.2); @@ -89,12 +89,12 @@ void testTransfersFromSchedule() { TransitStopFacility fromStop = data4.routeStops[t.fromRouteStop].routeStop.getStopFacility(); TransitStopFacility toStop = data4.routeStops[t.toRouteStop].routeStop.getStopFacility(); if (fromStop.getId().equals(stopId5) && toStop.getId().equals(stopId18)) { - Assert.assertEquals("transfer has wrong transfer time.", 1, t.transferTime); // transferTime gets rounded up to int vlues + Assertions.assertEquals(1, t.transferTime, "transfer has wrong transfer time."); // transferTime gets rounded up to int vlues foundCorrectTransfer = true; } } - Assert.assertTrue("did not find overwritten transfer", foundCorrectTransfer); - Assert.assertEquals("number of transfers should have stayed the same.", data2.transfers.length, data4.transfers.length); + Assertions.assertTrue(foundCorrectTransfer, "did not find overwritten transfer"); + Assertions.assertEquals(data2.transfers.length, data4.transfers.length, "number of transfers should have stayed the same."); } } diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorInVehicleCostTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorInVehicleCostTest.java index 05aa44fe5d2..846b4ee2cbe 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorInVehicleCostTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorInVehicleCostTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package ch.sbb.matsim.routing.pt.raptor; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -142,25 +142,25 @@ private void runTest(Fixture f, RaptorInVehicleCostCalculator inVehCostCalcualto Facility toFacility = new FakeFacility(new Coord(7100, 1100), Id.create("cd", Link.class)); List route1 = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFacility, toFacility, Time.parseTime("07:00:00"), null)); - Assert.assertNotNull(route1); + Assertions.assertNotNull(route1); System.out.println("calculated route:"); for (PlanElement leg : route1) { System.out.println(leg.toString() + " > " + ((Leg)leg).getRoute().getRouteDescription()); } - Assert.assertEquals(3, route1.size()); + Assertions.assertEquals(3, route1.size()); Leg leg1 = (Leg) route1.get(0); - Assert.assertEquals("walk", leg1.getMode()); + Assertions.assertEquals("walk", leg1.getMode()); Leg leg2 = (Leg) route1.get(1); - Assert.assertEquals("pt", leg2.getMode()); + Assertions.assertEquals("pt", leg2.getMode()); TransitPassengerRoute paxRoute1 = (TransitPassengerRoute) leg2.getRoute(); - Assert.assertEquals(expectedTransitLine, paxRoute1.getLineId()); + Assertions.assertEquals(expectedTransitLine, paxRoute1.getLineId()); Leg leg3 = (Leg) route1.get(2); - Assert.assertEquals("walk", leg3.getMode()); + Assertions.assertEquals("walk", leg3.getMode()); } private void fillExecutionTracker(Fixture f, OccupancyTracker tracker) { diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorIntermodalTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorIntermodalTest.java index 61ddb4ba6de..919dbbc9b4b 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorIntermodalTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorIntermodalTest.java @@ -21,7 +21,7 @@ import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; import ch.sbb.matsim.config.SwissRailRaptorConfigGroup.IntermodalAccessEgressParameterSet; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -110,27 +110,27 @@ void testIntermodalTrip() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 5, legs.size()); + Assertions.assertEquals(5, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("bike_3", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("bike_3", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("bike_3", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("bike_3", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(3); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(4); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } @Test @@ -186,32 +186,32 @@ void testIntermodalTrip_TripRouterIntegration() { System.out.println(pe); } - Assert.assertEquals("wrong number of PlanElements.", 9, planElements.size()); - Assert.assertTrue(planElements.get(0) instanceof Leg); - Assert.assertTrue(planElements.get(1) instanceof Activity); - Assert.assertTrue(planElements.get(2) instanceof Leg); - Assert.assertTrue(planElements.get(3) instanceof Activity); - Assert.assertTrue(planElements.get(4) instanceof Leg); - Assert.assertTrue(planElements.get(5) instanceof Activity); - Assert.assertTrue(planElements.get(6) instanceof Leg); - Assert.assertTrue(planElements.get(7) instanceof Activity); - Assert.assertTrue(planElements.get(8) instanceof Leg); - - Assert.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(1)).getType()); - Assert.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(3)).getType()); - Assert.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(5)).getType()); - Assert.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(7)).getType()); - - Assert.assertEquals(TransportMode.bike, ((Leg) planElements.get(0)).getMode()); - Assert.assertEquals(TransportMode.walk, ((Leg) planElements.get(2)).getMode()); - Assert.assertEquals(TransportMode.pt, ((Leg) planElements.get(4)).getMode()); - Assert.assertEquals(TransportMode.walk, ((Leg) planElements.get(6)).getMode()); - Assert.assertEquals(TransportMode.bike, ((Leg) planElements.get(8)).getMode()); - - Assert.assertEquals(0.0, ((Activity)planElements.get(1)).getMaximumDuration().seconds(), 0.0); - Assert.assertEquals(0.0, ((Activity)planElements.get(3)).getMaximumDuration().seconds(), 0.0); - Assert.assertEquals(0.0, ((Activity)planElements.get(5)).getMaximumDuration().seconds(), 0.0); - Assert.assertEquals(0.0, ((Activity)planElements.get(7)).getMaximumDuration().seconds(), 0.0); + Assertions.assertEquals(9, planElements.size(), "wrong number of PlanElements."); + Assertions.assertTrue(planElements.get(0) instanceof Leg); + Assertions.assertTrue(planElements.get(1) instanceof Activity); + Assertions.assertTrue(planElements.get(2) instanceof Leg); + Assertions.assertTrue(planElements.get(3) instanceof Activity); + Assertions.assertTrue(planElements.get(4) instanceof Leg); + Assertions.assertTrue(planElements.get(5) instanceof Activity); + Assertions.assertTrue(planElements.get(6) instanceof Leg); + Assertions.assertTrue(planElements.get(7) instanceof Activity); + Assertions.assertTrue(planElements.get(8) instanceof Leg); + + Assertions.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(1)).getType()); + Assertions.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(3)).getType()); + Assertions.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(5)).getType()); + Assertions.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(7)).getType()); + + Assertions.assertEquals(TransportMode.bike, ((Leg) planElements.get(0)).getMode()); + Assertions.assertEquals(TransportMode.walk, ((Leg) planElements.get(2)).getMode()); + Assertions.assertEquals(TransportMode.pt, ((Leg) planElements.get(4)).getMode()); + Assertions.assertEquals(TransportMode.walk, ((Leg) planElements.get(6)).getMode()); + Assertions.assertEquals(TransportMode.bike, ((Leg) planElements.get(8)).getMode()); + + Assertions.assertEquals(0.0, ((Activity)planElements.get(1)).getMaximumDuration().seconds(), 0.0); + Assertions.assertEquals(0.0, ((Activity)planElements.get(3)).getMaximumDuration().seconds(), 0.0); + Assertions.assertEquals(0.0, ((Activity)planElements.get(5)).getMaximumDuration().seconds(), 0.0); + Assertions.assertEquals(0.0, ((Activity)planElements.get(7)).getMaximumDuration().seconds(), 0.0); } @Test @@ -247,19 +247,19 @@ void testIntermodalTrip_walkOnlyNoSubpop() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_2", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_2", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("pt_2", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("pt_2", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } /** @@ -299,7 +299,7 @@ void testIntermodalTrip_withoutPt() { List legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac, toFac, 7*3600, f.dummyPerson)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } @Test @@ -352,11 +352,11 @@ void testDirectWalkFactor() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 1, legs.size()); + Assertions.assertEquals(1, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); // direct walk factor on f.config.transitRouter().setDirectWalkFactor(Double.POSITIVE_INFINITY); @@ -369,27 +369,27 @@ void testDirectWalkFactor() { System.out.println(leg1); } - Assert.assertEquals("wrong number of legs.", 5, legs.size()); + Assertions.assertEquals(5, legs.size(), "wrong number of legs."); leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(3); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("bike_3", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("bike_3", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(4); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("bike_3", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("bike_3", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } @Test @@ -449,39 +449,39 @@ void testAccessEgressModeFasterThanPt() { //returnNull data.config.setIntermodalLegOnlyHandling(SwissRailRaptorConfigGroup.IntermodalLegOnlyHandling.returnNull); List legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac, toFac, 7*3600, f.dummyPerson)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac2, toFac2, 7*3600, f.dummyPerson)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); //forbid data.config.setIntermodalLegOnlyHandling(SwissRailRaptorConfigGroup.IntermodalLegOnlyHandling.forbid); legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac, toFac, 7*3600, f.dummyPerson)); - Assert.assertNotNull("The router should find a pt route and not return null, but did return null", legs); - Assert.assertTrue( legs.stream().filter(Leg.class::isInstance).anyMatch(planElement -> ((Leg) planElement).getMode().equals(TransportMode.pt))); + Assertions.assertNotNull(legs, "The router should find a pt route and not return null, but did return null"); + Assertions.assertTrue( legs.stream().filter(Leg.class::isInstance).anyMatch(planElement -> ((Leg) planElement).getMode().equals(TransportMode.pt))); legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac2, toFac2, 7*3600, f.dummyPerson)); - Assert.assertNull("The router should not find a pt route and return null, but did return something else", legs); + Assertions.assertNull(legs, "The router should not find a pt route and return null, but did return something else"); //avoid data.config.setIntermodalLegOnlyHandling(SwissRailRaptorConfigGroup.IntermodalLegOnlyHandling.avoid); legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac, toFac, 7*3600, f.dummyPerson)); - Assert.assertNotNull("The router should find a pt route and not return null, but did return null", legs); - Assert.assertTrue( legs.stream().filter(Leg.class::isInstance).anyMatch(planElement -> ((Leg) planElement).getMode().equals(TransportMode.pt))); + Assertions.assertNotNull(legs, "The router should find a pt route and not return null, but did return null"); + Assertions.assertTrue( legs.stream().filter(Leg.class::isInstance).anyMatch(planElement -> ((Leg) planElement).getMode().equals(TransportMode.pt))); legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac2, toFac2, 7*3600, f.dummyPerson)); - Assert.assertNotNull("The router should find a pt route and not return null, but did return null", legs); - Assert.assertFalse( legs.stream().filter(Leg.class::isInstance).anyMatch(planElement -> ((Leg) planElement).getMode().equals(TransportMode.pt))); + Assertions.assertNotNull(legs, "The router should find a pt route and not return null, but did return null"); + Assertions.assertFalse( legs.stream().filter(Leg.class::isInstance).anyMatch(planElement -> ((Leg) planElement).getMode().equals(TransportMode.pt))); //allow data.config.setIntermodalLegOnlyHandling(SwissRailRaptorConfigGroup.IntermodalLegOnlyHandling.allow); legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac, toFac, 7*3600, f.dummyPerson)); - Assert.assertFalse( legs.stream().filter(Leg.class::isInstance).anyMatch(planElement -> ((Leg) planElement).getMode().equals(TransportMode.pt))); - Assert.assertNotNull("The router should find a pt route and not return null, but did return something else.", legs); + Assertions.assertFalse( legs.stream().filter(Leg.class::isInstance).anyMatch(planElement -> ((Leg) planElement).getMode().equals(TransportMode.pt))); + Assertions.assertNotNull(legs, "The router should find a pt route and not return null, but did return something else."); legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac2, toFac2, 7*3600, f.dummyPerson)); - Assert.assertNotNull("The router should find a pt route and not return null, but did return null", legs); - Assert.assertFalse( legs.stream().filter(Leg.class::isInstance).anyMatch(planElement -> ((Leg) planElement).getMode().equals(TransportMode.pt))); + Assertions.assertNotNull(legs, "The router should find a pt route and not return null, but did return null"); + Assertions.assertFalse( legs.stream().filter(Leg.class::isInstance).anyMatch(planElement -> ((Leg) planElement).getMode().equals(TransportMode.pt))); } @@ -533,19 +533,19 @@ void testIntermodalTrip_competingAccess() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } // second check: decrease bike speed, walk should be the better option @@ -563,19 +563,19 @@ void testIntermodalTrip_competingAccess() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } } @@ -638,19 +638,19 @@ void testIntermodalTrip_RandomAccessEgressModeRaptorStopFinder() { { // Test 1: Checks whether the amount of legs is correct, whether the legs have the correct modes, // and whether the legs start and end on the correct links - Assert.assertEquals("wrong number of legs.", 3, legs.size()); + Assertions.assertEquals(3, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertTrue((leg.getMode().equals(TransportMode.bike)) || (leg.getMode().equals(TransportMode.walk))); - Assert.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertTrue((leg.getMode().equals(TransportMode.bike)) || (leg.getMode().equals(TransportMode.walk))); + Assertions.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("pt_3", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertTrue((leg.getMode().equals(TransportMode.bike)) || (leg.getMode().equals(TransportMode.walk))); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertTrue((leg.getMode().equals(TransportMode.bike)) || (leg.getMode().equals(TransportMode.walk))); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } { // Test 2: Counts all different access/egress mode combinations. The assertions occur later. @@ -671,11 +671,11 @@ else if ((((Leg)(legs.get(0))).getMode().equals(TransportMode.bike)) && (((Leg)l { // Test 2: Tests whether Router chooses all 4 combinations of walk and bike. Also checks that no other // combination is present. - Assert.assertTrue(numWalkWalk > 0); - Assert.assertTrue(numWalkBike > 0); - Assert.assertTrue(numBikeWalk > 0); - Assert.assertTrue(numBikeBike > 0); - Assert.assertEquals(0, numOther); + Assertions.assertTrue(numWalkWalk > 0); + Assertions.assertTrue(numWalkBike > 0); + Assertions.assertTrue(numBikeWalk > 0); + Assertions.assertTrue(numBikeBike > 0); + Assertions.assertEquals(0, numOther); } } @@ -702,32 +702,32 @@ void testIntermodalTrip_accessTransfer() { System.out.println(leg); } - Assert.assertEquals(5, legs.size()); + Assertions.assertEquals(5, legs.size()); Leg legBike = (Leg) legs.get(0); - Assert.assertEquals("bike", legBike.getMode()); - Assert.assertEquals("from", legBike.getRoute().getStartLinkId().toString()); - Assert.assertEquals("bike_B", legBike.getRoute().getEndLinkId().toString()); + Assertions.assertEquals("bike", legBike.getMode()); + Assertions.assertEquals("from", legBike.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("bike_B", legBike.getRoute().getEndLinkId().toString()); Leg legTransfer = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.walk, legTransfer.getMode()); - Assert.assertEquals("bike_B", legTransfer.getRoute().getStartLinkId().toString()); - Assert.assertEquals("BB", legTransfer.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.walk, legTransfer.getMode()); + Assertions.assertEquals("bike_B", legTransfer.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("BB", legTransfer.getRoute().getEndLinkId().toString()); Leg legTransfer2 = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, legTransfer2.getMode()); - Assert.assertEquals("BB", legTransfer2.getRoute().getStartLinkId().toString()); - Assert.assertEquals("CC", legTransfer2.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.walk, legTransfer2.getMode()); + Assertions.assertEquals("BB", legTransfer2.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("CC", legTransfer2.getRoute().getEndLinkId().toString()); Leg legPT = (Leg) legs.get(3); - Assert.assertEquals("pt", legPT.getMode()); - Assert.assertEquals("CC", legPT.getRoute().getStartLinkId().toString()); - Assert.assertEquals("DD", legPT.getRoute().getEndLinkId().toString()); + Assertions.assertEquals("pt", legPT.getMode()); + Assertions.assertEquals("CC", legPT.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("DD", legPT.getRoute().getEndLinkId().toString()); Leg legAccess = (Leg) legs.get(4); - Assert.assertEquals(TransportMode.walk, legAccess.getMode()); - Assert.assertEquals("DD", legAccess.getRoute().getStartLinkId().toString()); - Assert.assertEquals("to", legAccess.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.walk, legAccess.getMode()); + Assertions.assertEquals("DD", legAccess.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("to", legAccess.getRoute().getEndLinkId().toString()); } /** @@ -757,22 +757,22 @@ void testIntermodalTrip_singleReachableStop() { System.out.println(leg); } - Assert.assertEquals(3, legs.size()); + Assertions.assertEquals(3, legs.size()); Leg legAccess = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, legAccess.getMode()); - Assert.assertEquals("from", legAccess.getRoute().getStartLinkId().toString()); - Assert.assertEquals("EE", legAccess.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.walk, legAccess.getMode()); + Assertions.assertEquals("from", legAccess.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("EE", legAccess.getRoute().getEndLinkId().toString()); Leg legPT = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.pt, legPT.getMode()); - Assert.assertEquals("EE", legPT.getRoute().getStartLinkId().toString()); - Assert.assertEquals("FF", legPT.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.pt, legPT.getMode()); + Assertions.assertEquals("EE", legPT.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("FF", legPT.getRoute().getEndLinkId().toString()); Leg legEgress = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, legEgress.getMode()); - Assert.assertEquals("FF", legEgress.getRoute().getStartLinkId().toString()); - Assert.assertEquals("to", legEgress.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.walk, legEgress.getMode()); + Assertions.assertEquals("FF", legEgress.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("to", legEgress.getRoute().getEndLinkId().toString()); } @@ -792,32 +792,32 @@ void testIntermodalTrip_egressTransfer() { System.out.println(leg); } - Assert.assertEquals(5, legs.size()); + Assertions.assertEquals(5, legs.size()); Leg legAccess = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, legAccess.getMode()); - Assert.assertEquals("from", legAccess.getRoute().getStartLinkId().toString()); - Assert.assertEquals("DD", legAccess.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.walk, legAccess.getMode()); + Assertions.assertEquals("from", legAccess.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("DD", legAccess.getRoute().getEndLinkId().toString()); Leg legPT = (Leg) legs.get(1); - Assert.assertEquals("pt", legPT.getMode()); - Assert.assertEquals("DD", legPT.getRoute().getStartLinkId().toString()); - Assert.assertEquals("CC", legPT.getRoute().getEndLinkId().toString()); + Assertions.assertEquals("pt", legPT.getMode()); + Assertions.assertEquals("DD", legPT.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("CC", legPT.getRoute().getEndLinkId().toString()); Leg legTransfer = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.walk, legTransfer.getMode()); - Assert.assertEquals("CC", legTransfer.getRoute().getStartLinkId().toString()); - Assert.assertEquals("BB", legTransfer.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.walk, legTransfer.getMode()); + Assertions.assertEquals("CC", legTransfer.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("BB", legTransfer.getRoute().getEndLinkId().toString()); Leg legTransfer2 = (Leg) legs.get(3); - Assert.assertEquals(TransportMode.walk, legTransfer2.getMode()); - Assert.assertEquals("BB", legTransfer2.getRoute().getStartLinkId().toString()); - Assert.assertEquals("bike_B", legTransfer2.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.walk, legTransfer2.getMode()); + Assertions.assertEquals("BB", legTransfer2.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("bike_B", legTransfer2.getRoute().getEndLinkId().toString()); Leg legBike = (Leg) legs.get(4); - Assert.assertEquals("bike", legBike.getMode()); - Assert.assertEquals("bike_B", legBike.getRoute().getStartLinkId().toString()); - Assert.assertEquals("to", legBike.getRoute().getEndLinkId().toString()); + Assertions.assertEquals("bike", legBike.getMode()); + Assertions.assertEquals("bike_B", legBike.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("to", legBike.getRoute().getEndLinkId().toString()); } /** @@ -839,7 +839,7 @@ void testIntermodalTrip_noPtStopsInRadius() { List legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac, toFac, 7.5 * 3600, f.dummyPerson)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } /** @@ -875,27 +875,27 @@ void testIntermodalTrip_accessModeRouterReturnsNull() { System.out.println(leg); } - Assert.assertEquals(4, legs.size()); + Assertions.assertEquals(4, legs.size()); Leg legBike = (Leg) legs.get(0); - Assert.assertEquals("bike", legBike.getMode()); - Assert.assertEquals("from", legBike.getRoute().getStartLinkId().toString()); - Assert.assertEquals("bike_B", legBike.getRoute().getEndLinkId().toString()); + Assertions.assertEquals("bike", legBike.getMode()); + Assertions.assertEquals("from", legBike.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("bike_B", legBike.getRoute().getEndLinkId().toString()); Leg legTransfer = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.walk, legTransfer.getMode()); - Assert.assertEquals("bike_B", legTransfer.getRoute().getStartLinkId().toString()); - Assert.assertEquals("BB", legTransfer.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.walk, legTransfer.getMode()); + Assertions.assertEquals("bike_B", legTransfer.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("BB", legTransfer.getRoute().getEndLinkId().toString()); Leg legTransfer2 = (Leg) legs.get(2); - Assert.assertEquals("pt", legTransfer2.getMode()); - Assert.assertEquals("BB", legTransfer2.getRoute().getStartLinkId().toString()); - Assert.assertEquals("AA", legTransfer2.getRoute().getEndLinkId().toString()); + Assertions.assertEquals("pt", legTransfer2.getMode()); + Assertions.assertEquals("BB", legTransfer2.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("AA", legTransfer2.getRoute().getEndLinkId().toString()); Leg legAccess = (Leg) legs.get(3); - Assert.assertEquals(TransportMode.walk, legAccess.getMode()); - Assert.assertEquals("AA", legAccess.getRoute().getStartLinkId().toString()); - Assert.assertEquals("to", legAccess.getRoute().getEndLinkId().toString()); + Assertions.assertEquals(TransportMode.walk, legAccess.getMode()); + Assertions.assertEquals("AA", legAccess.getRoute().getStartLinkId().toString()); + Assertions.assertEquals("to", legAccess.getRoute().getEndLinkId().toString()); // Part 2: Change bike router to return null. @@ -916,7 +916,7 @@ public List calcRoute(RoutingRequest request) { List legs2 = raptor2.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFac, toFac, 8 * 3600 - 900, f.dummyPerson)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs2); + Assertions.assertNull(legs2, "The router should not find a route and return null, but did return something else."); } /** @@ -972,27 +972,27 @@ void testIntermodalTrip_tripLengthShare() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 5, legs.size()); + Assertions.assertEquals(5, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(3); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(4); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } @Test @@ -1082,32 +1082,32 @@ public List calcRoute(RoutingRequest request) { for (PlanElement leg : legs) { System.out.println(leg); } - Assert.assertEquals("wrong number of segments.", 6, legs.size()); + Assertions.assertEquals(6, legs.size(), "wrong number of segments."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_1", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_1", Link.class), leg.getRoute().getEndLinkId()); Activity act = (Activity)legs.get(1); - Assert.assertEquals("bike interaction", act.getType()); - Assert.assertEquals(1.0, act.getMaximumDuration().seconds(), 0.01); + Assertions.assertEquals("bike interaction", act.getType()); + Assertions.assertEquals(1.0, act.getMaximumDuration().seconds(), 0.01); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("pt_1", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("pt_1", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getEndLinkId()); double arrivalTime = leg.getDepartureTime().seconds() + leg.getTravelTime().seconds(); leg = (Leg) legs.get(3); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(4); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); - Assert.assertTrue((int)leg.getDepartureTime().seconds() >= (int)arrivalTime ); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertTrue((int)leg.getDepartureTime().seconds() >= (int)arrivalTime ); leg = (Leg) legs.get(5); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } /** @@ -1205,36 +1205,36 @@ public List calcRoute(RoutingRequest request) { System.out.println(leg); } - Assert.assertEquals("wrong number of segments.", 9, legs.size()); + Assertions.assertEquals(9, legs.size(), "wrong number of segments."); Leg leg = (Leg) legs.get(0); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_1", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("from", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_1", Link.class), leg.getRoute().getEndLinkId()); Activity act = (Activity)legs.get(1); - Assert.assertEquals("bike interaction", act.getType()); - Assert.assertEquals(bikeInteractionDuration, act.getMaximumDuration().seconds(), 0.01); + Assertions.assertEquals("bike interaction", act.getType()); + Assertions.assertEquals(bikeInteractionDuration, act.getMaximumDuration().seconds(), 0.01); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("pt_1", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("pt_1", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getEndLinkId()); act = (Activity)legs.get(3); - Assert.assertEquals("pt interaction", act.getType()); + Assertions.assertEquals("pt interaction", act.getType()); leg = (Leg) legs.get(4); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("bike_0", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getEndLinkId()); act = (Activity)legs.get(5); - Assert.assertEquals("pt interaction", act.getType()); + Assertions.assertEquals("pt interaction", act.getType()); leg = (Leg) legs.get(6); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("pt_0", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); act = (Activity)legs.get(7); - Assert.assertEquals("pt interaction", act.getType()); + Assertions.assertEquals("pt interaction", act.getType()); leg = (Leg) legs.get(8); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } @Test @@ -1279,25 +1279,25 @@ void testIntermodalTripWithAccessAndEgressTimesAtStops() { System.out.println(leg); } - Assert.assertEquals("wrong number of legs.", 5, legs.size()); + Assertions.assertEquals(5, legs.size(), "wrong number of legs."); Leg leg = (Leg) legs.get(1); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("pt_2", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_2", Link.class), leg.getRoute().getEndLinkId()); - Assert.assertEquals(120.0,leg.getTravelTime().seconds(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("pt_2", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_2", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(120.0,leg.getTravelTime().seconds(), MatsimTestUtils.EPSILON); leg = (Leg) legs.get(2); - Assert.assertEquals(TransportMode.pt, leg.getMode()); - Assert.assertEquals(Id.create("pt_2", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.pt, leg.getMode()); + Assertions.assertEquals(Id.create("pt_2", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getEndLinkId()); leg = (Leg) legs.get(3); - Assert.assertEquals(TransportMode.walk, leg.getMode()); - Assert.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getEndLinkId()); - Assert.assertEquals(120.0,leg.getTravelTime().seconds(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(TransportMode.walk, leg.getMode()); + Assertions.assertEquals(Id.create("pt_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(120.0,leg.getTravelTime().seconds(), MatsimTestUtils.EPSILON); leg = (Leg) legs.get(4); - Assert.assertEquals(TransportMode.bike, leg.getMode()); - Assert.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); + Assertions.assertEquals(TransportMode.bike, leg.getMode()); + Assertions.assertEquals(Id.create("bike_5", Link.class), leg.getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("to", Link.class), leg.getRoute().getEndLinkId()); } diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java index f043d8bbc77..5085ec806b2 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java @@ -23,8 +23,8 @@ import java.util.Arrays; import java.util.List; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -114,7 +114,7 @@ public void install() { // this test mostly checks that no exception occurred RoutingModule module = tripRouter.getRoutingModule(TransportMode.pt); - Assert.assertTrue(module instanceof SwissRailRaptorRoutingModule); + Assertions.assertTrue(module instanceof SwissRailRaptorRoutingModule); } @Test @@ -190,7 +190,7 @@ public void install() { // test that swiss rail raptor was used TripRouter tripRouter = controler.getInjector().getInstance(TripRouter.class); RoutingModule module = tripRouter.getRoutingModule(TransportMode.pt); - Assert.assertTrue(module instanceof SwissRailRaptorRoutingModule); + Assertions.assertTrue(module instanceof SwissRailRaptorRoutingModule); // also test that our one agent got correctly routed with intermodal access List planElements = plan.getPlanElements(); @@ -198,41 +198,41 @@ public void install() { System.out.println(pe); } - Assert.assertEquals("wrong number of PlanElements.", 11, planElements.size()); - Assert.assertTrue(planElements.get(0) instanceof Activity); - Assert.assertTrue(planElements.get(1) instanceof Leg); - Assert.assertTrue(planElements.get(2) instanceof Activity); - Assert.assertTrue(planElements.get(3) instanceof Leg); - Assert.assertTrue(planElements.get(4) instanceof Activity); - Assert.assertTrue(planElements.get(5) instanceof Leg); - Assert.assertTrue(planElements.get(6) instanceof Activity); - Assert.assertTrue(planElements.get(7) instanceof Leg); - Assert.assertTrue(planElements.get(8) instanceof Activity); - Assert.assertTrue(planElements.get(9) instanceof Leg); - Assert.assertTrue(planElements.get(10) instanceof Activity); - - Assert.assertEquals("home", ((Activity) planElements.get(0)).getType()); - Assert.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(2)).getType()); - Assert.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(4)).getType()); - Assert.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(6)).getType()); - Assert.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(8)).getType()); - Assert.assertEquals("work", ((Activity) planElements.get(10)).getType()); - - Assert.assertEquals(TransportMode.bike, ((Leg) planElements.get(1)).getMode()); - Assert.assertEquals(TransportMode.walk, ((Leg) planElements.get(3)).getMode()); - Assert.assertEquals(TransportMode.pt, ((Leg) planElements.get(5)).getMode()); - Assert.assertEquals(TransportMode.walk, ((Leg) planElements.get(7)).getMode()); - Assert.assertEquals(TransportMode.bike, ((Leg) planElements.get(9)).getMode()); - - Assert.assertEquals(0.0, ((Activity) planElements.get(2)).getMaximumDuration().seconds(), 0.0); - Assert.assertEquals(0.0, ((Activity) planElements.get(4)).getMaximumDuration().seconds(), 0.0); - Assert.assertEquals(0.0, ((Activity) planElements.get(6)).getMaximumDuration().seconds(), 0.0); - Assert.assertEquals(0.0, ((Activity) planElements.get(8)).getMaximumDuration().seconds(), 0.0); - - Assert.assertTrue( ((Activity) planElements.get(2)).getEndTime().isUndefined() ); - Assert.assertTrue( ((Activity) planElements.get(4)).getEndTime().isUndefined() ); - Assert.assertTrue( ((Activity) planElements.get(6)).getEndTime().isUndefined() ); - Assert.assertTrue( ((Activity) planElements.get(8)).getEndTime().isUndefined() ); + Assertions.assertEquals(11, planElements.size(), "wrong number of PlanElements."); + Assertions.assertTrue(planElements.get(0) instanceof Activity); + Assertions.assertTrue(planElements.get(1) instanceof Leg); + Assertions.assertTrue(planElements.get(2) instanceof Activity); + Assertions.assertTrue(planElements.get(3) instanceof Leg); + Assertions.assertTrue(planElements.get(4) instanceof Activity); + Assertions.assertTrue(planElements.get(5) instanceof Leg); + Assertions.assertTrue(planElements.get(6) instanceof Activity); + Assertions.assertTrue(planElements.get(7) instanceof Leg); + Assertions.assertTrue(planElements.get(8) instanceof Activity); + Assertions.assertTrue(planElements.get(9) instanceof Leg); + Assertions.assertTrue(planElements.get(10) instanceof Activity); + + Assertions.assertEquals("home", ((Activity) planElements.get(0)).getType()); + Assertions.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(2)).getType()); + Assertions.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(4)).getType()); + Assertions.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(6)).getType()); + Assertions.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(8)).getType()); + Assertions.assertEquals("work", ((Activity) planElements.get(10)).getType()); + + Assertions.assertEquals(TransportMode.bike, ((Leg) planElements.get(1)).getMode()); + Assertions.assertEquals(TransportMode.walk, ((Leg) planElements.get(3)).getMode()); + Assertions.assertEquals(TransportMode.pt, ((Leg) planElements.get(5)).getMode()); + Assertions.assertEquals(TransportMode.walk, ((Leg) planElements.get(7)).getMode()); + Assertions.assertEquals(TransportMode.bike, ((Leg) planElements.get(9)).getMode()); + + Assertions.assertEquals(0.0, ((Activity) planElements.get(2)).getMaximumDuration().seconds(), 0.0); + Assertions.assertEquals(0.0, ((Activity) planElements.get(4)).getMaximumDuration().seconds(), 0.0); + Assertions.assertEquals(0.0, ((Activity) planElements.get(6)).getMaximumDuration().seconds(), 0.0); + Assertions.assertEquals(0.0, ((Activity) planElements.get(8)).getMaximumDuration().seconds(), 0.0); + + Assertions.assertTrue( ((Activity) planElements.get(2)).getEndTime().isUndefined() ); + Assertions.assertTrue( ((Activity) planElements.get(4)).getEndTime().isUndefined() ); + Assertions.assertTrue( ((Activity) planElements.get(6)).getEndTime().isUndefined() ); + Assertions.assertTrue( ((Activity) planElements.get(8)).getEndTime().isUndefined() ); // MM started filling the times of the swiss rail raptor pt interaction activities with content and so the above (evidently) started failing. I am // fixing it here: @@ -307,7 +307,7 @@ public void install() { // test that swiss rail raptor was used TripRouter tripRouter = controler.getInjector().getInstance(TripRouter.class); RoutingModule module = tripRouter.getRoutingModule(TransportMode.pt); - Assert.assertTrue(module instanceof SwissRailRaptorRoutingModule); + Assertions.assertTrue(module instanceof SwissRailRaptorRoutingModule); // Check routed plan List planElements = p1.getSelectedPlan().getPlanElements(); @@ -315,28 +315,28 @@ public void install() { System.out.println(pe); } - Assert.assertEquals("wrong number of PlanElements.", 7, planElements.size()); - Assert.assertTrue(planElements.get(0) instanceof Activity); - Assert.assertTrue(planElements.get(1) instanceof Leg); - Assert.assertTrue(planElements.get(2) instanceof Activity); - Assert.assertTrue(planElements.get(3) instanceof Leg); - Assert.assertTrue(planElements.get(4) instanceof Activity); - Assert.assertTrue(planElements.get(5) instanceof Leg); - Assert.assertTrue(planElements.get(6) instanceof Activity); + Assertions.assertEquals(7, planElements.size(), "wrong number of PlanElements."); + Assertions.assertTrue(planElements.get(0) instanceof Activity); + Assertions.assertTrue(planElements.get(1) instanceof Leg); + Assertions.assertTrue(planElements.get(2) instanceof Activity); + Assertions.assertTrue(planElements.get(3) instanceof Leg); + Assertions.assertTrue(planElements.get(4) instanceof Activity); + Assertions.assertTrue(planElements.get(5) instanceof Leg); + Assertions.assertTrue(planElements.get(6) instanceof Activity); - Assert.assertEquals("home", ((Activity) planElements.get(0)).getType()); - Assert.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(2)).getType()); - Assert.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(4)).getType()); - Assert.assertEquals("work", ((Activity) planElements.get(6)).getType()); + Assertions.assertEquals("home", ((Activity) planElements.get(0)).getType()); + Assertions.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(2)).getType()); + Assertions.assertEquals(PtConstants.TRANSIT_ACTIVITY_TYPE, ((Activity) planElements.get(4)).getType()); + Assertions.assertEquals("work", ((Activity) planElements.get(6)).getType()); - Assert.assertEquals(TransportMode.walk, ((Leg) planElements.get(1)).getMode()); - Assert.assertEquals(TransportMode.pt, ((Leg) planElements.get(3)).getMode()); - Assert.assertEquals(TransportMode.walk, ((Leg) planElements.get(5)).getMode()); + Assertions.assertEquals(TransportMode.walk, ((Leg) planElements.get(1)).getMode()); + Assertions.assertEquals(TransportMode.pt, ((Leg) planElements.get(3)).getMode()); + Assertions.assertEquals(TransportMode.walk, ((Leg) planElements.get(5)).getMode()); // Check route: should return one of the added lines although the removed green line would be faster Leg ptLeg = (Leg) planElements.get(3); TransitPassengerRoute ptRoute = (TransitPassengerRoute) ptLeg.getRoute(); - Assert.assertEquals(Id.create("AddedLine" + 1, TransitLine.class), ptRoute.getLineId()); + Assertions.assertEquals(Id.create("AddedLine" + 1, TransitLine.class), ptRoute.getLineId()); } /** @@ -378,8 +378,8 @@ void testRaptorParametersForPerson() { RaptorParametersForPerson parameters = controller.getInjector().getInstance(RaptorParametersForPerson.class); - Assert.assertEquals(-80.0, parameters.getRaptorParameters(personA).getMarginalUtilityOfWaitingPt_utl_s(), 1e-3); - Assert.assertEquals(-60.0, parameters.getRaptorParameters(personB).getMarginalUtilityOfWaitingPt_utl_s(), 1e-3); + Assertions.assertEquals(-80.0, parameters.getRaptorParameters(personA).getMarginalUtilityOfWaitingPt_utl_s(), 1e-3); + Assertions.assertEquals(-60.0, parameters.getRaptorParameters(personB).getMarginalUtilityOfWaitingPt_utl_s(), 1e-3); } private static class ScheduleModifierControlerListener implements StartupListener, IterationStartsListener { diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTest.java index e37985287b6..559a2970bf2 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTest.java @@ -21,7 +21,7 @@ import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; import ch.sbb.matsim.routing.pt.raptor.SwissRailRaptor.Builder; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -68,8 +68,8 @@ import java.util.List; import java.util.function.Supplier; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; /** * Most of these tests were copied from org.matsim.pt.router.TransitRouterImplTest @@ -98,7 +98,7 @@ void testSingleLine() { assertEquals(TransportMode.walk, ((Leg)legs.get(0)).getMode()); assertEquals(TransportMode.pt, ((Leg)legs.get(1)).getMode()); assertEquals(TransportMode.walk, ((Leg)legs.get(2)).getMode()); - assertTrue("expected TransitRoute in leg.", ((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute); + assertTrue(((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute, "expected TransitRoute in leg."); TransitPassengerRoute ptRoute = (TransitPassengerRoute) ((Leg)legs.get(1)).getRoute(); assertEquals(Id.create("0", TransitStopFacility.class), ptRoute.getAccessStopId()); assertEquals(Id.create("6", TransitStopFacility.class), ptRoute.getEgressStopId()); @@ -134,7 +134,7 @@ void testSingleLine_linkIds() { assertEquals(TransportMode.pt, ((Leg)legs.get(1)).getMode()); assertEquals(TransportMode.walk, ((Leg)legs.get(2)).getMode()); assertEquals(toLinkId, ((Leg)legs.get(2)).getRoute().getEndLinkId()); - assertTrue("expected TransitRoute in leg.", ((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute); + assertTrue(((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute, "expected TransitRoute in leg."); TransitPassengerRoute ptRoute = (TransitPassengerRoute) ((Leg)legs.get(1)).getRoute(); assertEquals(Id.create("0", TransitStopFacility.class), ptRoute.getAccessStopId()); assertEquals(Id.create("6", TransitStopFacility.class), ptRoute.getEgressStopId()); @@ -229,7 +229,7 @@ void testFromToSameStop() { Coord toCoord = new Coord(4100, 5050); List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(fromCoord), new FakeFacility(toCoord), 5.0*3600, null)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } @@ -303,7 +303,7 @@ void testSingleLine_DifferentWaitingTime() { actualTravelTime += ((Leg)leg).getTravelTime().seconds(); } double waitingTime = ((46 - min) % 20) * 60; // departures at *:06 and *:26 and *:46 - assertEquals("expected different waiting time at 05:"+min, waitingTime, actualTravelTime - inVehicleTime, MatsimTestUtils.EPSILON); + assertEquals(waitingTime, actualTravelTime - inVehicleTime, MatsimTestUtils.EPSILON, "expected different waiting time at 05:"+min); } } @@ -322,13 +322,13 @@ void testLineChange() { assertEquals(TransportMode.walk, ((Leg)legs.get(2)).getMode()); assertEquals(TransportMode.pt, ((Leg)legs.get(3)).getMode()); assertEquals(TransportMode.walk, ((Leg)legs.get(4)).getMode()); - assertTrue("expected TransitRoute in leg.", ((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute); + assertTrue(((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute, "expected TransitRoute in leg."); TransitPassengerRoute ptRoute = (TransitPassengerRoute) ((Leg)legs.get(1)).getRoute(); assertEquals(Id.create("0", TransitStopFacility.class), ptRoute.getAccessStopId()); assertEquals(Id.create("4", TransitStopFacility.class), ptRoute.getEgressStopId()); assertEquals(f.blueLine.getId(), ptRoute.getLineId()); assertEquals(Id.create("blue A > I", TransitRoute.class), ptRoute.getRouteId()); - assertTrue("expected TransitRoute in leg.", ((Leg)legs.get(3)).getRoute() instanceof TransitPassengerRoute); + assertTrue(((Leg)legs.get(3)).getRoute() instanceof TransitPassengerRoute, "expected TransitRoute in leg."); ptRoute = (TransitPassengerRoute) ((Leg)legs.get(3)).getRoute(); assertEquals(Id.create("18", TransitStopFacility.class), ptRoute.getAccessStopId()); assertEquals(Id.create("19", TransitStopFacility.class), ptRoute.getEgressStopId()); @@ -358,19 +358,19 @@ void testFasterAlternative() { TransitRouter router = createTransitRouter(f.schedule, f.config, f.network); Coord toCoord = new Coord(28100, 4950); List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility( new Coord(3800, 5100)), new FakeFacility(toCoord), 5.0*3600 + 40.0*60, null)); - assertEquals("wrong number of legs", 5, legs.size()); + assertEquals(5, legs.size(), "wrong number of legs"); assertEquals(TransportMode.walk, ((Leg)legs.get(0)).getMode()); assertEquals(TransportMode.pt, ((Leg)legs.get(1)).getMode()); assertEquals(TransportMode.walk, ((Leg)legs.get(2)).getMode()); assertEquals(TransportMode.pt, ((Leg)legs.get(3)).getMode()); assertEquals(TransportMode.walk, ((Leg)legs.get(4)).getMode()); - assertTrue("expected TransitRoute in leg.", ((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute); + assertTrue(((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute, "expected TransitRoute in leg."); TransitPassengerRoute ptRoute = (TransitPassengerRoute) ((Leg)legs.get(1)).getRoute(); assertEquals(Id.create("0", TransitStopFacility.class), ptRoute.getAccessStopId()); assertEquals(Id.create("4", TransitStopFacility.class), ptRoute.getEgressStopId()); assertEquals(f.blueLine.getId(), ptRoute.getLineId()); assertEquals(Id.create("blue A > I", TransitRoute.class), ptRoute.getRouteId()); - assertTrue("expected TransitRoute in leg.", ((Leg)legs.get(3)).getRoute() instanceof TransitPassengerRoute); + assertTrue(((Leg)legs.get(3)).getRoute() instanceof TransitPassengerRoute, "expected TransitRoute in leg."); ptRoute = (TransitPassengerRoute) ((Leg)legs.get(3)).getRoute(); assertEquals(Id.create("4", TransitStopFacility.class), ptRoute.getAccessStopId()); assertEquals(Id.create("12", TransitStopFacility.class), ptRoute.getEgressStopId()); @@ -401,7 +401,7 @@ void testTransferWeights() { RaptorParameters raptorParams = RaptorUtils.createParameters(f.config); TransitRouter router = createTransitRouter(f.schedule, f.config, f.network); List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(new Coord(11900, 5100)), new FakeFacility(new Coord(24100, 4950)), 6.0*3600 - 5.0*60, null)); - assertEquals("wrong number of legs", 5, legs.size()); + assertEquals(5, legs.size(), "wrong number of legs"); assertEquals(TransportMode.walk, ((Leg)legs.get(0)).getMode()); assertEquals(TransportMode.pt, ((Leg)legs.get(1)).getMode()); assertEquals(f.redLine.getId(), ((TransitPassengerRoute) ((Leg)legs.get(1)).getRoute()).getLineId()); @@ -414,7 +414,7 @@ void testTransferWeights() { double transferUtility = 300.0 * raptorParams.getMarginalUtilityOfTravelTime_utl_s(TransportMode.pt); // corresponds to 5 minutes transit travel time config.scoring().setUtilityOfLineSwitch(transferUtility); raptorParams = RaptorUtils.createParameters(config); - Assert.assertEquals(-transferUtility, raptorParams.getTransferPenaltyFixCostPerTransfer(), 0.0); + Assertions.assertEquals(-transferUtility, raptorParams.getTransferPenaltyFixCostPerTransfer(), 0.0); router = createTransitRouter(f.schedule, config, f.network); legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(new Coord(11900, 5100)), new FakeFacility(new Coord(24100, 4950)), 6.0*3600 - 5.0*60, null)); assertEquals(3, legs.size()); @@ -440,7 +440,7 @@ void testTransferTime() { f.config.transitRouter().setAdditionalTransferTime(0); TransitRouter router = createTransitRouter(f.schedule, f.config, f.network); List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(new Coord(11900, 5100)), new FakeFacility(new Coord(24100, 4950)), 6.0*3600 - 5.0*60, null)); - assertEquals("wrong number of legs",5, legs.size()); + assertEquals(5, legs.size(), "wrong number of legs"); assertEquals(TransportMode.walk, ((Leg)legs.get(0)).getMode()); assertEquals(TransportMode.pt, ((Leg)legs.get(1)).getMode()); assertEquals(f.redLine.getId(), ((TransitPassengerRoute) ((Leg)legs.get(1)).getRoute()).getLineId()); @@ -453,7 +453,7 @@ void testTransferTime() { config.transitRouter().setAdditionalTransferTime(3*60 + 1); router = createTransitRouter(f.schedule, config, f.network); // this is necessary to update the router for any change in config. legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(new Coord(11900, 5100)), new FakeFacility(new Coord(24100, 4950)), 6.0*3600 - 5.0*60, null)); - assertEquals("wrong number of legs",3, legs.size()); + assertEquals(3, legs.size(), "wrong number of legs"); assertEquals(TransportMode.walk, ((Leg)legs.get(0)).getMode()); assertEquals(TransportMode.pt, ((Leg)legs.get(1)).getMode()); assertEquals(f.blueLine.getId(), ((TransitPassengerRoute) ((Leg)legs.get(1)).getRoute()).getLineId()); @@ -473,7 +473,7 @@ void testAfterMidnight() { Coord toCoord = new Coord(16100, 5050); List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(fromCoord), new FakeFacility(toCoord), 25.0*3600, null)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } @Test @@ -488,7 +488,7 @@ void testCoordFarAway() { assertEquals(TransportMode.walk, ((Leg)legs.get(0)).getMode()); assertEquals(TransportMode.pt, ((Leg)legs.get(1)).getMode()); assertEquals(TransportMode.walk, ((Leg)legs.get(2)).getMode()); - assertTrue("expected TransitRoute in leg.", ((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute); + assertTrue(((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute, "expected TransitRoute in leg."); TransitPassengerRoute ptRoute = (TransitPassengerRoute) ((Leg)legs.get(1)).getRoute(); assertEquals(Id.create("0", TransitStopFacility.class), ptRoute.getAccessStopId()); assertEquals(Id.create("16", TransitStopFacility.class), ptRoute.getEgressStopId()); @@ -508,7 +508,7 @@ void testSingleWalkOnly() { TransitRouter router = createTransitRouter(f.schedule, f.scenario.getConfig(), f.scenario.getNetwork()); List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(f.coord2), new FakeFacility(f.coord4), 990, null)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } @@ -527,7 +527,7 @@ void testDoubleWalkOnly() { TransitRouter router = createTransitRouter(f.schedule, f.scenario.getConfig(), f.scenario.getNetwork()); List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(f.coord2), new FakeFacility(f.coord6), 990, null)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } @SuppressWarnings("unchecked") @@ -541,14 +541,14 @@ void testLongTransferTime_withTransitRouterWrapper() { Coord toCoord = f.toFacility.getCoord(); List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(fromCoord), new FakeFacility(toCoord), 7.0 * 3600 + 50 * 60, null)); double legDuration = calcTripDuration(new ArrayList<>(legs)); - Assert.assertEquals(5, legs.size()); - Assert.assertEquals(100, ((Leg)legs.get(0)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s; arrival at 07:51:40 - Assert.assertEquals(800, ((Leg)legs.get(1)).getTravelTime().seconds(), 0.0); // 8m 20s waiting for pt departure and 5m pt travel time -> 500s + 300s = 800s; arrival at 08:05:00 - Assert.assertEquals(295, ((Leg)legs.get(2)).getTravelTime().seconds(), + Assertions.assertEquals(5, legs.size()); + Assertions.assertEquals(100, ((Leg)legs.get(0)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s; arrival at 07:51:40 + Assertions.assertEquals(800, ((Leg)legs.get(1)).getTravelTime().seconds(), 0.0); // 8m 20s waiting for pt departure and 5m pt travel time -> 500s + 300s = 800s; arrival at 08:05:00 + Assertions.assertEquals(295, ((Leg)legs.get(2)).getTravelTime().seconds(), 0.0); // 0.004km with 1m/s walk speed, but minimal waiting time -> max(4s, 300s) = 300s -5 seconds margin; arrival at 08:10:00 - Assert.assertEquals(600, ((Leg)legs.get(3)).getTravelTime().seconds(), 0.0); // 5m 00s waiting for pt departure and 5m pt travel time -> 300s + 300s = 600s; arrival at 08:15:00 - Assert.assertEquals(100, ((Leg)legs.get(4)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s - Assert.assertEquals(1895.0, legDuration, 0.0); + Assertions.assertEquals(600, ((Leg)legs.get(3)).getTravelTime().seconds(), 0.0); // 5m 00s waiting for pt departure and 5m pt travel time -> 300s + 300s = 600s; arrival at 08:15:00 + Assertions.assertEquals(100, ((Leg)legs.get(4)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s + Assertions.assertEquals(1895.0, legDuration, 0.0); RoutingModule walkRoutingModule = DefaultRoutingModules.createTeleportationRouter(TransportMode.transit_walk, f.scenario, f.config.routing().getModeRoutingParams().get(TransportMode.walk)); @@ -561,14 +561,14 @@ void testLongTransferTime_withTransitRouterWrapper() { List planElements = (List) wrapper.calcRoute(DefaultRoutingRequest.withoutAttributes(f.fromFacility, f.toFacility, 7.0 * 3600 + 50 * 60, null)); double tripDuration = calcTripDuration(planElements); - Assert.assertEquals(9, planElements.size()); - Assert.assertEquals(100, ((Leg) planElements.get(0)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s; arrival at 07:51:40 - Assert.assertEquals(800, ((Leg) planElements.get(2)).getTravelTime().seconds(), 0.0); // 8m 20s waiting for pt departure and 5m pt travel time -> 500s + 300s = 800s; arrival at 08:05:00 - Assert.assertEquals(295, ((Leg) planElements.get(4)).getTravelTime().seconds(), + Assertions.assertEquals(9, planElements.size()); + Assertions.assertEquals(100, ((Leg) planElements.get(0)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s; arrival at 07:51:40 + Assertions.assertEquals(800, ((Leg) planElements.get(2)).getTravelTime().seconds(), 0.0); // 8m 20s waiting for pt departure and 5m pt travel time -> 500s + 300s = 800s; arrival at 08:05:00 + Assertions.assertEquals(295, ((Leg) planElements.get(4)).getTravelTime().seconds(), 0.0); // 0.004km with 1m/s walk speed, but minimal waiting time -> max(4s, 300s) = 300s; arrival at 08:10:00 - Assert.assertEquals(600, ((Leg) planElements.get(6)).getTravelTime().seconds(), 0.0); // 5m 00s waiting for pt departure and 5m pt travel time -> 300s + 300s = 600s; arrival at 08:15:00 - Assert.assertEquals(100, ((Leg) planElements.get(8)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s - Assert.assertEquals(1895.0, tripDuration, 0.0); + Assertions.assertEquals(600, ((Leg) planElements.get(6)).getTravelTime().seconds(), 0.0); // 5m 00s waiting for pt departure and 5m pt travel time -> 300s + 300s = 600s; arrival at 08:15:00 + Assertions.assertEquals(100, ((Leg) planElements.get(8)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s + Assertions.assertEquals(1895.0, tripDuration, 0.0); } // 65 minutes additional transfer time - miss one departure @@ -580,13 +580,13 @@ void testLongTransferTime_withTransitRouterWrapper() { Coord toCoord = f.toFacility.getCoord(); List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(fromCoord), new FakeFacility(toCoord), 7.0*3600 + 50*60, null)); double legDuration = calcTripDuration(new ArrayList<>(legs)); - Assert.assertEquals(5, legs.size()); - Assert.assertEquals(100, ((Leg)legs.get(0)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s; arrival at 07:51:40 - Assert.assertEquals(800, ((Leg)legs.get(1)).getTravelTime().seconds(), 0.0); // 8m 20s waiting for pt departure and 5m pt travel time -> 500s + 300s = 800s; arrival at 08:05:00 - Assert.assertEquals(3900, ((Leg)legs.get(2)).getTravelTime().seconds(), 0.0); // 0.004km with 1m/s walk speed, but minimal waiting time -> max(4s, 300s) = 300s; arrival at 08:10:00 - Assert.assertEquals(600, ((Leg)legs.get(3)).getTravelTime().seconds(), 0.0); // 5m 00s waiting for pt departure and 5m pt travel time -> 300s + 300s = 600s; arrival at 08:15:00 - Assert.assertEquals(100, ((Leg)legs.get(4)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s - Assert.assertEquals(5500.0, legDuration, 0.0); + Assertions.assertEquals(5, legs.size()); + Assertions.assertEquals(100, ((Leg)legs.get(0)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s; arrival at 07:51:40 + Assertions.assertEquals(800, ((Leg)legs.get(1)).getTravelTime().seconds(), 0.0); // 8m 20s waiting for pt departure and 5m pt travel time -> 500s + 300s = 800s; arrival at 08:05:00 + Assertions.assertEquals(3900, ((Leg)legs.get(2)).getTravelTime().seconds(), 0.0); // 0.004km with 1m/s walk speed, but minimal waiting time -> max(4s, 300s) = 300s; arrival at 08:10:00 + Assertions.assertEquals(600, ((Leg)legs.get(3)).getTravelTime().seconds(), 0.0); // 5m 00s waiting for pt departure and 5m pt travel time -> 300s + 300s = 600s; arrival at 08:15:00 + Assertions.assertEquals(100, ((Leg)legs.get(4)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s + Assertions.assertEquals(5500.0, legDuration, 0.0); RoutingModule walkRoutingModule = DefaultRoutingModules.createTeleportationRouter(TransportMode.transit_walk, f.scenario, f.config.routing().getModeRoutingParams().get(TransportMode.walk)); @@ -599,13 +599,13 @@ void testLongTransferTime_withTransitRouterWrapper() { List planElements = (List) wrapper.calcRoute(DefaultRoutingRequest.withoutAttributes(f.fromFacility, f.toFacility, 7.0*3600 + 50*60, null)); double tripDuration = calcTripDuration(planElements); - Assert.assertEquals(9, planElements.size()); - Assert.assertEquals(100, ((Leg)planElements.get(0)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s; arrival at 07:51:40 - Assert.assertEquals(800, ((Leg)planElements.get(2)).getTravelTime().seconds(), 0.0); // 8m 20s waiting for pt departure and 5m pt travel time -> 500s + 300s = 800s; arrival at 08:05:00 - Assert.assertEquals(3900, ((Leg)planElements.get(4)).getTravelTime().seconds(), 0.0); // 0.004km with 1m/s walk speed, but minimal waiting time -> max(4s, 300s) = 300s; arrival at 08:10:00 - Assert.assertEquals(600, ((Leg)planElements.get(6)).getTravelTime().seconds(), 0.0); // 5m 00s waiting for pt departure and 5m pt travel time -> 300s + 300s = 600s; arrival at 08:15:00 - Assert.assertEquals(100, ((Leg)planElements.get(8)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s - Assert.assertEquals(5500.0, tripDuration, 0.0); + Assertions.assertEquals(9, planElements.size()); + Assertions.assertEquals(100, ((Leg)planElements.get(0)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s; arrival at 07:51:40 + Assertions.assertEquals(800, ((Leg)planElements.get(2)).getTravelTime().seconds(), 0.0); // 8m 20s waiting for pt departure and 5m pt travel time -> 500s + 300s = 800s; arrival at 08:05:00 + Assertions.assertEquals(3900, ((Leg)planElements.get(4)).getTravelTime().seconds(), 0.0); // 0.004km with 1m/s walk speed, but minimal waiting time -> max(4s, 300s) = 300s; arrival at 08:10:00 + Assertions.assertEquals(600, ((Leg)planElements.get(6)).getTravelTime().seconds(), 0.0); // 5m 00s waiting for pt departure and 5m pt travel time -> 300s + 300s = 600s; arrival at 08:15:00 + Assertions.assertEquals(100, ((Leg)planElements.get(8)).getTravelTime().seconds(), 0.0); // 0.1km with 1m/s walk speed -> 100s + Assertions.assertEquals(5500.0, tripDuration, 0.0); } // 600 minutes additional transfer time - miss all departures @@ -615,7 +615,7 @@ void testLongTransferTime_withTransitRouterWrapper() { Coord fromCoord = f.fromFacility.getCoord(); Coord toCoord = f.toFacility.getCoord(); List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(fromCoord), new FakeFacility(toCoord), 7.0*3600 + 50*60, null)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); RoutingModule walkRoutingModule = DefaultRoutingModules.createTeleportationRouter(TransportMode.transit_walk, f.scenario, f.config.routing().getModeRoutingParams().get(TransportMode.walk)); @@ -628,7 +628,7 @@ void testLongTransferTime_withTransitRouterWrapper() { TransitRouterWrapper wrapper = new TransitRouterWrapper(router, f.schedule, f.scenario.getNetwork(), routingModule); List planElements = (List) wrapper.calcRoute(DefaultRoutingRequest.withoutAttributes(f.fromFacility, f.toFacility, 7.0*3600 + 50*60, null)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", planElements); + Assertions.assertNull(planElements, "The router should not find a route and return null, but did return something else."); } } @@ -666,17 +666,17 @@ void testNightBus() { assertEquals(TransportMode.walk, ((Leg)legs.get(4)).getMode()); assertEquals(TransportMode.pt, ((Leg)legs.get(5)).getMode()); assertEquals(TransportMode.walk, ((Leg)legs.get(6)).getMode()); - assertTrue("expected TransitRoute in leg.", ((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute); + assertTrue(((Leg)legs.get(1)).getRoute() instanceof TransitPassengerRoute, "expected TransitRoute in leg."); TransitPassengerRoute ptRoute = (TransitPassengerRoute) ((Leg)legs.get(1)).getRoute(); assertEquals(f.stop0.getId(), ptRoute.getAccessStopId()); assertEquals(f.stop1.getId(), ptRoute.getEgressStopId()); assertEquals(f.lineId0, ptRoute.getLineId()); - assertTrue("expected TransitRoute in leg.", ((Leg)legs.get(3)).getRoute() instanceof TransitPassengerRoute); + assertTrue(((Leg)legs.get(3)).getRoute() instanceof TransitPassengerRoute, "expected TransitRoute in leg."); ptRoute = (TransitPassengerRoute) ((Leg)legs.get(3)).getRoute(); assertEquals(f.stop1.getId(), ptRoute.getAccessStopId()); assertEquals(f.stop2.getId(), ptRoute.getEgressStopId()); assertEquals(f.lineId1, ptRoute.getLineId()); - assertTrue("expected TransitRoute in leg.", ((Leg)legs.get(5)).getRoute() instanceof TransitPassengerRoute); + assertTrue(((Leg)legs.get(5)).getRoute() instanceof TransitPassengerRoute, "expected TransitRoute in leg."); ptRoute = (TransitPassengerRoute) ((Leg)legs.get(5)).getRoute(); assertEquals(f.stop2.getId(), ptRoute.getAccessStopId()); assertEquals(f.stop3.getId(), ptRoute.getEgressStopId()); @@ -699,17 +699,17 @@ void testCircularLine() { System.out.println(leg); } - Assert.assertEquals(5, legs.size()); - Assert.assertEquals(TransportMode.walk, ((Leg)legs.get(0)).getMode()); - Assert.assertEquals(TransportMode.pt, ((Leg)legs.get(1)).getMode()); - Assert.assertEquals(TransportMode.walk, ((Leg)legs.get(2)).getMode()); - Assert.assertEquals(TransportMode.pt, ((Leg)legs.get(3)).getMode()); - Assert.assertEquals(TransportMode.walk, ((Leg)legs.get(4)).getMode()); - - Assert.assertEquals(f.greenLine.getId(), ((TransitPassengerRoute) ((Leg)legs.get(1)).getRoute()).getLineId()); - Assert.assertEquals(Id.create(23, TransitStopFacility.class), ((TransitPassengerRoute) ((Leg)legs.get(1)).getRoute()).getAccessStopId()); - Assert.assertEquals(f.greenLine.getId(), ((TransitPassengerRoute) ((Leg)legs.get(3)).getRoute()).getLineId()); - Assert.assertEquals(Id.create(20, TransitStopFacility.class), ((TransitPassengerRoute) ((Leg)legs.get(3)).getRoute()).getEgressStopId()); + Assertions.assertEquals(5, legs.size()); + Assertions.assertEquals(TransportMode.walk, ((Leg)legs.get(0)).getMode()); + Assertions.assertEquals(TransportMode.pt, ((Leg)legs.get(1)).getMode()); + Assertions.assertEquals(TransportMode.walk, ((Leg)legs.get(2)).getMode()); + Assertions.assertEquals(TransportMode.pt, ((Leg)legs.get(3)).getMode()); + Assertions.assertEquals(TransportMode.walk, ((Leg)legs.get(4)).getMode()); + + Assertions.assertEquals(f.greenLine.getId(), ((TransitPassengerRoute) ((Leg)legs.get(1)).getRoute()).getLineId()); + Assertions.assertEquals(Id.create(23, TransitStopFacility.class), ((TransitPassengerRoute) ((Leg)legs.get(1)).getRoute()).getAccessStopId()); + Assertions.assertEquals(f.greenLine.getId(), ((TransitPassengerRoute) ((Leg)legs.get(3)).getRoute()).getLineId()); + Assertions.assertEquals(Id.create(20, TransitStopFacility.class), ((TransitPassengerRoute) ((Leg)legs.get(3)).getRoute()).getEgressStopId()); } @Test @@ -728,7 +728,7 @@ void testRangeQuery() { System.out.println(i + " depTime = " + Time.writeTime(route.getDepartureTime()) + " arrTime = " + Time.writeTime(route.getDepartureTime() + route.getTravelTime()) + " # transfers = " + route.getNumberOfTransfers() + " costs = " + route.getTotalCosts()); } - Assert.assertEquals(6, routes.size()); + Assertions.assertEquals(6, routes.size()); assertRaptorRoute(routes.get(0), "05:40:12", "06:30:56", 0, 10.1466666); assertRaptorRoute(routes.get(1), "06:00:12", "06:50:56", 0, 10.1466666); @@ -739,10 +739,10 @@ void testRangeQuery() { } private void assertRaptorRoute(RaptorRoute route, String depTime, String arrTime, int expectedTransfers, double expectedCost) { - Assert.assertEquals("wrong number of transfers", expectedTransfers, route.getNumberOfTransfers()); - Assert.assertEquals("wrong departure time", Time.parseTime(depTime), route.getDepartureTime(), 0.99); - Assert.assertEquals("wrong arrival time", Time.parseTime(arrTime), route.getDepartureTime() + route.getTravelTime(), 0.99); - Assert.assertEquals("wrong cost", expectedCost, route.getTotalCosts(), 1e-5); + Assertions.assertEquals(expectedTransfers, route.getNumberOfTransfers(), "wrong number of transfers"); + Assertions.assertEquals(Time.parseTime(depTime), route.getDepartureTime(), 0.99, "wrong departure time"); + Assertions.assertEquals(Time.parseTime(arrTime), route.getDepartureTime() + route.getTravelTime(), 0.99, "wrong arrival time"); + Assertions.assertEquals(expectedCost, route.getTotalCosts(), 1e-5, "wrong cost"); } /** test for https://github.com/SchweizerischeBundesbahnen/matsim-sbb-extensions/issues/1 @@ -773,7 +773,7 @@ void testUnusedTransitStop() { double depTime = 5.0 * 3600 + 50 * 60; List legs = raptor.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(fromCoord), new FakeFacility(toCoord), depTime, null)); // this test mostly checks that there are no Exceptions. - Assert.assertEquals(3, legs.size()); + Assertions.assertEquals(3, legs.size()); } @Test @@ -788,7 +788,7 @@ void testTravelTimeDependentTransferCosts() { Coord toCoord = new Coord(20000, 100); double depTime = 6.0 * 3600; List routes = raptor.calcRoutes(new FakeFacility(fromCoord), new FakeFacility(toCoord), depTime - 300, depTime, depTime + 300, null, new AttributesImpl()); - Assert.assertEquals(1, routes.size()); + Assertions.assertEquals(1, routes.size()); RaptorRoute route1 = routes.get(0); RaptorParameters params = RaptorUtils.createParameters(config); @@ -797,7 +797,7 @@ void testTravelTimeDependentTransferCosts() { double expectedAccessEgressTime = 2 * 100; // 2 * 100 meters at 1m/s beeline walk speed (beeline factor included) double expectedCost = (expectedTravelTime + expectedAccessEgressTime) * -params.getMarginalUtilityOfTravelTime_utl_s(TransportMode.pt); - Assert.assertEquals(expectedCost, route1.getTotalCosts(), 1e-7); + Assertions.assertEquals(expectedCost, route1.getTotalCosts(), 1e-7); } { // test 2 + 0 * tt @@ -808,7 +808,7 @@ void testTravelTimeDependentTransferCosts() { Coord toCoord = new Coord(20000, 100); double depTime = 6.0 * 3600; List routes = raptor.calcRoutes(new FakeFacility(fromCoord), new FakeFacility(toCoord), depTime - 300, depTime, depTime + 300, null, new AttributesImpl()); - Assert.assertEquals(1, routes.size()); + Assertions.assertEquals(1, routes.size()); RaptorRoute route1 = routes.get(0); RaptorParameters params = RaptorUtils.createParameters(config); @@ -817,7 +817,7 @@ void testTravelTimeDependentTransferCosts() { double expectedAccessEgressTime = 2 * 100; // 2 * 100 meters at 1m/s double expectedCost = (expectedTravelTime + expectedAccessEgressTime) * -params.getMarginalUtilityOfTravelTime_utl_s(TransportMode.pt) + 2; - Assert.assertEquals(expectedCost, route1.getTotalCosts(), 1e-7); + Assertions.assertEquals(expectedCost, route1.getTotalCosts(), 1e-7); } { // test 2 + 9 * tt[h] @@ -828,7 +828,7 @@ void testTravelTimeDependentTransferCosts() { Coord toCoord = new Coord(20000, 100); double depTime = 6.0 * 3600; List routes = raptor.calcRoutes(new FakeFacility(fromCoord), new FakeFacility(toCoord), depTime - 300, depTime, depTime + 300, null, new AttributesImpl()); - Assert.assertEquals(1, routes.size()); + Assertions.assertEquals(1, routes.size()); RaptorRoute route1 = routes.get(0); RaptorParameters params = RaptorUtils.createParameters(config); @@ -837,7 +837,7 @@ void testTravelTimeDependentTransferCosts() { double expectedAccessEgressTime = 2 * 100; // 2 * 100 meters at 1m/s double expectedCost = (expectedTravelTime + expectedAccessEgressTime) * -params.getMarginalUtilityOfTravelTime_utl_s(TransportMode.pt) + 2 + 0.0025 * expectedTravelTime; - Assert.assertEquals(expectedCost, route1.getTotalCosts(), 1e-7); + Assertions.assertEquals(expectedCost, route1.getTotalCosts(), 1e-7); } { // test 2 + 9 * tt[h], longer trip @@ -848,7 +848,7 @@ void testTravelTimeDependentTransferCosts() { Coord toCoord = new Coord(40000, 100); double depTime = 6.0 * 3600; List routes = raptor.calcRoutes(new FakeFacility(fromCoord), new FakeFacility(toCoord), depTime - 300, depTime, depTime + 300, null, new AttributesImpl()); - Assert.assertEquals(1, routes.size()); + Assertions.assertEquals(1, routes.size()); RaptorRoute route1 = routes.get(0); RaptorParameters params = RaptorUtils.createParameters(config); @@ -857,7 +857,7 @@ void testTravelTimeDependentTransferCosts() { double expectedAccessEgressTime = 2 * 100; // 2 * 100 meters at 1m/s double expectedCost = (expectedTravelTime + expectedAccessEgressTime) * -params.getMarginalUtilityOfTravelTime_utl_s(TransportMode.pt) + 2 + 0.0025 * expectedTravelTime; - Assert.assertEquals(expectedCost, route1.getTotalCosts(), 1e-7); + Assertions.assertEquals(expectedCost, route1.getTotalCosts(), 1e-7); } } @@ -891,7 +891,7 @@ public double calcTransferCost(Supplier transfer, RaptorParameters rap for (PlanElement leg : legs) { System.out.println(leg); } - Assert.assertTrue("TransferCost function must have been called at least once.", transferCount[0] > 0); + Assertions.assertTrue(transferCount[0] > 0, "TransferCost function must have been called at least once."); } private Config prepareConfig(double transferFixedCost, double transferRelativeCostFactor) { @@ -1059,7 +1059,7 @@ void testDepartureAfterLastBus(){ List legs = router.calcRoute(DefaultRoutingRequest.withoutAttributes(new FakeFacility(fromCoord), new FakeFacility(toCoord), 11.0*3600, null)); - Assert.assertNull("The router should not find a route and return null, but did return something else.", legs); + Assertions.assertNull(legs, "The router should not find a route and return null, but did return something else."); } /** diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTreeTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTreeTest.java index a380bd4ebca..a027ef2c909 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTreeTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorTreeTest.java @@ -20,7 +20,7 @@ package ch.sbb.matsim.routing.pt.raptor; import ch.sbb.matsim.routing.pt.raptor.SwissRailRaptorCore.TravelInfo; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -55,7 +55,7 @@ void testSingleStop_dep0740atN_optimized() { double depTime = 7*3600 + 40*60; Map, TravelInfo> map = raptor.calcTree(fromStop, depTime, raptorParams, null); - Assert.assertEquals("wrong number of reached stops.", f.schedule.getFacilities().size(), map.size()); + Assertions.assertEquals(f.schedule.getFacilities().size(), map.size(), "wrong number of reached stops."); assertTravelInfo(map, 0 , "23", 1, "07:41:00", "08:14:07"); // transfer at C, 7:50/8:02 blue, walk at A assertTravelInfo(map, 1 , "23", 1, "07:41:00", "08:14:00"); // transfer at C, 7:50/8:02 blue @@ -98,11 +98,11 @@ void testSingleStop_dep0740atN_unoptimized() { double depTime = 7*3600 + 40*60; Map, TravelInfo> map = raptor.calcTree(fromStop, depTime, raptorParams, null); - Assert.assertEquals("wrong number of reached stops.", 20, map.size()); + Assertions.assertEquals(20, map.size(), "wrong number of reached stops."); - Assert.assertNull(map.get(Id.create(0, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(0, TransitStopFacility.class))); // unreachable assertTravelInfo(map, 1 , "23", 1, "07:41:00", "08:14:00"); // transfer at C, 7:50/8:02 blue - Assert.assertNull(map.get(Id.create(2, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(2, TransitStopFacility.class))); // unreachable assertTravelInfo(map, 3 , "23", 1, "07:41:00", "08:09:00"); // transfer at C, 7:50/8:02 blue assertTravelInfo(map, 4 , "23", 0, "07:41:00", "07:50:04"); // transfer at C, 7:50, walk 3.12 (-> 4) seconds (2.6 meters) assertTravelInfo(map, 5 , "23", 0, "07:41:00", "07:50:04"); // transfer at C, 7:50, walk 3.12 (-> 4) seconds (2.6 meters) @@ -115,9 +115,9 @@ void testSingleStop_dep0740atN_unoptimized() { assertTravelInfo(map, 12, "23", 1, "07:41:00", "08:09:00"); // transfer at C, 7:50/8:00 red assertTravelInfo(map, 13, "23", 1, "07:41:00", "08:09:07"); // transfer at C, 7:50/8:00 red, walk 4 meters / 7 seconds assertTravelInfo(map, 14, "23", 2, "07:41:00", "08:19:00"); // transfer at C, 7:50/8:00 red, transfer at G, 8:09/8:12 - Assert.assertNull(map.get(Id.create(15, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(15, TransitStopFacility.class))); // unreachable assertTravelInfo(map, 16, "23", 2, "07:41:00", "08:24:00"); // transfer at C, 7:50/8:00 red, transfer at G, 8:09/8:12 - Assert.assertNull(map.get(Id.create(17, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(17, TransitStopFacility.class))); // unreachable assertTravelInfo(map, 18, "23", 0, "07:41:00", "07:50:00"); // directly reachable assertTravelInfo(map, 19, "23", 1, "07:41:00", "08:01:00"); // transfer at C, 7:50/7:51 green assertTravelInfo(map, 20, "23", 1, "07:41:00", "08:11:00"); // transfer at C, 7:50/7:51 green @@ -144,7 +144,7 @@ void testSingleStop_dep0750atN_optimized() { Map, TravelInfo> map = raptor.calcTree(fromStop, depTime, raptorParams, null); // latest departure on green line is at 07:51, so we'll miss some stops! - Assert.assertEquals("wrong number of reached stops.", 21, map.size()); + Assertions.assertEquals(21, map.size(), "wrong number of reached stops."); assertTravelInfo(map, 0 , "23", 1, "07:51:00", "08:14:07"); // same as [1], then walk assertTravelInfo(map, 1 , "23", 1, "07:51:00", "08:14:00"); // transfer at C, 8:00/8:02 blue @@ -165,10 +165,10 @@ void testSingleStop_dep0750atN_optimized() { assertTravelInfo(map, 16, "23", 1, "07:51:00", "08:44:00"); // transfer at C, 8:00/8:02 blue assertTravelInfo(map, 17, "23", 1, "07:51:00", "08:44:07"); // same as [16], then walk assertTravelInfo(map, 18, "23", 0, "07:51:00", "08:00:00"); // directly reachable - Assert.assertNull(map.get(Id.create(19, TransitStopFacility.class))); // unreachable - Assert.assertNull(map.get(Id.create(20, TransitStopFacility.class))); + Assertions.assertNull(map.get(Id.create(19, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(20, TransitStopFacility.class))); assertTravelInfo(map, 21, "23", 1, "07:51:00", "08:28:04"); // transfer at C, 8:00/8:01 green, walk 2 meters / 3.12 (-> 4) seconds - Assert.assertNull(map.get(Id.create(22, TransitStopFacility.class))); + Assertions.assertNull(map.get(Id.create(22, TransitStopFacility.class))); assertTravelInfo(map, 23, "23", 0, "07:50:00", "07:50:00"); // our start location } @@ -188,31 +188,31 @@ void testSingleStop_dep0750atN_unoptimized() { Map, TravelInfo> map = raptor.calcTree(fromStop, depTime, raptorParams, null); // latest departure on green line is at 07:51, so we'll miss some stops! - Assert.assertEquals("wrong number of reached stops.", 14, map.size()); + Assertions.assertEquals(14, map.size(), "wrong number of reached stops."); - Assert.assertNull(map.get(Id.create(0, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(0, TransitStopFacility.class))); // unreachable assertTravelInfo(map, 1 , "23", 1, "07:51:00", "08:14:00"); // transfer at C, 8:00/8:02 blue - Assert.assertNull(map.get(Id.create(2, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(2, TransitStopFacility.class))); // unreachable assertTravelInfo(map, 3 , "23", 1, "07:51:00", "08:09:00"); // transfer at C, 8:00/8:02 blue assertTravelInfo(map, 4 , "23", 0, "07:51:00", "08:00:04"); // transfer at C, 8:00, walk 3.12 (-> 4) seconds (2.6 meters) assertTravelInfo(map, 5 , "23", 0, "07:51:00", "08:00:04"); // transfer at C, 8:00, walk 3.12 (-> 4) seconds (2.6 meters) assertTravelInfo(map, 6 , "23", 1, "07:51:00", "08:09:00"); // transfer at C, 8:00/8:02 blue - Assert.assertNull(map.get(Id.create(7, TransitStopFacility.class))); // unreachable, no more departures at C(red) or G(blue) + Assertions.assertNull(map.get(Id.create(7, TransitStopFacility.class))); // unreachable, no more departures at C(red) or G(blue) assertTravelInfo(map, 8 , "23", 1, "07:51:00", "08:16:00"); // transfer at C, 8:00/8:02 blue - Assert.assertNull(map.get(Id.create(9, TransitStopFacility.class))); // unreachable, no more departures at C(red) or G(blue) + Assertions.assertNull(map.get(Id.create(9, TransitStopFacility.class))); // unreachable, no more departures at C(red) or G(blue) assertTravelInfo(map, 10, "23", 1, "07:51:00", "08:23:00"); // transfer at C, 8:00/8:02 blue - Assert.assertNull(map.get(Id.create(11, TransitStopFacility.class))); // unreachable, no more departures at C(red) or G(blue) + Assertions.assertNull(map.get(Id.create(11, TransitStopFacility.class))); // unreachable, no more departures at C(red) or G(blue) assertTravelInfo(map, 12, "23", 1, "07:51:00", "08:28:00"); // transfer at C, 8:00/8:02 blue assertTravelInfo(map, 13, "23", 1, "07:51:00", "08:28:07"); // transfer at C, 8:00/8:02 blue, walk (4 meters) (transfer to red line is allowed) assertTravelInfo(map, 14, "23", 1, "07:51:00", "08:39:00"); // transfer at C, 8:00/8:02 blue - Assert.assertNull(map.get(Id.create(15, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(15, TransitStopFacility.class))); // unreachable assertTravelInfo(map, 16, "23", 1, "07:51:00", "08:44:00"); // transfer at C, 8:00/8:02 blue - Assert.assertNull(map.get(Id.create(17, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(17, TransitStopFacility.class))); // unreachable assertTravelInfo(map, 18, "23", 0, "07:51:00", "08:00:00"); // directly reachable - Assert.assertNull(map.get(Id.create(19, TransitStopFacility.class))); // unreachable - Assert.assertNull(map.get(Id.create(20, TransitStopFacility.class))); + Assertions.assertNull(map.get(Id.create(19, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(20, TransitStopFacility.class))); assertTravelInfo(map, 21, "23", 1, "07:51:00", "08:28:04"); // transfer at C, 8:00/8:01 green, walk 2.6 meters / 4 seconds - Assert.assertNull(map.get(Id.create(22, TransitStopFacility.class))); + Assertions.assertNull(map.get(Id.create(22, TransitStopFacility.class))); assertTravelInfo(map, 23, "23", 0, "07:50:00", "07:50:00"); // our start location } @@ -237,7 +237,7 @@ void testMultipleStops_optimized() { fromStops.add(fromStopH); Map, TravelInfo> map = raptor.calcTree(fromStops, depTime, raptorParams, null); - Assert.assertEquals("wrong number of reached stops.", f.schedule.getFacilities().size(), map.size()); + Assertions.assertEquals(f.schedule.getFacilities().size(), map.size(), "wrong number of reached stops."); assertTravelInfo(map, 0 , "2", 0, "07:49:00", "07:54:07"); // initial transfer at B (not counted), walk at A assertTravelInfo(map, 1 , "2", 0, "07:49:00", "07:54:00"); // initial transfer at B (not counted) @@ -284,9 +284,9 @@ void testMultipleStops_unoptimized() { fromStops.add(fromStopH); Map, TravelInfo> map = raptor.calcTree(fromStops, depTime, raptorParams, null); - Assert.assertEquals("wrong number of reached stops.", 22, map.size()); + Assertions.assertEquals(22, map.size(), "wrong number of reached stops."); - Assert.assertNull(map.get(Id.create(0, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(0, TransitStopFacility.class))); // unreachable assertTravelInfo(map, 1 , "15", 0, "07:43:00", "08:34:00"); // from H, directly reachable assertTravelInfo(map, 2 , "2", 0, "07:30:00", "07:30:00"); // from B, we started here assertTravelInfo(map, 3 , "15", 0, "07:43:00", "08:29:00"); // from H, directly reachable @@ -303,7 +303,7 @@ void testMultipleStops_unoptimized() { assertTravelInfo(map, 14, "2", 0, "07:33:00", "08:19:00"); // from B, directly reachable assertTravelInfo(map, 15, "15", 0, "07:30:00", "07:30:00"); // from H, we started here assertTravelInfo(map, 16, "2", 0, "07:33:00", "08:24:00"); // from B, directly reachable - Assert.assertNull(map.get(Id.create(17, TransitStopFacility.class))); // unreachable + Assertions.assertNull(map.get(Id.create(17, TransitStopFacility.class))); // unreachable assertTravelInfo(map, 18, "2", 0, "07:33:00", "07:38:04"); // from B, transfer at C, 7:38 (walk 2.6m) assertTravelInfo(map, 19, "2", 1, "07:33:00", "07:51:00"); // from B, transfer at C, 7:38/7:41 green assertTravelInfo(map, 20, "2", 1, "07:33:00", "08:01:00"); // from B, transfer at C, 7:38/7:41 green @@ -334,15 +334,15 @@ void testSingleStop_costs_dep0740atN_optimized() { TravelInfo info0740 = map.get(stop19id); TravelInfo info0739 = raptor.calcTree(fromStop, 7*3600 + 39*60, raptorParams, null).get(stop19id); - Assert.assertEquals("departure time should be the same.", info0740.ptDepartureTime, info0739.ptDepartureTime, 0.0); - Assert.assertEquals("arrival time should be the same.", info0740.ptArrivalTime, info0739.ptArrivalTime, 0.0); - Assert.assertEquals("travel time should be the same.", info0740.ptTravelTime, info0739.ptTravelTime, 0.0); - Assert.assertEquals("access time should be independent of waiting time.", info0740.accessTime, info0739.accessTime, 0.0); - Assert.assertEquals("access cost should be independent of waiting time.", info0740.accessCost, info0739.accessCost, 0.0); - Assert.assertEquals("travel cost should be independent of waiting time.", info0740.travelCost, info0739.travelCost, 0.0); + Assertions.assertEquals(info0740.ptDepartureTime, info0739.ptDepartureTime, 0.0, "departure time should be the same."); + Assertions.assertEquals(info0740.ptArrivalTime, info0739.ptArrivalTime, 0.0, "arrival time should be the same."); + Assertions.assertEquals(info0740.ptTravelTime, info0739.ptTravelTime, 0.0, "travel time should be the same."); + Assertions.assertEquals(info0740.accessTime, info0739.accessTime, 0.0, "access time should be independent of waiting time."); + Assertions.assertEquals(info0740.accessCost, info0739.accessCost, 0.0, "access cost should be independent of waiting time."); + Assertions.assertEquals(info0740.travelCost, info0739.travelCost, 0.0, "travel cost should be independent of waiting time."); - Assert.assertEquals("waiting time should differ by 1 minute", info0740.waitingTime, info0739.waitingTime - 60, 0.0); - Assert.assertTrue("waiting cost should differ", info0740.waitingCost < info0739.waitingCost); + Assertions.assertEquals(info0740.waitingTime, info0739.waitingTime - 60, 0.0, "waiting time should differ by 1 minute"); + Assertions.assertTrue(info0740.waitingCost < info0739.waitingCost, "waiting cost should differ"); } @Test @@ -367,13 +367,13 @@ void testSingleStop_raptorroute_dep0740atN_optimized() { TravelInfo info = map.get(stop2id); RaptorRoute route = info.getRaptorRoute(); - Assert.assertNotNull(route); + Assertions.assertNotNull(route); List parts = new ArrayList<>(); for (RaptorRoute.RoutePart part : route.getParts()) { parts.add(part); } - Assert.assertEquals(5, parts.size()); + Assertions.assertEquals(5, parts.size()); RaptorRoute.RoutePart stage1 = parts.get(0); RaptorRoute.RoutePart stage2 = parts.get(1); RaptorRoute.RoutePart stage3 = parts.get(2); @@ -381,32 +381,32 @@ void testSingleStop_raptorroute_dep0740atN_optimized() { RaptorRoute.RoutePart stage5 = parts.get(4); - Assert.assertNull(stage1.line); // access walk - Assert.assertEquals(0, stage1.distance, 0.0); - Assert.assertEquals(0, stage1.arrivalTime - stage1.depTime, 0.0); + Assertions.assertNull(stage1.line); // access walk + Assertions.assertEquals(0, stage1.distance, 0.0); + Assertions.assertEquals(0, stage1.arrivalTime - stage1.depTime, 0.0); - Assert.assertEquals("green", stage2.line.getId().toString()); - Assert.assertEquals(TransportMode.pt, stage2.mode); - Assert.assertEquals(540, stage2.arrivalTime - stage2.boardingTime, 1e-7); - Assert.assertEquals(10000, stage2.distance, 1e-7); + Assertions.assertEquals("green", stage2.line.getId().toString()); + Assertions.assertEquals(TransportMode.pt, stage2.mode); + Assertions.assertEquals(540, stage2.arrivalTime - stage2.boardingTime, 1e-7); + Assertions.assertEquals(10000, stage2.distance, 1e-7); - Assert.assertNull(stage3.line); // transfer + Assertions.assertNull(stage3.line); // transfer - Assert.assertEquals("blue", stage4.line.getId().toString()); - Assert.assertEquals(TransportMode.pt, stage4.mode); - Assert.assertEquals(660, stage4.arrivalTime - stage4.boardingTime, 1e-7); - Assert.assertEquals(5000, stage4.distance, 1e-7); + Assertions.assertEquals("blue", stage4.line.getId().toString()); + Assertions.assertEquals(TransportMode.pt, stage4.mode); + Assertions.assertEquals(660, stage4.arrivalTime - stage4.boardingTime, 1e-7); + Assertions.assertEquals(5000, stage4.distance, 1e-7); - Assert.assertNull(stage5.line); // egress_walk + Assertions.assertNull(stage5.line); // egress_walk } private void assertTravelInfo(Map, TravelInfo> map, int stopId, String expectedDepartureStop, int expectedTransfers, String expectedDepartureTime, String expectedArrivalTime) { TravelInfo info = map.get(Id.create(stopId, TransitStopFacility.class)); - Assert.assertNotNull("Stop " + stopId + " is not reachable.", info); - Assert.assertEquals("wrong departure stop", expectedDepartureStop, info.departureStop.toString()); - Assert.assertEquals("wrong number of transfers", expectedTransfers, info.transferCount); - Assert.assertEquals("unexpected arrival time: " + Time.writeTime(info.ptArrivalTime), Time.parseTime(expectedArrivalTime), Math.floor(info.ptArrivalTime), 0.0); - Assert.assertEquals("unexpected departure time: " + Time.writeTime(info.ptDepartureTime), Time.parseTime(expectedDepartureTime), Math.floor(info.ptDepartureTime), 0.0); + Assertions.assertNotNull(info, "Stop " + stopId + " is not reachable."); + Assertions.assertEquals(expectedDepartureStop, info.departureStop.toString(), "wrong departure stop"); + Assertions.assertEquals(expectedTransfers, info.transferCount, "wrong number of transfers"); + Assertions.assertEquals(Time.parseTime(expectedArrivalTime), Math.floor(info.ptArrivalTime), 0.0, "unexpected arrival time: " + Time.writeTime(info.ptArrivalTime)); + Assertions.assertEquals(Time.parseTime(expectedDepartureTime), Math.floor(info.ptDepartureTime), 0.0, "unexpected departure time: " + Time.writeTime(info.ptDepartureTime)); } } diff --git a/matsim/src/test/java/org/matsim/analysis/CalcAverageTripLengthTest.java b/matsim/src/test/java/org/matsim/analysis/CalcAverageTripLengthTest.java index 05d463b8b0c..b6017637f1e 100644 --- a/matsim/src/test/java/org/matsim/analysis/CalcAverageTripLengthTest.java +++ b/matsim/src/test/java/org/matsim/analysis/CalcAverageTripLengthTest.java @@ -22,6 +22,8 @@ package org.matsim.analysis; import java.util.ArrayList; + +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -42,9 +44,7 @@ import org.matsim.core.scenario.ScenarioUtils; import org.matsim.testcases.MatsimTestUtils; -import org.junit.Assert; - - public class CalcAverageTripLengthTest { + public class CalcAverageTripLengthTest { @Test void testWithRoute() { @@ -89,9 +89,9 @@ void testWithRoute() { // test simple route, startLink should not be included, endLink should CalcAverageTripLength catl = new CalcAverageTripLength(network); - Assert.assertEquals(0.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); catl.run(plan); - Assert.assertEquals(300.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(300.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); // extend route by one link, test again linkIds.add(l3.getId()); @@ -100,7 +100,7 @@ void testWithRoute() { catl = new CalcAverageTripLength(network); catl.run(plan); - Assert.assertEquals(700.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(700.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); // don't reset catl, modify route, test average linkIds.remove(1); @@ -108,7 +108,7 @@ void testWithRoute() { ((Activity) act2).setLinkId(l3.getId()); catl.run(plan); - Assert.assertEquals(500.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(500.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); } @Test @@ -145,7 +145,7 @@ void testWithRoute_OneLinkRoute() { // test simple route, startLink should not be included, endLink should be CalcAverageTripLength catl = new CalcAverageTripLength(network); catl.run(plan); - Assert.assertEquals(100.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(100.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); } @Test @@ -178,7 +178,7 @@ void testWithRoute_StartEndOnSameLink() { // test simple route, none of the links should be included, as there is no real traffic CalcAverageTripLength catl = new CalcAverageTripLength(network); catl.run(plan); - Assert.assertEquals(0.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, catl.getAverageTripLength(), MatsimTestUtils.EPSILON); } } diff --git a/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java b/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java index 88e253fa21b..d2b5219d8b5 100644 --- a/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java +++ b/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java @@ -24,8 +24,8 @@ import java.io.IOException; import org.junit.After; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -167,7 +167,7 @@ private void runTest( CalcLegTimes calcLegTimes ) throws IOException { calcLegTimes.writeStats(utils.getOutputDirectory() + CalcLegTimesTest.BASE_FILE_NAME); - Assert.assertEquals(readResult(utils.getInputDirectory() + CalcLegTimesTest.BASE_FILE_NAME), + Assertions.assertEquals(readResult(utils.getInputDirectory() + CalcLegTimesTest.BASE_FILE_NAME), readResult(utils.getOutputDirectory() + CalcLegTimesTest.BASE_FILE_NAME)); } diff --git a/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java b/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java index 06e85721459..d147c947e34 100644 --- a/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java +++ b/matsim/src/test/java/org/matsim/analysis/CalcLinkStatsTest.java @@ -21,7 +21,7 @@ import java.io.File; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -86,10 +86,10 @@ void testAddData() { cls.addData(analyzer, ttimes); - Assert.assertEquals(3.0, cls.getAvgLinkVolumes(link1.getId())[0], 1e-8); - Assert.assertEquals(1.0, cls.getAvgLinkVolumes(link2.getId())[0], 1e-8); - Assert.assertEquals(1.0, cls.getAvgLinkVolumes(link1.getId())[1], 1e-8); - Assert.assertEquals(4.0, cls.getAvgLinkVolumes(link2.getId())[1], 1e-8); + Assertions.assertEquals(3.0, cls.getAvgLinkVolumes(link1.getId())[0], 1e-8); + Assertions.assertEquals(1.0, cls.getAvgLinkVolumes(link2.getId())[0], 1e-8); + Assertions.assertEquals(1.0, cls.getAvgLinkVolumes(link1.getId())[1], 1e-8); + Assertions.assertEquals(4.0, cls.getAvgLinkVolumes(link2.getId())[1], 1e-8); analyzer.reset(1); // generate some pseudo traffic for hour 0: 4 veh on link 1; 3 veh on link 2 @@ -111,15 +111,15 @@ void testAddData() { cls.addData(analyzer, ttimes); - Assert.assertEquals(3.5, cls.getAvgLinkVolumes(link1.getId())[0], 1e-8); - Assert.assertEquals(2.0, cls.getAvgLinkVolumes(link2.getId())[0], 1e-8); - Assert.assertEquals(2.5, cls.getAvgLinkVolumes(link1.getId())[1], 1e-8); - Assert.assertEquals(3.0, cls.getAvgLinkVolumes(link2.getId())[1], 1e-8); + Assertions.assertEquals(3.5, cls.getAvgLinkVolumes(link1.getId())[0], 1e-8); + Assertions.assertEquals(2.0, cls.getAvgLinkVolumes(link2.getId())[0], 1e-8); + Assertions.assertEquals(2.5, cls.getAvgLinkVolumes(link1.getId())[1], 1e-8); + Assertions.assertEquals(3.0, cls.getAvgLinkVolumes(link2.getId())[1], 1e-8); cls.reset(); - Assert.assertEquals(0, cls.getAvgLinkVolumes(link1.getId()).length); - Assert.assertEquals(0, cls.getAvgLinkVolumes(link2.getId()).length); + Assertions.assertEquals(0, cls.getAvgLinkVolumes(link1.getId()).length); + Assertions.assertEquals(0, cls.getAvgLinkVolumes(link2.getId()).length); } /** @@ -196,22 +196,22 @@ void testAddDataObservedTravelTime() { cls.addData(analyzer, ttimes); // volumes - Assert.assertEquals(3.0, cls.getAvgLinkVolumes(link1.getId())[0], 1e-8); - Assert.assertEquals(1.0, cls.getAvgLinkVolumes(link2.getId())[0], 1e-8); - Assert.assertEquals(1.0, cls.getAvgLinkVolumes(link1.getId())[1], 1e-8); - Assert.assertEquals(4.0, cls.getAvgLinkVolumes(link2.getId())[1], 1e-8); + Assertions.assertEquals(3.0, cls.getAvgLinkVolumes(link1.getId())[0], 1e-8); + Assertions.assertEquals(1.0, cls.getAvgLinkVolumes(link2.getId())[0], 1e-8); + Assertions.assertEquals(1.0, cls.getAvgLinkVolumes(link1.getId())[1], 1e-8); + Assertions.assertEquals(4.0, cls.getAvgLinkVolumes(link2.getId())[1], 1e-8); // travel times - Assert.assertEquals( 1530/3., cls.getAvgTravelTimes(link1.getId())[0], 1e-8 ); - Assert.assertEquals( 30./1., cls.getAvgTravelTimes(link2.getId())[0], 1e-8 ); - Assert.assertEquals( 200./1., cls.getAvgTravelTimes(link1.getId())[1], 1e-8 ); - Assert.assertEquals( 100./4., cls.getAvgTravelTimes(link2.getId())[1], 1e-8 ); - Assert.assertEquals( link2.getLength() / link2.getFreespeed(), cls.getAvgTravelTimes(link2.getId())[3], 1e-8 ); + Assertions.assertEquals( 1530/3., cls.getAvgTravelTimes(link1.getId())[0], 1e-8 ); + Assertions.assertEquals( 30./1., cls.getAvgTravelTimes(link2.getId())[0], 1e-8 ); + Assertions.assertEquals( 200./1., cls.getAvgTravelTimes(link1.getId())[1], 1e-8 ); + Assertions.assertEquals( 100./4., cls.getAvgTravelTimes(link2.getId())[1], 1e-8 ); + Assertions.assertEquals( link2.getLength() / link2.getFreespeed(), cls.getAvgTravelTimes(link2.getId())[3], 1e-8 ); cls.reset(); - Assert.assertEquals(0, cls.getAvgLinkVolumes(link1.getId()).length); - Assert.assertEquals(0, cls.getAvgLinkVolumes(link2.getId()).length); + Assertions.assertEquals(0, cls.getAvgLinkVolumes(link1.getId()).length); + Assertions.assertEquals(0, cls.getAvgLinkVolumes(link2.getId()).length); } @Test @@ -273,13 +273,13 @@ void testWriteRead() { String filename = this.util.getOutputDirectory() + "linkstats.txt"; cls.writeFile(filename); - Assert.assertTrue(new File(filename).exists()); + Assertions.assertTrue(new File(filename).exists()); CalcLinkStats cls2 = new CalcLinkStats(network); cls2.readFile(filename); - Assert.assertEquals(3.5, cls2.getAvgLinkVolumes(link1.getId())[0], 1e-8); - Assert.assertEquals(2.0, cls2.getAvgLinkVolumes(link2.getId())[0], 1e-8); - Assert.assertEquals(2.5, cls2.getAvgLinkVolumes(link1.getId())[1], 1e-8); - Assert.assertEquals(3.0, cls2.getAvgLinkVolumes(link2.getId())[1], 1e-8); + Assertions.assertEquals(3.5, cls2.getAvgLinkVolumes(link1.getId())[0], 1e-8); + Assertions.assertEquals(2.0, cls2.getAvgLinkVolumes(link2.getId())[0], 1e-8); + Assertions.assertEquals(2.5, cls2.getAvgLinkVolumes(link1.getId())[1], 1e-8); + Assertions.assertEquals(3.0, cls2.getAvgLinkVolumes(link2.getId())[1], 1e-8); } } diff --git a/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java index 4d16738191e..1757e6a3f99 100644 --- a/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/IterationTravelStatsControlerListenerTest.java @@ -10,7 +10,7 @@ import java.io.Reader; import java.util.zip.GZIPInputStream; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -149,12 +149,14 @@ private void readAndValidateValues(Scenario scenario) { Person personInScenario = scenario.getPopulation().getPersons().get(personId); Activity firstActivity = identifyFirstActivity(personInScenario); - Assert.assertEquals("wrong score", personInScenario.getSelectedPlan().getScore(), Double.valueOf(column[executed_score]), MatsimTestUtils.EPSILON); - Assert.assertEquals("x coordinate does not match", firstActivity.getCoord().getX(), x, - MatsimTestUtils.EPSILON); - Assert.assertEquals("y coordinate does not match", firstActivity.getCoord().getY(), y, - MatsimTestUtils.EPSILON); - Assert.assertEquals("type of first activity does not match", firstActivity.getType(), column[first_act_type]); + Assertions.assertEquals(personInScenario.getSelectedPlan().getScore(), Double.valueOf(column[executed_score]), MatsimTestUtils.EPSILON, "wrong score"); + Assertions.assertEquals(firstActivity.getCoord().getX(), x, + MatsimTestUtils.EPSILON, + "x coordinate does not match"); + Assertions.assertEquals(firstActivity.getCoord().getY(), y, + MatsimTestUtils.EPSILON, + "y coordinate does not match"); + Assertions.assertEquals(firstActivity.getType(), column[first_act_type], "type of first activity does not match"); break; } diff --git a/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java b/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java index e29dfc0af55..6735136a654 100644 --- a/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java +++ b/matsim/src/test/java/org/matsim/analysis/LegHistogramTest.java @@ -20,7 +20,7 @@ package org.matsim.analysis; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.Set; @@ -181,7 +181,7 @@ void testReset() { histo.reset(1); modes = histo.getLegModes(); - assertEquals("After reset, there should be 0 known leg-modes", 0, modes.size()); + assertEquals(0, modes.size(), "After reset, there should be 0 known leg-modes"); assertFalse(modes.contains(TransportMode.car)); } } diff --git a/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java index 214b7fffb9b..8ec2fb9f37d 100644 --- a/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/LinkStatsControlerListenerTest.java @@ -20,7 +20,7 @@ package org.matsim.analysis; import com.google.inject.*; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -102,210 +102,210 @@ public void install() { config.linkStats().setWriteLinkStatsInterval(10); // test defaults - Assert.assertEquals(10, config.linkStats().getWriteLinkStatsInterval()); - Assert.assertEquals(5, config.linkStats().getAverageLinkStatsOverIterations()); + Assertions.assertEquals(10, config.linkStats().getWriteLinkStatsInterval()); + Assertions.assertEquals(5, config.linkStats().getAverageLinkStatsOverIterations()); // now the real tests - Assert.assertFalse(lscl.useVolumesOfIteration(0, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(1, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(2, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(3, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(4, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(5, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(6, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(7, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(8, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(9, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(10, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(11, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(12, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(13, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(14, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(15, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(16, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(17, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(18, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(19, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(20, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(21, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(0, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(1, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(2, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(3, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(4, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(5, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(6, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(7, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(8, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(9, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(10, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(11, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(12, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(13, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(14, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(15, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(16, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(17, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(18, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(19, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(20, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(21, 0)); // change some values config.linkStats().setWriteLinkStatsInterval(8); config.linkStats().setAverageLinkStatsOverIterations(2); - Assert.assertFalse(lscl.useVolumesOfIteration(0, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(1, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(2, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(3, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(4, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(5, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(6, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(7, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(8, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(9, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(10, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(11, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(12, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(13, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(14, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(15, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(16, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(17, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(18, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(19, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(20, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(21, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(0, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(1, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(2, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(3, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(4, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(5, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(6, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(7, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(8, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(9, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(10, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(11, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(12, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(13, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(14, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(15, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(16, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(17, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(18, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(19, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(20, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(21, 0)); // change some values: averaging = 1 config.linkStats().setWriteLinkStatsInterval(5); config.linkStats().setAverageLinkStatsOverIterations(1); - Assert.assertTrue(lscl.useVolumesOfIteration(0, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(1, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(2, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(3, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(4, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(5, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(6, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(7, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(8, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(9, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(10, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(11, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(12, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(13, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(14, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(15, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(16, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(17, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(18, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(19, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(20, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(21, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(0, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(1, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(2, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(3, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(4, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(5, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(6, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(7, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(8, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(9, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(10, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(11, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(12, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(13, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(14, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(15, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(16, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(17, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(18, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(19, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(20, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(21, 0)); // change some values: averaging = 0 config.linkStats().setWriteLinkStatsInterval(5); config.linkStats().setAverageLinkStatsOverIterations(0); - Assert.assertTrue(lscl.useVolumesOfIteration(0, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(1, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(2, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(3, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(4, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(5, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(6, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(7, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(8, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(9, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(10, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(11, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(12, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(13, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(14, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(15, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(16, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(17, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(18, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(19, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(20, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(21, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(0, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(1, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(2, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(3, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(4, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(5, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(6, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(7, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(8, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(9, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(10, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(11, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(12, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(13, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(14, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(15, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(16, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(17, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(18, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(19, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(20, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(21, 0)); // change some values: interval = 0 config.linkStats().setWriteLinkStatsInterval(0); config.linkStats().setAverageLinkStatsOverIterations(2); - Assert.assertFalse(lscl.useVolumesOfIteration(0, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(1, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(2, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(3, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(4, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(5, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(6, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(7, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(8, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(9, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(10, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(11, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(12, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(13, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(14, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(15, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(16, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(17, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(18, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(19, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(20, 0)); - Assert.assertFalse(lscl.useVolumesOfIteration(21, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(0, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(1, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(2, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(3, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(4, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(5, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(6, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(7, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(8, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(9, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(10, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(11, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(12, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(13, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(14, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(15, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(16, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(17, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(18, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(19, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(20, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(21, 0)); // change some values: interval equal averaging config.linkStats().setWriteLinkStatsInterval(5); config.linkStats().setAverageLinkStatsOverIterations(5); - Assert.assertFalse(lscl.useVolumesOfIteration(0, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(1, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(2, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(3, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(4, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(5, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(6, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(7, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(8, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(9, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(10, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(11, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(12, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(13, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(14, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(15, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(16, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(17, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(18, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(19, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(20, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(21, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(0, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(1, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(2, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(3, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(4, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(5, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(6, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(7, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(8, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(9, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(10, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(11, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(12, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(13, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(14, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(15, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(16, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(17, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(18, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(19, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(20, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(21, 0)); // change some values: averaging > interval config.linkStats().setWriteLinkStatsInterval(5); config.linkStats().setAverageLinkStatsOverIterations(6); - Assert.assertFalse(lscl.useVolumesOfIteration(0, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(1, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(2, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(3, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(4, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(5, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(6, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(7, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(8, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(9, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(10, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(11, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(12, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(13, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(14, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(15, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(16, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(17, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(18, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(19, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(20, 0)); - Assert.assertTrue(lscl.useVolumesOfIteration(21, 0)); + Assertions.assertFalse(lscl.useVolumesOfIteration(0, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(1, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(2, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(3, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(4, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(5, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(6, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(7, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(8, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(9, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(10, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(11, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(12, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(13, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(14, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(15, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(16, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(17, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(18, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(19, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(20, 0)); + Assertions.assertTrue(lscl.useVolumesOfIteration(21, 0)); // change some values: different firstIteration config.linkStats().setWriteLinkStatsInterval(5); config.linkStats().setAverageLinkStatsOverIterations(3); - Assert.assertFalse(lscl.useVolumesOfIteration(4, 4)); - Assert.assertFalse(lscl.useVolumesOfIteration(5, 4)); - Assert.assertFalse(lscl.useVolumesOfIteration(6, 4)); - Assert.assertFalse(lscl.useVolumesOfIteration(7, 4)); - Assert.assertTrue(lscl.useVolumesOfIteration(8, 4)); - Assert.assertTrue(lscl.useVolumesOfIteration(9, 4)); - Assert.assertTrue(lscl.useVolumesOfIteration(10, 4)); - Assert.assertFalse(lscl.useVolumesOfIteration(11, 4)); - Assert.assertFalse(lscl.useVolumesOfIteration(12, 4)); - Assert.assertTrue(lscl.useVolumesOfIteration(13, 4)); - Assert.assertTrue(lscl.useVolumesOfIteration(14, 4)); - Assert.assertTrue(lscl.useVolumesOfIteration(15, 4)); - Assert.assertFalse(lscl.useVolumesOfIteration(16, 4)); - Assert.assertFalse(lscl.useVolumesOfIteration(17, 4)); - Assert.assertTrue(lscl.useVolumesOfIteration(18, 4)); - Assert.assertTrue(lscl.useVolumesOfIteration(19, 4)); - Assert.assertTrue(lscl.useVolumesOfIteration(20, 4)); - Assert.assertFalse(lscl.useVolumesOfIteration(21, 4)); + Assertions.assertFalse(lscl.useVolumesOfIteration(4, 4)); + Assertions.assertFalse(lscl.useVolumesOfIteration(5, 4)); + Assertions.assertFalse(lscl.useVolumesOfIteration(6, 4)); + Assertions.assertFalse(lscl.useVolumesOfIteration(7, 4)); + Assertions.assertTrue(lscl.useVolumesOfIteration(8, 4)); + Assertions.assertTrue(lscl.useVolumesOfIteration(9, 4)); + Assertions.assertTrue(lscl.useVolumesOfIteration(10, 4)); + Assertions.assertFalse(lscl.useVolumesOfIteration(11, 4)); + Assertions.assertFalse(lscl.useVolumesOfIteration(12, 4)); + Assertions.assertTrue(lscl.useVolumesOfIteration(13, 4)); + Assertions.assertTrue(lscl.useVolumesOfIteration(14, 4)); + Assertions.assertTrue(lscl.useVolumesOfIteration(15, 4)); + Assertions.assertFalse(lscl.useVolumesOfIteration(16, 4)); + Assertions.assertFalse(lscl.useVolumesOfIteration(17, 4)); + Assertions.assertTrue(lscl.useVolumesOfIteration(18, 4)); + Assertions.assertTrue(lscl.useVolumesOfIteration(19, 4)); + Assertions.assertTrue(lscl.useVolumesOfIteration(20, 4)); + Assertions.assertFalse(lscl.useVolumesOfIteration(21, 4)); } @Test @@ -335,14 +335,14 @@ public void install() { config.controller().setWritePlansInterval(0); controler.run(); - Assert.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.0/0.linkstats.txt.gz").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.1/1.linkstats.txt.gz").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.2/2.linkstats.txt.gz").exists()); - Assert.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.3/3.linkstats.txt.gz").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.4/4.linkstats.txt.gz").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.5/5.linkstats.txt.gz").exists()); - Assert.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.6/6.linkstats.txt.gz").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.7/7.linkstats.txt.gz").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.0/0.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.1/1.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.2/2.linkstats.txt.gz").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.3/3.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.4/4.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.5/5.linkstats.txt.gz").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.6/6.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.7/7.linkstats.txt.gz").exists()); } @Test @@ -378,23 +378,23 @@ public void install() { controler.getConfig().controller().setWriteEventsInterval(0); controler.run(); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.0/0.linkstats.txt.gz").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.1/1.linkstats.txt.gz").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.2/2.linkstats.txt.gz").exists()); - Assert.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.3/3.linkstats.txt.gz").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.4/4.linkstats.txt.gz").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.5/5.linkstats.txt.gz").exists()); - Assert.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.6/6.linkstats.txt.gz").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.7/7.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.0/0.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.1/1.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.2/2.linkstats.txt.gz").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.3/3.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.4/4.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.5/5.linkstats.txt.gz").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.6/6.linkstats.txt.gz").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.7/7.linkstats.txt.gz").exists()); double[] volumes = getVolumes(config.controller().getOutputDirectory() + "ITERS/it.3/3.linkstats.txt"); - Assert.assertEquals(3, volumes[0], 1e-8); - Assert.assertEquals(3.5, volumes[1], 1e-8); - Assert.assertEquals(4, volumes[2], 1e-8); + Assertions.assertEquals(3, volumes[0], 1e-8); + Assertions.assertEquals(3.5, volumes[1], 1e-8); + Assertions.assertEquals(4, volumes[2], 1e-8); volumes = getVolumes(config.controller().getOutputDirectory() + "ITERS/it.6/6.linkstats.txt"); - Assert.assertEquals(6, volumes[0], 1e-8); - Assert.assertEquals(6.5, volumes[1], 1e-8); - Assert.assertEquals(7, volumes[2], 1e-8); + Assertions.assertEquals(6, volumes[0], 1e-8); + Assertions.assertEquals(6.5, volumes[1], 1e-8); + Assertions.assertEquals(7, volumes[2], 1e-8); } private double[] getVolumes(final String filename) throws IOException { diff --git a/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java index 51f97e29a64..8fc4eb25898 100644 --- a/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ModeChoiceCoverageControlerListenerTest.java @@ -1,6 +1,6 @@ package org.matsim.analysis; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -58,10 +58,8 @@ void testChangePlanModes() { modeCC.notifyIterationEnds(new IterationEndsEvent(null, 0,false)); Map>> modeChoiceCoverageHistory = modeCC.getModeChoiceCoverageHistory(); - Assert.assertEquals( "There should only be one mode in the mode modeCCHistory", - 1, modeChoiceCoverageHistory.get(1).keySet().size()); - Assert.assertEquals( "Since all trips were completed with walk, mcc for walk should be 1.0 (or 100%)", - (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(0)); + Assertions.assertEquals( 1, modeChoiceCoverageHistory.get(1).keySet().size(), "There should only be one mode in the mode modeCCHistory"); + Assertions.assertEquals( (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(0), "Since all trips were completed with walk, mcc for walk should be 1.0 (or 100%)"); // Iteration 1: walk - bike Plan plan2 = makePlan(person, TransportMode.walk, TransportMode.bike); @@ -69,14 +67,10 @@ void testChangePlanModes() { person.setSelectedPlan(plan2); modeCC.notifyIterationEnds(new IterationEndsEvent(null, 1,false)); - Assert.assertEquals( "There should now be two modes in modeCCHistory", - 2, modeChoiceCoverageHistory.get(1).keySet().size()); - Assert.assertEquals( "Since all trips were completed with walk (in previous iterations), mcc for walk should be 1.0 (or 100%)", - (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(1)); - Assert.assertEquals( "The mcc for bike from the 0th iteration should be 0.0, since bike only showed up in this iteration", - (Double) 0.0, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(0)); - Assert.assertEquals( "Since 1 of 2 trips were completed with bike, mcc for bike should be 0.5 (or 50%)", - (Double) 0.5, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(1)); + Assertions.assertEquals( 2, modeChoiceCoverageHistory.get(1).keySet().size(), "There should now be two modes in modeCCHistory"); + Assertions.assertEquals( (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(1), "Since all trips were completed with walk (in previous iterations), mcc for walk should be 1.0 (or 100%)"); + Assertions.assertEquals( (Double) 0.0, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(0), "The mcc for bike from the 0th iteration should be 0.0, since bike only showed up in this iteration"); + Assertions.assertEquals( (Double) 0.5, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(1), "Since 1 of 2 trips were completed with bike, mcc for bike should be 0.5 (or 50%)"); // Iteration 3: bike - walk Plan plan3 = makePlan(person, TransportMode.bike, TransportMode.walk); @@ -84,12 +78,9 @@ void testChangePlanModes() { person.setSelectedPlan(plan3); modeCC.notifyIterationEnds(new IterationEndsEvent(null, 2,false)); - Assert.assertEquals( "There should still be two modes in modeCCHistory", - 2, modeChoiceCoverageHistory.get(1).keySet().size()); - Assert.assertEquals( "Since all trips were completed with walk (in previous iterations), mcc for walk should be 1.0 (or 100%)", - (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(2)); - Assert.assertEquals( "Since all trips were completed with bike (in previous iterations), mcc for bike should be 1.0 (or 100%)", - (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(2)); + Assertions.assertEquals( 2, modeChoiceCoverageHistory.get(1).keySet().size(), "There should still be two modes in modeCCHistory"); + Assertions.assertEquals( (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(2), "Since all trips were completed with walk (in previous iterations), mcc for walk should be 1.0 (or 100%)"); + Assertions.assertEquals( (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(2), "Since all trips were completed with bike (in previous iterations), mcc for bike should be 1.0 (or 100%)"); } @Test @@ -122,10 +113,8 @@ void testTwoAgents() { modeCC.notifyIterationEnds(new IterationEndsEvent(null, 0,false)); Map>> modeChoiceCoverageHistory = modeCC.getModeChoiceCoverageHistory(); - Assert.assertEquals( "There should only be one mode in the mode modeCCHistory", - 1, modeChoiceCoverageHistory.get(1).keySet().size()); - Assert.assertEquals( "Since all trips were completed with walk, mcc for walk should be 1.0 (or 100%)", - (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(0)); + Assertions.assertEquals( 1, modeChoiceCoverageHistory.get(1).keySet().size(), "There should only be one mode in the mode modeCCHistory"); + Assertions.assertEquals( (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(0), "Since all trips were completed with walk, mcc for walk should be 1.0 (or 100%)"); // Iteration 1: p1: walk - bike, p2: walk - walk Plan person1plan2 = makePlan(person1, TransportMode.walk, TransportMode.bike); @@ -137,12 +126,9 @@ void testTwoAgents() { person2.setSelectedPlan(person2plan2); modeCC.notifyIterationEnds(new IterationEndsEvent(null, 1,false)); - Assert.assertEquals( "There should now be two modes in modeCCHistory", - 2, modeChoiceCoverageHistory.get(1).keySet().size()); - Assert.assertEquals( "Since all trips were completed with walk (in previous iterations), mcc for walk should be 1.0 (or 100%)", - (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(1)); - Assert.assertEquals( "Since 1 of 4 trips were completed with bike, mcc for bike should be 0.25 (or 25%)", - (Double) 0.25, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(1)); + Assertions.assertEquals( 2, modeChoiceCoverageHistory.get(1).keySet().size(), "There should now be two modes in modeCCHistory"); + Assertions.assertEquals( (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(1), "Since all trips were completed with walk (in previous iterations), mcc for walk should be 1.0 (or 100%)"); + Assertions.assertEquals( (Double) 0.25, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(1), "Since 1 of 4 trips were completed with bike, mcc for bike should be 0.25 (or 25%)"); // Iteration 3: p1: walk - walk, p2: bike - bike Plan person1plan3 = makePlan(person1, TransportMode.walk, TransportMode.walk); @@ -154,12 +140,9 @@ void testTwoAgents() { person2.setSelectedPlan(person2plan3); modeCC.notifyIterationEnds(new IterationEndsEvent(null, 2,false)); - Assert.assertEquals( "There should still be two modes in modeCCHistory", - 2, modeChoiceCoverageHistory.get(1).keySet().size()); - Assert.assertEquals( "Since all trips were completed with walk (in previous iterations), mcc for walk should be 1.0 (or 100%)", - (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(2)); - Assert.assertEquals( "Since 3 of 4 trips were completed with bike (in previous iterations), mcc for bike should be 0.75 (or 75%)", - (Double) 0.75, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(2)); + Assertions.assertEquals( 2, modeChoiceCoverageHistory.get(1).keySet().size(), "There should still be two modes in modeCCHistory"); + Assertions.assertEquals( (Double) 1.0, modeChoiceCoverageHistory.get(1).get(TransportMode.walk).get(2), "Since all trips were completed with walk (in previous iterations), mcc for walk should be 1.0 (or 100%)"); + Assertions.assertEquals( (Double) 0.75, modeChoiceCoverageHistory.get(1).get(TransportMode.bike).get(2), "Since 3 of 4 trips were completed with bike (in previous iterations), mcc for bike should be 0.75 (or 75%)"); } @Test @@ -186,12 +169,9 @@ void testDifferentLevels() { modeCC.notifyIterationEnds(new IterationEndsEvent(null, 0,false)); Map>> modeChoiceCoverageHistory = modeCC.getModeChoiceCoverageHistory(); - Assert.assertEquals("1x threshold should be met after 1 iteration", - (Double) 1.0, modeChoiceCoverageHistory.get(1).get("walk").get(0)); - Assert.assertEquals("5x threshold should NOT be met after 1 iteration", - (Double) 0.0, modeChoiceCoverageHistory.get(5).get("walk").get(0)); - Assert.assertEquals("10x threshold should NOT be met after 1 iteration", - (Double) 0.0, modeChoiceCoverageHistory.get(10).get("walk").get(0)); + Assertions.assertEquals((Double) 1.0, modeChoiceCoverageHistory.get(1).get("walk").get(0), "1x threshold should be met after 1 iteration"); + Assertions.assertEquals((Double) 0.0, modeChoiceCoverageHistory.get(5).get("walk").get(0), "5x threshold should NOT be met after 1 iteration"); + Assertions.assertEquals((Double) 0.0, modeChoiceCoverageHistory.get(10).get("walk").get(0), "10x threshold should NOT be met after 1 iteration"); // After 5 iterations @@ -199,24 +179,18 @@ void testDifferentLevels() { modeCC.notifyIterationEnds(new IterationEndsEvent(null, i,false)); } - Assert.assertEquals("1x threshold should be met after 5 iterations", - (Double) 1.0, modeChoiceCoverageHistory.get(1).get("walk").get(4)); - Assert.assertEquals("5x threshold should be met after 5 iterations", - (Double) 1.0, modeChoiceCoverageHistory.get(5).get("walk").get(4)); - Assert.assertEquals("10x threshold should NOT be met after 5 iterations", - (Double) 0.0, modeChoiceCoverageHistory.get(10).get("walk").get(4)); + Assertions.assertEquals((Double) 1.0, modeChoiceCoverageHistory.get(1).get("walk").get(4), "1x threshold should be met after 5 iterations"); + Assertions.assertEquals((Double) 1.0, modeChoiceCoverageHistory.get(5).get("walk").get(4), "5x threshold should be met after 5 iterations"); + Assertions.assertEquals((Double) 0.0, modeChoiceCoverageHistory.get(10).get("walk").get(4), "10x threshold should NOT be met after 5 iterations"); // After 10 iterations for (int i = 5; i < 10; i++) { modeCC.notifyIterationEnds(new IterationEndsEvent(null, i,false)); } - Assert.assertEquals("1x threshold should be met after 10 iterations", - (Double) 1.0, modeChoiceCoverageHistory.get(1).get("walk").get(9)); - Assert.assertEquals("5x threshold should be met after 10 iterations", - (Double) 1.0, modeChoiceCoverageHistory.get(5).get("walk").get(9)); - Assert.assertEquals("10x threshold should be met after 10 iterations", - (Double) 1.0, modeChoiceCoverageHistory.get(10).get("walk").get(9)); + Assertions.assertEquals((Double) 1.0, modeChoiceCoverageHistory.get(1).get("walk").get(9), "1x threshold should be met after 10 iterations"); + Assertions.assertEquals((Double) 1.0, modeChoiceCoverageHistory.get(5).get("walk").get(9), "5x threshold should be met after 10 iterations"); + Assertions.assertEquals((Double) 1.0, modeChoiceCoverageHistory.get(10).get("walk").get(9), "10x threshold should be met after 10 iterations"); } diff --git a/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java index 400c0b270f8..a98645be213 100644 --- a/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java @@ -10,7 +10,7 @@ import java.util.HashMap; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -436,25 +436,19 @@ private void readAndcompareValues(HashMap modes, int itr) { : 0; double othervalue = (other > 0) ? Double.parseDouble(column[other]) : 0; double ridevalue = (ride > 0) ? Double.parseDouble(column[ride]) : 0; - Assert.assertEquals("car mode has an unexpected score", - (modes.get(TransportMode.car).doubleValue() / totalTrips), carvalue, 0); - Assert.assertEquals("walk mode has an unexpected score", - (modes.get(TransportMode.walk).doubleValue() / totalTrips), walkvalue, 0); - Assert.assertEquals("pt mode has an unexpected score", - (modes.get(TransportMode.pt).doubleValue() / totalTrips), ptvalue, 0); - Assert.assertEquals("bike mode has an unexpected score", - (modes.get(TransportMode.bike).doubleValue() / totalTrips), bikevalue, 0); - Assert.assertEquals("non_network_walk mode has an unexpected score", - (modes.get(TransportMode.non_network_walk).doubleValue() / totalTrips), - non_network_walkvalue, 0); - Assert.assertEquals("other mode has an unexpected score", - (modes.get(TransportMode.other).doubleValue() / totalTrips), othervalue, 0); - Assert.assertEquals("ride mode has an unexpected score", - (modes.get(TransportMode.ride).doubleValue() / totalTrips), ridevalue, 0); - - Assert.assertEquals("sum of the scores of all modes in not equal to 1", 1.0, + Assertions.assertEquals((modes.get(TransportMode.car).doubleValue() / totalTrips), carvalue, 0, "car mode has an unexpected score"); + Assertions.assertEquals((modes.get(TransportMode.walk).doubleValue() / totalTrips), walkvalue, 0, "walk mode has an unexpected score"); + Assertions.assertEquals((modes.get(TransportMode.pt).doubleValue() / totalTrips), ptvalue, 0, "pt mode has an unexpected score"); + Assertions.assertEquals((modes.get(TransportMode.bike).doubleValue() / totalTrips), bikevalue, 0, "bike mode has an unexpected score"); + Assertions.assertEquals((modes.get(TransportMode.non_network_walk).doubleValue() / totalTrips), + non_network_walkvalue, 0, "non_network_walk mode has an unexpected score"); + Assertions.assertEquals((modes.get(TransportMode.other).doubleValue() / totalTrips), othervalue, 0, "other mode has an unexpected score"); + Assertions.assertEquals((modes.get(TransportMode.ride).doubleValue() / totalTrips), ridevalue, 0, "ride mode has an unexpected score"); + + Assertions.assertEquals(1.0, carvalue + walkvalue + ptvalue + bikevalue + non_network_walkvalue + othervalue + ridevalue, - 0.01); + 0.01, + "sum of the scores of all modes in not equal to 1"); break; } diff --git a/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java b/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java index 38e5bec0a4e..3344b3405e1 100644 --- a/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/PHbyModeCalculatorTest.java @@ -8,8 +8,9 @@ import java.io.IOException; import java.util.HashMap; import java.util.Iterator; -import java.util.List; -import org.junit.Assert; +import java.util.List; + +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -179,16 +180,16 @@ private void readAndValidateValues(int itr, IdMap map) { double pt_wait_value = Double.parseDouble(column[pt_wait]); double stageActivity_wait_value = Double.parseDouble(column[stageActivity_wait]); - Assert.assertEquals("car_travel hour does not match", Math.round(modeValues.get("car") / 3600.0), - car_travel_value, 0); - Assert.assertEquals("pt_travel hour score does not match", Math.round(modeValues.get("pt") / 3600.0), - pt_travel_value, 0); - Assert.assertEquals("walk_travel hour does not match", Math.round(modeValues.get("walk") / 3600.0), - walk_travel_value, 0); - Assert.assertEquals("pt_wait hour does not match", Math.round(modeValues.get("pt_wait") / 3600.0), - pt_wait_value, 0); - Assert.assertEquals("stageActivity_wait hour does not match", Math.round(modeValues.get("stageActivity_wait") / 3600.0), - stageActivity_wait_value, 0); + Assertions.assertEquals(Math.round(modeValues.get("car") / 3600.0), + car_travel_value, 0, "car_travel hour does not match"); + Assertions.assertEquals(Math.round(modeValues.get("pt") / 3600.0), + pt_travel_value, 0, "pt_travel hour score does not match"); + Assertions.assertEquals(Math.round(modeValues.get("walk") / 3600.0), + walk_travel_value, 0, "walk_travel hour does not match"); + Assertions.assertEquals(Math.round(modeValues.get("pt_wait") / 3600.0), + pt_wait_value, 0, "pt_wait hour does not match"); + Assertions.assertEquals(Math.round(modeValues.get("stageActivity_wait") / 3600.0), + stageActivity_wait_value, 0, "stageActivity_wait hour does not match"); break; } diff --git a/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java b/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java index b2153471206..00398f6e1d2 100644 --- a/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/PKMbyModeCalculatorTest.java @@ -8,7 +8,8 @@ import java.io.IOException; import java.util.HashMap; import java.util.stream.Collectors; -import org.junit.Assert; + +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -217,9 +218,9 @@ private void readAndValidateValues(int itr, Double totalCar, Double totalPt, Dou double ptStat = (pt > 0) ? Double.parseDouble(column[pt]) : 0; double walkStat = (walk > 0) ? Double.parseDouble(column[walk]) : 0; - Assert.assertEquals("Car stats score does not match", Math.round((totalCar / 1000)), carStat, 0); - Assert.assertEquals("PT stats score does not match", Math.round((totalPt / 1000)), ptStat, 0); - Assert.assertEquals("Walk stats score does not match", Math.round((totalWalk / 1000)), walkStat, 0); + Assertions.assertEquals(Math.round((totalCar / 1000)), carStat, 0, "Car stats score does not match"); + Assertions.assertEquals(Math.round((totalPt / 1000)), ptStat, 0, "PT stats score does not match"); + Assertions.assertEquals(Math.round((totalWalk / 1000)), walkStat, 0, "Walk stats score does not match"); break; } iteration++; diff --git a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java index 1fb5b7900f9..1a25c737c17 100644 --- a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java @@ -6,7 +6,7 @@ import java.util.ListIterator; import org.assertj.core.api.Assertions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -543,14 +543,18 @@ private void readAndValidateValues(String outDir, int itr, Population populatio double avgBest = (avgbest > 0) ? Double.parseDouble(column[avgbest]) : 0; double avgAverage = (avgaverage > 0) ? Double.parseDouble(column[avgaverage]) : 0; - Assert.assertEquals("avg. executed score does not match", (getScore(population, "avgexecuted")/(4-itr)), avgExecuted, - 0); - Assert.assertEquals("avg. worst score does not match", (getScore(population, "avgworst")/(4-itr)), avgWorst, - 0); - Assert.assertEquals("avg. best score does not match", (getScore(population, "avgbest")/(4-itr)), avgBest, - 0); - Assert.assertEquals("avg average score does not match", (getScore(population, "avgaverage")/getNoOfPlans(population)), avgAverage, - 0); + Assertions.assertEquals((getScore(population, "avgexecuted")/(4-itr)), avgExecuted, + 0, + "avg. executed score does not match"); + Assertions.assertEquals((getScore(population, "avgworst")/(4-itr)), avgWorst, + 0, + "avg. worst score does not match"); + Assertions.assertEquals((getScore(population, "avgbest")/(4-itr)), avgBest, + 0, + "avg. best score does not match"); + Assertions.assertEquals((getScore(population, "avgaverage")/getNoOfPlans(population)), avgAverage, + 0, + "avg average score does not match"); } iteration++; } diff --git a/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java b/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java index 0ed11f63558..574b827fa39 100644 --- a/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TransportPlanningMainModeIdentifierTest.java @@ -4,9 +4,9 @@ package org.matsim.analysis; import java.util.ArrayList; -import java.util.List; - -import org.junit.Assert; +import java.util.List; + +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.TransportMode; @@ -98,6 +98,6 @@ private String identifyMainMode(List planElements) { private void validateValues(Plan plan, String mainMode) { String mainModeIdentified = identifyMainMode(plan.getPlanElements()); - Assert.assertEquals(mainModeIdentified, mainMode); + Assertions.assertEquals(mainModeIdentified, mainMode); } } diff --git a/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java b/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java index a98fef56fbf..40db8e0ba7f 100644 --- a/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java @@ -9,7 +9,7 @@ import java.util.HashMap; import java.util.stream.Collectors; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -376,10 +376,12 @@ private void readAndValidateValues(int itr, Double legSum, int totalTrip, long t double avgLegvalue = (avglegdis > 0) ? Double.parseDouble(column[avglegdis]) : 0; double avgTripvalue = (avgtripdis > 0) ? Double.parseDouble(column[avgtripdis]) : 0; - Assert.assertEquals("avg. Average Trip distance does not match", (legSum / totalTrip), avgTripvalue, - 0); - Assert.assertEquals("avg. Average Leg distance does not match", (legSum / totalLeg), avgLegvalue, - 0); + Assertions.assertEquals((legSum / totalTrip), avgTripvalue, + 0, + "avg. Average Trip distance does not match"); + Assertions.assertEquals((legSum / totalLeg), avgLegvalue, + 0, + "avg. Average Leg distance does not match"); break; } diff --git a/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java b/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java index e5eccd66e12..3f3a03411eb 100644 --- a/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TripsAndLegsCSVWriterTest.java @@ -20,7 +20,7 @@ package org.matsim.analysis; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.analysis.TripsAndLegsCSVWriter.NoLegsWriterExtension; @@ -422,27 +422,27 @@ private void readAndValidateLegs(ArrayList legsfromplan, String legFile) while ((line = br.readLine()) != null && legItr.hasNext()) { String[] column = line.split(";", -1); Map nextleg = (Map) legItr.next(); - Assert.assertEquals("dep_time is not as expected", String.valueOf(nextleg.get("dep_time")) , column[dep_time]); - Assert.assertEquals("trav_time is not as expected", String.valueOf(nextleg.get("trav_time")) , column[trav_time]); - Assert.assertEquals("wait_time is not as expected", String.valueOf(nextleg.get("wait_time")) , column[wait_time]); - Assert.assertEquals("Distance is not as expected", String.valueOf(nextleg.get("distance")) , column[distance]); - Assert.assertEquals("mode is not as expected", String.valueOf(nextleg.get("mode")) , column[mode]); - Assert.assertEquals("start_link is not as expected", String.valueOf(nextleg.get("start_link")) , column[start_link]); - Assert.assertEquals("start_x is not as expected", String.valueOf(nextleg.get("start_x")) , column[start_x]); - Assert.assertEquals("start_y is not as expected", String.valueOf(nextleg.get("start_y")) , column[start_y]); - Assert.assertEquals("End link is not as expected", String.valueOf(nextleg.get("end_link")) , column[end_link]); - Assert.assertEquals("end_x is not as expected", String.valueOf(nextleg.get("end_x")) , column[end_x]); - Assert.assertEquals("end_y is not as expected", String.valueOf(nextleg.get("end_y")) , column[end_y]); - Assert.assertEquals("person is not as expected", String.valueOf(nextleg.get("person")) , column[person]); - Assert.assertEquals("trip_id is not as expected", String.valueOf(nextleg.get("trip_id")) , column[trip_id]); - Assert.assertEquals("access_stop_id is not as expected", String.valueOf(nextleg.get("access_stop_id")) , column[access_stop_id] != null ? column[access_stop_id] : ""); - Assert.assertEquals("egress_stop_id is not as expected", String.valueOf(nextleg.get("egress_stop_id")) , column[egress_stop_id] != null ? column[egress_stop_id] : ""); - Assert.assertEquals("transit_line is not as expected", String.valueOf(nextleg.get("transit_line")) , column[transit_line] != null ? column[transit_line] : ""); - Assert.assertEquals("transit_route is not as expected", String.valueOf(nextleg.get("transit_route")) , column[transit_route] != null ? column[transit_route] : ""); - Assert.assertEquals("vehicleId is not as expected", String.valueOf(nextleg.get("vehicle_id")) , column[vehicle_id] != null ? column[vehicle_id] : ""); + Assertions.assertEquals(String.valueOf(nextleg.get("dep_time")) , column[dep_time], "dep_time is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("trav_time")) , column[trav_time], "trav_time is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("wait_time")) , column[wait_time], "wait_time is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("distance")) , column[distance], "Distance is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("mode")) , column[mode], "mode is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("start_link")) , column[start_link], "start_link is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("start_x")) , column[start_x], "start_x is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("start_y")) , column[start_y], "start_y is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("end_link")) , column[end_link], "End link is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("end_x")) , column[end_x], "end_x is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("end_y")) , column[end_y], "end_y is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("person")) , column[person], "person is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("trip_id")) , column[trip_id], "trip_id is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("access_stop_id")) , column[access_stop_id] != null ? column[access_stop_id] : "", "access_stop_id is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("egress_stop_id")) , column[egress_stop_id] != null ? column[egress_stop_id] : "", "egress_stop_id is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("transit_line")) , column[transit_line] != null ? column[transit_line] : "", "transit_line is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("transit_route")) , column[transit_route] != null ? column[transit_route] : "", "transit_route is not as expected"); + Assertions.assertEquals(String.valueOf(nextleg.get("vehicle_id")) , column[vehicle_id] != null ? column[vehicle_id] : "", "vehicleId is not as expected"); if (isIntermodalWalkPt >= 0) { // column from CustomLegsWriterExtension is present - Assert.assertEquals("isIntermodalWalkPt is not as expected", String.valueOf(nextleg.get("isIntermodalWalkPt")) , column[isIntermodalWalkPt]); + Assertions.assertEquals(String.valueOf(nextleg.get("isIntermodalWalkPt")) , column[isIntermodalWalkPt], "isIntermodalWalkPt is not as expected"); } } }catch (IOException e) { @@ -467,41 +467,45 @@ private void readAndValidateTrips(Map persontrips, String tripFi String[] column = line.split(";"); String trip_id_value = column[trip_id]; Map tripvalues = (Map) persontrips.get(trip_id_value); - Assert.assertEquals("Departure time is not as expected", String.valueOf(tripvalues.get("departureTime")), column[dep_time]); - Assert.assertEquals("Travel time is not as expected", String.valueOf(tripvalues.get("travelTime")), column[trav_time]); - Assert.assertEquals("Travel distance is not as expected", String.valueOf(tripvalues.get("traveled_distance")), - column[traveled_distance]); - Assert.assertEquals("Euclidean distance is not as expected", tripvalues.get("euclideanDistance"), - Integer.parseInt(column[euclidean_distance])); - Assert.assertEquals("Main mode is not as expected", - tripvalues.get("main_mode"), column[main_mode]); - Assert.assertEquals("Longest distance mode is not as expected", - tripvalues.get("longest_distance_mode"), column[longest_distance_mode]); - Assert.assertEquals("Modes is not as expected", String.valueOf(tripvalues.get("modes")), column[modes]); - Assert.assertEquals("Start activity type is not as expected", String.valueOf(tripvalues.get("start_activity_type")), - column[start_activity_type]); - Assert.assertEquals("End activity type is not as expected", String.valueOf(tripvalues.get("end_activity_type")), - column[end_activity_type]); - Assert.assertEquals("Start facility id is not as expected", String.valueOf(tripvalues.get("start_facility_id")), - column[start_facility_id]); - Assert.assertEquals("Start link is not as expected", String.valueOf(tripvalues.get("start_link")), column[start_link]); - Assert.assertEquals("Start x is not as expected", String.valueOf(tripvalues.get("start_x")), column[start_x]); - Assert.assertEquals("Start y is not as expected", String.valueOf(tripvalues.get("start_y")), column[start_y]); - Assert.assertEquals("End facility id is not as expected", String.valueOf(tripvalues.get("end_facility_id")), - column[end_facility_id]); - Assert.assertEquals("End link is not as expected", String.valueOf(tripvalues.get("end_link")), column[end_link]); - Assert.assertEquals("End x is not as expected", String.valueOf(tripvalues.get("end_x")), column[end_x]); - Assert.assertEquals("End y is not as expected", String.valueOf(tripvalues.get("end_y")), column[end_y]); - Assert.assertEquals("waiting_time is not as expected", String.valueOf(tripvalues.get("waiting_time")), column[wait_time]); - Assert.assertEquals("person is not as expected", String.valueOf(tripvalues.get("person")), column[person]); - Assert.assertEquals("trip_number is not as expected", String.valueOf(tripvalues.get("trip_number")), column[trip_number]); - Assert.assertEquals("trip_id is not as expected", String.valueOf(tripvalues.get("trip_id")), column[trip_id]); + Assertions.assertEquals(String.valueOf(tripvalues.get("departureTime")), column[dep_time], "Departure time is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("travelTime")), column[trav_time], "Travel time is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("traveled_distance")), + column[traveled_distance], + "Travel distance is not as expected"); + Assertions.assertEquals(tripvalues.get("euclideanDistance"), + Integer.parseInt(column[euclidean_distance]), + "Euclidean distance is not as expected"); + Assertions.assertEquals(tripvalues.get("main_mode"), column[main_mode], "Main mode is not as expected"); + Assertions.assertEquals(tripvalues.get("longest_distance_mode"), column[longest_distance_mode], "Longest distance mode is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("modes")), column[modes], "Modes is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("start_activity_type")), + column[start_activity_type], + "Start activity type is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("end_activity_type")), + column[end_activity_type], + "End activity type is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("start_facility_id")), + column[start_facility_id], + "Start facility id is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("start_link")), column[start_link], "Start link is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("start_x")), column[start_x], "Start x is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("start_y")), column[start_y], "Start y is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("end_facility_id")), + column[end_facility_id], + "End facility id is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("end_link")), column[end_link], "End link is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("end_x")), column[end_x], "End x is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("end_y")), column[end_y], "End y is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("waiting_time")), column[wait_time], "waiting_time is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("person")), column[person], "person is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("trip_number")), column[trip_number], "trip_number is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("trip_id")), column[trip_id], "trip_id is not as expected"); if(column.length > 21) { - Assert.assertEquals("first_pt_boarding_stop is not as expected", String.valueOf(tripvalues.get("first_pt_boarding_stop")), column[first_pt_boarding_stop]); - Assert.assertEquals("last_pt_egress_stop is not as expected", String.valueOf(tripvalues.get("last_pt_egress_stop")), column[last_pt_egress_stop]); + Assertions.assertEquals(String.valueOf(tripvalues.get("first_pt_boarding_stop")), column[first_pt_boarding_stop], "first_pt_boarding_stop is not as expected"); + Assertions.assertEquals(String.valueOf(tripvalues.get("last_pt_egress_stop")), column[last_pt_egress_stop], "last_pt_egress_stop is not as expected"); } if(column.length > 23) { - Assert.assertEquals("transitStopsVisited is not as expected", String.valueOf(tripvalues.get("transitStopsVisited")), column[transitStopsVisited]); + Assertions.assertEquals(String.valueOf(tripvalues.get("transitStopsVisited")), column[transitStopsVisited], "transitStopsVisited is not as expected"); } } } catch (IOException e) { diff --git a/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java b/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java index 511778fce7c..cbc860120e0 100644 --- a/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/VolumesAnalyzerTest.java @@ -3,7 +3,7 @@ */ package org.matsim.analysis; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -103,14 +103,14 @@ void performTest() { double[] volume = analyzer.getVolumesPerHourForLink(link1); int[] volumeForLink = analyzer.getVolumesForLink(link1); - Assert.assertEquals(volume[1], 2.0, 0); - Assert.assertEquals(volume[2], 3.0, 0); - Assert.assertEquals(volume[3], 2.0, 0); - Assert.assertEquals(volume[6], 5.0, 0); - Assert.assertEquals(volumeForLink[1], 2, 0); - Assert.assertEquals(volumeForLink[2], 3, 0); - Assert.assertEquals(volumeForLink[3], 2, 0); - Assert.assertEquals(volumeForLink[6], 5, 0); + Assertions.assertEquals(volume[1], 2.0, 0); + Assertions.assertEquals(volume[2], 3.0, 0); + Assertions.assertEquals(volume[3], 2.0, 0); + Assertions.assertEquals(volume[6], 5.0, 0); + Assertions.assertEquals(volumeForLink[1], 2, 0); + Assertions.assertEquals(volumeForLink[2], 3, 0); + Assertions.assertEquals(volumeForLink[3], 2, 0); + Assertions.assertEquals(volumeForLink[6], 5, 0); VolumesAnalyzer analyzerBike = new VolumesAnalyzer(3600, 86400, network, true); @@ -128,8 +128,8 @@ void performTest() { double[] volumeBike = analyzerBike.getVolumesPerHourForLink(link2, TransportMode.bike); int[] volumeForLinkBike = analyzerBike.getVolumesForLink(link2, TransportMode.bike); - Assert.assertEquals(volumeBike[6], 3.0, 0); - Assert.assertEquals(volumeForLinkBike[6], 3, 0); + Assertions.assertEquals(volumeBike[6], 3.0, 0); + Assertions.assertEquals(volumeForLinkBike[6], 3, 0); } } diff --git a/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java b/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java index e8686cd7cf4..e8703896826 100644 --- a/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java +++ b/matsim/src/test/java/org/matsim/analysis/linkPaxVolumes/LinkPaxVolumesAnalysisTest.java @@ -22,7 +22,7 @@ import org.apache.commons.csv.CSVFormat; import org.apache.commons.csv.CSVParser; import org.apache.commons.csv.CSVRecord; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.analysis.linkpaxvolumes.LinkPaxVolumesAnalysis; @@ -331,12 +331,12 @@ void testLinkPaxVolumes() { List allDayRecordList = parser.getRecords(); List allDayRecordListLink2 = allDayRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("link")).equals("link2")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, allDayRecordListLink2.size()); - Assert.assertEquals("Wrong PassengerInclDriver on Link2",8, Double.parseDouble(allDayRecordListLink2.get(0).get(2)),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, allDayRecordListLink2.size(), "Either no record or more than one record"); + Assertions.assertEquals(8, Double.parseDouble(allDayRecordListLink2.get(0).get(2)),MatsimTestUtils.EPSILON,"Wrong PassengerInclDriver on Link2"); List allDayRecordListLink2b = allDayRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("link")).equals("link2b")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, allDayRecordListLink2b.size()); - Assert.assertEquals("Wrong amount of Vehicles on Link2b",3, Double.parseDouble(allDayRecordListLink2b.get(0).get(1)),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, allDayRecordListLink2b.size(), "Either no record or more than one record"); + Assertions.assertEquals(3, Double.parseDouble(allDayRecordListLink2b.get(0).get(1)),MatsimTestUtils.EPSILON,"Wrong amount of Vehicles on Link2b"); } catch (FileNotFoundException e) { e.printStackTrace(); @@ -353,20 +353,20 @@ void testLinkPaxVolumes() { List networkModePerHourRecordList = parser.getRecords(); List networkModePerHourRecordListLink2 = networkModePerHourRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("link")).equals("link2") && record.get(parser.getHeaderMap().get("networkMode")).equals("car") && record.get(parser.getHeaderMap().get("hour")).equals("0")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, networkModePerHourRecordListLink2.size()); - Assert.assertEquals("Wrong PassengerInclDriver on Link2",3, Double.parseDouble(networkModePerHourRecordListLink2.get(0).get("passengersInclDriver")),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, networkModePerHourRecordListLink2.size(), "Either no record or more than one record"); + Assertions.assertEquals(3, Double.parseDouble(networkModePerHourRecordListLink2.get(0).get("passengersInclDriver")),MatsimTestUtils.EPSILON,"Wrong PassengerInclDriver on Link2"); List networkModePerHourRecordListLink2b = networkModePerHourRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("link")).equals("link2b") && record.get(parser.getHeaderMap().get("networkMode")).equals("car") && record.get(parser.getHeaderMap().get("hour")).equals("0")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, networkModePerHourRecordListLink2b.size()); - Assert.assertEquals("Wrong amount of Vehicles on Link2b",2, Double.parseDouble(networkModePerHourRecordListLink2b.get(0).get("vehicles")),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, networkModePerHourRecordListLink2b.size(), "Either no record or more than one record"); + Assertions.assertEquals(2, Double.parseDouble(networkModePerHourRecordListLink2b.get(0).get("vehicles")),MatsimTestUtils.EPSILON,"Wrong amount of Vehicles on Link2b"); List networkModePerHourRecordListLink2Pt = networkModePerHourRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("link")).equals("link2") && record.get(parser.getHeaderMap().get("networkMode")).equals("train") && record.get(parser.getHeaderMap().get("hour")).equals("1")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, networkModePerHourRecordListLink2Pt.size()); - Assert.assertEquals("Wrong amount of passengersInclDriver on Link2",5, Double.parseDouble(networkModePerHourRecordListLink2Pt.get(0).get("passengersInclDriver")),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, networkModePerHourRecordListLink2Pt.size(), "Either no record or more than one record"); + Assertions.assertEquals(5, Double.parseDouble(networkModePerHourRecordListLink2Pt.get(0).get("passengersInclDriver")),MatsimTestUtils.EPSILON,"Wrong amount of passengersInclDriver on Link2"); List networkModePerHourRecordListLink4b = networkModePerHourRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("link")).equals("link4b") && record.get(parser.getHeaderMap().get("networkMode")).equals("car") && record.get(parser.getHeaderMap().get("hour")).equals("10")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, networkModePerHourRecordListLink4b.size()); - Assert.assertEquals("Wrong amount of Vehicles on Link4b",0, Double.parseDouble(networkModePerHourRecordListLink4b.get(0).get("vehicles")),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, networkModePerHourRecordListLink4b.size(), "Either no record or more than one record"); + Assertions.assertEquals(0, Double.parseDouble(networkModePerHourRecordListLink4b.get(0).get("vehicles")),MatsimTestUtils.EPSILON,"Wrong amount of Vehicles on Link4b"); } catch (FileNotFoundException e) { e.printStackTrace(); @@ -383,12 +383,12 @@ void testLinkPaxVolumes() { List vehicleTypePerHourRecordList = parser.getRecords(); List vehicleTypePerHourRecordListLink2 = vehicleTypePerHourRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("link")).equals("link2") && record.get(parser.getHeaderMap().get("vehicleType")).equals("vehiclesType1") && record.get(parser.getHeaderMap().get("hour")).equals("0")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, vehicleTypePerHourRecordListLink2.size()); - Assert.assertEquals("Wrong PassengerInclDriver on Link2",3, Double.parseDouble(vehicleTypePerHourRecordListLink2.get(0).get(4)),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, vehicleTypePerHourRecordListLink2.size(), "Either no record or more than one record"); + Assertions.assertEquals(3, Double.parseDouble(vehicleTypePerHourRecordListLink2.get(0).get(4)),MatsimTestUtils.EPSILON,"Wrong PassengerInclDriver on Link2"); List vehicleTypePerHourRecordListLink2b = vehicleTypePerHourRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("link")).equals("link2b") && record.get(parser.getHeaderMap().get("vehicleType")).equals("transitVehicleType") && record.get(parser.getHeaderMap().get("hour")).equals("1")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, vehicleTypePerHourRecordListLink2b.size()); - Assert.assertEquals("Wrong amount of Vehicles on Link2b",1, Double.parseDouble(vehicleTypePerHourRecordListLink2b.get(0).get(3)),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, vehicleTypePerHourRecordListLink2b.size(), "Either no record or more than one record"); + Assertions.assertEquals(1, Double.parseDouble(vehicleTypePerHourRecordListLink2b.get(0).get(3)),MatsimTestUtils.EPSILON,"Wrong amount of Vehicles on Link2b"); } catch (FileNotFoundException e) { e.printStackTrace(); @@ -404,14 +404,14 @@ void testLinkPaxVolumes() { List perPassengerModeRecordList = parser.getRecords(); List perPassengerModeRecordListLink4b = perPassengerModeRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("link")).equals("link4b") && record.get(parser.getHeaderMap().get("passengerMode")).equals("pt") && record.get(parser.getHeaderMap().get("hour")).equals("1")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, perPassengerModeRecordListLink4b.size()); - Assert.assertEquals("Wrong amount of Vehicles on Link4b",1, Double.parseDouble(perPassengerModeRecordListLink4b.get(0).get("vehicles")),MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong amount of passengersPossiblyInclDriver on Link4b",3, Double.parseDouble(perPassengerModeRecordListLink4b.get(0).get("passengersPossiblyInclDriver")),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, perPassengerModeRecordListLink4b.size(), "Either no record or more than one record"); + Assertions.assertEquals(1, Double.parseDouble(perPassengerModeRecordListLink4b.get(0).get("vehicles")),MatsimTestUtils.EPSILON,"Wrong amount of Vehicles on Link4b"); + Assertions.assertEquals(3, Double.parseDouble(perPassengerModeRecordListLink4b.get(0).get("passengersPossiblyInclDriver")),MatsimTestUtils.EPSILON,"Wrong amount of passengersPossiblyInclDriver on Link4b"); List perPassengerModeRecordListLink2 = perPassengerModeRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("link")).equals("link2") && record.get(parser.getHeaderMap().get("passengerMode")).equals("car") && record.get(parser.getHeaderMap().get("hour")).equals("0")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, perPassengerModeRecordListLink2.size()); - Assert.assertEquals("Wrong amount of Vehicles on Link2b",1, Double.parseDouble(perPassengerModeRecordListLink2.get(0).get("vehicles")),MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong amount of passengersPossiblyInclDriver on Link4b",2, Double.parseDouble(perPassengerModeRecordListLink2.get(0).get("passengersPossiblyInclDriver")),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, perPassengerModeRecordListLink2.size(), "Either no record or more than one record"); + Assertions.assertEquals(1, Double.parseDouble(perPassengerModeRecordListLink2.get(0).get("vehicles")),MatsimTestUtils.EPSILON,"Wrong amount of Vehicles on Link2b"); + Assertions.assertEquals(2, Double.parseDouble(perPassengerModeRecordListLink2.get(0).get("passengersPossiblyInclDriver")),MatsimTestUtils.EPSILON,"Wrong amount of passengersPossiblyInclDriver on Link4b"); } catch (FileNotFoundException e) { e.printStackTrace(); @@ -427,14 +427,14 @@ void testLinkPaxVolumes() { List statsPerVehicleTypeRecordList = parser.getRecords(); List statsPerVehicleTypeRecordListVehiclesType1 = statsPerVehicleTypeRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("vehicleType")).equals("vehiclesType1")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, statsPerVehicleTypeRecordListVehiclesType1.size()); - Assert.assertEquals("Wrong sum of passengerKm",0.6, Double.parseDouble(statsPerVehicleTypeRecordListVehiclesType1.get(0).get("passengerKm")),MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong sum of vehicleKm",0.2, Double.parseDouble(statsPerVehicleTypeRecordListVehiclesType1.get(0).get("vehicleKm")),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, statsPerVehicleTypeRecordListVehiclesType1.size(), "Either no record or more than one record"); + Assertions.assertEquals(0.6, Double.parseDouble(statsPerVehicleTypeRecordListVehiclesType1.get(0).get("passengerKm")),MatsimTestUtils.EPSILON,"Wrong sum of passengerKm"); + Assertions.assertEquals(0.2, Double.parseDouble(statsPerVehicleTypeRecordListVehiclesType1.get(0).get("vehicleKm")),MatsimTestUtils.EPSILON,"Wrong sum of vehicleKm"); List statsPerVehicleTypeRecordListTransitVehicleType = statsPerVehicleTypeRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("vehicleType")).equals("transitVehicleType")).collect(Collectors.toList()); - Assert.assertEquals("Wrong sum of passengerKm",3.1, Double.parseDouble(statsPerVehicleTypeRecordListTransitVehicleType.get(0).get("passengerKm")),MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong sum of vehicleKm",0.7, Double.parseDouble(statsPerVehicleTypeRecordListTransitVehicleType.get(0).get("vehicleKm")),MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong vehicleHoursOnNetwork",0.0125, Double.parseDouble(statsPerVehicleTypeRecordListTransitVehicleType.get(0).get("vehicleHoursOnNetwork")),MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.1, Double.parseDouble(statsPerVehicleTypeRecordListTransitVehicleType.get(0).get("passengerKm")),MatsimTestUtils.EPSILON,"Wrong sum of passengerKm"); + Assertions.assertEquals(0.7, Double.parseDouble(statsPerVehicleTypeRecordListTransitVehicleType.get(0).get("vehicleKm")),MatsimTestUtils.EPSILON,"Wrong sum of vehicleKm"); + Assertions.assertEquals(0.0125, Double.parseDouble(statsPerVehicleTypeRecordListTransitVehicleType.get(0).get("vehicleHoursOnNetwork")),MatsimTestUtils.EPSILON,"Wrong vehicleHoursOnNetwork"); } catch (FileNotFoundException e) { e.printStackTrace(); diff --git a/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java b/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java index 4e1e6b20caf..a973c4a7e58 100644 --- a/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java +++ b/matsim/src/test/java/org/matsim/analysis/personMoney/PersonMoneyEventAggregatorTest.java @@ -22,7 +22,7 @@ import org.apache.commons.csv.CSVParser; import org.apache.commons.csv.CSVRecord; import org.apache.commons.lang3.mutable.MutableDouble; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -98,20 +98,20 @@ public void reset(int iteration) { List csvRecordListA = csvRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("transactionPartner")).equals(drt_A) && record.get(parser.getHeaderMap().get("purpose")).equals("drtFare")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, csvRecordListA.size()); - Assert.assertEquals("Wrong personMoneyAmountSum for drt_A",19.07, Double.parseDouble(csvRecordListA.get(0).get(2)),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, csvRecordListA.size(), "Either no record or more than one record"); + Assertions.assertEquals(19.07, Double.parseDouble(csvRecordListA.get(0).get(2)),MatsimTestUtils.EPSILON,"Wrong personMoneyAmountSum for drt_A"); List csvRecordList0 = csvRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("transactionPartner")).equals("DrtA") && record.get(parser.getHeaderMap().get("purpose")).equals("DrtFare")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, csvRecordList0.size()); - Assert.assertEquals("Wrong personMoneyAmountSum for empty purpose",4.1, Double.parseDouble(csvRecordList0.get(0).get(2)),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, csvRecordList0.size(), "Either no record or more than one record"); + Assertions.assertEquals(4.1, Double.parseDouble(csvRecordList0.get(0).get(2)),MatsimTestUtils.EPSILON,"Wrong personMoneyAmountSum for empty purpose"); List csvRecordListB = csvRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("transactionPartner")).equals(drt_B) && record.get(parser.getHeaderMap().get("purpose")).equals("drtFare")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record",1, csvRecordListB.size()); - Assert.assertEquals("Wrong personMoneyAmountSum for drt_B",16, Double.parseDouble(csvRecordListB.get(0).get(2)),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, csvRecordListB.size(), "Either no record or more than one record"); + Assertions.assertEquals(16, Double.parseDouble(csvRecordListB.get(0).get(2)),MatsimTestUtils.EPSILON,"Wrong personMoneyAmountSum for drt_B"); List csvRecordListC = csvRecordList.stream().filter(record -> record.get(parser.getHeaderMap().get("transactionPartner")).equals(drt_C) && record.get(parser.getHeaderMap().get("purpose")).equals("drtFare")).collect(Collectors.toList()); - Assert.assertEquals("Either no record or more than one record for drt_C",1, csvRecordListC.size()); - Assert.assertEquals("Wrong personMoneyAmountSum",2.5, Double.parseDouble(csvRecordListC.get(0).get(2)),MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, csvRecordListC.size(), "Either no record or more than one record for drt_C"); + Assertions.assertEquals(2.5, Double.parseDouble(csvRecordListC.get(0).get(2)),MatsimTestUtils.EPSILON,"Wrong personMoneyAmountSum"); } catch (FileNotFoundException e) { e.printStackTrace(); diff --git a/matsim/src/test/java/org/matsim/analysis/pt/stop2stop/PtStop2StopAnalysisTest.java b/matsim/src/test/java/org/matsim/analysis/pt/stop2stop/PtStop2StopAnalysisTest.java index dc39adf4358..88e5fb60349 100644 --- a/matsim/src/test/java/org/matsim/analysis/pt/stop2stop/PtStop2StopAnalysisTest.java +++ b/matsim/src/test/java/org/matsim/analysis/pt/stop2stop/PtStop2StopAnalysisTest.java @@ -19,7 +19,7 @@ package org.matsim.analysis.pt.stop2stop; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -145,30 +145,30 @@ void testPtStop2StopAnalysisSingle() { && entry.departureId.equals(departureId_bus1_route1_dep1) && entry.stopId.equals(transitStopFacilityId1) && entry.stopSequence == 0).collect(Collectors.toList()); System.out.println(line1_route1_dep1_stop1.size()); - Assert.assertEquals("Either no entry or more than entry for " + transitLineId_bus1 + ", " + transitRouteId_bus1_route1 + ", " + departureId_bus1_route1_dep1 + ", " + departureId_bus1_route1_dep1 + ", " + transitStopFacilityId1 + ", 0",1, line1_route1_dep1_stop1.size()); - Assert.assertNull("There should be no previous stop, but there was", line1_route1_dep1_stop1.get(0).stopPreviousId); - Assert.assertEquals("Wrong arrivalTimeScheduled", 1.0, line1_route1_dep1_stop1.get(0).arrivalTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong arrivalDelay", 0.0, line1_route1_dep1_stop1.get(0).arrivalDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals(3.0, line1_route1_dep1_stop1.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, line1_route1_dep1_stop1.get(0).departureDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, line1_route1_dep1_stop1.get(0).passengersAtArrival, MatsimTestUtils.EPSILON); - Assert.assertEquals(veh_bus1.getType().getCapacity().getSeats() + veh_bus1.getType().getCapacity().getStandingRoom(), line1_route1_dep1_stop1.get(0).totalVehicleCapacity, MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, line1_route1_dep1_stop1.get(0).passengersAlighting, MatsimTestUtils.EPSILON); - Assert.assertEquals(2.0, line1_route1_dep1_stop1.get(0).passengersBoarding, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, line1_route1_dep1_stop1.size(), "Either no entry or more than entry for " + transitLineId_bus1 + ", " + transitRouteId_bus1_route1 + ", " + departureId_bus1_route1_dep1 + ", " + departureId_bus1_route1_dep1 + ", " + transitStopFacilityId1 + ", 0"); + Assertions.assertNull(line1_route1_dep1_stop1.get(0).stopPreviousId, "There should be no previous stop, but there was"); + Assertions.assertEquals(1.0, line1_route1_dep1_stop1.get(0).arrivalTimeScheduled, MatsimTestUtils.EPSILON, "Wrong arrivalTimeScheduled"); + Assertions.assertEquals(0.0, line1_route1_dep1_stop1.get(0).arrivalDelay, MatsimTestUtils.EPSILON, "Wrong arrivalDelay"); + Assertions.assertEquals(3.0, line1_route1_dep1_stop1.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, line1_route1_dep1_stop1.get(0).departureDelay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, line1_route1_dep1_stop1.get(0).passengersAtArrival, MatsimTestUtils.EPSILON); + Assertions.assertEquals(veh_bus1.getType().getCapacity().getSeats() + veh_bus1.getType().getCapacity().getStandingRoom(), line1_route1_dep1_stop1.get(0).totalVehicleCapacity, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, line1_route1_dep1_stop1.get(0).passengersAlighting, MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, line1_route1_dep1_stop1.get(0).passengersBoarding, MatsimTestUtils.EPSILON); List> linkList = new ArrayList<>(); linkList.add(linkId1); - Assert.assertEquals("Wrong links", linkList, line1_route1_dep1_stop1.get(0).linkIdsSincePreviousStop); + Assertions.assertEquals(linkList, line1_route1_dep1_stop1.get(0).linkIdsSincePreviousStop, "Wrong links"); List line1_route1_dep1_stop3 = ptStop2StopAnalysis.getStop2StopEntriesByDeparture().stream() .filter(entry -> entry.transitLineId.equals(transitLineId_bus1) && entry.transitRouteId.equals(transitRouteId_bus1_route1) && entry.departureId.equals(departureId_bus1_route1_dep1) && entry.stopId.equals(transitStopFacilityId3) && entry.stopSequence == 2).collect(Collectors.toList()); - Assert.assertEquals("Either no entry or more than entry for " + transitLineId_bus1 + ", " + transitRouteId_bus1_route1 + ", " + departureId_bus1_route1_dep1 + ", " + departureId_bus1_route1_dep1 + ", " + transitStopFacilityId3 + ", 0",1, line1_route1_dep1_stop3.size()); - Assert.assertEquals("There is no previous stop", transitStopFacilityId2, line1_route1_dep1_stop3.get(0).stopPreviousId); - Assert.assertEquals(12.0, line1_route1_dep1_stop3.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong arrivalTimeScheduled", 12.0, line1_route1_dep1_stop3.get(0).arrivalTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong arrival delay", -1.0, line1_route1_dep1_stop3.get(0).arrivalDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong departure delay", 1.0, line1_route1_dep1_stop3.get(0).departureDelay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, line1_route1_dep1_stop3.size(), "Either no entry or more than entry for " + transitLineId_bus1 + ", " + transitRouteId_bus1_route1 + ", " + departureId_bus1_route1_dep1 + ", " + departureId_bus1_route1_dep1 + ", " + transitStopFacilityId3 + ", 0"); + Assertions.assertEquals(transitStopFacilityId2, line1_route1_dep1_stop3.get(0).stopPreviousId, "There is no previous stop"); + Assertions.assertEquals(12.0, line1_route1_dep1_stop3.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); + Assertions.assertEquals(12.0, line1_route1_dep1_stop3.get(0).arrivalTimeScheduled, MatsimTestUtils.EPSILON, "Wrong arrivalTimeScheduled"); + Assertions.assertEquals(-1.0, line1_route1_dep1_stop3.get(0).arrivalDelay, MatsimTestUtils.EPSILON, "Wrong arrival delay"); + Assertions.assertEquals(1.0, line1_route1_dep1_stop3.get(0).departureDelay, MatsimTestUtils.EPSILON, "Wrong departure delay"); } // ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ @@ -445,53 +445,53 @@ void testPtStop2StopAnalysisMulti() { // Tests List bus1_dep1_stop1 = ptStop2StopAnalysis.getStop2StopEntriesByDeparture().stream().filter(entry -> entry.transitLineId.equals(transitLineId_bus1) && entry.transitRouteId.equals(transitRouteId_bus1_route1) && entry.departureId.equals(departureId_bus1_dep1) && entry.stopId.equals(transitStopFacilityId1) && entry.stopSequence == 0).collect(Collectors.toList()); - Assert.assertEquals("Either no entry or more than entry for " + transitLineId_bus1 + ", " + transitRouteId_bus1_route1 + ", " + departureId_bus1_dep1 + ", " + departureId_bus1_dep1 + ", " + transitStopFacilityId1 + ", 0",1, bus1_dep1_stop1.size()); - Assert.assertNull("There should be no previous stop, but there was", bus1_dep1_stop1.get(0).stopPreviousId); - Assert.assertEquals("Wrong arrivalTimeScheduled", 1.0, bus1_dep1_stop1.get(0).arrivalTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong arrivalDelay", 0.0, bus1_dep1_stop1.get(0).arrivalDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals(3.0, bus1_dep1_stop1.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, bus1_dep1_stop1.get(0).departureDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, bus1_dep1_stop1.get(0).passengersAtArrival, MatsimTestUtils.EPSILON); - Assert.assertEquals(veh_bus1_dep1.getType().getCapacity().getSeats() + veh_bus1_dep1.getType().getCapacity().getStandingRoom(), bus1_dep1_stop1.get(0).totalVehicleCapacity, MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, bus1_dep1_stop1.get(0).passengersAlighting, MatsimTestUtils.EPSILON); - Assert.assertEquals(2.0, bus1_dep1_stop1.get(0).passengersBoarding, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, bus1_dep1_stop1.size(), "Either no entry or more than entry for " + transitLineId_bus1 + ", " + transitRouteId_bus1_route1 + ", " + departureId_bus1_dep1 + ", " + departureId_bus1_dep1 + ", " + transitStopFacilityId1 + ", 0"); + Assertions.assertNull(bus1_dep1_stop1.get(0).stopPreviousId, "There should be no previous stop, but there was"); + Assertions.assertEquals(1.0, bus1_dep1_stop1.get(0).arrivalTimeScheduled, MatsimTestUtils.EPSILON, "Wrong arrivalTimeScheduled"); + Assertions.assertEquals(0.0, bus1_dep1_stop1.get(0).arrivalDelay, MatsimTestUtils.EPSILON, "Wrong arrivalDelay"); + Assertions.assertEquals(3.0, bus1_dep1_stop1.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, bus1_dep1_stop1.get(0).departureDelay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, bus1_dep1_stop1.get(0).passengersAtArrival, MatsimTestUtils.EPSILON); + Assertions.assertEquals(veh_bus1_dep1.getType().getCapacity().getSeats() + veh_bus1_dep1.getType().getCapacity().getStandingRoom(), bus1_dep1_stop1.get(0).totalVehicleCapacity, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, bus1_dep1_stop1.get(0).passengersAlighting, MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, bus1_dep1_stop1.get(0).passengersBoarding, MatsimTestUtils.EPSILON); List> linkList = new ArrayList<>(); linkList.add(linkId1); - Assert.assertEquals("Wrong links", linkList, bus1_dep1_stop1.get(0).linkIdsSincePreviousStop); + Assertions.assertEquals(linkList, bus1_dep1_stop1.get(0).linkIdsSincePreviousStop, "Wrong links"); List bus1_dep1_stop3 = ptStop2StopAnalysis.getStop2StopEntriesByDeparture().stream().filter(entry -> entry.transitLineId.equals(transitLineId_bus1) && entry.transitRouteId.equals(transitRouteId_bus1_route1) && entry.departureId.equals(departureId_bus1_dep1) && entry.stopId.equals(transitStopFacilityId4) && entry.stopSequence == 2).collect(Collectors.toList()); System.out.println(bus1_dep1_stop3.isEmpty()); - Assert.assertEquals("Either no entry or more than entry for " + transitLineId_bus1 + ", " + transitRouteId_bus1_route1 + ", " + departureId_bus1_dep1 + ", " + departureId_bus1_dep1 + ", " + transitStopFacilityId4 + ", 0",1, bus1_dep1_stop3.size()); - Assert.assertEquals("Wrong arrivalDelay", 0.0, bus1_dep1_stop3.get(0).arrivalDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals(15.0, bus1_dep1_stop3.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, bus1_dep1_stop3.get(0).departureDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals(3.0, bus1_dep1_stop3.get(0).passengersAtArrival, MatsimTestUtils.EPSILON); - Assert.assertEquals(veh_bus1_dep1.getType().getCapacity().getSeats() + veh_bus1_dep1.getType().getCapacity().getStandingRoom(), bus1_dep1_stop1.get(0).totalVehicleCapacity, MatsimTestUtils.EPSILON); - Assert.assertEquals(3.0, bus1_dep1_stop3.get(0).passengersAlighting, MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, bus1_dep1_stop3.get(0).passengersBoarding, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, bus1_dep1_stop3.size(), "Either no entry or more than entry for " + transitLineId_bus1 + ", " + transitRouteId_bus1_route1 + ", " + departureId_bus1_dep1 + ", " + departureId_bus1_dep1 + ", " + transitStopFacilityId4 + ", 0"); + Assertions.assertEquals(0.0, bus1_dep1_stop3.get(0).arrivalDelay, MatsimTestUtils.EPSILON, "Wrong arrivalDelay"); + Assertions.assertEquals(15.0, bus1_dep1_stop3.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, bus1_dep1_stop3.get(0).departureDelay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.0, bus1_dep1_stop3.get(0).passengersAtArrival, MatsimTestUtils.EPSILON); + Assertions.assertEquals(veh_bus1_dep1.getType().getCapacity().getSeats() + veh_bus1_dep1.getType().getCapacity().getStandingRoom(), bus1_dep1_stop1.get(0).totalVehicleCapacity, MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.0, bus1_dep1_stop3.get(0).passengersAlighting, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, bus1_dep1_stop3.get(0).passengersBoarding, MatsimTestUtils.EPSILON); List bus1_dep1_stop4 = ptStop2StopAnalysis.getStop2StopEntriesByDeparture().stream().filter(entry -> entry.transitLineId.equals(transitLineId_bus1) && entry.transitRouteId.equals(transitRouteId_bus1_route2) && entry.departureId.equals(departureId_bus1_dep1) && entry.stopId.equals(transitStopFacilityId2) && entry.stopSequence == 1).collect(Collectors.toList()); - Assert.assertEquals("Either no entry or more than entry for " + transitLineId_bus1 + ", " + transitRouteId_bus1_route2 + ", " + departureId_bus1_dep1 + ", " + departureId_bus1_dep1 + ", " + transitStopFacilityId2 + ", 0",1, bus1_dep1_stop4.size()); - Assert.assertEquals("Wrong arrivalTimeScheduled", 28.0, bus1_dep1_stop4.get(0).arrivalTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong arrivalDelay", 0.0, bus1_dep1_stop4.get(0).arrivalDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals(29.0, bus1_dep1_stop4.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, bus1_dep1_stop4.get(0).departureDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals(5.0, bus1_dep1_stop4.get(0).passengersAtArrival, MatsimTestUtils.EPSILON); - Assert.assertEquals(veh_bus1_dep1.getType().getCapacity().getSeats() + veh_bus1_dep1.getType().getCapacity().getStandingRoom(), bus1_dep1_stop1.get(0).totalVehicleCapacity, MatsimTestUtils.EPSILON); - Assert.assertEquals(2.0, bus1_dep1_stop4.get(0).passengersAlighting, MatsimTestUtils.EPSILON); - Assert.assertEquals(2.0, bus1_dep1_stop4.get(0).passengersBoarding, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, bus1_dep1_stop4.size(), "Either no entry or more than entry for " + transitLineId_bus1 + ", " + transitRouteId_bus1_route2 + ", " + departureId_bus1_dep1 + ", " + departureId_bus1_dep1 + ", " + transitStopFacilityId2 + ", 0"); + Assertions.assertEquals(28.0, bus1_dep1_stop4.get(0).arrivalTimeScheduled, MatsimTestUtils.EPSILON, "Wrong arrivalTimeScheduled"); + Assertions.assertEquals(0.0, bus1_dep1_stop4.get(0).arrivalDelay, MatsimTestUtils.EPSILON, "Wrong arrivalDelay"); + Assertions.assertEquals(29.0, bus1_dep1_stop4.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, bus1_dep1_stop4.get(0).departureDelay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(5.0, bus1_dep1_stop4.get(0).passengersAtArrival, MatsimTestUtils.EPSILON); + Assertions.assertEquals(veh_bus1_dep1.getType().getCapacity().getSeats() + veh_bus1_dep1.getType().getCapacity().getStandingRoom(), bus1_dep1_stop1.get(0).totalVehicleCapacity, MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, bus1_dep1_stop4.get(0).passengersAlighting, MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.0, bus1_dep1_stop4.get(0).passengersBoarding, MatsimTestUtils.EPSILON); List train1_dep1_stop4 = ptStop2StopAnalysis.getStop2StopEntriesByDeparture().stream().filter(entry -> entry.transitLineId.equals(transitLineId_train1) && entry.transitRouteId.equals(transitRouteId_train1_route1) && entry.departureId.equals(departureId_train1_dep1) && entry.stopId.equals(transitStopFacilityId6) && entry.stopSequence == 3).collect(Collectors.toList()); - Assert.assertEquals("Either no entry or more than entry for " + transitLineId_train1 + ", " + transitRouteId_train1_route1 + ", " + departureId_train1_dep1 + ", " + transitStopFacilityId6 + ", 0",1, train1_dep1_stop4.size()); - Assert.assertEquals("Wrong arrivalTimeScheduled", 19.0, train1_dep1_stop4.get(0).arrivalTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals("Wrong arrivalDelay", 0.0, train1_dep1_stop4.get(0).arrivalDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals(21.0, train1_dep1_stop4.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, train1_dep1_stop4.get(0).departureDelay, MatsimTestUtils.EPSILON); - Assert.assertEquals(6.0, train1_dep1_stop4.get(0).passengersAtArrival, MatsimTestUtils.EPSILON); - Assert.assertEquals(veh_bus1_dep1.getType().getCapacity().getSeats() + veh_bus1_dep1.getType().getCapacity().getStandingRoom(), bus1_dep1_stop1.get(0).totalVehicleCapacity, MatsimTestUtils.EPSILON); - Assert.assertEquals(4.0, train1_dep1_stop4.get(0).passengersAlighting, MatsimTestUtils.EPSILON); - Assert.assertEquals(1.0, train1_dep1_stop4.get(0).passengersBoarding, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, train1_dep1_stop4.size(), "Either no entry or more than entry for " + transitLineId_train1 + ", " + transitRouteId_train1_route1 + ", " + departureId_train1_dep1 + ", " + transitStopFacilityId6 + ", 0"); + Assertions.assertEquals(19.0, train1_dep1_stop4.get(0).arrivalTimeScheduled, MatsimTestUtils.EPSILON, "Wrong arrivalTimeScheduled"); + Assertions.assertEquals(0.0, train1_dep1_stop4.get(0).arrivalDelay, MatsimTestUtils.EPSILON, "Wrong arrivalDelay"); + Assertions.assertEquals(21.0, train1_dep1_stop4.get(0).departureTimeScheduled, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, train1_dep1_stop4.get(0).departureDelay, MatsimTestUtils.EPSILON); + Assertions.assertEquals(6.0, train1_dep1_stop4.get(0).passengersAtArrival, MatsimTestUtils.EPSILON); + Assertions.assertEquals(veh_bus1_dep1.getType().getCapacity().getSeats() + veh_bus1_dep1.getType().getCapacity().getStandingRoom(), bus1_dep1_stop1.get(0).totalVehicleCapacity, MatsimTestUtils.EPSILON); + Assertions.assertEquals(4.0, train1_dep1_stop4.get(0).passengersAlighting, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.0, train1_dep1_stop4.get(0).passengersBoarding, MatsimTestUtils.EPSILON); } } \ No newline at end of file diff --git a/matsim/src/test/java/org/matsim/api/core/v01/CoordTest.java b/matsim/src/test/java/org/matsim/api/core/v01/CoordTest.java index 8a9e0264d4b..30e2646fb26 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/CoordTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/CoordTest.java @@ -20,7 +20,7 @@ package org.matsim.api.core.v01; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; import org.matsim.testcases.MatsimTestUtils; @@ -63,22 +63,22 @@ void testCoord3D() { void testGetX() { // 2D Coord c2 = new Coord(0.0, 1.0); - assertEquals("Wrong x-value.", 0.0, c2.getX(), MatsimTestUtils.EPSILON); + assertEquals(0.0, c2.getX(), MatsimTestUtils.EPSILON, "Wrong x-value."); // 3D Coord c3 = new Coord(0.0, 1.0, 2.0); - assertEquals("Wrong x-value.", 0.0, c3.getX(), MatsimTestUtils.EPSILON); + assertEquals(0.0, c3.getX(), MatsimTestUtils.EPSILON, "Wrong x-value."); } @Test void testGetY() { // 2D Coord c2 = new Coord(0.0, 1.0); - assertEquals("Wrong y-value.", 1.0, c2.getY(), MatsimTestUtils.EPSILON); + assertEquals(1.0, c2.getY(), MatsimTestUtils.EPSILON, "Wrong y-value."); // 3D Coord c3 = new Coord(0.0, 1.0, 2.0); - assertEquals("Wrong y-value.", 1.0, c3.getY(), MatsimTestUtils.EPSILON); + assertEquals(1.0, c3.getY(), MatsimTestUtils.EPSILON, "Wrong y-value."); } @Test @@ -95,7 +95,7 @@ void testGetZ() { // 3D Coord c3 = new Coord(0.0, 1.0, 2.0); - assertEquals("Wrong z-value.", 2.0, c3.getZ(), MatsimTestUtils.EPSILON); + assertEquals(2.0, c3.getZ(), MatsimTestUtils.EPSILON, "Wrong z-value."); } @Test @@ -110,15 +110,15 @@ void testEqualsObject() { Coord c3b = new Coord(0.0, 1.0, 2.0); Coord c3c = new Coord(0.0, 1.0, 3.0); - assertFalse("Coordinates should not be equal.", c2a.equals(dummy)); - assertTrue("Coordinates should not be equal.", c2a.equals(c2b)); - assertFalse("Coordinates should not be equal.", c2a.equals(c2c)); - assertFalse("2D coordinate should not be equal to 3D coordinate.", c2a.equals(c3a)); + assertFalse(c2a.equals(dummy), "Coordinates should not be equal."); + assertTrue(c2a.equals(c2b), "Coordinates should not be equal."); + assertFalse(c2a.equals(c2c), "Coordinates should not be equal."); + assertFalse(c2a.equals(c3a), "2D coordinate should not be equal to 3D coordinate."); - assertFalse("Coordinates should not be equal.", c3a.equals(dummy)); - assertTrue("Coordinates should not be equal.", c3a.equals(c3b)); - assertFalse("Coordinates should not be equal.", c3a.equals(c3c)); - assertFalse("3D coordinate should not be equal to 2D coordinate.", c3a.equals(c2a)); + assertFalse(c3a.equals(dummy), "Coordinates should not be equal."); + assertTrue(c3a.equals(c3b), "Coordinates should not be equal."); + assertFalse(c3a.equals(c3c), "Coordinates should not be equal."); + assertFalse(c3a.equals(c2a), "3D coordinate should not be equal to 2D coordinate."); } @Test diff --git a/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java b/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java index b92c50d4c4d..7c026b15ca4 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.api.core.v01; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.File; diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdAnnotationsTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdAnnotationsTest.java index f2e82c6ecdb..ac679f3d593 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdAnnotationsTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdAnnotationsTest.java @@ -2,7 +2,7 @@ import java.util.Objects; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.IdAnnotations.JsonId; import org.matsim.api.core.v01.network.Link; @@ -29,9 +29,9 @@ void testRecordJsonIds() throws JsonProcessingException { String s = objectMapper.writeValueAsString(recordWithIds1); RecordWithIds recordWithIds2 = objectMapper.readValue(s, RecordWithIds.class); - Assert.assertEquals(recordWithIds1, recordWithIds2); - Assert.assertEquals(personId, recordWithIds2.personId); - Assert.assertSame(personId, recordWithIds2.personId); + Assertions.assertEquals(recordWithIds1, recordWithIds2); + Assertions.assertEquals(personId, recordWithIds2.personId); + Assertions.assertSame(personId, recordWithIds2.personId); } @Test @@ -42,9 +42,9 @@ void testRecordJsonIdsWithNull() throws JsonProcessingException { String s = objectMapper.writeValueAsString(recordWithIds1); RecordWithIds recordWithIds2 = objectMapper.readValue(s, RecordWithIds.class); - Assert.assertEquals(recordWithIds1, recordWithIds2); - Assert.assertEquals(personId, recordWithIds2.personId); - Assert.assertSame(personId, recordWithIds2.personId); + Assertions.assertEquals(recordWithIds1, recordWithIds2); + Assertions.assertEquals(personId, recordWithIds2.personId); + Assertions.assertSame(personId, recordWithIds2.personId); } @Test @@ -58,9 +58,9 @@ void testClassJsonIds() throws JsonProcessingException { String s = objectMapper.writeValueAsString(classWithIds1); ClassWithIds classWithIds2 = objectMapper.readValue(s, ClassWithIds.class); - Assert.assertEquals(classWithIds1, classWithIds2); - Assert.assertEquals(personId, classWithIds2.personId); - Assert.assertSame(personId, classWithIds2.personId); + Assertions.assertEquals(classWithIds1, classWithIds2); + Assertions.assertEquals(personId, classWithIds2.personId); + Assertions.assertSame(personId, classWithIds2.personId); } @Test @@ -71,9 +71,9 @@ void testClassJsonIdsWithNull() throws JsonProcessingException { String s = objectMapper.writeValueAsString(classWithIds1); ClassWithIds classWithIds2 = objectMapper.readValue(s, ClassWithIds.class); - Assert.assertEquals(classWithIds1, classWithIds2); - Assert.assertEquals(personId, classWithIds2.personId); - Assert.assertSame(personId, classWithIds2.personId); + Assertions.assertEquals(classWithIds1, classWithIds2); + Assertions.assertEquals(personId, classWithIds2.personId); + Assertions.assertSame(personId, classWithIds2.personId); } @JsonNaming(PropertyNamingStrategies.SnakeCaseStrategy.class) diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java index 2562a5798c8..04c48fcafe8 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java @@ -3,8 +3,8 @@ import java.util.LinkedHashMap; import java.util.Map; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.network.Link; @@ -48,7 +48,7 @@ void testMapKey() { throw new RuntimeException(e); } System.out.println(s); - Assert.assertEquals("{\"0\":\"a\",\"1\":\"b\"}", s); + Assertions.assertEquals("{\"0\":\"a\",\"1\":\"b\"}", s); // deserialize Map, String> map1; @@ -57,10 +57,10 @@ void testMapKey() { } catch (JsonProcessingException e) { throw new RuntimeException(e); } - Assert.assertEquals(map0, map1); - Assert.assertEquals(linkId0, + Assertions.assertEquals(map0, map1); + Assertions.assertEquals(linkId0, map1.keySet().stream().filter(lId -> lId.equals(linkId0)).findFirst().orElseThrow()); - Assert.assertSame(linkId0, + Assertions.assertSame(linkId0, map1.keySet().stream().filter(lId -> lId.equals(linkId0)).findFirst().orElseThrow()); } @@ -86,7 +86,7 @@ void testMapValue() { throw new RuntimeException(e); } System.out.println(s); - Assert.assertEquals("{\"a\":\"0\",\"b\":\"1\"}", s); + Assertions.assertEquals("{\"a\":\"0\",\"b\":\"1\"}", s); // deserialize Map> map1; @@ -95,9 +95,9 @@ void testMapValue() { } catch (JsonProcessingException e) { throw new RuntimeException(e); } - Assert.assertEquals(map0, map1); - Assert.assertEquals(linkId0, map1.get("a")); - Assert.assertSame(linkId0, map1.get("a")); + Assertions.assertEquals(map0, map1); + Assertions.assertEquals(linkId0, map1.get("a")); + Assertions.assertSame(linkId0, map1.get("a")); } } diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdMapTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdMapTest.java index f57550f3272..37460662068 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdMapTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdMapTest.java @@ -1,6 +1,6 @@ package org.matsim.api.core.v01; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Person; import org.matsim.core.utils.collections.Tuple; @@ -17,36 +17,36 @@ public class IdMapTest { void testPutGetRemoveSize() { IdMap map = new IdMap<>(Person.class, 10); - Assert.assertEquals(0, map.size()); - Assert.assertTrue(map.isEmpty()); + Assertions.assertEquals(0, map.size()); + Assertions.assertTrue(map.isEmpty()); - Assert.assertNull(map.put(Id.create(1, Person.class), "one")); + Assertions.assertNull(map.put(Id.create(1, Person.class), "one")); - Assert.assertEquals(1, map.size()); - Assert.assertFalse(map.isEmpty()); + Assertions.assertEquals(1, map.size()); + Assertions.assertFalse(map.isEmpty()); - Assert.assertNull(map.put(Id.create(2, Person.class), "two")); + Assertions.assertNull(map.put(Id.create(2, Person.class), "two")); - Assert.assertEquals(2, map.size()); - Assert.assertFalse(map.isEmpty()); + Assertions.assertEquals(2, map.size()); + Assertions.assertFalse(map.isEmpty()); - Assert.assertEquals("one", map.put(Id.create(1, Person.class), "also-one")); - Assert.assertEquals(2, map.size()); + Assertions.assertEquals("one", map.put(Id.create(1, Person.class), "also-one")); + Assertions.assertEquals(2, map.size()); - Assert.assertNull(map.put(Id.create(3, Person.class), "three")); - Assert.assertEquals(3, map.size()); + Assertions.assertNull(map.put(Id.create(3, Person.class), "three")); + Assertions.assertEquals(3, map.size()); - Assert.assertNull(map.put(Id.create(4, Person.class), null)); - Assert.assertEquals(3, map.size()); + Assertions.assertNull(map.put(Id.create(4, Person.class), null)); + Assertions.assertEquals(3, map.size()); - Assert.assertEquals("also-one", map.get(Id.create(1, Person.class))); - Assert.assertEquals("two", map.get(Id.create(2, Person.class))); - Assert.assertEquals("three", map.get(Id.create(3, Person.class))); - Assert.assertNull(map.get(Id.create(4, Person.class))); + Assertions.assertEquals("also-one", map.get(Id.create(1, Person.class))); + Assertions.assertEquals("two", map.get(Id.create(2, Person.class))); + Assertions.assertEquals("three", map.get(Id.create(3, Person.class))); + Assertions.assertNull(map.get(Id.create(4, Person.class))); - Assert.assertEquals("two", map.remove(Id.create(2, Person.class))); - Assert.assertEquals(2, map.size()); - Assert.assertNull(map.get(Id.create(2, Person.class))); + Assertions.assertEquals("two", map.remove(Id.create(2, Person.class))); + Assertions.assertEquals(2, map.size()); + Assertions.assertNull(map.get(Id.create(2, Person.class))); } @Test @@ -62,19 +62,19 @@ void testIterable() { int i = 0; for (String data : map) { if (i == 0) { - Assert.assertEquals("one", data); + Assertions.assertEquals("one", data); } else if (i == 1) { - Assert.assertEquals("two", data); + Assertions.assertEquals("two", data); } else if (i == 2) { - Assert.assertEquals("four", data); + Assertions.assertEquals("four", data); } else if (i == 3) { - Assert.assertEquals("five", data); + Assertions.assertEquals("five", data); } else { throw new RuntimeException("unexpected element: " + data); } i++; } - Assert.assertEquals(4, i); + Assertions.assertEquals(4, i); } @Test @@ -91,17 +91,17 @@ void testForEach() { map.forEach((k, v) -> data.add(new Tuple<>(k, v))); - Assert.assertEquals(Id.create(1, Person.class), data.get(0).getFirst()); - Assert.assertEquals("one", data.get(0).getSecond()); + Assertions.assertEquals(Id.create(1, Person.class), data.get(0).getFirst()); + Assertions.assertEquals("one", data.get(0).getSecond()); - Assert.assertEquals(Id.create(2, Person.class), data.get(1).getFirst()); - Assert.assertEquals("two", data.get(1).getSecond()); + Assertions.assertEquals(Id.create(2, Person.class), data.get(1).getFirst()); + Assertions.assertEquals("two", data.get(1).getSecond()); - Assert.assertEquals(Id.create(4, Person.class), data.get(2).getFirst()); - Assert.assertEquals("four", data.get(2).getSecond()); + Assertions.assertEquals(Id.create(4, Person.class), data.get(2).getFirst()); + Assertions.assertEquals("four", data.get(2).getSecond()); - Assert.assertEquals(Id.create(5, Person.class), data.get(3).getFirst()); - Assert.assertEquals("five", data.get(3).getSecond()); + Assertions.assertEquals(Id.create(5, Person.class), data.get(3).getFirst()); + Assertions.assertEquals("five", data.get(3).getSecond()); } @Test @@ -114,26 +114,26 @@ void testContainsKey() { map.put(Id.create(4, Person.class), "four"); map.put(Id.create(5, Person.class), "five"); - Assert.assertTrue(map.containsKey(Id.create(1, Person.class))); - Assert.assertTrue(map.containsKey(Id.create(2, Person.class))); - Assert.assertFalse(map.containsKey(Id.create(3, Person.class))); - Assert.assertTrue(map.containsKey(Id.create(4, Person.class))); - Assert.assertTrue(map.containsKey(Id.create(5, Person.class))); - Assert.assertFalse(map.containsKey(Id.create(6, Person.class))); - - Assert.assertTrue(map.containsKey(Id.create(1, Person.class).index())); - Assert.assertTrue(map.containsKey(Id.create(2, Person.class).index())); - Assert.assertFalse(map.containsKey(Id.create(3, Person.class).index())); - Assert.assertTrue(map.containsKey(Id.create(4, Person.class).index())); - Assert.assertTrue(map.containsKey(Id.create(5, Person.class).index())); - Assert.assertFalse(map.containsKey(Id.create(6, Person.class).index())); - - Assert.assertTrue(map.containsKey((Object) Id.create(1, Person.class))); - Assert.assertTrue(map.containsKey((Object) Id.create(2, Person.class))); - Assert.assertFalse(map.containsKey((Object) Id.create(3, Person.class))); - Assert.assertTrue(map.containsKey((Object) Id.create(4, Person.class))); - Assert.assertTrue(map.containsKey((Object) Id.create(5, Person.class))); - Assert.assertFalse(map.containsKey((Object) Id.create(6, Person.class))); + Assertions.assertTrue(map.containsKey(Id.create(1, Person.class))); + Assertions.assertTrue(map.containsKey(Id.create(2, Person.class))); + Assertions.assertFalse(map.containsKey(Id.create(3, Person.class))); + Assertions.assertTrue(map.containsKey(Id.create(4, Person.class))); + Assertions.assertTrue(map.containsKey(Id.create(5, Person.class))); + Assertions.assertFalse(map.containsKey(Id.create(6, Person.class))); + + Assertions.assertTrue(map.containsKey(Id.create(1, Person.class).index())); + Assertions.assertTrue(map.containsKey(Id.create(2, Person.class).index())); + Assertions.assertFalse(map.containsKey(Id.create(3, Person.class).index())); + Assertions.assertTrue(map.containsKey(Id.create(4, Person.class).index())); + Assertions.assertTrue(map.containsKey(Id.create(5, Person.class).index())); + Assertions.assertFalse(map.containsKey(Id.create(6, Person.class).index())); + + Assertions.assertTrue(map.containsKey((Object) Id.create(1, Person.class))); + Assertions.assertTrue(map.containsKey((Object) Id.create(2, Person.class))); + Assertions.assertFalse(map.containsKey((Object) Id.create(3, Person.class))); + Assertions.assertTrue(map.containsKey((Object) Id.create(4, Person.class))); + Assertions.assertTrue(map.containsKey((Object) Id.create(5, Person.class))); + Assertions.assertFalse(map.containsKey((Object) Id.create(6, Person.class))); } @Test @@ -146,12 +146,12 @@ void testContainsValue() { map.put(Id.create(4, Person.class), "four"); map.put(Id.create(5, Person.class), "five"); - Assert.assertTrue(map.containsValue("one")); - Assert.assertTrue(map.containsValue("two")); - Assert.assertFalse(map.containsValue("three")); - Assert.assertTrue(map.containsValue("four")); - Assert.assertTrue(map.containsValue("five")); - Assert.assertFalse(map.containsValue("six")); + Assertions.assertTrue(map.containsValue("one")); + Assertions.assertTrue(map.containsValue("two")); + Assertions.assertFalse(map.containsValue("three")); + Assertions.assertTrue(map.containsValue("four")); + Assertions.assertTrue(map.containsValue("five")); + Assertions.assertFalse(map.containsValue("six")); } @Test @@ -167,13 +167,13 @@ void testPutAll_IdMap() { map.putAll(map2); - Assert.assertEquals(4, map.size()); + Assertions.assertEquals(4, map.size()); - Assert.assertEquals("one", map.get(Id.create(1, Person.class))); - Assert.assertEquals("two", map.get(Id.create(2, Person.class))); - Assert.assertNull(map.get(Id.create(3, Person.class))); - Assert.assertEquals("four", map.get(Id.create(4, Person.class))); - Assert.assertEquals("five", map.get(Id.create(5, Person.class))); + Assertions.assertEquals("one", map.get(Id.create(1, Person.class))); + Assertions.assertEquals("two", map.get(Id.create(2, Person.class))); + Assertions.assertNull(map.get(Id.create(3, Person.class))); + Assertions.assertEquals("four", map.get(Id.create(4, Person.class))); + Assertions.assertEquals("five", map.get(Id.create(5, Person.class))); } @Test @@ -189,13 +189,13 @@ void testPutAll_GenericMap() { map.putAll(map2); - Assert.assertEquals(4, map.size()); + Assertions.assertEquals(4, map.size()); - Assert.assertEquals("one", map.get(Id.create(1, Person.class))); - Assert.assertEquals("two", map.get(Id.create(2, Person.class))); - Assert.assertNull(map.get(Id.create(3, Person.class))); - Assert.assertEquals("four", map.get(Id.create(4, Person.class))); - Assert.assertEquals("five", map.get(Id.create(5, Person.class))); + Assertions.assertEquals("one", map.get(Id.create(1, Person.class))); + Assertions.assertEquals("two", map.get(Id.create(2, Person.class))); + Assertions.assertNull(map.get(Id.create(3, Person.class))); + Assertions.assertEquals("four", map.get(Id.create(4, Person.class))); + Assertions.assertEquals("five", map.get(Id.create(5, Person.class))); } @Test @@ -208,17 +208,17 @@ void testClear() { map.put(Id.create(4, Person.class), "four"); map.put(Id.create(5, Person.class), "five"); - Assert.assertEquals(4, map.size()); + Assertions.assertEquals(4, map.size()); map.clear(); - Assert.assertEquals(0, map.size()); + Assertions.assertEquals(0, map.size()); - Assert.assertNull(map.get(Id.create(1, Person.class))); - Assert.assertNull(map.get(Id.create(2, Person.class))); - Assert.assertNull(map.get(Id.create(3, Person.class))); + Assertions.assertNull(map.get(Id.create(1, Person.class))); + Assertions.assertNull(map.get(Id.create(2, Person.class))); + Assertions.assertNull(map.get(Id.create(3, Person.class))); - Assert.assertFalse(map.containsKey(Id.create(1, Person.class))); + Assertions.assertFalse(map.containsKey(Id.create(1, Person.class))); } @Test @@ -232,28 +232,28 @@ void testValues() { map.put(Id.create(5, Person.class), "five"); Collection coll = map.values(); - Assert.assertEquals(4, coll.size()); + Assertions.assertEquals(4, coll.size()); map.put(Id.create(6, Person.class), "six"); - Assert.assertEquals(5, coll.size()); + Assertions.assertEquals(5, coll.size()); - Assert.assertTrue(coll.remove("one")); - Assert.assertFalse(coll.remove("null")); + Assertions.assertTrue(coll.remove("one")); + Assertions.assertFalse(coll.remove("null")); - Assert.assertFalse(map.containsValue("one")); - Assert.assertTrue(map.containsValue("two")); + Assertions.assertFalse(map.containsValue("one")); + Assertions.assertTrue(map.containsValue("two")); - Assert.assertTrue(coll.contains("two")); - Assert.assertFalse(coll.contains("one")); + Assertions.assertTrue(coll.contains("two")); + Assertions.assertFalse(coll.contains("one")); Set values = new HashSet<>(); coll.forEach(v -> values.add(v)); - Assert.assertEquals(4, values.size()); - Assert.assertTrue(values.contains("two")); - Assert.assertTrue(values.contains("four")); - Assert.assertTrue(values.contains("five")); - Assert.assertTrue(values.contains("six")); + Assertions.assertEquals(4, values.size()); + Assertions.assertTrue(values.contains("two")); + Assertions.assertTrue(values.contains("four")); + Assertions.assertTrue(values.contains("five")); + Assertions.assertTrue(values.contains("six")); } @Test @@ -273,28 +273,28 @@ void testKeySet() { map.put(id5, "five"); Set> set = map.keySet(); - Assert.assertEquals(4, set.size()); + Assertions.assertEquals(4, set.size()); map.put(id6, "six"); - Assert.assertEquals(5, set.size()); + Assertions.assertEquals(5, set.size()); - Assert.assertTrue(set.remove(id1)); - Assert.assertFalse(set.remove(id3)); + Assertions.assertTrue(set.remove(id1)); + Assertions.assertFalse(set.remove(id3)); - Assert.assertFalse(map.containsKey(id1)); - Assert.assertTrue(map.containsKey(id2)); + Assertions.assertFalse(map.containsKey(id1)); + Assertions.assertTrue(map.containsKey(id2)); - Assert.assertTrue(set.contains(id2)); - Assert.assertFalse(set.contains(id1)); + Assertions.assertTrue(set.contains(id2)); + Assertions.assertFalse(set.contains(id1)); Set> keys = new HashSet<>(); set.forEach(k -> keys.add(k)); - Assert.assertEquals(4, keys.size()); - Assert.assertTrue(keys.contains(id2)); - Assert.assertTrue(keys.contains(id4)); - Assert.assertTrue(keys.contains(id5)); - Assert.assertTrue(keys.contains(id6)); + Assertions.assertEquals(4, keys.size()); + Assertions.assertTrue(keys.contains(id2)); + Assertions.assertTrue(keys.contains(id4)); + Assertions.assertTrue(keys.contains(id5)); + Assertions.assertTrue(keys.contains(id6)); } @Test @@ -314,10 +314,10 @@ void testEntrySet() { map.put(id5, "five"); Set, String>> set = map.entrySet(); - Assert.assertEquals(4, set.size()); + Assertions.assertEquals(4, set.size()); map.put(id6, "six"); - Assert.assertEquals(5, set.size()); + Assertions.assertEquals(5, set.size()); Map, Map.Entry, String>> entries = new HashMap<>(); @@ -325,30 +325,30 @@ void testEntrySet() { entries.put(e.getKey(), e); } - Assert.assertEquals(id1, entries.get(id1).getKey()); - Assert.assertEquals("one", entries.get(id1).getValue()); - Assert.assertEquals("two", entries.get(id2).getValue()); - Assert.assertEquals("four", entries.get(id4).getValue()); - Assert.assertEquals("five", entries.get(id5).getValue()); + Assertions.assertEquals(id1, entries.get(id1).getKey()); + Assertions.assertEquals("one", entries.get(id1).getValue()); + Assertions.assertEquals("two", entries.get(id2).getValue()); + Assertions.assertEquals("four", entries.get(id4).getValue()); + Assertions.assertEquals("five", entries.get(id5).getValue()); - Assert.assertTrue(set.remove(entries.get(id1))); - Assert.assertFalse(set.remove(new Object())); + Assertions.assertTrue(set.remove(entries.get(id1))); + Assertions.assertFalse(set.remove(new Object())); - Assert.assertFalse(map.containsKey(id1)); - Assert.assertTrue(map.containsKey(id2)); + Assertions.assertFalse(map.containsKey(id1)); + Assertions.assertTrue(map.containsKey(id2)); - Assert.assertTrue(set.contains(entries.get(id2))); - Assert.assertFalse(set.contains(entries.get(id1))); + Assertions.assertTrue(set.contains(entries.get(id2))); + Assertions.assertFalse(set.contains(entries.get(id1))); // test forEach Set, String>> es = new HashSet<>(); set.forEach(k -> es.add(k)); - Assert.assertEquals(4, es.size()); - Assert.assertTrue(es.contains(entries.get(id2))); - Assert.assertTrue(es.contains(entries.get(id4))); - Assert.assertTrue(es.contains(entries.get(id5))); - Assert.assertTrue(es.contains(entries.get(id6))); + Assertions.assertEquals(4, es.size()); + Assertions.assertTrue(es.contains(entries.get(id2))); + Assertions.assertTrue(es.contains(entries.get(id4))); + Assertions.assertTrue(es.contains(entries.get(id5))); + Assertions.assertTrue(es.contains(entries.get(id6))); } @Test @@ -368,28 +368,28 @@ void testIterator_iterate() { map.put(id5, "five"); Iterator iter = map.iterator(); - Assert.assertNotNull(iter); + Assertions.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("one", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("one", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("two", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("two", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("four", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("four", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("five", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("five", iter.next()); - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); try { iter.next(); - Assert.fail("Expected exception, got none."); + Assertions.fail("Expected exception, got none."); } catch (NoSuchElementException ignore) { } - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); } @Test @@ -409,24 +409,24 @@ void testIterator_remove() { map.put(id5, "five"); Iterator iter = map.iterator(); - Assert.assertNotNull(iter); + Assertions.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("one", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("one", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("two", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("two", iter.next()); iter.remove(); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("four", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("four", iter.next()); - Assert.assertEquals(3, map.size()); - Assert.assertTrue(map.containsValue("one")); - Assert.assertFalse(map.containsValue("two")); - Assert.assertTrue(map.containsValue("four")); - Assert.assertTrue(map.containsValue("five")); + Assertions.assertEquals(3, map.size()); + Assertions.assertTrue(map.containsValue("one")); + Assertions.assertFalse(map.containsValue("two")); + Assertions.assertTrue(map.containsValue("four")); + Assertions.assertTrue(map.containsValue("five")); } @Test @@ -446,10 +446,10 @@ void testKeySetToArray() { map.put(id5, "five"); Id[] array = (Id[]) map.keySet().toArray(); - Assert.assertEquals(id1, array[0]); - Assert.assertEquals(id2, array[1]); - Assert.assertEquals(id4, array[2]); - Assert.assertEquals(id5, array[3]); + Assertions.assertEquals(id1, array[0]); + Assertions.assertEquals(id2, array[1]); + Assertions.assertEquals(id4, array[2]); + Assertions.assertEquals(id5, array[3]); } @@ -466,37 +466,37 @@ void testEqualsAndHashCode() { IdMap mapB = new IdMap<>(Person.class, 4); IdMap mapC = new IdMap<>(Person.class, 10); - Assert.assertEquals(mapA, mapA); - Assert.assertEquals(mapA, mapB); - Assert.assertEquals(mapA, mapC); - Assert.assertEquals(mapA.hashCode(), mapB.hashCode()); - Assert.assertEquals(mapA.hashCode(), mapC.hashCode()); + Assertions.assertEquals(mapA, mapA); + Assertions.assertEquals(mapA, mapB); + Assertions.assertEquals(mapA, mapC); + Assertions.assertEquals(mapA.hashCode(), mapB.hashCode()); + Assertions.assertEquals(mapA.hashCode(), mapC.hashCode()); mapA.put(id1, "one"); mapB.put(id1, "one"); - Assert.assertEquals(mapA, mapA); - Assert.assertEquals(mapA, mapB); - Assert.assertNotEquals(mapA, mapC); - Assert.assertEquals(mapA.hashCode(), mapB.hashCode()); - Assert.assertNotEquals(mapA.hashCode(), mapC.hashCode()); + Assertions.assertEquals(mapA, mapA); + Assertions.assertEquals(mapA, mapB); + Assertions.assertNotEquals(mapA, mapC); + Assertions.assertEquals(mapA.hashCode(), mapB.hashCode()); + Assertions.assertNotEquals(mapA.hashCode(), mapC.hashCode()); mapC.put(id1, "one"); - Assert.assertEquals(mapA, mapC); - Assert.assertEquals(mapA.hashCode(), mapC.hashCode()); + Assertions.assertEquals(mapA, mapC); + Assertions.assertEquals(mapA.hashCode(), mapC.hashCode()); mapA.put(id2, "two"); mapB.put(id3, "three"); - Assert.assertNotEquals(mapA, mapB); - Assert.assertNotEquals(mapA.hashCode(), mapB.hashCode()); + Assertions.assertNotEquals(mapA, mapB); + Assertions.assertNotEquals(mapA.hashCode(), mapB.hashCode()); mapA.put(id3, "three"); mapB.put(id2, "two"); - Assert.assertEquals(mapA, mapB); - Assert.assertEquals(mapA.hashCode(), mapB.hashCode()); + Assertions.assertEquals(mapA, mapB); + Assertions.assertEquals(mapA.hashCode(), mapB.hashCode()); mapA.put(id4, "four"); mapA.put(id5, "five"); @@ -505,39 +505,39 @@ void testEqualsAndHashCode() { mapA.remove(id5, "five"); mapA.remove(id6, "six"); - Assert.assertEquals(mapA, mapB); - Assert.assertEquals(mapA.hashCode(), mapB.hashCode()); + Assertions.assertEquals(mapA, mapB); + Assertions.assertEquals(mapA.hashCode(), mapB.hashCode()); - Assert.assertEquals(mapA.entrySet(), mapB.entrySet()); - Assert.assertEquals(mapA.entrySet().hashCode(), mapB.entrySet().hashCode()); - Assert.assertEquals(mapA.keySet(), mapB.keySet()); - Assert.assertEquals(mapA.keySet().hashCode(), mapB.keySet().hashCode()); + Assertions.assertEquals(mapA.entrySet(), mapB.entrySet()); + Assertions.assertEquals(mapA.entrySet().hashCode(), mapB.entrySet().hashCode()); + Assertions.assertEquals(mapA.keySet(), mapB.keySet()); + Assertions.assertEquals(mapA.keySet().hashCode(), mapB.keySet().hashCode()); mapA.put(id4, "four"); mapB.put(id4, "DifferentFour"); - Assert.assertNotEquals(mapA, mapB); - Assert.assertNotEquals(mapA.hashCode(), mapB.hashCode()); + Assertions.assertNotEquals(mapA, mapB); + Assertions.assertNotEquals(mapA.hashCode(), mapB.hashCode()); - Assert.assertNotEquals(mapA.entrySet(), mapB.entrySet()); - Assert.assertNotEquals(mapA.entrySet().hashCode(), mapB.entrySet().hashCode()); - Assert.assertEquals(mapA.keySet(), mapB.keySet()); - Assert.assertEquals(mapA.keySet().hashCode(), mapB.keySet().hashCode()); + Assertions.assertNotEquals(mapA.entrySet(), mapB.entrySet()); + Assertions.assertNotEquals(mapA.entrySet().hashCode(), mapB.entrySet().hashCode()); + Assertions.assertEquals(mapA.keySet(), mapB.keySet()); + Assertions.assertEquals(mapA.keySet().hashCode(), mapB.keySet().hashCode()); HashMap, String> hMapA = new HashMap, String>(mapA); // The commented out tests will fail right now because the hashCode of IdImpl is based on the id, not the index - Assert.assertEquals(hMapA, mapA); + Assertions.assertEquals(hMapA, mapA); // Assert.assertEquals(hMapA.hashCode(), mapA.hashCode()); - Assert.assertEquals(hMapA.entrySet(), mapA.entrySet()); + Assertions.assertEquals(hMapA.entrySet(), mapA.entrySet()); // Assert.assertEquals(hMapA.entrySet().hashCode(), mapA.entrySet().hashCode()); - Assert.assertEquals(hMapA.keySet(), mapA.keySet()); + Assertions.assertEquals(hMapA.keySet(), mapA.keySet()); // Assert.assertEquals(hMapA.keySet().hashCode(), mapA.keySet().hashCode()); - Assert.assertNotEquals(hMapA, mapB); - Assert.assertNotEquals(hMapA.hashCode(), mapB.hashCode()); - Assert.assertNotEquals(hMapA.entrySet(), mapB.entrySet()); - Assert.assertNotEquals(hMapA.entrySet().hashCode(), mapB.entrySet().hashCode()); - Assert.assertEquals(hMapA.keySet(), mapB.keySet()); + Assertions.assertNotEquals(hMapA, mapB); + Assertions.assertNotEquals(hMapA.hashCode(), mapB.hashCode()); + Assertions.assertNotEquals(hMapA.entrySet(), mapB.entrySet()); + Assertions.assertNotEquals(hMapA.entrySet().hashCode(), mapB.entrySet().hashCode()); + Assertions.assertEquals(hMapA.keySet(), mapB.keySet()); // Assert.assertEquals(hMapA.keySet().hashCode(), mapB.keySet().hashCode()); // Best way I could think of to explicitly test the equals() of Entry (i.e. not inside the EntrySet) @@ -545,11 +545,11 @@ void testEqualsAndHashCode() { while (iter.hasNext()) { Entry, String> e = iter.next(); if (e.getKey() != id4) { - Assert.assertTrue(mapB.entrySet().contains(e)); + Assertions.assertTrue(mapB.entrySet().contains(e)); } else { - Assert.assertFalse(mapB.entrySet().contains(e)); + Assertions.assertFalse(mapB.entrySet().contains(e)); } - Assert.assertTrue(hMapA.entrySet().contains(e)); + Assertions.assertTrue(hMapA.entrySet().contains(e)); } } diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdSetTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdSetTest.java index 63bee1c218d..02629f3f0dc 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdSetTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdSetTest.java @@ -1,6 +1,6 @@ package org.matsim.api.core.v01; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.Person; @@ -23,36 +23,36 @@ void testAddContainsRemoveSize() { Id id3 = Id.create("3", Person.class); Id id4 = Id.create("4", Person.class); - Assert.assertEquals(0, set.size()); - Assert.assertTrue(set.isEmpty()); - - Assert.assertTrue(set.add(id1)); - Assert.assertEquals(1, set.size()); - Assert.assertFalse(set.isEmpty()); - Assert.assertTrue(set.contains(id1)); - Assert.assertFalse(set.contains(id2)); - Assert.assertTrue(set.contains(id1.index())); - Assert.assertFalse(set.contains(id2.index())); - - Assert.assertFalse(set.add(id1)); - Assert.assertEquals(1, set.size()); - - Assert.assertTrue(set.add(id3)); - Assert.assertEquals(2, set.size()); - Assert.assertTrue(set.contains(id1)); - Assert.assertFalse(set.contains(id2)); - Assert.assertTrue(set.contains(id3)); - Assert.assertTrue(set.contains(id1.index())); - Assert.assertFalse(set.contains(id2.index())); - Assert.assertTrue(set.contains(id3.index())); - - Assert.assertFalse(set.remove(id4)); - Assert.assertEquals(2, set.size()); - - Assert.assertTrue(set.remove(id1)); - Assert.assertEquals(1, set.size()); - Assert.assertFalse(set.remove(id1)); - Assert.assertEquals(1, set.size()); + Assertions.assertEquals(0, set.size()); + Assertions.assertTrue(set.isEmpty()); + + Assertions.assertTrue(set.add(id1)); + Assertions.assertEquals(1, set.size()); + Assertions.assertFalse(set.isEmpty()); + Assertions.assertTrue(set.contains(id1)); + Assertions.assertFalse(set.contains(id2)); + Assertions.assertTrue(set.contains(id1.index())); + Assertions.assertFalse(set.contains(id2.index())); + + Assertions.assertFalse(set.add(id1)); + Assertions.assertEquals(1, set.size()); + + Assertions.assertTrue(set.add(id3)); + Assertions.assertEquals(2, set.size()); + Assertions.assertTrue(set.contains(id1)); + Assertions.assertFalse(set.contains(id2)); + Assertions.assertTrue(set.contains(id3)); + Assertions.assertTrue(set.contains(id1.index())); + Assertions.assertFalse(set.contains(id2.index())); + Assertions.assertTrue(set.contains(id3.index())); + + Assertions.assertFalse(set.remove(id4)); + Assertions.assertEquals(2, set.size()); + + Assertions.assertTrue(set.remove(id1)); + Assertions.assertEquals(1, set.size()); + Assertions.assertFalse(set.remove(id1)); + Assertions.assertEquals(1, set.size()); } @Test @@ -69,17 +69,17 @@ void testIterator() { set.add(id1); Iterator> iter = set.iterator(); - Assert.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(id1, iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(id2, iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(id4, iter.next()); - Assert.assertFalse(iter.hasNext()); + Assertions.assertNotNull(iter); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(id1, iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(id2, iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(id4, iter.next()); + Assertions.assertFalse(iter.hasNext()); try { iter.next(); - Assert.fail("expected NoSuchElementException, got none."); + Assertions.fail("expected NoSuchElementException, got none."); } catch (NoSuchElementException ignore) { } } @@ -99,14 +99,14 @@ void testClear() { set.add(id1); set.add(id4); - Assert.assertEquals(3, set.size()); + Assertions.assertEquals(3, set.size()); set.clear(); - Assert.assertEquals(0, set.size()); - Assert.assertTrue(set.isEmpty()); + Assertions.assertEquals(0, set.size()); + Assertions.assertTrue(set.isEmpty()); - Assert.assertFalse(set.iterator().hasNext()); + Assertions.assertFalse(set.iterator().hasNext()); } @Test @@ -129,16 +129,16 @@ void testAddAll() { set2.add(id4); set2.add(id5); - Assert.assertTrue(set1.addAll(set2)); + Assertions.assertTrue(set1.addAll(set2)); - Assert.assertTrue(set1.contains(id1)); - Assert.assertTrue(set1.contains(id3)); - Assert.assertTrue(set1.contains(id4)); - Assert.assertTrue(set1.contains(id5)); - Assert.assertTrue(set1.contains(id6)); - Assert.assertEquals(5, set1.size()); + Assertions.assertTrue(set1.contains(id1)); + Assertions.assertTrue(set1.contains(id3)); + Assertions.assertTrue(set1.contains(id4)); + Assertions.assertTrue(set1.contains(id5)); + Assertions.assertTrue(set1.contains(id6)); + Assertions.assertEquals(5, set1.size()); - Assert.assertFalse(set1.addAll(set2)); + Assertions.assertFalse(set1.addAll(set2)); } @Test @@ -161,15 +161,15 @@ void testRemoveAll() { set2.add(id4); set2.add(id5); - Assert.assertTrue(set1.removeAll(set2)); + Assertions.assertTrue(set1.removeAll(set2)); - Assert.assertTrue(set1.contains(id1)); - Assert.assertFalse(set1.contains(id2)); - Assert.assertTrue(set1.contains(id3)); - Assert.assertFalse(set1.contains(id4)); - Assert.assertFalse(set1.contains(id5)); - Assert.assertFalse(set1.contains(id6)); - Assert.assertEquals(2, set1.size()); + Assertions.assertTrue(set1.contains(id1)); + Assertions.assertFalse(set1.contains(id2)); + Assertions.assertTrue(set1.contains(id3)); + Assertions.assertFalse(set1.contains(id4)); + Assertions.assertFalse(set1.contains(id5)); + Assertions.assertFalse(set1.contains(id6)); + Assertions.assertEquals(2, set1.size()); } @Test @@ -192,16 +192,16 @@ void testRetainAll() { set2.add(id4); set2.add(id5); - Assert.assertTrue(set1.retainAll(set2)); + Assertions.assertTrue(set1.retainAll(set2)); - Assert.assertFalse(set1.contains(id1)); - Assert.assertFalse(set1.contains(id2)); - Assert.assertFalse(set1.contains(id3)); - Assert.assertTrue(set1.contains(id4)); - Assert.assertFalse(set1.contains(id5)); - Assert.assertFalse(set1.contains(id6)); + Assertions.assertFalse(set1.contains(id1)); + Assertions.assertFalse(set1.contains(id2)); + Assertions.assertFalse(set1.contains(id3)); + Assertions.assertTrue(set1.contains(id4)); + Assertions.assertFalse(set1.contains(id5)); + Assertions.assertFalse(set1.contains(id6)); - Assert.assertEquals(1, set1.size()); + Assertions.assertEquals(1, set1.size()); } @Test @@ -224,12 +224,12 @@ void testContainsAll() { set2.add(id4); set2.add(id5); - Assert.assertFalse(set1.containsAll(set2)); + Assertions.assertFalse(set1.containsAll(set2)); set1.add(id5); set1.add(id6); - Assert.assertTrue(set1.containsAll(set2)); + Assertions.assertTrue(set1.containsAll(set2)); } @Test @@ -249,22 +249,22 @@ void testToArray() { Id[] array1 = set.toArray(); - Assert.assertEquals(3, array1.length); + Assertions.assertEquals(3, array1.length); Id tmp = array1[0]; for (int i = 1; i < array1.length; i++) { if (tmp.index() > array1[i].index()) { - Assert.fail(); + Assertions.fail(); } else { tmp = array1[i]; } } Id[] array2 = set.toArray((Id[]) new Id[3]); - Assert.assertEquals(3, array2.length); + Assertions.assertEquals(3, array2.length); tmp = array2[0]; for (int i = 1; i < array2.length; i++) { if (tmp.index() > array2[i].index()) { - Assert.fail(); + Assertions.fail(); } else { tmp = array2[i]; } @@ -277,24 +277,24 @@ void testToArray() { tmpArray[3] = id2; tmpArray[4] = id1; Id[] array3 = set.toArray(tmpArray); - Assert.assertEquals(5, array3.length); + Assertions.assertEquals(5, array3.length); tmp = array3[0]; for (int i = 1; i < array1.length; i++) { if (tmp.index() > array3[i].index()) { - Assert.fail(); + Assertions.fail(); } else { tmp = array3[i]; } } - Assert.assertNull(array3[3]); - Assert.assertNull(array3[4]); + Assertions.assertNull(array3[3]); + Assertions.assertNull(array3[4]); Id[] array4 = set.toArray((Id[]) new Id[1]); // too small - Assert.assertEquals(3, array4.length); + Assertions.assertEquals(3, array4.length); tmp = array4[0]; for (int i = 1; i < array4.length; i++) { if (tmp.index() > array4[i].index()) { - Assert.fail(); + Assertions.fail(); } else { tmp = array4[i]; } @@ -314,33 +314,33 @@ void testEqualsAndHashCode() { IdSet setB = new IdSet<>(Person.class, 4); IdSet setWrongType = new IdSet<>(Link.class, 4); - Assert.assertEquals(setA, setA); - Assert.assertEquals(setA, setB); - Assert.assertNotEquals(setA, setWrongType); + Assertions.assertEquals(setA, setA); + Assertions.assertEquals(setA, setB); + Assertions.assertNotEquals(setA, setWrongType); setA.add(id1); - Assert.assertEquals(setA, setA); - Assert.assertNotEquals(setA, setB); - Assert.assertEquals(setA.hashCode(), setA.hashCode()); - Assert.assertNotEquals(setA.hashCode(), setB.hashCode()); + Assertions.assertEquals(setA, setA); + Assertions.assertNotEquals(setA, setB); + Assertions.assertEquals(setA.hashCode(), setA.hashCode()); + Assertions.assertNotEquals(setA.hashCode(), setB.hashCode()); setB.add(id1); - Assert.assertEquals(setA, setB); - Assert.assertEquals(setA.hashCode(), setB.hashCode()); + Assertions.assertEquals(setA, setB); + Assertions.assertEquals(setA.hashCode(), setB.hashCode()); setA.add(id2); setA.add(id3); - Assert.assertNotEquals(setA, setB); - Assert.assertNotEquals(setA.hashCode(), setB.hashCode()); + Assertions.assertNotEquals(setA, setB); + Assertions.assertNotEquals(setA.hashCode(), setB.hashCode()); setB.add(id3); setB.add(id2); - Assert.assertEquals(setA, setB); - Assert.assertEquals(setA.hashCode(), setB.hashCode()); + Assertions.assertEquals(setA, setB); + Assertions.assertEquals(setA.hashCode(), setB.hashCode()); setA.add(id4); setA.add(id5); @@ -349,16 +349,16 @@ void testEqualsAndHashCode() { setA.remove(id5); setA.remove(id6); - Assert.assertEquals(setA, setB); - Assert.assertEquals(setA.hashCode(), setB.hashCode()); + Assertions.assertEquals(setA, setB); + Assertions.assertEquals(setA.hashCode(), setB.hashCode()); setA.add(id4); HashSet> hSetA = new HashSet>(setA); - Assert.assertEquals(hSetA, setA); - Assert.assertNotEquals(hSetA, setB); + Assertions.assertEquals(hSetA, setA); + Assertions.assertNotEquals(hSetA, setB); // Assert.assertEquals(hSetA.hashCode(), setA.hashCode()); // this does not work yet because the hashCode() of IdImpl still uses id instead of index - Assert.assertNotEquals(hSetA.hashCode(), setB.hashCode()); + Assertions.assertNotEquals(hSetA.hashCode(), setB.hashCode()); } } diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdTest.java index 77bc2676621..1b52880e52d 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdTest.java @@ -22,14 +22,14 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.utils.collections.Tuple; import java.util.ArrayList; import java.util.List; - public class IdTest { + public class IdTest { private final static Logger LOG = LogManager.getLogger(IdTest.class); @@ -38,8 +38,8 @@ void testConstructor() { Id linkId1 = Id.create("1", TLink.class); Id linkId2 = Id.create("2", TLink.class); - Assert.assertEquals("1", linkId1.toString()); - Assert.assertEquals("2", linkId2.toString()); + Assertions.assertEquals("1", linkId1.toString()); + Assertions.assertEquals("2", linkId2.toString()); } @Test @@ -47,13 +47,13 @@ void testIdConstructor() { Id nodeId1 = Id.create("1", TNode.class); Id linkId1 = Id.create(nodeId1, TLink.class); - Assert.assertEquals("1", linkId1.toString()); + Assertions.assertEquals("1", linkId1.toString()); } @Test void testIdConstructor_Null() { Id linkId1 = Id.create((Id) null, TLink.class); - Assert.assertNull(linkId1); + Assertions.assertNull(linkId1); } @Test @@ -62,8 +62,8 @@ void testObjectIdentity_cache() { Id linkId2 = Id.create("2", TLink.class); Id linkId1again = Id.create("1", TLink.class); - Assert.assertTrue(linkId1 == linkId1again); - Assert.assertFalse(linkId1 == linkId2); + Assertions.assertTrue(linkId1 == linkId1again); + Assertions.assertFalse(linkId1 == linkId2); } @Test @@ -71,7 +71,7 @@ void testObjectIdentity_types() { Id linkId1 = Id.create("1", TLink.class); Id nodeId1 = Id.create("1", TNode.class); - Assert.assertFalse((Id) linkId1 == (Id) nodeId1); + Assertions.assertFalse((Id) linkId1 == (Id) nodeId1); } @Test @@ -81,10 +81,10 @@ void testCompareTo() { Id linkId1again = Id.create("1", TLink.class); Id nodeId1 = Id.create("1", TNode.class); - Assert.assertTrue(linkId1.compareTo(linkId2) < 0); - Assert.assertTrue(linkId1.compareTo(linkId1) == 0); - Assert.assertTrue(linkId1.compareTo(linkId1again) == 0); - Assert.assertTrue(linkId2.compareTo(linkId1) > 0); + Assertions.assertTrue(linkId1.compareTo(linkId2) < 0); + Assertions.assertTrue(linkId1.compareTo(linkId1) == 0); + Assertions.assertTrue(linkId1.compareTo(linkId1again) == 0); + Assertions.assertTrue(linkId2.compareTo(linkId1) > 0); // try { // Assert.assertTrue(linkId1.compareTo((Id) nodeId1) == 0); @@ -99,20 +99,20 @@ void testResetCaches() { Id.create("1", TLink.class); Id.create("2", TLink.class); int count = Id.getNumberOfIds(TLink.class); - Assert.assertTrue(count > 0); // it might be > 2 if other tests have run before creating Ids of this class + Assertions.assertTrue(count > 0); // it might be > 2 if other tests have run before creating Ids of this class Id.resetCaches(); - Assert.assertEquals(0, Id.getNumberOfIds(TLink.class)); + Assertions.assertEquals(0, Id.getNumberOfIds(TLink.class)); Id.create("1", TLink.class); Id.create("2", TLink.class); Id.create("3", TLink.class); - Assert.assertEquals(3, Id.getNumberOfIds(TLink.class)); + Assertions.assertEquals(3, Id.getNumberOfIds(TLink.class)); } @Test void testResetCaches_onlyFromJUnit() throws InterruptedException { Id.create("1", TLink.class); int countBefore = Id.getNumberOfIds(TLink.class); - Assert.assertTrue(countBefore > 0); + Assertions.assertTrue(countBefore > 0); Runnable runnable = () -> { Id.resetCaches(); @@ -129,9 +129,9 @@ void testResetCaches_onlyFromJUnit() throws InterruptedException { LOG.info("Caught exception: " + t.getSecond().getMessage()); } - Assert.assertFalse("There should have be an exception!", caughtExceptions.isEmpty()); + Assertions.assertFalse(caughtExceptions.isEmpty(), "There should have be an exception!"); int countAfter = Id.getNumberOfIds(TLink.class); - Assert.assertEquals("The number of created Ids should not have changed.", countBefore, countAfter); + Assertions.assertEquals(countBefore, countAfter, "The number of created Ids should not have changed."); } private static class TLink {} diff --git a/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java b/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java index c6e62203b22..4900e6a3ae9 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/NetworkCreationTest.java @@ -19,8 +19,8 @@ * *********************************************************************** */ package org.matsim.api.core.v01; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/api/core/v01/network/AbstractNetworkTest.java b/matsim/src/test/java/org/matsim/api/core/v01/network/AbstractNetworkTest.java index 0e52b8b0594..c0dc3f0f4ef 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/network/AbstractNetworkTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/network/AbstractNetworkTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -41,57 +41,57 @@ public abstract class AbstractNetworkTest { void removeLink() { Fixture f = new Fixture(getEmptyTestNetwork()); - Assert.assertTrue(f.network.getLinks().containsKey(f.linkIds[1])); - Assert.assertEquals(1, f.network.getNodes().get(f.nodeIds[1]).getInLinks().size()); + Assertions.assertTrue(f.network.getLinks().containsKey(f.linkIds[1])); + Assertions.assertEquals(1, f.network.getNodes().get(f.nodeIds[1]).getInLinks().size()); f.network.removeLink(f.linkIds[1]); - Assert.assertFalse(f.network.getLinks().containsKey(f.linkIds[1])); - Assert.assertEquals(0, f.network.getNodes().get(f.nodeIds[1]).getInLinks().size()); - Assert.assertEquals(1, f.network.getNodes().get(f.nodeIds[1]).getOutLinks().size()); + Assertions.assertFalse(f.network.getLinks().containsKey(f.linkIds[1])); + Assertions.assertEquals(0, f.network.getNodes().get(f.nodeIds[1]).getInLinks().size()); + Assertions.assertEquals(1, f.network.getNodes().get(f.nodeIds[1]).getOutLinks().size()); - Assert.assertTrue(f.network.getLinks().containsKey(f.linkIds[2])); + Assertions.assertTrue(f.network.getLinks().containsKey(f.linkIds[2])); f.network.removeLink(f.linkIds[2]); - Assert.assertFalse(f.network.getLinks().containsKey(f.linkIds[2])); + Assertions.assertFalse(f.network.getLinks().containsKey(f.linkIds[2])); - Assert.assertTrue(f.network.getNodes().containsKey(f.nodeIds[1])); - Assert.assertEquals(0, f.network.getNodes().get(f.nodeIds[1]).getOutLinks().size()); + Assertions.assertTrue(f.network.getNodes().containsKey(f.nodeIds[1])); + Assertions.assertEquals(0, f.network.getNodes().get(f.nodeIds[1]).getOutLinks().size()); - Assert.assertEquals(2, f.network.getNodes().get(f.nodeIds[5]).getOutLinks().size()); - Assert.assertEquals(2, f.network.getNodes().get(f.nodeIds[8]).getInLinks().size()); + Assertions.assertEquals(2, f.network.getNodes().get(f.nodeIds[5]).getOutLinks().size()); + Assertions.assertEquals(2, f.network.getNodes().get(f.nodeIds[8]).getInLinks().size()); f.network.removeLink(f.linkIds[10]); - Assert.assertEquals(1, f.network.getNodes().get(f.nodeIds[5]).getOutLinks().size()); - Assert.assertEquals(1, f.network.getNodes().get(f.nodeIds[8]).getInLinks().size()); + Assertions.assertEquals(1, f.network.getNodes().get(f.nodeIds[5]).getOutLinks().size()); + Assertions.assertEquals(1, f.network.getNodes().get(f.nodeIds[8]).getInLinks().size()); } @Test void removeNode() { Fixture f = new Fixture(getEmptyTestNetwork()); - Assert.assertEquals(8, f.network.getNodes().size()); - Assert.assertEquals(12, f.network.getLinks().size()); - Assert.assertTrue(f.network.getLinks().containsKey(f.linkIds[1])); - Assert.assertTrue(f.network.getLinks().containsKey(f.linkIds[2])); - Assert.assertTrue(f.network.getNodes().containsKey(f.nodeIds[1])); + Assertions.assertEquals(8, f.network.getNodes().size()); + Assertions.assertEquals(12, f.network.getLinks().size()); + Assertions.assertTrue(f.network.getLinks().containsKey(f.linkIds[1])); + Assertions.assertTrue(f.network.getLinks().containsKey(f.linkIds[2])); + Assertions.assertTrue(f.network.getNodes().containsKey(f.nodeIds[1])); f.network.removeNode(f.nodeIds[1]); - Assert.assertEquals(7, f.network.getNodes().size()); - Assert.assertEquals(10, f.network.getLinks().size()); - Assert.assertFalse(f.network.getLinks().containsKey(f.linkIds[1])); - Assert.assertFalse(f.network.getLinks().containsKey(f.linkIds[2])); - Assert.assertFalse(f.network.getNodes().containsKey(f.nodeIds[1])); - Assert.assertFalse(f.network.getNodes().get(f.nodeIds[4]).getOutLinks().containsKey(f.linkIds[1])); - Assert.assertTrue(f.network.getNodes().get(f.nodeIds[4]).getOutLinks().containsKey(f.linkIds[5])); - Assert.assertTrue(f.network.getNodes().get(f.nodeIds[4]).getOutLinks().containsKey(f.linkIds[7])); + Assertions.assertEquals(7, f.network.getNodes().size()); + Assertions.assertEquals(10, f.network.getLinks().size()); + Assertions.assertFalse(f.network.getLinks().containsKey(f.linkIds[1])); + Assertions.assertFalse(f.network.getLinks().containsKey(f.linkIds[2])); + Assertions.assertFalse(f.network.getNodes().containsKey(f.nodeIds[1])); + Assertions.assertFalse(f.network.getNodes().get(f.nodeIds[4]).getOutLinks().containsKey(f.linkIds[1])); + Assertions.assertTrue(f.network.getNodes().get(f.nodeIds[4]).getOutLinks().containsKey(f.linkIds[5])); + Assertions.assertTrue(f.network.getNodes().get(f.nodeIds[4]).getOutLinks().containsKey(f.linkIds[7])); f.network.removeNode(f.nodeIds[8]); - Assert.assertEquals(6, f.network.getNodes().size()); - Assert.assertEquals(6, f.network.getLinks().size()); - Assert.assertFalse(f.network.getLinks().containsKey(f.linkIds[8])); - Assert.assertFalse(f.network.getLinks().containsKey(f.linkIds[9])); - Assert.assertFalse(f.network.getNodes().containsKey(f.nodeIds[10])); - Assert.assertFalse(f.network.getNodes().containsKey(f.nodeIds[11])); - Assert.assertFalse(f.network.getNodes().get(f.nodeIds[5]).getOutLinks().containsKey(f.linkIds[10])); - Assert.assertTrue(f.network.getNodes().get(f.nodeIds[5]).getOutLinks().containsKey(f.linkIds[6])); - Assert.assertFalse(f.network.getNodes().get(f.nodeIds[5]).getInLinks().containsKey(f.linkIds[9])); - Assert.assertTrue(f.network.getNodes().get(f.nodeIds[5]).getInLinks().containsKey(f.linkIds[3])); + Assertions.assertEquals(6, f.network.getNodes().size()); + Assertions.assertEquals(6, f.network.getLinks().size()); + Assertions.assertFalse(f.network.getLinks().containsKey(f.linkIds[8])); + Assertions.assertFalse(f.network.getLinks().containsKey(f.linkIds[9])); + Assertions.assertFalse(f.network.getNodes().containsKey(f.nodeIds[10])); + Assertions.assertFalse(f.network.getNodes().containsKey(f.nodeIds[11])); + Assertions.assertFalse(f.network.getNodes().get(f.nodeIds[5]).getOutLinks().containsKey(f.linkIds[10])); + Assertions.assertTrue(f.network.getNodes().get(f.nodeIds[5]).getOutLinks().containsKey(f.linkIds[6])); + Assertions.assertFalse(f.network.getNodes().get(f.nodeIds[5]).getInLinks().containsKey(f.linkIds[9])); + Assertions.assertTrue(f.network.getNodes().get(f.nodeIds[5]).getInLinks().containsKey(f.linkIds[3])); } /** diff --git a/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java b/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java index 8a5ea4b5d90..860317a57de 100644 --- a/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java +++ b/matsim/src/test/java/org/matsim/core/config/CommandLineTest.java @@ -2,7 +2,7 @@ import static org.junit.jupiter.api.Assertions.assertThrows; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -27,7 +27,7 @@ void testStandardUsage() { Config config = ConfigUtils.loadConfig( args ) ; CommandLine cmd = ConfigUtils.getCommandLine( args ); - Assert.assertEquals( "abc", cmd.getOption( "something" ).get() ); + Assertions.assertEquals( "abc", cmd.getOption( "something" ).get() ); } @@ -45,7 +45,7 @@ void testTypo() { Config config = ConfigUtils.loadConfig(args) ; CommandLine cmd = ConfigUtils.getCommandLine(args); - Assert.assertEquals("abc", cmd.getOption("someting").get()); + Assertions.assertEquals("abc", cmd.getOption("someting").get()); }); @@ -67,7 +67,7 @@ void testAdditionalConfigGroup() { String[] args = {configFilename, "--config:mockConfigGroup.abc=28"}; Config config = ConfigUtils.loadConfig( args ); MockConfigGroup mcg = ConfigUtils.addOrGetModule( config, MockConfigGroup.class ) ; - Assert.assertEquals( 28., mcg.getAbc(), 0. ); + Assertions.assertEquals( 28., mcg.getAbc(), 0. ); } } @@ -92,9 +92,9 @@ void testSetParameterInAllParameterSets() { String[] args = { configFilename, "--config:mockConfigGroup.mockSet[*=*].test=c" }; Config config = ConfigUtils.loadConfig(args); MockConfigGroup mockConfigGroup = ConfigUtils.addOrGetModule(config, MockConfigGroup.class); - Assert.assertEquals(2, mockConfigGroup.getParameterSets(MockParameterSet.SET_TYPE).size()); + Assertions.assertEquals(2, mockConfigGroup.getParameterSets(MockParameterSet.SET_TYPE).size()); for (ConfigGroup parameterSet : mockConfigGroup.getParameterSets(MockParameterSet.SET_TYPE)) { - Assert.assertEquals("c", ((MockParameterSet) parameterSet).test); + Assertions.assertEquals("c", ((MockParameterSet) parameterSet).test); } } } @@ -129,7 +129,7 @@ void testFixNotYetExistingAdditionalConfigGroup() { String[] args = {configFilename, "--config:mockConfigGroup.abc=28"}; Config config = ConfigUtils.loadConfig( args, new MockConfigGroup() ); MockConfigGroup mcg = ConfigUtils.addOrGetModule( config, MockConfigGroup.class ) ; - Assert.assertEquals( 28., mcg.getAbc(), 0. ); + Assertions.assertEquals( 28., mcg.getAbc(), 0. ); } } diff --git a/matsim/src/test/java/org/matsim/core/config/ConfigReaderMatsimV2Test.java b/matsim/src/test/java/org/matsim/core/config/ConfigReaderMatsimV2Test.java index 89bf12288d9..87f1f6e53fd 100644 --- a/matsim/src/test/java/org/matsim/core/config/ConfigReaderMatsimV2Test.java +++ b/matsim/src/test/java/org/matsim/core/config/ConfigReaderMatsimV2Test.java @@ -1,6 +1,6 @@ package org.matsim.core.config; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.config.groups.ControllerConfigGroup; @@ -33,7 +33,7 @@ void testModuleNameAlias() { r2.getConfigAliases().addAlias("theController", ControllerConfigGroup.GROUP_NAME); r2.readStream(bais); - Assert.assertEquals(27, config.controller().getLastIteration()); + Assertions.assertEquals(27, config.controller().getLastIteration()); } @Test @@ -54,8 +54,8 @@ void testModuleNameAlias_noOldModules() { r2.readStream(bais); - Assert.assertEquals(27, config.controller().getLastIteration()); - Assert.assertNull(config.getModules().get("controler")); + Assertions.assertEquals(27, config.controller().getLastIteration()); + Assertions.assertNull(config.getModules().get("controler")); } @Test @@ -77,7 +77,7 @@ void testParamNameAlias() { r2.getConfigAliases().addAlias("theLastIteration", "lastIteration"); r2.readStream(bais); - Assert.assertEquals(23, config.controller().getLastIteration()); + Assertions.assertEquals(23, config.controller().getLastIteration()); } @Test @@ -100,7 +100,7 @@ void testModuleAndParamNameAlias() { r2.getConfigAliases().addAlias("theLastIteration", "lastIteration"); r2.readStream(bais); - Assert.assertEquals(23, config.controller().getLastIteration()); + Assertions.assertEquals(23, config.controller().getLastIteration()); } /** @@ -132,8 +132,8 @@ void testConditionalParamNameAliasWithModuleRenaming() { r2.getConfigAliases().addAlias("input", "inputPlansFile", "plans"); r2.readStream(bais); - Assert.assertEquals("my_network.xml.gz", config.network().getInputFile()); - Assert.assertEquals("my_plans.xml.gz", config.plans().getInputFile()); + Assertions.assertEquals("my_network.xml.gz", config.network().getInputFile()); + Assertions.assertEquals("my_plans.xml.gz", config.plans().getInputFile()); } /** @@ -163,8 +163,8 @@ void testConditionalParamNameAlias() { r2.getConfigAliases().addAlias("input", "inputPlansFile", "plans"); r2.readStream(bais); - Assert.assertEquals("my_network.xml.gz", config.network().getInputFile()); - Assert.assertEquals("my_plans.xml.gz", config.plans().getInputFile()); + Assertions.assertEquals("my_network.xml.gz", config.network().getInputFile()); + Assertions.assertEquals("my_plans.xml.gz", config.plans().getInputFile()); } /** @@ -192,8 +192,8 @@ void testConditionalParamNameAlias2() { r2.getConfigAliases().addAlias("inputNetworkFile", "inputPlansFile", "plans"); r2.readStream(bais); - Assert.assertEquals("my_network.xml.gz", config.network().getInputFile()); - Assert.assertEquals("my_plans.xml.gz", config.plans().getInputFile()); + Assertions.assertEquals("my_network.xml.gz", config.network().getInputFile()); + Assertions.assertEquals("my_plans.xml.gz", config.plans().getInputFile()); } /** @@ -218,7 +218,7 @@ void testConditionalParamNameAlias3() { r2.getConfigAliases().addAlias("inputPlansFile", "input", "inexistant"); r2.readStream(bais); // if the alias were matched, it should produce an exception, as "input" is not known - Assert.assertEquals("my_plans.xml.gz", config.plans().getInputFile()); + Assertions.assertEquals("my_plans.xml.gz", config.plans().getInputFile()); } /** @@ -243,7 +243,7 @@ void testConditionalParamNameAlias4() { r2.getConfigAliases().addAlias("inputPlansFile", "input", "plans", "inexistant"); r2.readStream(bais); // if the alias were matched, it should produce an exception, as "input" is not known - Assert.assertEquals("my_plans.xml.gz", config.plans().getInputFile()); + Assertions.assertEquals("my_plans.xml.gz", config.plans().getInputFile()); } @@ -289,7 +289,7 @@ void testAliasWithParamSets() { r2.getConfigAliases().addAlias("theMode", "mode", "scoring", "scoringParameters", "modeParams"); r2.readStream(bais); - Assert.assertEquals(-5.6, config.scoring().getModes().get("car").getMarginalUtilityOfTraveling(), 1e-7); - Assert.assertEquals(-8.7, config.scoring().getModes().get("unicycle").getMarginalUtilityOfTraveling(), 1e-7); + Assertions.assertEquals(-5.6, config.scoring().getModes().get("car").getMarginalUtilityOfTraveling(), 1e-7); + Assertions.assertEquals(-8.7, config.scoring().getModes().get("unicycle").getMarginalUtilityOfTraveling(), 1e-7); } } diff --git a/matsim/src/test/java/org/matsim/core/config/ConfigTest.java b/matsim/src/test/java/org/matsim/core/config/ConfigTest.java index 07c481b7935..93dac756f89 100644 --- a/matsim/src/test/java/org/matsim/core/config/ConfigTest.java +++ b/matsim/src/test/java/org/matsim/core/config/ConfigTest.java @@ -21,7 +21,7 @@ import java.io.ByteArrayInputStream; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** @@ -36,8 +36,8 @@ void testAddModule_beforeLoading() { config.addModule(group); - Assert.assertNull(group.getA()); - Assert.assertNull(group.getB()); + Assertions.assertNull(group.getA()); + Assertions.assertNull(group.getB()); String str = "\n" + "\n" + @@ -49,8 +49,8 @@ void testAddModule_beforeLoading() { ""; new ConfigReader(config).parse(new ByteArrayInputStream(str.getBytes())); - Assert.assertEquals("aaa", group.getA()); - Assert.assertEquals("bbb", group.getB()); + Assertions.assertEquals("aaa", group.getA()); + Assertions.assertEquals("bbb", group.getB()); } @Test @@ -58,8 +58,8 @@ void testAddModule_afterLoading() { Config config = new Config(); ConfigTestGroup group = new ConfigTestGroup(); - Assert.assertNull(group.getA()); - Assert.assertNull(group.getB()); + Assertions.assertNull(group.getA()); + Assertions.assertNull(group.getB()); String str = "\n" + "\n" + @@ -71,15 +71,15 @@ void testAddModule_afterLoading() { ""; new ConfigReader(config).parse(new ByteArrayInputStream(str.getBytes())); - Assert.assertEquals("aaa", config.getParam("ctg", "a")); - Assert.assertEquals("bbb", config.getParam("ctg", "b")); - Assert.assertNull(group.getA()); - Assert.assertNull(group.getB()); + Assertions.assertEquals("aaa", config.getParam("ctg", "a")); + Assertions.assertEquals("bbb", config.getParam("ctg", "b")); + Assertions.assertNull(group.getA()); + Assertions.assertNull(group.getB()); config.addModule(group); - Assert.assertEquals("aaa", group.getA()); - Assert.assertEquals("bbb", group.getB()); + Assertions.assertEquals("aaa", group.getA()); + Assertions.assertEquals("bbb", group.getB()); } private static class ConfigTestGroup extends ConfigGroup { diff --git a/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java b/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java index 0bdd7443ea7..7961e195c2c 100644 --- a/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java +++ b/matsim/src/test/java/org/matsim/core/config/MaterializeConfigTest.java @@ -2,7 +2,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -27,9 +27,8 @@ final void testMaterializeAfterReadParameterSets() { configGroup.addParameterSet(set); } - Assert.assertEquals( - "unexpected number of parameter sets in initial config group", - 2, configGroup.getParameterSets("blabla").size()); + Assertions.assertEquals( + 2, configGroup.getParameterSets("blabla").size(), "unexpected number of parameter sets in initial config group"); ConfigUtils.writeConfig(config, utils.getOutputDirectory() + "ad-hoc-config.xml"); } @@ -40,9 +39,8 @@ final void testMaterializeAfterReadParameterSets() { { ConfigGroup configGroup = config.getModule(TestConfigGroup.GROUP_NAME); - Assert.assertEquals( - "unexpected number of parameter sets in non materialized config group", - 2, configGroup.getParameterSets("blabla").size()); + Assertions.assertEquals( + 2, configGroup.getParameterSets("blabla").size(), "unexpected number of parameter sets in non materialized config group"); } // materialize the config group @@ -50,13 +48,12 @@ final void testMaterializeAfterReadParameterSets() { TestConfigGroup.class); // this should have two parameter sets here - Assert.assertEquals( - "unexpected number of parameter sets in materialized config group", - 2, configGroup.getParameterSets("blabla").size()); + Assertions.assertEquals( + 2, configGroup.getParameterSets("blabla").size(), "unexpected number of parameter sets in materialized config group"); // check if you are getting back the values from the config file: for (TestParameterSet set : (Iterable) configGroup.getParameterSets("blabla")) { - Assert.assertEquals("unexpected value for parameter in parameter set", "life is wonderful", set.getParameter()); + Assertions.assertEquals("life is wonderful", set.getParameter(), "unexpected value for parameter in parameter set"); } } diff --git a/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java index 45243363ca7..49632ba3bd9 100644 --- a/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/ReflectiveConfigGroupTest.java @@ -31,8 +31,7 @@ import java.util.List; import java.util.Map; import java.util.Set; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.extension.RegisterExtension; @@ -363,7 +362,7 @@ public Object getStuff() { final String param = "my unknown param"; final String value = "my val"; testee.addParam(param, value); - Assert.assertEquals("unexpected stored value", value, testee.getValue(param)); + Assertions.assertEquals(value, testee.getValue(param), "unexpected stored value"); } @Test diff --git a/matsim/src/test/java/org/matsim/core/config/consistency/ConfigConsistencyCheckerImplTest.java b/matsim/src/test/java/org/matsim/core/config/consistency/ConfigConsistencyCheckerImplTest.java index 1e996282944..476b05c265b 100644 --- a/matsim/src/test/java/org/matsim/core/config/consistency/ConfigConsistencyCheckerImplTest.java +++ b/matsim/src/test/java/org/matsim/core/config/consistency/ConfigConsistencyCheckerImplTest.java @@ -20,7 +20,7 @@ package org.matsim.core.config.consistency; import org.apache.logging.log4j.Level; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.Config; @@ -46,7 +46,7 @@ void testCheckPlanCalcScore_DefaultsOk() { try { logger.activate(); ConfigConsistencyCheckerImpl.checkPlanCalcScore(config); - Assert.assertEquals(0, logger.getWarnCount()); + Assertions.assertEquals(0, logger.getWarnCount()); } finally { // make sure counter is deactivated at the end logger.deactivate(); @@ -64,7 +64,7 @@ void testCheckPlanCalcScore_Traveling() { try { logger.activate(); ConfigConsistencyCheckerImpl.checkPlanCalcScore(config); - Assert.assertEquals(1, logger.getWarnCount()); + Assertions.assertEquals(1, logger.getWarnCount()); } finally { // make sure counter is deactivated at the end logger.deactivate(); @@ -82,7 +82,7 @@ void testCheckPlanCalcScore_TravelingPt() { try { logger.activate(); ConfigConsistencyCheckerImpl.checkPlanCalcScore(config); - Assert.assertEquals(1, logger.getWarnCount()); + Assertions.assertEquals(1, logger.getWarnCount()); } finally { // make sure counter is deactivated at the end logger.deactivate(); @@ -100,7 +100,7 @@ void testCheckPlanCalcScore_TravelingBike() { try { logger.activate(); ConfigConsistencyCheckerImpl.checkPlanCalcScore(config); - Assert.assertEquals(1, logger.getWarnCount()); + Assertions.assertEquals(1, logger.getWarnCount()); } finally { // make sure counter is deactivated at the end logger.deactivate(); @@ -118,7 +118,7 @@ void testCheckPlanCalcScore_TravelingWalk() { try { logger.activate(); ConfigConsistencyCheckerImpl.checkPlanCalcScore(config); - Assert.assertEquals(1, logger.getWarnCount()); + Assertions.assertEquals(1, logger.getWarnCount()); } finally { // make sure counter is deactivated at the end logger.deactivate(); @@ -136,7 +136,7 @@ void testCheckPlanCalcScore_PtInteractionActivity() { try { ConfigConsistencyCheckerImpl.checkPlanCalcScore(config); - Assert.assertEquals(0,1) ; // should never get here + Assertions.assertEquals(0,1) ; // should never get here } catch ( Exception ee ){ System.out.println("expected exception") ; @@ -147,7 +147,7 @@ void testCheckPlanCalcScore_PtInteractionActivity() { try { ConfigConsistencyCheckerImpl.checkPlanCalcScore(config ); } catch ( Exception ee ){ - Assert.assertEquals(0,1) ; // should never get here + Assertions.assertEquals(0,1) ; // should never get here } } @@ -162,7 +162,7 @@ void checkConsistencyBetweenRouterAndTravelTimeCalculatorTest(){ config.travelTimeCalculator().setSeparateModes( false ); { boolean problem = ConfigConsistencyCheckerImpl.checkConsistencyBetweenRouterAndTravelTimeCalculator( config ); - Assert.assertFalse( problem ); + Assertions.assertFalse( problem ); } { Set modes = new LinkedHashSet<>( config.routing().getNetworkModes() ); @@ -170,7 +170,7 @@ void checkConsistencyBetweenRouterAndTravelTimeCalculatorTest(){ config.routing().setNetworkModes( modes ); boolean problem = ConfigConsistencyCheckerImpl.checkConsistencyBetweenRouterAndTravelTimeCalculator( config ); - Assert.assertFalse( problem ); + Assertions.assertFalse( problem ); } { Set modes = new LinkedHashSet<>( config.travelTimeCalculator().getAnalyzedModes() ); @@ -178,7 +178,7 @@ void checkConsistencyBetweenRouterAndTravelTimeCalculatorTest(){ config.travelTimeCalculator().setAnalyzedModes( modes ); boolean problem = ConfigConsistencyCheckerImpl.checkConsistencyBetweenRouterAndTravelTimeCalculator( config ); - Assert.assertFalse( problem ); + Assertions.assertFalse( problem ); } { Set modes = new LinkedHashSet<>( config.travelTimeCalculator().getAnalyzedModes() ); @@ -186,7 +186,7 @@ void checkConsistencyBetweenRouterAndTravelTimeCalculatorTest(){ config.travelTimeCalculator().setAnalyzedModes( modes ); boolean problem = ConfigConsistencyCheckerImpl.checkConsistencyBetweenRouterAndTravelTimeCalculator( config ); - Assert.assertFalse( problem ); + Assertions.assertFalse( problem ); } } { @@ -214,7 +214,7 @@ void checkConsistencyBetweenRouterAndTravelTimeCalculatorTest(){ config.travelTimeCalculator().setAnalyzedModes( modes ); boolean problem = ConfigConsistencyCheckerImpl.checkConsistencyBetweenRouterAndTravelTimeCalculator( config ); - Assert.assertFalse( problem ); + Assertions.assertFalse( problem ); } { Set modes = new LinkedHashSet<>( config.travelTimeCalculator().getAnalyzedModes() ); @@ -222,7 +222,7 @@ void checkConsistencyBetweenRouterAndTravelTimeCalculatorTest(){ config.travelTimeCalculator().setAnalyzedModes( modes ); boolean problem = ConfigConsistencyCheckerImpl.checkConsistencyBetweenRouterAndTravelTimeCalculator( config ); - Assert.assertFalse( problem ); + Assertions.assertFalse( problem ); } } diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java index 26499157749..bde1b7346d9 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java @@ -23,7 +23,7 @@ import java.util.EnumSet; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.config.groups.ControllerConfigGroup.EventsFileFormat; @@ -41,42 +41,42 @@ void testEventsFileFormat() { Set formats; // test initial value formats = cg.getEventsFileFormats(); - Assert.assertEquals(1, formats.size()); - Assert.assertTrue(formats.contains(EventsFileFormat.xml)); - Assert.assertEquals("xml", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); + Assertions.assertEquals(1, formats.size()); + Assertions.assertTrue(formats.contains(EventsFileFormat.xml)); + Assertions.assertEquals("xml", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); // test setting with setEventsFileFormat cg.setEventsFileFormats(EnumSet.of(EventsFileFormat.xml)); formats = cg.getEventsFileFormats(); - Assert.assertEquals(1, formats.size()); - Assert.assertTrue(formats.contains(EventsFileFormat.xml)); - Assert.assertEquals("xml", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); + Assertions.assertEquals(1, formats.size()); + Assertions.assertTrue(formats.contains(EventsFileFormat.xml)); + Assertions.assertEquals("xml", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); // test setting to none cg.setEventsFileFormats(EnumSet.noneOf(EventsFileFormat.class)); formats = cg.getEventsFileFormats(); - Assert.assertEquals(0, formats.size()); - Assert.assertEquals("", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); + Assertions.assertEquals(0, formats.size()); + Assertions.assertEquals("", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); // test setting with addParam cg.addParam(ControllerConfigGroup.EVENTS_FILE_FORMAT, "xml"); formats = cg.getEventsFileFormats(); - Assert.assertEquals(1, formats.size()); - Assert.assertTrue(formats.contains(EventsFileFormat.xml)); - Assert.assertEquals("xml", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); + Assertions.assertEquals(1, formats.size()); + Assertions.assertTrue(formats.contains(EventsFileFormat.xml)); + Assertions.assertEquals("xml", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); // test setting to none cg.addParam(ControllerConfigGroup.EVENTS_FILE_FORMAT, ""); formats = cg.getEventsFileFormats(); - Assert.assertEquals(0, formats.size()); - Assert.assertEquals("", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); + Assertions.assertEquals(0, formats.size()); + Assertions.assertEquals("", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); // test setting with non-conform formatting cg.addParam(ControllerConfigGroup.EVENTS_FILE_FORMAT, " xml\t\t "); formats = cg.getEventsFileFormats(); - Assert.assertEquals(1, formats.size()); - Assert.assertTrue(formats.contains(EventsFileFormat.xml)); - Assert.assertEquals("xml", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); + Assertions.assertEquals(1, formats.size()); + Assertions.assertTrue(formats.contains(EventsFileFormat.xml)); + Assertions.assertEquals("xml", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); // test setting to non-conform none cg.addParam(ControllerConfigGroup.EVENTS_FILE_FORMAT, " \t "); formats = cg.getEventsFileFormats(); - Assert.assertEquals(0, formats.size()); - Assert.assertEquals("", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); + Assertions.assertEquals(0, formats.size()); + Assertions.assertEquals("", cg.getValue(ControllerConfigGroup.EVENTS_FILE_FORMAT)); } /** @@ -89,16 +89,16 @@ void testEventsFileFormat() { void testMobsim() { ControllerConfigGroup cg = new ControllerConfigGroup(); // test initial value - Assert.assertEquals("qsim", cg.getMobsim()); - Assert.assertEquals("qsim", cg.getValue(ControllerConfigGroup.MOBSIM)); + Assertions.assertEquals("qsim", cg.getMobsim()); + Assertions.assertEquals("qsim", cg.getValue(ControllerConfigGroup.MOBSIM)); // test setting to null cg.setMobsim(null); - Assert.assertNull(cg.getMobsim()); - Assert.assertNull(cg.getValue(ControllerConfigGroup.MOBSIM)); + Assertions.assertNull(cg.getMobsim()); + Assertions.assertNull(cg.getValue(ControllerConfigGroup.MOBSIM)); // test setting with addParam cg.addParam(ControllerConfigGroup.MOBSIM, "queueSimulation"); - Assert.assertEquals("queueSimulation", cg.getMobsim()); - Assert.assertEquals("queueSimulation", cg.getValue(ControllerConfigGroup.MOBSIM)); + Assertions.assertEquals("queueSimulation", cg.getMobsim()); + Assertions.assertEquals("queueSimulation", cg.getValue(ControllerConfigGroup.MOBSIM)); } /** @@ -111,13 +111,13 @@ void testMobsim() { void testWritePlansInterval() { ControllerConfigGroup cg = new ControllerConfigGroup(); // test initial value - Assert.assertEquals(50, cg.getWritePlansInterval()); + Assertions.assertEquals(50, cg.getWritePlansInterval()); // test setting with setMobsim cg.setWritePlansInterval(4); - Assert.assertEquals(4, cg.getWritePlansInterval()); + Assertions.assertEquals(4, cg.getWritePlansInterval()); // test setting with addParam cg.addParam("writePlansInterval", "2"); - Assert.assertEquals(2, cg.getWritePlansInterval()); + Assertions.assertEquals(2, cg.getWritePlansInterval()); } /** @@ -128,19 +128,19 @@ void testWritePlansInterval() { void testLink2LinkRouting(){ ControllerConfigGroup cg = new ControllerConfigGroup(); //initial value - Assert.assertFalse(cg.isLinkToLinkRoutingEnabled()); + Assertions.assertFalse(cg.isLinkToLinkRoutingEnabled()); //modify by string cg.addParam("enableLinkToLinkRouting", "true"); - Assert.assertTrue(cg.isLinkToLinkRoutingEnabled()); + Assertions.assertTrue(cg.isLinkToLinkRoutingEnabled()); cg.addParam("enableLinkToLinkRouting", "false"); - Assert.assertFalse(cg.isLinkToLinkRoutingEnabled()); + Assertions.assertFalse(cg.isLinkToLinkRoutingEnabled()); //modify by boolean cg.setLinkToLinkRoutingEnabled(true); - Assert.assertTrue(cg.isLinkToLinkRoutingEnabled()); - Assert.assertEquals("true", cg.getValue("enableLinkToLinkRouting")); + Assertions.assertTrue(cg.isLinkToLinkRoutingEnabled()); + Assertions.assertEquals("true", cg.getValue("enableLinkToLinkRouting")); cg.setLinkToLinkRoutingEnabled(false); - Assert.assertFalse(cg.isLinkToLinkRoutingEnabled()); - Assert.assertEquals("false", cg.getValue("enableLinkToLinkRouting")); + Assertions.assertFalse(cg.isLinkToLinkRoutingEnabled()); + Assertions.assertEquals("false", cg.getValue("enableLinkToLinkRouting")); } /** @@ -151,14 +151,14 @@ void testLink2LinkRouting(){ void testWriteSnapshotInterval(){ ControllerConfigGroup cg = new ControllerConfigGroup(); //initial value - Assert.assertEquals(1, cg.getWriteSnapshotsInterval()); + Assertions.assertEquals(1, cg.getWriteSnapshotsInterval()); //modify by string cg.addParam("writeSnapshotsInterval", "10"); - Assert.assertEquals(10, cg.getWriteSnapshotsInterval()); + Assertions.assertEquals(10, cg.getWriteSnapshotsInterval()); //modify by boolean cg.setWriteSnapshotsInterval(42); - Assert.assertEquals("42", cg.getValue("writeSnapshotsInterval")); - Assert.assertEquals(42, cg.getWriteSnapshotsInterval()); + Assertions.assertEquals("42", cg.getValue("writeSnapshotsInterval")); + Assertions.assertEquals(42, cg.getWriteSnapshotsInterval()); } diff --git a/matsim/src/test/java/org/matsim/core/config/groups/CountsConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/CountsConfigGroupTest.java index f1c2fdf7276..84c2cacaa03 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/CountsConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/CountsConfigGroupTest.java @@ -19,7 +19,7 @@ package org.matsim.core.config.groups; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** @@ -31,44 +31,44 @@ public class CountsConfigGroupTest { void testWriteCountsInterval() { CountsConfigGroup cg = new CountsConfigGroup(); // test initial value - Assert.assertEquals(10, cg.getWriteCountsInterval()); - Assert.assertEquals("10", cg.getValue("writeCountsInterval")); + Assertions.assertEquals(10, cg.getWriteCountsInterval()); + Assertions.assertEquals("10", cg.getValue("writeCountsInterval")); // test setting with setMobsim cg.setWriteCountsInterval(4); - Assert.assertEquals(4, cg.getWriteCountsInterval()); - Assert.assertEquals("4", cg.getValue("writeCountsInterval")); + Assertions.assertEquals(4, cg.getWriteCountsInterval()); + Assertions.assertEquals("4", cg.getValue("writeCountsInterval")); // test setting with addParam cg.addParam("writeCountsInterval", "2"); - Assert.assertEquals(2, cg.getWriteCountsInterval()); - Assert.assertEquals("2", cg.getValue("writeCountsInterval")); + Assertions.assertEquals(2, cg.getWriteCountsInterval()); + Assertions.assertEquals("2", cg.getValue("writeCountsInterval")); } @Test void testGetParams_writeCountsInterval() { CountsConfigGroup cg = new CountsConfigGroup(); - Assert.assertNotNull(cg.getParams().get("writeCountsInterval")); + Assertions.assertNotNull(cg.getParams().get("writeCountsInterval")); } @Test void testWriteAverageOverIterations() { CountsConfigGroup cg = new CountsConfigGroup(); // test initial value - Assert.assertEquals(5, cg.getAverageCountsOverIterations()); - Assert.assertEquals("5", cg.getValue("averageCountsOverIterations")); + Assertions.assertEquals(5, cg.getAverageCountsOverIterations()); + Assertions.assertEquals("5", cg.getValue("averageCountsOverIterations")); // test setting with setMobsim cg.setAverageCountsOverIterations(4); - Assert.assertEquals(4, cg.getAverageCountsOverIterations()); - Assert.assertEquals("4", cg.getValue("averageCountsOverIterations")); + Assertions.assertEquals(4, cg.getAverageCountsOverIterations()); + Assertions.assertEquals("4", cg.getValue("averageCountsOverIterations")); // test setting with addParam cg.addParam("averageCountsOverIterations", "2"); - Assert.assertEquals(2, cg.getAverageCountsOverIterations()); - Assert.assertEquals("2", cg.getValue("averageCountsOverIterations")); + Assertions.assertEquals(2, cg.getAverageCountsOverIterations()); + Assertions.assertEquals("2", cg.getValue("averageCountsOverIterations")); } @Test void testGetParams_averageCountsOverIterations() { CountsConfigGroup cg = new CountsConfigGroup(); - Assert.assertNotNull(cg.getParams().get("averageCountsOverIterations")); + Assertions.assertNotNull(cg.getParams().get("averageCountsOverIterations")); } } diff --git a/matsim/src/test/java/org/matsim/core/config/groups/LinkStatsConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/LinkStatsConfigGroupTest.java index 363c5eca282..a5355580a77 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/LinkStatsConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/LinkStatsConfigGroupTest.java @@ -19,7 +19,7 @@ package org.matsim.core.config.groups; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** @@ -31,44 +31,44 @@ public class LinkStatsConfigGroupTest { void testWriteLinkStatsInterval() { LinkStatsConfigGroup cg = new LinkStatsConfigGroup(); // test initial value - Assert.assertEquals(50, cg.getWriteLinkStatsInterval()); - Assert.assertEquals("50", cg.getValue("writeLinkStatsInterval")); + Assertions.assertEquals(50, cg.getWriteLinkStatsInterval()); + Assertions.assertEquals("50", cg.getValue("writeLinkStatsInterval")); // test setting with setMobsim cg.setWriteLinkStatsInterval(4); - Assert.assertEquals(4, cg.getWriteLinkStatsInterval()); - Assert.assertEquals("4", cg.getValue("writeLinkStatsInterval")); + Assertions.assertEquals(4, cg.getWriteLinkStatsInterval()); + Assertions.assertEquals("4", cg.getValue("writeLinkStatsInterval")); // test setting with addParam cg.addParam("writeLinkStatsInterval", "2"); - Assert.assertEquals(2, cg.getWriteLinkStatsInterval()); - Assert.assertEquals("2", cg.getValue("writeLinkStatsInterval")); + Assertions.assertEquals(2, cg.getWriteLinkStatsInterval()); + Assertions.assertEquals("2", cg.getValue("writeLinkStatsInterval")); } @Test void testGetParams_writeLinkStatsInterval() { LinkStatsConfigGroup cg = new LinkStatsConfigGroup(); - Assert.assertNotNull(cg.getParams().get("writeLinkStatsInterval")); + Assertions.assertNotNull(cg.getParams().get("writeLinkStatsInterval")); } @Test void testWriteAverageOverIterations() { LinkStatsConfigGroup cg = new LinkStatsConfigGroup(); // test initial value - Assert.assertEquals(5, cg.getAverageLinkStatsOverIterations()); - Assert.assertEquals("5", cg.getValue("averageLinkStatsOverIterations")); + Assertions.assertEquals(5, cg.getAverageLinkStatsOverIterations()); + Assertions.assertEquals("5", cg.getValue("averageLinkStatsOverIterations")); // test setting with setMobsim cg.setAverageLinkStatsOverIterations(4); - Assert.assertEquals(4, cg.getAverageLinkStatsOverIterations()); - Assert.assertEquals("4", cg.getValue("averageLinkStatsOverIterations")); + Assertions.assertEquals(4, cg.getAverageLinkStatsOverIterations()); + Assertions.assertEquals("4", cg.getValue("averageLinkStatsOverIterations")); // test setting with addParam cg.addParam("averageLinkStatsOverIterations", "2"); - Assert.assertEquals(2, cg.getAverageLinkStatsOverIterations()); - Assert.assertEquals("2", cg.getValue("averageLinkStatsOverIterations")); + Assertions.assertEquals(2, cg.getAverageLinkStatsOverIterations()); + Assertions.assertEquals("2", cg.getValue("averageLinkStatsOverIterations")); } @Test void testGetParams_averageLinkStatsOverIterations() { LinkStatsConfigGroup cg = new LinkStatsConfigGroup(); - Assert.assertNotNull(cg.getParams().get("averageLinkStatsOverIterations")); + Assertions.assertNotNull(cg.getParams().get("averageLinkStatsOverIterations")); } } diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java index ba0ff07c5f3..3109c603b79 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ReplanningConfigGroupTest.java @@ -20,8 +20,8 @@ package org.matsim.core.config.groups; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.fail; import java.util.Map; @@ -68,8 +68,8 @@ void testParamNames() { log.info("Catched IllegalArgumentException, as expected: " + e.getMessage()); } - assertEquals("unexpected number of strategy settings", 1, configGroup - .getStrategySettings().size()); + assertEquals(1, configGroup + .getStrategySettings().size(), "unexpected number of strategy settings"); } /** @@ -177,40 +177,40 @@ private void assertIdentical( final ReplanningConfigGroup initialGroup, final ReplanningConfigGroup inputConfigGroup) { assertEquals( - "wrong config template for "+msg, initialGroup.getExternalExeConfigTemplate(), - inputConfigGroup.getExternalExeConfigTemplate() ); + inputConfigGroup.getExternalExeConfigTemplate(), + "wrong config template for "+msg ); assertEquals( - "wrong ExternalExeTimeOut for "+msg, initialGroup.getExternalExeTimeOut(), - inputConfigGroup.getExternalExeTimeOut() ); + inputConfigGroup.getExternalExeTimeOut(), + "wrong ExternalExeTimeOut for "+msg ); assertEquals( - "wrong ExternalExeTmpFileRootDir for "+msg, initialGroup.getExternalExeTmpFileRootDir(), - inputConfigGroup.getExternalExeTmpFileRootDir() ); + inputConfigGroup.getExternalExeTmpFileRootDir(), + "wrong ExternalExeTmpFileRootDir for "+msg ); assertEquals( - "wrong FractionOfIterationsToDisableInnovation for "+msg, initialGroup.getFractionOfIterationsToDisableInnovation(), inputConfigGroup.getFractionOfIterationsToDisableInnovation(), - MatsimTestUtils.EPSILON ); + MatsimTestUtils.EPSILON, + "wrong FractionOfIterationsToDisableInnovation for "+msg ); assertEquals( - "wrong MaxAgentPlanMemorySize for "+msg, initialGroup.getMaxAgentPlanMemorySize(), - inputConfigGroup.getMaxAgentPlanMemorySize() ); + inputConfigGroup.getMaxAgentPlanMemorySize(), + "wrong MaxAgentPlanMemorySize for "+msg ); assertEquals( - "wrong PlanSelectorForRemoval for "+msg, initialGroup.getPlanSelectorForRemoval(), - inputConfigGroup.getPlanSelectorForRemoval() ); + inputConfigGroup.getPlanSelectorForRemoval(), + "wrong PlanSelectorForRemoval for "+msg ); assertEquals( - "wrong number of StrategySettings for "+msg, initialGroup.getStrategySettings().size(), - inputConfigGroup.getStrategySettings().size() ); + inputConfigGroup.getStrategySettings().size(), + "wrong number of StrategySettings for "+msg ); } private ConfigGroup toUnderscoredModule(final ReplanningConfigGroup initialGroup) { diff --git a/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java index 45f9c4e335c..aa4b8641b71 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/RoutingConfigGroupTest.java @@ -26,7 +26,7 @@ import static org.junit.jupiter.api.Assertions.assertThrows; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.TransportMode; @@ -52,7 +52,7 @@ void testAddModeParamsTwice() { { Config config = ConfigUtils.createConfig(); RoutingConfigGroup group = config.routing(); - Assert.assertEquals( N_MODE_ROUTING_PARAMS_DEFAULT, group.getModeRoutingParams().size() ); + Assertions.assertEquals( N_MODE_ROUTING_PARAMS_DEFAULT, group.getModeRoutingParams().size() ); group.clearModeRoutingParams(); // group.setTeleportedModeSpeed( TransportMode.bike, 1. ); // Assert.assertEquals( 1, group.getModeRoutingParams().size() ); @@ -66,7 +66,7 @@ void testAddModeParamsTwice() { { Config config = ConfigUtils.loadConfig( filename ) ; RoutingConfigGroup group = config.routing(); - Assert.assertEquals( 0, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 0, group.getModeRoutingParams().size() ); } } @@ -77,21 +77,21 @@ void testClearParamsWriteRead() { { Config config = ConfigUtils.createConfig(); RoutingConfigGroup group = config.routing(); - Assert.assertEquals( N_MODE_ROUTING_PARAMS_DEFAULT, group.getModeRoutingParams().size() ); + Assertions.assertEquals( N_MODE_ROUTING_PARAMS_DEFAULT, group.getModeRoutingParams().size() ); group.clearModeRoutingParams(); group.setTeleportedModeSpeed( TransportMode.bike, 1. ); - Assert.assertEquals( 1, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 1, group.getModeRoutingParams().size() ); group.setTeleportedModeSpeed( "abc", 1. ); - Assert.assertEquals( 2, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 2, group.getModeRoutingParams().size() ); group.clearModeRoutingParams(); - Assert.assertEquals( 0, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 0, group.getModeRoutingParams().size() ); ConfigUtils.writeConfig( config, filename ); } { Config config = ConfigUtils.loadConfig( filename ) ; RoutingConfigGroup group = config.routing(); - Assert.assertEquals( 0, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 0, group.getModeRoutingParams().size() ); } } @@ -102,22 +102,22 @@ void testRemoveParamsWriteRead() { { Config config = ConfigUtils.createConfig(); RoutingConfigGroup group = config.routing(); - Assert.assertEquals( N_MODE_ROUTING_PARAMS_DEFAULT, group.getModeRoutingParams().size() ); + Assertions.assertEquals( N_MODE_ROUTING_PARAMS_DEFAULT, group.getModeRoutingParams().size() ); group.setTeleportedModeSpeed( TransportMode.bike, 1. ); - Assert.assertEquals( 1, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 1, group.getModeRoutingParams().size() ); group.setTeleportedModeSpeed( "abc", 1. ); - Assert.assertEquals( 2, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 2, group.getModeRoutingParams().size() ); for( String mode : group.getModeRoutingParams().keySet() ){ group.removeModeRoutingParams( mode ); } - Assert.assertEquals( 0, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 0, group.getModeRoutingParams().size() ); ConfigUtils.writeConfig( config, filename ); } { Config config = ConfigUtils.loadConfig( filename ) ; RoutingConfigGroup group = config.routing(); - Assert.assertEquals( 0, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 0, group.getModeRoutingParams().size() ); } } @@ -125,13 +125,13 @@ void testRemoveParamsWriteRead() { void testClearDefaults() { Config config = ConfigUtils.createConfig( ) ; RoutingConfigGroup group = config.routing() ; - Assert.assertEquals( N_MODE_ROUTING_PARAMS_DEFAULT, group.getModeRoutingParams().size() ); + Assertions.assertEquals( N_MODE_ROUTING_PARAMS_DEFAULT, group.getModeRoutingParams().size() ); group.setTeleportedModeSpeed( "def", 1. ); - Assert.assertEquals( 1, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 1, group.getModeRoutingParams().size() ); group.setTeleportedModeSpeed( "abc", 1. ); - Assert.assertEquals( 2, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 2, group.getModeRoutingParams().size() ); group.clearModeRoutingParams( ); - Assert.assertEquals( 0, group.getModeRoutingParams().size() ); + Assertions.assertEquals( 0, group.getModeRoutingParams().size() ); } @Test @@ -156,17 +156,17 @@ void testBackwardsCompatibility() { RoutingConfigGroup group = new RoutingConfigGroup(); // test default - Assert.assertEquals("different default than expected.", 3.0 / 3.6, group.getTeleportedModeSpeeds().get(TransportMode.walk), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.0 / 3.6, group.getTeleportedModeSpeeds().get(TransportMode.walk), MatsimTestUtils.EPSILON, "different default than expected."); try { group.addParam("walkSpeedFactor", "1.5"); } catch (IllegalArgumentException e) { log.info("catched expected exception: " + e.getMessage()); - Assert.assertFalse("Exception-Message should not be empty.", e.getMessage().isEmpty()); + Assertions.assertFalse(e.getMessage().isEmpty(), "Exception-Message should not be empty."); } - Assert.assertEquals("value should not have changed.", 3.0 / 3.6, group.getTeleportedModeSpeeds().get(TransportMode.walk), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3.0 / 3.6, group.getTeleportedModeSpeeds().get(TransportMode.walk), MatsimTestUtils.EPSILON, "value should not have changed."); group.addParam("walkSpeed", "1.5"); - Assert.assertEquals("value should have changed.", 1.5, group.getTeleportedModeSpeeds().get(TransportMode.walk), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.5, group.getTeleportedModeSpeeds().get(TransportMode.walk), MatsimTestUtils.EPSILON, "value should have changed."); } @Test @@ -175,10 +175,10 @@ void testDefaultsAreCleared() { // group.clearModeRoutingParams(); group.setTeleportedModeSpeed( "skateboard" , 20 / 3.6 ); group.setTeleportedModeSpeed( "longboard" , 20 / 3.6 ); - Assert.assertEquals( - "unexpected number of modes after adding new mode in "+group.getModeRoutingParams(), + Assertions.assertEquals( 2, - group.getModeRoutingParams().size() ); + group.getModeRoutingParams().size(), + "unexpected number of modes after adding new mode in "+group.getModeRoutingParams() ); } @Test @@ -254,25 +254,23 @@ private static void assertIdentical( final String msg, final RoutingConfigGroup initialGroup, final RoutingConfigGroup inputConfigGroup) { - Assert.assertEquals( - "unexpected beelineDistanceFactor", -// initialGroup.getBeelineDistanceFactor(), -// inputConfigGroup.getBeelineDistanceFactor(), + Assertions.assertEquals( initialGroup.getBeelineDistanceFactors(), - inputConfigGroup.getBeelineDistanceFactors() ) ; + inputConfigGroup.getBeelineDistanceFactors(), + "unexpected beelineDistanceFactor" ) ; // MatsimTestUtils.EPSILON ); - Assert.assertEquals( - "unexpected networkModes", + Assertions.assertEquals( initialGroup.getNetworkModes(), - inputConfigGroup.getNetworkModes() ); - Assert.assertEquals( - "unexpected teleportedModeFreespeedFactors", + inputConfigGroup.getNetworkModes(), + "unexpected networkModes" ); + Assertions.assertEquals( initialGroup.getTeleportedModeFreespeedFactors(), - inputConfigGroup.getTeleportedModeFreespeedFactors() ); - Assert.assertEquals( - "unexpected teleportedModeSpeeds", + inputConfigGroup.getTeleportedModeFreespeedFactors(), + "unexpected teleportedModeFreespeedFactors" ); + Assertions.assertEquals( initialGroup.getTeleportedModeSpeeds(), - inputConfigGroup.getTeleportedModeSpeeds() ); + inputConfigGroup.getTeleportedModeSpeeds(), + "unexpected teleportedModeSpeeds" ); } private static ConfigGroup toUnderscoredModule(final RoutingConfigGroup initialGroup) { diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java index 80512022e3f..a745ea1a452 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ScoringConfigGroupTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.TransportMode; @@ -41,7 +41,7 @@ import org.matsim.core.config.groups.ScoringConfigGroup.ModeParams; import org.matsim.testcases.MatsimTestUtils; - public class ScoringConfigGroupTest { + public class ScoringConfigGroupTest { private static final Logger log = LogManager.getLogger(ScoringConfigGroupTest.class); @@ -53,16 +53,16 @@ private void testResultsBeforeCheckConsistency( Config config, boolean fullyHier if ( ! fullyHierarchical ){ // mode params are there for default modes: - Assert.assertNotNull( scoringConfig.getModes().get( TransportMode.car ) ); - Assert.assertNotNull( scoringConfig.getModes().get( TransportMode.walk ) ); - Assert.assertNotNull( scoringConfig.getModes().get( TransportMode.bike ) ); - Assert.assertNotNull( scoringConfig.getModes().get( TransportMode.ride ) ); - Assert.assertNotNull( scoringConfig.getModes().get( TransportMode.pt ) ); - Assert.assertNotNull( scoringConfig.getModes().get( TransportMode.other ) ); + Assertions.assertNotNull( scoringConfig.getModes().get( TransportMode.car ) ); + Assertions.assertNotNull( scoringConfig.getModes().get( TransportMode.walk ) ); + Assertions.assertNotNull( scoringConfig.getModes().get( TransportMode.bike ) ); + Assertions.assertNotNull( scoringConfig.getModes().get( TransportMode.ride ) ); + Assertions.assertNotNull( scoringConfig.getModes().get( TransportMode.pt ) ); + Assertions.assertNotNull( scoringConfig.getModes().get( TransportMode.other ) ); // default stage/interaction params are there for pt and drt (as a service): - Assert.assertNotNull( scoringConfig.getActivityParams( createStageActivityType( TransportMode.pt ) ) ); - Assert.assertNotNull( scoringConfig.getActivityParams( createStageActivityType( TransportMode.drt ) ) ); + Assertions.assertNotNull( scoringConfig.getActivityParams( createStageActivityType( TransportMode.pt ) ) ); + Assertions.assertNotNull( scoringConfig.getActivityParams( createStageActivityType( TransportMode.drt ) ) ); } // default stage/interaction params for modes routed on the network are not yet there: // for( String networkMode : config.plansCalcRoute().getNetworkModes() ){ @@ -74,7 +74,7 @@ private void testResultsAfterCheckConsistency( Config config ) { // default stage/interaction params for modes routed on the network are now there: for( String networkMode : config.routing().getNetworkModes() ){ - Assert.assertNotNull( scoringConfig.getActivityParams( createStageActivityType( networkMode ) ) ); + Assertions.assertNotNull( scoringConfig.getActivityParams( createStageActivityType( networkMode ) ) ); } } @@ -140,13 +140,13 @@ void testVersionWoScoringparams() { void testAddActivityParams() { ScoringConfigGroup c = new ScoringConfigGroup(); int originalSize = c.getActivityParams().size(); - Assert.assertNull(c.getActivityParams("type1")); - Assert.assertEquals(originalSize, c.getActivityParams().size()); + Assertions.assertNull(c.getActivityParams("type1")); + Assertions.assertEquals(originalSize, c.getActivityParams().size()); ActivityParams ap = new ActivityParams("type1"); c.addActivityParams(ap); - Assert.assertEquals(ap, c.getActivityParams("type1")); - Assert.assertEquals(originalSize + 1, c.getActivityParams().size()); + Assertions.assertEquals(ap, c.getActivityParams("type1")); + Assertions.assertEquals(originalSize + 1, c.getActivityParams().size()); } @Test @@ -178,183 +178,189 @@ private void assertIdentical( final String msg, final ScoringConfigGroup initialGroup, final ScoringConfigGroup inputConfigGroup) { - Assert.assertEquals( - "wrong brainExpBeta "+msg, + Assertions.assertEquals( initialGroup.getBrainExpBeta(), inputConfigGroup.getBrainExpBeta(), - 1e-7); - Assert.assertEquals( - "wrong constantBike "+msg, + 1e-7, + "wrong brainExpBeta "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.bike).getConstant(), inputConfigGroup.getModes().get(TransportMode.bike).getConstant(), - 1e-7); - Assert.assertEquals( - "wrong constantCar "+msg, + 1e-7, + "wrong constantBike "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.car).getConstant(), inputConfigGroup.getModes().get(TransportMode.car).getConstant(), - 1e-7); - Assert.assertEquals( - "wrong constantOther "+msg, + 1e-7, + "wrong constantCar "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.other).getConstant(), inputConfigGroup.getModes().get(TransportMode.other).getConstant(), - 1e-7); - Assert.assertEquals( - "wrong constantPt "+msg, + 1e-7, + "wrong constantOther "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.pt).getConstant(), inputConfigGroup.getModes().get(TransportMode.pt).getConstant(), - 1e-7); - Assert.assertEquals( - "wrong constantWalk "+msg, + 1e-7, + "wrong constantPt "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.walk).getConstant(), inputConfigGroup.getModes().get(TransportMode.walk).getConstant(), - 1e-7); - Assert.assertEquals( - "wrong lateArrival_utils_hr "+msg, + 1e-7, + "wrong constantWalk "+msg); + Assertions.assertEquals( initialGroup.getLateArrival_utils_hr(), inputConfigGroup.getLateArrival_utils_hr(), - 1e-7 ); - Assert.assertEquals( - "wrong earlyDeparture_utils_hr "+msg, + 1e-7, + "wrong lateArrival_utils_hr "+msg ); + Assertions.assertEquals( initialGroup.getEarlyDeparture_utils_hr(), inputConfigGroup.getEarlyDeparture_utils_hr(), - 1e-7 ); - Assert.assertEquals( - "wrong learningRate "+msg, + 1e-7, + "wrong earlyDeparture_utils_hr "+msg ); + Assertions.assertEquals( initialGroup.getLearningRate(), inputConfigGroup.getLearningRate(), - 1e-7 ); - Assert.assertEquals( - "wrong marginalUtilityOfMoney "+msg, + 1e-7, + "wrong learningRate "+msg ); + Assertions.assertEquals( initialGroup.getMarginalUtilityOfMoney(), inputConfigGroup.getMarginalUtilityOfMoney() , - 1e-7); - Assert.assertEquals( - "wrong marginalUtlOfDistanceOther "+msg, + 1e-7, + "wrong marginalUtilityOfMoney "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.other).getMarginalUtilityOfDistance(), inputConfigGroup.getModes().get(TransportMode.other).getMarginalUtilityOfDistance(), - 1e-7); - Assert.assertEquals( - "wrong marginalUtlOfDistanceWalk "+msg, + 1e-7, + "wrong marginalUtlOfDistanceOther "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.walk).getMarginalUtilityOfDistance(), inputConfigGroup.getModes().get(TransportMode.walk).getMarginalUtilityOfDistance(), - 1e-7); - Assert.assertEquals( - "wrong marginalUtlOfWaiting_utils_hr "+msg, + 1e-7, + "wrong marginalUtlOfDistanceWalk "+msg); + Assertions.assertEquals( initialGroup.getMarginalUtlOfWaiting_utils_hr(), inputConfigGroup.getMarginalUtlOfWaiting_utils_hr(), - 1e-7 ); - Assert.assertEquals( - "wrong marginalUtlOfWaitingPt_utils_hr "+msg, + 1e-7, + "wrong marginalUtlOfWaiting_utils_hr "+msg ); + Assertions.assertEquals( initialGroup.getMarginalUtlOfWaitingPt_utils_hr(), inputConfigGroup.getMarginalUtlOfWaitingPt_utils_hr(), - 1e-7 ); - Assert.assertEquals( - "wrong monetaryDistanceCostRateCar "+msg, + 1e-7, + "wrong marginalUtlOfWaitingPt_utils_hr "+msg ); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.car).getMonetaryDistanceRate(), inputConfigGroup.getModes().get(TransportMode.car).getMonetaryDistanceRate(), - 1e-7); - Assert.assertEquals( - "wrong monetaryDistanceCostRatePt "+msg, + 1e-7, + "wrong monetaryDistanceCostRateCar "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.pt).getMonetaryDistanceRate(), inputConfigGroup.getModes().get(TransportMode.pt).getMonetaryDistanceRate(), - 1e-7); - Assert.assertEquals( - "wrong pathSizeLogitBeta "+msg, + 1e-7, + "wrong monetaryDistanceCostRatePt "+msg); + Assertions.assertEquals( initialGroup.getPathSizeLogitBeta(), inputConfigGroup.getPathSizeLogitBeta(), - 1e-7 ); - Assert.assertEquals( - "wrong performing_utils_hr "+msg, + 1e-7, + "wrong pathSizeLogitBeta "+msg ); + Assertions.assertEquals( initialGroup.getPerforming_utils_hr(), inputConfigGroup.getPerforming_utils_hr(), - 1e-7 ); - Assert.assertEquals( - "wrong traveling_utils_hr "+msg, + 1e-7, + "wrong performing_utils_hr "+msg ); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.car).getMarginalUtilityOfTraveling(), inputConfigGroup.getModes().get(TransportMode.car).getMarginalUtilityOfTraveling(), - 1e-7); - Assert.assertEquals( - "wrong travelingBike_utils_hr "+msg, + 1e-7, + "wrong traveling_utils_hr "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.bike).getMarginalUtilityOfTraveling(), inputConfigGroup.getModes().get(TransportMode.bike).getMarginalUtilityOfTraveling(), - 1e-7); - Assert.assertEquals( - "wrong travelingOther_utils_hr "+msg, + 1e-7, + "wrong travelingBike_utils_hr "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.other).getMarginalUtilityOfTraveling(), inputConfigGroup.getModes().get(TransportMode.other).getMarginalUtilityOfTraveling(), - 1e-7); - Assert.assertEquals( - "wrong travelingPt_utils_hr "+msg, + 1e-7, + "wrong travelingOther_utils_hr "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.pt).getMarginalUtilityOfTraveling(), inputConfigGroup.getModes().get(TransportMode.pt).getMarginalUtilityOfTraveling(), - 1e-7); - Assert.assertEquals( - "wrong travelingWalk_utils_hr "+msg, + 1e-7, + "wrong travelingPt_utils_hr "+msg); + Assertions.assertEquals( initialGroup.getModes().get(TransportMode.walk).getMarginalUtilityOfTraveling(), inputConfigGroup.getModes().get(TransportMode.walk).getMarginalUtilityOfTraveling(), - 1e-7); - Assert.assertEquals( - "wrong utilityOfLineSwitch "+msg, + 1e-7, + "wrong travelingWalk_utils_hr "+msg); + Assertions.assertEquals( initialGroup.getUtilityOfLineSwitch(), inputConfigGroup.getUtilityOfLineSwitch(), - 1e-7 ); + 1e-7, + "wrong utilityOfLineSwitch "+msg ); for ( ActivityParams initialSettings : initialGroup.getActivityParams() ) { final ActivityParams inputSettings = inputConfigGroup.getActivityParams( initialSettings.getActivityType() ); - Assert.assertEquals( - "wrong type "+msg, + Assertions.assertEquals( initialSettings.getActivityType(), - inputSettings.getActivityType() ); - Assert.assertEquals( - "wrong closingTime "+msg, initialSettings.getClosingTime(), - inputSettings.getClosingTime()); - Assert.assertEquals( - "wrong earliestEndTime "+msg, initialSettings.getEarliestEndTime(), - inputSettings.getEarliestEndTime()); - Assert.assertEquals( - "wrong latestStartTime "+msg, initialSettings.getLatestStartTime(), - inputSettings.getLatestStartTime()); - Assert.assertEquals( - "wrong minimalDuration "+msg, initialSettings.getMinimalDuration(), - inputSettings.getMinimalDuration()); - Assert.assertEquals( - "wrong openingTime "+msg, initialSettings.getOpeningTime(), - inputSettings.getOpeningTime()); - Assert.assertEquals( - "wrong priority "+msg, + inputSettings.getActivityType(), + "wrong type "+msg ); + Assertions.assertEquals( + initialSettings.getClosingTime(), + inputSettings.getClosingTime(), + "wrong closingTime "+msg); + Assertions.assertEquals( + initialSettings.getEarliestEndTime(), + inputSettings.getEarliestEndTime(), + "wrong earliestEndTime "+msg); + Assertions.assertEquals( + initialSettings.getLatestStartTime(), + inputSettings.getLatestStartTime(), + "wrong latestStartTime "+msg); + Assertions.assertEquals( + initialSettings.getMinimalDuration(), + inputSettings.getMinimalDuration(), + "wrong minimalDuration "+msg); + Assertions.assertEquals( + initialSettings.getOpeningTime(), + inputSettings.getOpeningTime(), + "wrong openingTime "+msg); + Assertions.assertEquals( initialSettings.getPriority(), inputSettings.getPriority(), - 1e-7 ); - Assert.assertEquals( - "wrong typicalDuration "+msg, initialSettings.getTypicalDuration(), - inputSettings.getTypicalDuration()); + 1e-7, + "wrong priority "+msg ); + Assertions.assertEquals( + initialSettings.getTypicalDuration(), + inputSettings.getTypicalDuration(), + "wrong typicalDuration "+msg); } for ( ModeParams initialSettings : initialGroup.getModes().values() ) { final String mode = initialSettings.getMode(); final ModeParams inputSettings = inputConfigGroup.getModes().get( mode ); - Assert.assertEquals( - "wrong constant "+msg, + Assertions.assertEquals( initialSettings.getConstant(), inputSettings.getConstant(), - 1e-7 ); - Assert.assertEquals( - "wrong marginalUtilityOfDistance "+msg, + 1e-7, + "wrong constant "+msg ); + Assertions.assertEquals( initialSettings.getMarginalUtilityOfDistance(), inputSettings.getMarginalUtilityOfDistance(), - 1e-7 ); - Assert.assertEquals( - "wrong marginalUtilityOfTraveling "+msg, + 1e-7, + "wrong marginalUtilityOfDistance "+msg ); + Assertions.assertEquals( initialSettings.getMarginalUtilityOfTraveling(), inputSettings.getMarginalUtilityOfTraveling(), - 1e-7 ); - Assert.assertEquals( - "wrong monetaryDistanceRate "+msg, + 1e-7, + "wrong marginalUtilityOfTraveling "+msg ); + Assertions.assertEquals( initialSettings.getMonetaryDistanceRate(), inputSettings.getMonetaryDistanceRate(), - 1e-7 ); + 1e-7, + "wrong monetaryDistanceRate "+msg ); } diff --git a/matsim/src/test/java/org/matsim/core/config/groups/SubtourModeChoiceConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/SubtourModeChoiceConfigGroupTest.java index 77bcf5c5869..3a70bea64d6 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/SubtourModeChoiceConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/SubtourModeChoiceConfigGroupTest.java @@ -19,10 +19,7 @@ * *********************************************************************** */ package org.matsim.core.config.groups; -import static org.junit.Assert.assertArrayEquals; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; @@ -41,40 +38,40 @@ void testModes() throws Exception { SubtourModeChoiceConfigGroup.MODES, "foot,car,balloon" ); assertArrayEquals( - msg, new String[]{"foot", "car", "balloon" }, - group.getModes() ); + group.getModes(), + msg ); assertEquals( - msgString, "foot,car,balloon", group.getValue( - SubtourModeChoiceConfigGroup.MODES )); + SubtourModeChoiceConfigGroup.MODES ), + msgString); group.addParam( SubtourModeChoiceConfigGroup.MODES, " rocket,bike" ); assertArrayEquals( - msg, new String[]{"rocket", "bike" }, - group.getModes() ); + group.getModes(), + msg ); assertEquals( - msgString, "rocket,bike", group.getValue( - SubtourModeChoiceConfigGroup.MODES )); + SubtourModeChoiceConfigGroup.MODES ), + msgString); group.addParam( SubtourModeChoiceConfigGroup.MODES, "skateboard , unicycle " ); assertArrayEquals( - msg, new String[]{"skateboard", "unicycle" }, - group.getModes() ); + group.getModes(), + msg ); assertEquals( - msgString, "skateboard,unicycle", group.getValue( - SubtourModeChoiceConfigGroup.MODES )); + SubtourModeChoiceConfigGroup.MODES ), + msgString); } @Test @@ -87,40 +84,40 @@ void testChainBasedModes() throws Exception { SubtourModeChoiceConfigGroup.CHAINBASEDMODES, "foot,car,balloon" ); assertArrayEquals( - msg, new String[]{"foot", "car", "balloon" }, - group.getChainBasedModes() ); + group.getChainBasedModes(), + msg ); assertEquals( - msgString, "foot,car,balloon", group.getValue( - SubtourModeChoiceConfigGroup.CHAINBASEDMODES)); + SubtourModeChoiceConfigGroup.CHAINBASEDMODES), + msgString); group.addParam( SubtourModeChoiceConfigGroup.CHAINBASEDMODES, " rocket,bike" ); assertArrayEquals( - msg, new String[]{"rocket", "bike" }, - group.getChainBasedModes() ); + group.getChainBasedModes(), + msg ); assertEquals( - msgString, "rocket,bike", group.getValue( - SubtourModeChoiceConfigGroup.CHAINBASEDMODES)); + SubtourModeChoiceConfigGroup.CHAINBASEDMODES), + msgString); group.addParam( SubtourModeChoiceConfigGroup.CHAINBASEDMODES, "skateboard , unicycle " ); assertArrayEquals( - msg, new String[]{"skateboard", "unicycle" }, - group.getChainBasedModes() ); + group.getChainBasedModes(), + msg ); assertEquals( - msgString, "skateboard,unicycle", group.getValue( - SubtourModeChoiceConfigGroup.CHAINBASEDMODES)); + SubtourModeChoiceConfigGroup.CHAINBASEDMODES), + msgString); } @Test @@ -128,18 +125,18 @@ void testCarAvail() throws Exception { SubtourModeChoiceConfigGroup group = new SubtourModeChoiceConfigGroup(); assertFalse( - "default value is not backward compatible", - group.considerCarAvailability() ); + group.considerCarAvailability(), + "default value is not backward compatible" ); group.addParam( SubtourModeChoiceConfigGroup.CARAVAIL, "true" ); - assertTrue( "the value was not set to true" , group.considerCarAvailability() ); + assertTrue( group.considerCarAvailability(), "the value was not set to true" ); group.addParam( SubtourModeChoiceConfigGroup.CARAVAIL, "false" ); - assertFalse( "the value was not set to false" , group.considerCarAvailability() ); + assertFalse( group.considerCarAvailability(), "the value was not set to false" ); } } diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java b/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java index d4b1efc64b6..e889fb576ea 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java @@ -20,8 +20,8 @@ package org.matsim.core.controler; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; import java.util.ArrayList; import java.util.List; @@ -88,10 +88,10 @@ void testEvents() { controler.run(config); //test for startup events StartupEvent startup = listener.getStartupEvent(); - assertNotNull("No ControlerStartupEvent fired!", startup); + assertNotNull(startup, "No ControlerStartupEvent fired!"); //test for shutdown ShutdownEvent shutdown = listener.getShutdownEvent(); - assertNotNull("No ControlerShutdownEvent fired!", shutdown); + assertNotNull(shutdown, "No ControlerShutdownEvent fired!"); //test for iterations //setup List setupIt = listener.getIterationStartsEvents(); diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java index b304f34dbd1..88478e19bb8 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java @@ -20,8 +20,7 @@ package org.matsim.core.controler; -import static org.junit.Assert.*; -import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.*; import static org.matsim.core.config.groups.ControllerConfigGroup.CompressionType; import static org.matsim.core.config.groups.ControllerConfigGroup.SnapshotFormat; @@ -34,7 +33,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.runner.RunWith; @@ -138,13 +137,13 @@ void testConstructor_EventsManagerTypeImmutable() { MatsimServices controler = new Controler(config); try { controler.getConfig().setParam("eventsManager", "numberOfThreads", "2"); - Assert.fail("Expected exception"); + Assertions.fail("Expected exception"); } catch (Exception e) { log.info("catched expected exception", e); } try { controler.getConfig().setParam("eventsManager", "estimatedNumberOfEvents", "200000"); - Assert.fail("Expected exception"); + Assertions.fail("Expected exception"); } catch (Exception e) { log.info("catched expected exception", e); } @@ -222,8 +221,8 @@ void testTravelTimeCalculation() { // test if the travel time calculator got the right result // the actual result is 151sec, not 150, as each vehicle "loses" 1sec in the buffer - assertEquals("TravelTimeCalculator has wrong result", avgTravelTimeLink2, - controler.getLinkTravelTimes().getLinkTravelTime(f.link2, 7 * 3600, null, null), MatsimTestUtils.EPSILON); + assertEquals(avgTravelTimeLink2, + controler.getLinkTravelTimes().getLinkTravelTime(f.link2, 7 * 3600, null, null), MatsimTestUtils.EPSILON, "TravelTimeCalculator has wrong result"); // now test that the ReRoute-Strategy also knows about these travel times... config.controller().setLastIteration(1); @@ -239,8 +238,8 @@ void testTravelTimeCalculation() { // test that the plans have the correct travel times // (travel time of the plan does not contain first and last link) - assertEquals("ReRoute seems to have wrong travel times.", avgTravelTimeLink2, - ((Leg)(person1.getPlans().get(1).getPlanElements().get(1))).getTravelTime().seconds(), MatsimTestUtils.EPSILON); + assertEquals(avgTravelTimeLink2, + ((Leg)(person1.getPlans().get(1).getPlanElements().get(1))).getTravelTime().seconds(), MatsimTestUtils.EPSILON, "ReRoute seems to have wrong travel times."); } /** @@ -288,8 +287,8 @@ public Mobsim get() { controler.getConfig().controller().setDumpDataAtEnd(false); controler.run(); - assertTrue("Custom ScoringFunctionFactory was not set.", - controler.getScoringFunctionFactory() instanceof DummyScoringFunctionFactory); + assertTrue(controler.getScoringFunctionFactory() instanceof DummyScoringFunctionFactory, + "Custom ScoringFunctionFactory was not set."); } /** @@ -372,12 +371,12 @@ public Mobsim get() { // but do not assume that the leg will be the same instance... for (Plan plan : new Plan[]{plan1, plan2}) { assertEquals( - "unexpected plan length in "+plan.getPlanElements(), 3, - plan.getPlanElements().size()); + plan.getPlanElements().size(), + "unexpected plan length in "+plan.getPlanElements()); assertNotNull( - "null route in plan "+plan.getPlanElements(), - ((Leg) plan.getPlanElements().get( 1 )).getRoute()); + ((Leg) plan.getPlanElements().get( 1 )).getRoute(), + "null route in plan "+plan.getPlanElements()); } } @@ -482,16 +481,16 @@ public Mobsim get() { // but do not assume that the leg will be the same instance... for (Plan plan : new Plan[]{plan1, plan2}) { assertEquals( - "unexpected plan length in "+plan.getPlanElements(), expectedPlanLength, - plan.getPlanElements().size()); + plan.getPlanElements().size(), + "unexpected plan length in "+plan.getPlanElements()); assertNotNull( - "null route in plan "+plan.getPlanElements(), - ((Leg) plan.getPlanElements().get( 1 )).getRoute()); + ((Leg) plan.getPlanElements().get( 1 )).getRoute(), + "null route in plan "+plan.getPlanElements()); if ( !f.scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { assertNotNull( - "null route in plan "+plan.getPlanElements(), - ((Leg) plan.getPlanElements().get( 3 )).getRoute()); + ((Leg) plan.getPlanElements().get( 3 )).getRoute(), + "null route in plan "+plan.getPlanElements()); } } } @@ -545,8 +544,8 @@ void testSetWriteEventsInterval() { config.controller().setWritePlansInterval(0); final Controler controler = new Controler(config); - assertFalse("Default for Controler.writeEventsInterval should be different from the interval we plan to use, otherwise it's hard to decide if it works correctly.", - 3 == controler.getConfig().controller().getWriteEventsInterval()); + assertFalse(3 == controler.getConfig().controller().getWriteEventsInterval(), + "Default for Controler.writeEventsInterval should be different from the interval we plan to use, otherwise it's hard to decide if it works correctly."); controler.getConfig().controller().setWriteEventsInterval(3); assertEquals(3, controler.getConfig().controller().getWriteEventsInterval()); @@ -589,8 +588,8 @@ void testSetWriteEventsIntervalConfig() { config.controller().setWritePlansInterval(0); final Controler controler = new Controler(config); - assertFalse("Default for Controler.writeEventsInterval should be different from the interval we plan to use, otherwise it's hard to decide if it works correctly.", - 3 == controler.getConfig().controller().getWriteEventsInterval()); + assertFalse(3 == controler.getConfig().controller().getWriteEventsInterval(), + "Default for Controler.writeEventsInterval should be different from the interval we plan to use, otherwise it's hard to decide if it works correctly."); controler.getConfig().controller().setCreateGraphs(false); controler.addOverridingModule(new AbstractModule() { @Override @@ -630,8 +629,8 @@ void testSetWriteEventsNever() { config.controller().setWritePlansInterval(0); final Controler controler = new Controler(config); - assertFalse("Default for Controler.writeEventsInterval should be different from the interval we plan to use, otherwise it's hard to decide if it works correctly.", - 0 == controler.getConfig().controller().getWriteEventsInterval()); + assertFalse(0 == controler.getConfig().controller().getWriteEventsInterval(), + "Default for Controler.writeEventsInterval should be different from the interval we plan to use, otherwise it's hard to decide if it works correctly."); controler.getConfig().controller().setWriteEventsInterval(0); assertEquals(0, controler.getConfig().controller().getWriteEventsInterval()); controler.getConfig().controller().setCreateGraphs(false); @@ -819,7 +818,7 @@ public Mobsim get() { controler.getConfig().controller().setCreateGraphs(false); controler.getConfig().controller().setDumpDataAtEnd(false); controler.run(); - Assert.fail("expected exception, got none."); + Assertions.fail("expected exception, got none."); // note: I moved loadScenario in the controler from run() into the constructor to mirror the loading sequence one has // when calling new Controler(scenario). In consequence, it fails already in the constructor; one could stop after that. @@ -854,7 +853,7 @@ public Mobsim get() { controler.getConfig().controller().setCreateGraphs(false); controler.getConfig().controller().setDumpDataAtEnd(false); controler.run(); - Assert.fail("expected exception, got none."); + Assertions.fail("expected exception, got none."); // note: I moved loadScenario in the controler from run() into the constructor to mirror the loading sequence one has // when calling new Controler(scenario). In consequence, it fails already in the constructor; one could stop after that. @@ -889,7 +888,7 @@ public Mobsim get() { controler.getConfig().controller().setCreateGraphs(false); controler.getConfig().controller().setDumpDataAtEnd(false); controler.run(); - Assert.fail("expected exception, got none."); + Assertions.fail("expected exception, got none."); // note: I moved loadScenario in the controler from run() into the constructor to mirror the loading sequence one has // when calling new Controler(scenario). In consequence, it fails already in the constructor; one could stop after that. @@ -974,10 +973,10 @@ public void install() { controler.run(); - Assert.assertSame( - "adding a Guice module to the controler from a Guice module is allowed but has no effect", + Assertions.assertSame( replacementScenario, - controler.getScenario()); + controler.getScenario(), + "adding a Guice module to the controler from a Guice module is allowed but has no effect"); }); } diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerListenerManagerImplTest.java b/matsim/src/test/java/org/matsim/core/controler/ControlerListenerManagerImplTest.java index 762a73afc2e..2705f6444af 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerListenerManagerImplTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerListenerManagerImplTest.java @@ -21,7 +21,7 @@ package org.matsim.core.controler; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.controler.events.IterationStartsEvent; import org.matsim.core.controler.events.ShutdownEvent; @@ -30,7 +30,7 @@ import org.matsim.core.controler.listener.ShutdownListener; import org.matsim.core.controler.listener.StartupListener; - /** + /** * @author mrieser / senozon */ public class ControlerListenerManagerImplTest { @@ -44,32 +44,32 @@ void testAddControlerListener_ClassHierarchy() { m.addControlerListener(ecl); m.fireControlerStartupEvent(); - Assert.assertEquals(1, ccl.nOfStartups); - Assert.assertEquals(0, ccl.nOfIterStarts); - Assert.assertEquals(1, ecl.nOfStartups); - Assert.assertEquals(0, ecl.nOfIterStarts); - Assert.assertEquals(0, ecl.nOfShutdowns); + Assertions.assertEquals(1, ccl.nOfStartups); + Assertions.assertEquals(0, ccl.nOfIterStarts); + Assertions.assertEquals(1, ecl.nOfStartups); + Assertions.assertEquals(0, ecl.nOfIterStarts); + Assertions.assertEquals(0, ecl.nOfShutdowns); m.fireControlerIterationStartsEvent(0, false); - Assert.assertEquals(1, ccl.nOfStartups); - Assert.assertEquals(1, ccl.nOfIterStarts); - Assert.assertEquals(1, ecl.nOfStartups); - Assert.assertEquals(1, ecl.nOfIterStarts); - Assert.assertEquals(0, ecl.nOfShutdowns); + Assertions.assertEquals(1, ccl.nOfStartups); + Assertions.assertEquals(1, ccl.nOfIterStarts); + Assertions.assertEquals(1, ecl.nOfStartups); + Assertions.assertEquals(1, ecl.nOfIterStarts); + Assertions.assertEquals(0, ecl.nOfShutdowns); m.fireControlerIterationStartsEvent(1, false); - Assert.assertEquals(1, ccl.nOfStartups); - Assert.assertEquals(2, ccl.nOfIterStarts); - Assert.assertEquals(1, ecl.nOfStartups); - Assert.assertEquals(2, ecl.nOfIterStarts); - Assert.assertEquals(0, ecl.nOfShutdowns); + Assertions.assertEquals(1, ccl.nOfStartups); + Assertions.assertEquals(2, ccl.nOfIterStarts); + Assertions.assertEquals(1, ecl.nOfStartups); + Assertions.assertEquals(2, ecl.nOfIterStarts); + Assertions.assertEquals(0, ecl.nOfShutdowns); m.fireControlerShutdownEvent(false, 1); - Assert.assertEquals(1, ccl.nOfStartups); - Assert.assertEquals(2, ccl.nOfIterStarts); - Assert.assertEquals(1, ecl.nOfStartups); - Assert.assertEquals(2, ecl.nOfIterStarts); - Assert.assertEquals(1, ecl.nOfShutdowns); + Assertions.assertEquals(1, ccl.nOfStartups); + Assertions.assertEquals(2, ccl.nOfIterStarts); + Assertions.assertEquals(1, ecl.nOfStartups); + Assertions.assertEquals(2, ecl.nOfIterStarts); + Assertions.assertEquals(1, ecl.nOfShutdowns); } @Test @@ -81,32 +81,32 @@ void testAddCoreControlerListener_ClassHierarchy() { m.addCoreControlerListener(ecl); m.fireControlerStartupEvent(); - Assert.assertEquals(1, ccl.nOfStartups); - Assert.assertEquals(0, ccl.nOfIterStarts); - Assert.assertEquals(1, ecl.nOfStartups); - Assert.assertEquals(0, ecl.nOfIterStarts); - Assert.assertEquals(0, ecl.nOfShutdowns); + Assertions.assertEquals(1, ccl.nOfStartups); + Assertions.assertEquals(0, ccl.nOfIterStarts); + Assertions.assertEquals(1, ecl.nOfStartups); + Assertions.assertEquals(0, ecl.nOfIterStarts); + Assertions.assertEquals(0, ecl.nOfShutdowns); m.fireControlerIterationStartsEvent(0, false); - Assert.assertEquals(1, ccl.nOfStartups); - Assert.assertEquals(1, ccl.nOfIterStarts); - Assert.assertEquals(1, ecl.nOfStartups); - Assert.assertEquals(1, ecl.nOfIterStarts); - Assert.assertEquals(0, ecl.nOfShutdowns); + Assertions.assertEquals(1, ccl.nOfStartups); + Assertions.assertEquals(1, ccl.nOfIterStarts); + Assertions.assertEquals(1, ecl.nOfStartups); + Assertions.assertEquals(1, ecl.nOfIterStarts); + Assertions.assertEquals(0, ecl.nOfShutdowns); m.fireControlerIterationStartsEvent(1, false); - Assert.assertEquals(1, ccl.nOfStartups); - Assert.assertEquals(2, ccl.nOfIterStarts); - Assert.assertEquals(1, ecl.nOfStartups); - Assert.assertEquals(2, ecl.nOfIterStarts); - Assert.assertEquals(0, ecl.nOfShutdowns); + Assertions.assertEquals(1, ccl.nOfStartups); + Assertions.assertEquals(2, ccl.nOfIterStarts); + Assertions.assertEquals(1, ecl.nOfStartups); + Assertions.assertEquals(2, ecl.nOfIterStarts); + Assertions.assertEquals(0, ecl.nOfShutdowns); m.fireControlerShutdownEvent(false, 1); - Assert.assertEquals(1, ccl.nOfStartups); - Assert.assertEquals(2, ccl.nOfIterStarts); - Assert.assertEquals(1, ecl.nOfStartups); - Assert.assertEquals(2, ecl.nOfIterStarts); - Assert.assertEquals(1, ecl.nOfShutdowns); + Assertions.assertEquals(1, ccl.nOfStartups); + Assertions.assertEquals(2, ccl.nOfIterStarts); + Assertions.assertEquals(1, ecl.nOfStartups); + Assertions.assertEquals(2, ecl.nOfIterStarts); + Assertions.assertEquals(1, ecl.nOfShutdowns); } private static class CountingControlerListener implements StartupListener, IterationStartsListener { diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java b/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java index af2cf20fe23..3659acdf9f6 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerMobsimIntegrationTest.java @@ -24,7 +24,7 @@ import com.google.inject.Provider; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -69,7 +69,7 @@ public Mobsim get() { c.getConfig().controller().setDumpDataAtEnd(false); c.getConfig().controller().setWriteEventsInterval(0); c.run(); - Assert.assertEquals(1, mf.callCount); + Assertions.assertEquals(1, mf.callCount); } @Test diff --git a/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java b/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java index 1bb0b102e20..79e6db37f10 100644 --- a/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java @@ -21,8 +21,8 @@ package org.matsim.core.controler; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.config.Config; @@ -31,7 +31,7 @@ import org.matsim.core.controler.listener.IterationStartsListener; import org.matsim.testcases.MatsimTestUtils; - public class MatsimServicesImplTest { + public class MatsimServicesImplTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); @@ -53,7 +53,7 @@ public void install() { @Override public void notifyIterationStarts(IterationStartsEvent event) { - Assert.assertSame(event.getIteration(), event.getServices().getIterationNumber()); + Assertions.assertSame(event.getIteration(), event.getServices().getIterationNumber()); } diff --git a/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java b/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java index 76d790ebe04..5fa3ccb628a 100644 --- a/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/OutputDirectoryHierarchyTest.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.core.controler; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.config.groups.ControllerConfigGroup; @@ -48,9 +48,9 @@ void testFailureIfDirectoryExists() { OutputDirectoryHierarchy.OverwriteFileSetting.failIfDirectoryExists, ControllerConfigGroup.CompressionType.none); - Assert.assertTrue( - "Directory was not created", - new File( outputDirectory ).exists() ); + Assertions.assertTrue( + new File( outputDirectory ).exists(), + "Directory was not created" ); // put something in the directory try ( final BufferedWriter writer = IOUtils.getBufferedWriter( outputDirectory+"/some_file" ) ) { @@ -70,7 +70,7 @@ void testFailureIfDirectoryExists() { catch ( RuntimeException e ) { return; } - Assert.fail( "no exception thrown when directory exists!" ); + Assertions.fail( "no exception thrown when directory exists!" ); } @Test @@ -84,9 +84,9 @@ void testOverrideIfDirectoryExists() { OutputDirectoryHierarchy.OverwriteFileSetting.overwriteExistingFiles, ControllerConfigGroup.CompressionType.none); - Assert.assertTrue( - "Directory was not created", - new File( outputDirectory ).exists() ); + Assertions.assertTrue( + new File( outputDirectory ).exists(), + "Directory was not created" ); // put something in the directory try ( final BufferedWriter writer = IOUtils.getBufferedWriter( outputDirectory+"/some_file" ) ) { @@ -102,9 +102,9 @@ void testOverrideIfDirectoryExists() { OutputDirectoryHierarchy.OverwriteFileSetting.overwriteExistingFiles, ControllerConfigGroup.CompressionType.none); - Assert.assertTrue( - "Directory was cleared", - new File( outputDirectory+"/some_file" ).exists() ); + Assertions.assertTrue( + new File( outputDirectory+"/some_file" ).exists(), + "Directory was cleared" ); } @@ -119,9 +119,9 @@ void testDeleteIfDirectoryExists() { OutputDirectoryHierarchy.OverwriteFileSetting.deleteDirectoryIfExists, ControllerConfigGroup.CompressionType.none); - Assert.assertTrue( - "Directory was not created", - new File( outputDirectory ).exists() ); + Assertions.assertTrue( + new File( outputDirectory ).exists(), + "Directory was not created" ); // put something in the directory try ( final BufferedWriter writer = IOUtils.getBufferedWriter( outputDirectory+"/some_file" ) ) { @@ -137,13 +137,13 @@ void testDeleteIfDirectoryExists() { OutputDirectoryHierarchy.OverwriteFileSetting.deleteDirectoryIfExists, ControllerConfigGroup.CompressionType.none); - Assert.assertTrue( - "Directory was deleted but not re-created!", - new File( outputDirectory ).exists() ); + Assertions.assertTrue( + new File( outputDirectory ).exists(), + "Directory was deleted but not re-created!" ); - Assert.assertFalse( - "Directory was not cleared", - new File( outputDirectory+"/some_file" ).exists() ); + Assertions.assertFalse( + new File( outputDirectory+"/some_file" ).exists(), + "Directory was not cleared" ); } } diff --git a/matsim/src/test/java/org/matsim/core/controler/OverrideCarTraveltimeTest.java b/matsim/src/test/java/org/matsim/core/controler/OverrideCarTraveltimeTest.java index ff00e8c4fac..941b7e749ee 100644 --- a/matsim/src/test/java/org/matsim/core/controler/OverrideCarTraveltimeTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/OverrideCarTraveltimeTest.java @@ -20,9 +20,7 @@ * *********************************************************************** */ package org.matsim.core.controler; - - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.Person; @@ -39,7 +37,7 @@ import jakarta.inject.Inject; import java.util.Map; -public class OverrideCarTraveltimeTest { + public class OverrideCarTraveltimeTest { public static void main(String[] args) { final Config config = ConfigUtils.createConfig(); @@ -94,8 +92,8 @@ private static class InterestingControlerListener implements ReplanningListener @Override public void notifyReplanning(ReplanningEvent event) { - Assert.assertEquals(42.0, travelTimes.get(TransportMode.car).getLinkTravelTime(null, 0.0, null, null), 0.0); - Assert.assertEquals(37.0, travelDisutilities.get(TransportMode.car).createTravelDisutility(travelTimes.get(TransportMode.car)).getLinkTravelDisutility(null, 0.0, null, null), 0.0); + Assertions.assertEquals(42.0, travelTimes.get(TransportMode.car).getLinkTravelTime(null, 0.0, null, null), 0.0); + Assertions.assertEquals(37.0, travelDisutilities.get(TransportMode.car).createTravelDisutility(travelTimes.get(TransportMode.car)).getLinkTravelDisutility(null, 0.0, null, null), 0.0); } } } diff --git a/matsim/src/test/java/org/matsim/core/controler/PrepareForSimImplTest.java b/matsim/src/test/java/org/matsim/core/controler/PrepareForSimImplTest.java index 582276839b3..424631dd064 100644 --- a/matsim/src/test/java/org/matsim/core/controler/PrepareForSimImplTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/PrepareForSimImplTest.java @@ -21,7 +21,7 @@ import java.util.*; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -102,8 +102,9 @@ void testSingleLegTripRoutingMode() { prepareForSimImpl.run(); - Assert.assertEquals("wrong routing mode!", TransportMode.pt, - TripStructureUtils.getRoutingMode(leg)); + Assertions.assertEquals(TransportMode.pt, + TripStructureUtils.getRoutingMode(leg), + "wrong routing mode!"); } // test routing mode set, such as after TripsToLegsAlgorithm + replanning strategy @@ -129,8 +130,9 @@ void testSingleLegTripRoutingMode() { prepareForSimImpl.run(); - Assert.assertEquals("wrong routing mode!", TransportMode.pt, - TripStructureUtils.getRoutingMode(leg)); + Assertions.assertEquals(TransportMode.pt, + TripStructureUtils.getRoutingMode(leg), + "wrong routing mode!"); } } @@ -165,9 +167,10 @@ void testSingleFallbackModeLegTrip() { prepareForSimImpl.run(); - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg.getMode()); - Assert.assertEquals("wrong routing mode!", TransportMode.pt, - TripStructureUtils.getRoutingMode(leg)); + Assertions.assertEquals(TransportMode.walk, leg.getMode(), "wrong leg mode replacement!"); + Assertions.assertEquals(TransportMode.pt, + TripStructureUtils.getRoutingMode(leg), + "wrong routing mode!"); } // test outdated fallback mode single leg trip (arbitrary drt mode) @@ -193,9 +196,10 @@ void testSingleFallbackModeLegTrip() { prepareForSimImpl.run(); - Assert.assertEquals("wrong leg mode replacement", TransportMode.walk, leg.getMode()); - Assert.assertEquals("wrong routing mode!", "drt67", - TripStructureUtils.getRoutingMode(leg)); + Assertions.assertEquals(TransportMode.walk, leg.getMode(), "wrong leg mode replacement"); + Assertions.assertEquals("drt67", + TripStructureUtils.getRoutingMode(leg), + "wrong routing mode!"); } } @@ -242,14 +246,14 @@ void testCorrectTripsRemainUnchanged() { prepareForSimImpl.run(); // Check leg modes remain unchanged - Assert.assertEquals("wrong leg mode!", TransportMode.walk, leg1.getMode()); - Assert.assertEquals("wrong routing mode!", TransportMode.car, leg2.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.walk, leg3.getMode()); + Assertions.assertEquals(TransportMode.walk, leg1.getMode(), "wrong leg mode!"); + Assertions.assertEquals(TransportMode.car, leg2.getMode(), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.walk, leg3.getMode(), "wrong leg mode!"); // Check routing mode: - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg1)); - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg2)); - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg3)); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg1), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg2), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg3), "wrong routing mode!"); } // test complicated intermodal trip with consistent routing modes passes unchanged @@ -339,29 +343,29 @@ void testCorrectTripsRemainUnchanged() { // TODO: Currently all TransportMode.non_network_walk legs are replaced by TransportMode.walk, so we cannot check // the correct handling of them right now. // Assert.assertEquals("wrong routing mode!", TransportMode.non_network_walk, leg1.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.walk, leg2.getMode()); + Assertions.assertEquals(TransportMode.walk, leg2.getMode(), "wrong leg mode!"); // Assert.assertEquals("wrong routing mode!", TransportMode.non_network_walk, leg3.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.drt, leg4.getMode()); + Assertions.assertEquals(TransportMode.drt, leg4.getMode(), "wrong leg mode!"); // Assert.assertEquals("wrong routing mode!", TransportMode.non_network_walk, leg5.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.walk, leg6.getMode()); + Assertions.assertEquals(TransportMode.walk, leg6.getMode(), "wrong leg mode!"); // Assert.assertEquals("wrong routing mode!", TransportMode.non_network_walk, leg7.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.pt, leg8.getMode()); + Assertions.assertEquals(TransportMode.pt, leg8.getMode(), "wrong leg mode!"); // Assert.assertEquals("wrong routing mode!", TransportMode.non_network_walk, leg9.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.walk, leg10.getMode()); + Assertions.assertEquals(TransportMode.walk, leg10.getMode(), "wrong leg mode!"); // Assert.assertEquals("wrong routing mode!", TransportMode.non_network_walk, leg11.getMode()); // Check routing mode remains unchanged - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg1)); - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg2)); - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg3)); - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg4)); - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg5)); - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg6)); - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg7)); - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg8)); - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg9)); - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg10)); - Assert.assertEquals("wrong routing mode!", "intermodal pt", TripStructureUtils.getRoutingMode(leg11)); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg1), "wrong routing mode!"); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg2), "wrong routing mode!"); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg3), "wrong routing mode!"); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg4), "wrong routing mode!"); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg5), "wrong routing mode!"); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg6), "wrong routing mode!"); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg7), "wrong routing mode!"); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg8), "wrong routing mode!"); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg9), "wrong routing mode!"); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg10), "wrong routing mode!"); + Assertions.assertEquals("intermodal pt", TripStructureUtils.getRoutingMode(leg11), "wrong routing mode!"); } } @@ -406,7 +410,7 @@ void testRoutingModeConsistency() { config.plans(), new MainModeIdentifierImpl(), TimeInterpretation.create(config)); prepareForSimImpl.run(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} } @@ -443,7 +447,7 @@ void testRoutingModeConsistency() { config.plans(), new MainModeIdentifierImpl(), TimeInterpretation.create(config)); prepareForSimImpl.run(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} } } @@ -492,7 +496,7 @@ void testOutdatedHelperModesReplacement() { config.plans(), new MainModeIdentifierImpl(), TimeInterpretation.create(config)); prepareForSimImpl.run(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} // Should work with config.plans().setHandlingOfPlansWithoutRoutingMode(HandlingOfPlansWithoutRoutingMode.useMainModeIdentifier); @@ -504,14 +508,14 @@ void testOutdatedHelperModesReplacement() { prepareForSimImpl.run(); // Check replacement of outdated helper modes. - Assert.assertEquals("wrong leg mode!", TransportMode.walk, leg1.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.car, leg2.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.walk, leg3.getMode()); + Assertions.assertEquals(TransportMode.walk, leg1.getMode(), "wrong leg mode!"); + Assertions.assertEquals(TransportMode.car, leg2.getMode(), "wrong leg mode!"); + Assertions.assertEquals(TransportMode.walk, leg3.getMode(), "wrong leg mode!"); // Check routing mode: - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg1)); - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg2)); - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg3)); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg1), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg2), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg3), "wrong routing mode!"); } // test car trip with outdated access/egress walk modes @@ -550,7 +554,7 @@ void testOutdatedHelperModesReplacement() { config.plans(), new MainModeIdentifierImpl(), TimeInterpretation.create(config)); prepareForSimImpl.run(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} // Should work with config.plans().setHandlingOfPlansWithoutRoutingMode(HandlingOfPlansWithoutRoutingMode.useMainModeIdentifier); @@ -562,14 +566,14 @@ void testOutdatedHelperModesReplacement() { prepareForSimImpl.run(); // Check replacement of outdated helper modes. - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg1.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.car, leg2.getMode()); - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg3.getMode()); + Assertions.assertEquals(TransportMode.walk, leg1.getMode(), "wrong leg mode replacement!"); + Assertions.assertEquals(TransportMode.car, leg2.getMode(), "wrong leg mode!"); + Assertions.assertEquals(TransportMode.walk, leg3.getMode(), "wrong leg mode replacement!"); // Check routing mode: - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg1)); - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg2)); - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg3)); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg1), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg2), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg3), "wrong routing mode!"); } // test complicated intermodal drt+pt trip with outdated access/egress walk modes @@ -632,7 +636,7 @@ void testOutdatedHelperModesReplacement() { config.plans(), new MainModeIdentifierImpl(), TimeInterpretation.create(config)); prepareForSimImpl.run(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} // Should work with config.plans().setHandlingOfPlansWithoutRoutingMode(HandlingOfPlansWithoutRoutingMode.useMainModeIdentifier); @@ -644,13 +648,13 @@ void testOutdatedHelperModesReplacement() { prepareForSimImpl.run(); // Check replacement of outdated helper modes. - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg1.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.drt, leg2.getMode()); - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg3.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.pt, leg4.getMode()); - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg5.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.pt, leg6.getMode()); - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg7.getMode()); + Assertions.assertEquals(TransportMode.walk, leg1.getMode(), "wrong leg mode replacement!"); + Assertions.assertEquals(TransportMode.drt, leg2.getMode(), "wrong leg mode!"); + Assertions.assertEquals(TransportMode.walk, leg3.getMode(), "wrong leg mode replacement!"); + Assertions.assertEquals(TransportMode.pt, leg4.getMode(), "wrong leg mode!"); + Assertions.assertEquals(TransportMode.walk, leg5.getMode(), "wrong leg mode replacement!"); + Assertions.assertEquals(TransportMode.pt, leg6.getMode(), "wrong leg mode!"); + Assertions.assertEquals(TransportMode.walk, leg7.getMode(), "wrong leg mode replacement!"); /* * Check routing mode: @@ -661,13 +665,13 @@ void testOutdatedHelperModesReplacement() { * For the scope of this test it is sufficient, that the MainModeIdentifier is run, returns a main mode * and that this main mode is assigned as routingMode to all legs. */ - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg1)); - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg2)); - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg3)); - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg4)); - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg5)); - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg6)); - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg7)); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg1), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg2), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg3), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg4), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg5), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg6), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg7), "wrong routing mode!"); } } @@ -727,7 +731,7 @@ void testOutdatedFallbackAndHelperModesReplacement() { config.plans(), new MainModeIdentifierImpl(), TimeInterpretation.create(config)); prepareForSimImpl.run(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} // Should work with config.plans().setHandlingOfPlansWithoutRoutingMode(HandlingOfPlansWithoutRoutingMode.useMainModeIdentifier); @@ -739,11 +743,11 @@ void testOutdatedFallbackAndHelperModesReplacement() { prepareForSimImpl.run(); // Check replacement of outdated helper modes. - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg1.getMode()); - Assert.assertEquals("wrong leg mode!", TransportMode.drt, leg2.getMode()); - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg3.getMode()); - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg4.getMode()); - Assert.assertEquals("wrong leg mode replacement!", TransportMode.walk, leg5.getMode()); + Assertions.assertEquals(TransportMode.walk, leg1.getMode(), "wrong leg mode replacement!"); + Assertions.assertEquals(TransportMode.drt, leg2.getMode(), "wrong leg mode!"); + Assertions.assertEquals(TransportMode.walk, leg3.getMode(), "wrong leg mode replacement!"); + Assertions.assertEquals(TransportMode.walk, leg4.getMode(), "wrong leg mode replacement!"); + Assertions.assertEquals(TransportMode.walk, leg5.getMode(), "wrong leg mode replacement!"); /* * Check routing mode: @@ -754,11 +758,11 @@ void testOutdatedFallbackAndHelperModesReplacement() { * For the scope of thios test it is sufficient, that the MainModeIdentifier is run, returns a main mode * and that this main mode is assigned as routingMode to all legs. */ - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg1)); - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg2)); - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg3)); - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg4)); - Assert.assertEquals("wrong routing mode!", TransportMode.drt, TripStructureUtils.getRoutingMode(leg5)); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg1), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg2), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg3), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg4), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.drt, TripStructureUtils.getRoutingMode(leg5), "wrong routing mode!"); } } diff --git a/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java b/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java index cd9a12401fe..bf276c9c0b6 100644 --- a/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/TerminationTest.java @@ -2,7 +2,7 @@ import java.io.File; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -37,24 +37,24 @@ public class TerminationTest { void testSimulationEndsOnInterval() { prepareExperiment(2, 4, ControllerConfigGroup.CleanIterations.keep).run(); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.4/4.events.xml.gz").exists()); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/output_events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.4/4.events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/output_events.xml.gz").exists()); long iterationOutput = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/ITERS/it.4/4.events.xml.gz"); long mainOutput = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/output_events.xml.gz"); - Assert.assertEquals(iterationOutput, mainOutput); + Assertions.assertEquals(iterationOutput, mainOutput); } @Test void testOnlyRunIterationZero() { prepareExperiment(2, 0, ControllerConfigGroup.CleanIterations.keep).run(); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.0/0.events.xml.gz").exists()); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/output_events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.0/0.events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/output_events.xml.gz").exists()); long iterationOutput = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/ITERS/it.0/0.events.xml.gz"); long mainOutput = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/output_events.xml.gz"); - Assert.assertEquals(iterationOutput, mainOutput); + Assertions.assertEquals(iterationOutput, mainOutput); } @Test @@ -64,19 +64,19 @@ void testSimulationEndsOffInterval() { prepareExperiment(2, 3, ControllerConfigGroup.CleanIterations.keep).run(); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.2/2.events.xml.gz").exists()); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.3/3.events.xml.gz").exists()); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/output_events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.2/2.events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.3/3.events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/output_events.xml.gz").exists()); long iterationOutput = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/ITERS/it.3/3.events.xml.gz"); long mainOutput = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/output_events.xml.gz"); - Assert.assertEquals(iterationOutput, mainOutput); + Assertions.assertEquals(iterationOutput, mainOutput); } @Test void testSimulationEndDeleteIters() { prepareExperiment(2, 3, ControllerConfigGroup.CleanIterations.delete).run(); - Assert.assertFalse(new File(utils.getOutputDirectory(), "/ITERS").exists()); + Assertions.assertFalse(new File(utils.getOutputDirectory(), "/ITERS").exists()); } private Controler prepareExperiment(int interval, int criterion, ControllerConfigGroup.CleanIterations iters) { @@ -114,14 +114,14 @@ public boolean doTerminate(int iteration) { controller.run(); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.2/2.events.xml.gz").exists()); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.3/3.events.xml.gz").exists()); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.4/4.events.xml.gz").exists()); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/output_events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.2/2.events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.3/3.events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.4/4.events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/output_events.xml.gz").exists()); long iterationOutput = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/ITERS/it.4/4.events.xml.gz"); long mainOutput = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/output_events.xml.gz"); - Assert.assertEquals(iterationOutput, mainOutput); + Assertions.assertEquals(iterationOutput, mainOutput); } @Test @@ -170,14 +170,14 @@ public void install() { controler.run(); - Assert.assertEquals(12, (int) controler.getIterationNumber()); + Assertions.assertEquals(12, (int) controler.getIterationNumber()); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.12/12.events.xml.gz").exists()); - Assert.assertTrue(new File(utils.getOutputDirectory(), "/output_events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/ITERS/it.12/12.events.xml.gz").exists()); + Assertions.assertTrue(new File(utils.getOutputDirectory(), "/output_events.xml.gz").exists()); long iterationOutput = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/ITERS/it.12/12.events.xml.gz"); long mainOutput = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/output_events.xml.gz"); - Assert.assertEquals(iterationOutput, mainOutput); + Assertions.assertEquals(iterationOutput, mainOutput); } @Singleton diff --git a/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java b/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java index c2be0f5b584..10d912cfe9d 100644 --- a/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/TransitControlerIntegrationTest.java @@ -20,12 +20,12 @@ package org.matsim.core.controler; -import static org.junit.Assert.assertEquals; - import java.util.ArrayList; import java.util.Collections; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; diff --git a/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java b/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java index bf569a37ec6..a7d15e09856 100644 --- a/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/corelisteners/ListenersInjectionTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.core.controler.corelisteners; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.analysis.IterationStopWatch; @@ -98,10 +98,10 @@ public void install() { final ControlerListener o1 = injector.getInstance( klass ); final ControlerListener o2 = injector.getInstance( klass ); - Assert.assertSame( - "Two different instances of "+klass.getName()+" returned by injector!", + Assertions.assertSame( o1, - o2 ); + o2, + "Two different instances of "+klass.getName()+" returned by injector!" ); } } diff --git a/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java b/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java index a686c394e77..e1c992d5e45 100644 --- a/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java +++ b/matsim/src/test/java/org/matsim/core/controler/corelisteners/PlansDumpingIT.java @@ -27,8 +27,8 @@ import java.io.File; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertFalse; +import static org.junit.jupiter.api.Assertions.assertTrue; /** * @author mrieser diff --git a/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java b/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java index fe6e6f93cef..b81e448daa3 100644 --- a/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/ActEndEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java b/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java index c0a64d343d4..ec074cd0fd7 100644 --- a/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/ActStartEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java b/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java index b0645c6f797..219d9fcec2d 100644 --- a/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/AgentMoneyEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java b/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java index 0bc24ebe510..b25eafec20c 100644 --- a/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/AgentWaitingForPtEventTest.java @@ -19,7 +19,7 @@ package org.matsim.core.events; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -44,10 +44,10 @@ void testReadWriteXml() { double time = 5.0 * 3600 + 11.0 + 60; AgentWaitingForPtEvent event = new AgentWaitingForPtEvent(time, person.getId(), waitStopId, destinationStopId); AgentWaitingForPtEvent event2 = XmlEventsTester.testWriteReadXml(helper.getOutputDirectory() + "events.xml", event); - Assert.assertEquals("wrong time of event.", time, event2.getTime(), 1e-8); - Assert.assertEquals("1", event2.getPersonId().toString()); - Assert.assertEquals("1980", event2.getWaitingAtStopId().toString()); - Assert.assertEquals("0511", event2.getDestinationStopId().toString()); + Assertions.assertEquals(time, event2.getTime(), 1e-8, "wrong time of event."); + Assertions.assertEquals("1", event2.getPersonId().toString()); + Assertions.assertEquals("1980", event2.getWaitingAtStopId().toString()); + Assertions.assertEquals("0511", event2.getDestinationStopId().toString()); } } diff --git a/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java b/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java index 86fd56add98..8ef75877488 100644 --- a/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java +++ b/matsim/src/test/java/org/matsim/core/events/BasicEventsHandlerTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -61,7 +61,7 @@ void testLinkEnterEventHandler() { events.processEvent(new LinkEnterEvent(8.0*3600, Id.create("veh", Vehicle.class), link1.getId())); events.finishProcessing(); - assertEquals("expected number of handled events wrong.", 1, handler.counter); + assertEquals(1, handler.counter, "expected number of handled events wrong."); } diff --git a/matsim/src/test/java/org/matsim/core/events/CustomEventTest.java b/matsim/src/test/java/org/matsim/core/events/CustomEventTest.java index bee022f3d97..c7501de96e7 100644 --- a/matsim/src/test/java/org/matsim/core/events/CustomEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/CustomEventTest.java @@ -28,7 +28,7 @@ import java.util.ArrayList; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; @@ -100,12 +100,12 @@ public void reset(int iteration) { Id.createPersonId(event.getAttributes().get("person")))); eventsReaderXMLv1.parse(new ByteArrayInputStream(buf)); eventsManager2.finishProcessing(); - Assert.assertEquals(1, oneEvent.size()); + Assertions.assertEquals(1, oneEvent.size()); Event event = oneEvent.get(0); - Assert.assertTrue(event instanceof RainOnPersonEvent); + Assertions.assertTrue(event instanceof RainOnPersonEvent); RainOnPersonEvent ropEvent = ((RainOnPersonEvent)event); - Assert.assertEquals(0.0, ropEvent.getTime(), 1e-7); - Assert.assertEquals(Id.createPersonId("wurst"), ropEvent.getPersonId()); + Assertions.assertEquals(0.0, ropEvent.getTime(), 1e-7); + Assertions.assertEquals(Id.createPersonId("wurst"), ropEvent.getPersonId()); } @Test @@ -139,12 +139,12 @@ public void reset(int iteration) { Id.createPersonId(event.getAttributes().get("person")))); eventsReader.parse(new ByteArrayInputStream(buf)); eventsManager2.finishProcessing(); - Assert.assertEquals(1, oneEvent.size()); + Assertions.assertEquals(1, oneEvent.size()); Event event = oneEvent.get(0); - Assert.assertTrue(event instanceof RainOnPersonEvent); + Assertions.assertTrue(event instanceof RainOnPersonEvent); RainOnPersonEvent ropEvent = ((RainOnPersonEvent)event); - Assert.assertEquals(0.0, ropEvent.getTime(), 1e-7); - Assert.assertEquals(Id.createPersonId("wurst"), ropEvent.getPersonId()); + Assertions.assertEquals(0.0, ropEvent.getTime(), 1e-7); + Assertions.assertEquals(Id.createPersonId("wurst"), ropEvent.getPersonId()); } } diff --git a/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java b/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java index 7bbdfa343bc..34d55f8b32d 100644 --- a/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java +++ b/matsim/src/test/java/org/matsim/core/events/EventsHandlerHierarchyTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/EventsManagerImplTest.java b/matsim/src/test/java/org/matsim/core/events/EventsManagerImplTest.java index 0ea80ab3d12..157a0c73db1 100644 --- a/matsim/src/test/java/org/matsim/core/events/EventsManagerImplTest.java +++ b/matsim/src/test/java/org/matsim/core/events/EventsManagerImplTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.events.Event; import org.matsim.core.api.experimental.events.EventsManager; @@ -45,7 +45,7 @@ void testProcessEvent_CustomEventHandler() { manager.initProcessing(); manager.processEvent(new MyEvent(123.45)); manager.finishProcessing(); - Assert.assertEquals("EventHandler was not called.", 1, handler.counter); + Assertions.assertEquals(1, handler.counter, "EventHandler was not called."); } /** @@ -60,12 +60,12 @@ void testProcessEvent_ExceptionInEventHandler() { try { manager.processEvent(new MyEvent(123.45)); manager.finishProcessing(); - Assert.fail("expected exception, but got none."); + Assertions.fail("expected exception, but got none."); } catch (final RuntimeException e) { log.info("Catched expected exception.", e); - Assert.assertEquals(1, handler.counter); - Assert.assertTrue(e.getCause() instanceof ArithmeticException); + Assertions.assertEquals(1, handler.counter); + Assertions.assertTrue(e.getCause() instanceof ArithmeticException); } } diff --git a/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java b/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java index ca1a804be6d..3bbf1a1626a 100644 --- a/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java +++ b/matsim/src/test/java/org/matsim/core/events/EventsReadersTest.java @@ -20,13 +20,13 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; - import java.io.IOException; import javax.xml.parsers.ParserConfigurationException; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.ActivityEndEvent; @@ -72,7 +72,7 @@ public void reset(final int iteration) { @Override public void handleEvent(final ActivityEndEvent event) { this.eventCounter++; - assertEquals("expected activity-End-Event to be event #1", 1, this.eventCounter); + assertEquals(1, this.eventCounter, "expected activity-End-Event to be event #1"); assertEquals(21610.0, event.getTime(), 0.0); assertEquals("1", event.getPersonId().toString()); assertEquals(Id.create("2", Link.class), event.getLinkId()); @@ -81,7 +81,7 @@ public void handleEvent(final ActivityEndEvent event) { @Override public void handleEvent(final PersonDepartureEvent event) { this.eventCounter++; - assertEquals("expected agentDeparture-Event to be event #2", 2, this.eventCounter); + assertEquals(2, this.eventCounter, "expected agentDeparture-Event to be event #2"); assertEquals(21620.0, event.getTime(), 0.0); assertEquals("2", event.getPersonId().toString()); assertEquals("3", event.getLinkId().toString()); @@ -90,7 +90,7 @@ public void handleEvent(final PersonDepartureEvent event) { @Override public void handleEvent(final VehicleEntersTrafficEvent event) { this.eventCounter++; - assertEquals("expected wait2link-Event to be event #3", 3, this.eventCounter); + assertEquals(3, this.eventCounter, "expected wait2link-Event to be event #3"); assertEquals(21630.0, event.getTime(), 0.0); assertEquals("3", event.getPersonId().toString()); assertEquals("4", event.getLinkId().toString()); @@ -99,7 +99,7 @@ public void handleEvent(final VehicleEntersTrafficEvent event) { @Override public void handleEvent(final LinkLeaveEvent event) { this.eventCounter++; - assertEquals("expected linkleave-Event to be event #4", 4, this.eventCounter); + assertEquals(4, this.eventCounter, "expected linkleave-Event to be event #4"); assertEquals(21640.0, event.getTime(), 0.0); assertEquals("4", event.getVehicleId().toString()); assertEquals("5", event.getLinkId().toString()); @@ -108,7 +108,7 @@ public void handleEvent(final LinkLeaveEvent event) { @Override public void handleEvent(final LinkEnterEvent event) { this.eventCounter++; - assertEquals("expected linkleave-Event to be event #5", 5, this.eventCounter); + assertEquals(5, this.eventCounter, "expected linkleave-Event to be event #5"); assertEquals(21650.0, event.getTime(), 0.0); assertEquals("5", event.getVehicleId().toString()); assertEquals("6", event.getLinkId().toString()); @@ -117,7 +117,7 @@ public void handleEvent(final LinkEnterEvent event) { @Override public void handleEvent(final PersonArrivalEvent event) { this.eventCounter++; - assertEquals("expected agentArrival-Event to be event #6", 6, this.eventCounter); + assertEquals(6, this.eventCounter, "expected agentArrival-Event to be event #6"); assertEquals(21660.0, event.getTime(), 0.0); assertEquals("6", event.getPersonId().toString()); assertEquals("7", event.getLinkId().toString()); @@ -126,7 +126,7 @@ public void handleEvent(final PersonArrivalEvent event) { @Override public void handleEvent(final ActivityStartEvent event) { this.eventCounter++; - assertEquals("expected activityStart-Event to be event #7", 7, this.eventCounter); + assertEquals(7, this.eventCounter, "expected activityStart-Event to be event #7"); assertEquals(21670.0, event.getTime(), 0.0); assertEquals("7", event.getPersonId().toString()); assertEquals(Id.create("8", Link.class), event.getLinkId()); @@ -135,7 +135,7 @@ public void handleEvent(final ActivityStartEvent event) { @Override public void handleEvent(final PersonStuckEvent event) { this.eventCounter++; - assertEquals("expected agentStuck-Event to be event #8", 8, this.eventCounter); + assertEquals(8, this.eventCounter, "expected agentStuck-Event to be event #8"); assertEquals(21680.0, event.getTime(), 0.0); assertEquals("8", event.getPersonId().toString()); assertEquals("9", event.getLinkId().toString()); @@ -152,7 +152,7 @@ final void testXmlReader() throws SAXException, ParserConfigurationException, IO EventsReaderXMLv1 reader = new EventsReaderXMLv1(events); reader.readFile(utils.getClassInputDirectory() + "events.xml"); events.finishProcessing(); - assertEquals("number of read events", 8, handler.eventCounter); + assertEquals(8, handler.eventCounter, "number of read events"); } @Test @@ -164,6 +164,6 @@ final void testAutoFormatReaderXml() { MatsimEventsReader reader = new MatsimEventsReader(events); reader.readFile(utils.getClassInputDirectory() + "events.xml"); events.finishProcessing(); - assertEquals("number of read events", 8, handler.eventCounter); + assertEquals(8, handler.eventCounter, "number of read events"); } } diff --git a/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java b/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java index 705c6e08aff..bee56a1098e 100644 --- a/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/GenericEventTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java b/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java index 7a400077bce..9fc85975063 100644 --- a/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/LinkEnterEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java b/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java index 7a9f373ed82..a8a66112726 100644 --- a/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/LinkLeaveEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java b/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java index 373075691ec..24ce9763e4c 100644 --- a/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java +++ b/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java @@ -5,8 +5,8 @@ import org.matsim.api.core.v01.events.Event; import org.matsim.core.api.experimental.events.EventsManager; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertThrows; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertThrows; public class ParallelEventsManagerTest { diff --git a/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java index 60110acc6ce..81670a0a2bb 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonArrivalEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java index f1372da2f07..60bca5c85e4 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonDepartureEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java index 849a0f7878e..30dd6163dca 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonEntersVehicleEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -49,7 +49,7 @@ void testReadWriteXml() { Vehicle vehicle = VehicleUtils.createVehicle(Id.create(80, Vehicle.class ), vehicleType ); PersonEntersVehicleEvent event = new PersonEntersVehicleEvent(5.0 * 3600 + 11.0 * 60, person.getId(), vehicle.getId()); PersonEntersVehicleEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event); - assertEquals("wrong time of event.", 5.0 * 3600 + 11.0 * 60, event2.getTime(), MatsimTestUtils.EPSILON); - assertEquals("wrong vehicle id.", "80", event2.getVehicleId().toString()); + assertEquals(5.0 * 3600 + 11.0 * 60, event2.getTime(), MatsimTestUtils.EPSILON, "wrong time of event."); + assertEquals("80", event2.getVehicleId().toString(), "wrong vehicle id."); } } diff --git a/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java index 867624642ad..760dbebf652 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonLeavesVehicleEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -49,7 +49,7 @@ void testWriteReadXml() { Vehicle vehicle = VehicleUtils.createVehicle(Id.create(80, Vehicle.class ), vehicleType ); PersonLeavesVehicleEvent event = new PersonLeavesVehicleEvent(5.0 * 3600 + 11.0 * 60, person.getId(), vehicle.getId()); PersonLeavesVehicleEvent event2 = XmlEventsTester.testWriteReadXml(utils.getOutputDirectory() + "events.xml", event); - assertEquals("wrong time of event.", 5.0 * 3600 + 11.0 * 60, event2.getTime(), MatsimTestUtils.EPSILON); - assertEquals("wrong vehicle id.", "80", event2.getVehicleId().toString()); + assertEquals(5.0 * 3600 + 11.0 * 60, event2.getTime(), MatsimTestUtils.EPSILON, "wrong time of event."); + assertEquals("80", event2.getVehicleId().toString(), "wrong vehicle id."); } } diff --git a/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java b/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java index b17e124d471..f4511932195 100644 --- a/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/PersonStuckEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java b/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java index 37d6156086e..c877308fdf4 100644 --- a/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/TransitDriverStartsEventTest.java @@ -19,7 +19,7 @@ package org.matsim.core.events; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -47,11 +47,11 @@ void testWriteReadXml() { Id.create("route-R1", TransitRoute.class), Id.create("departure-D-1", Departure.class)); final TransitDriverStartsEvent event2 = XmlEventsTester.testWriteReadXml(this.utils.getOutputDirectory() + "events.xml", event1); - Assert.assertEquals(event1.getTime(), event2.getTime(), 1.0e-9); - Assert.assertEquals(event1.getDriverId(), event2.getDriverId()); - Assert.assertEquals(event1.getVehicleId(), event2.getVehicleId()); - Assert.assertEquals(event1.getTransitRouteId(), event2.getTransitRouteId()); - Assert.assertEquals(event1.getTransitLineId(), event2.getTransitLineId()); - Assert.assertEquals(event1.getDepartureId(), event2.getDepartureId()); + Assertions.assertEquals(event1.getTime(), event2.getTime(), 1.0e-9); + Assertions.assertEquals(event1.getDriverId(), event2.getDriverId()); + Assertions.assertEquals(event1.getVehicleId(), event2.getVehicleId()); + Assertions.assertEquals(event1.getTransitRouteId(), event2.getTransitRouteId()); + Assertions.assertEquals(event1.getTransitLineId(), event2.getTransitLineId()); + Assertions.assertEquals(event1.getDepartureId(), event2.getDepartureId()); } } diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java index 15d82589b79..6d62b155c7f 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleAbortsEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java index 26d0fa561f8..163cd012116 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleArrivesAtFacilityEventImplTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java index 11e414b40f2..d5c92b87340 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleDepartsAtFacilityEventImplTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java index af9686b35bc..20bbccf116e 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleEntersTrafficEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java b/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java index 7428df475b5..78269929392 100644 --- a/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java +++ b/matsim/src/test/java/org/matsim/core/events/VehicleLeavesTrafficEventTest.java @@ -20,7 +20,7 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/events/XmlEventsTester.java b/matsim/src/test/java/org/matsim/core/events/XmlEventsTester.java index 2fb45c2ff5a..c68271864bd 100644 --- a/matsim/src/test/java/org/matsim/core/events/XmlEventsTester.java +++ b/matsim/src/test/java/org/matsim/core/events/XmlEventsTester.java @@ -20,8 +20,8 @@ package org.matsim.core.events; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.io.File; import java.util.Map; @@ -62,15 +62,14 @@ public static T testWriteReadXml(final String eventsFile, fina new MatsimEventsReader(events).readFile(eventsFile); events.finishProcessing(); - assertEquals("there must be 1 event.", 1, collector.getEvents().size()); + assertEquals(1, collector.getEvents().size(), "there must be 1 event."); Event readEvent = collector.getEvents().iterator().next(); - assertEquals("event has wrong class.", event.getClass(), readEvent.getClass()); + assertEquals(event.getClass(), readEvent.getClass(), "event has wrong class."); Map writtenAttributes = event.getAttributes(); Map readAttributes = readEvent.getAttributes(); for (Map.Entry attribute : writtenAttributes.entrySet()) { - assertEquals("attribute '" + attribute.getKey() + "' is different after reading the event.", - attribute.getValue(), readAttributes.get(attribute.getKey())); + assertEquals(attribute.getValue(), readAttributes.get(attribute.getKey()), "attribute '" + attribute.getKey() + "' is different after reading the event."); } return (T) readEvent; diff --git a/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterJsonTest.java b/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterJsonTest.java index 60a4cc3c49a..4cda0b0cb93 100644 --- a/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterJsonTest.java +++ b/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterJsonTest.java @@ -1,6 +1,6 @@ package org.matsim.core.events.algorithms; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.GenericEvent; @@ -43,15 +43,15 @@ void testSpecialCharacters() { new MatsimEventsReader(events).readStream(bios, ControllerConfigGroup.EventsFileFormat.json); events.finishProcessing(); - Assert.assertEquals("there must be 2 events.", 2, collector.getEvents().size()); + Assertions.assertEquals(2, collector.getEvents().size(), "there must be 2 events."); LinkLeaveEvent event1 = (LinkLeaveEvent) collector.getEvents().get(0); LinkLeaveEvent event2 = (LinkLeaveEvent) collector.getEvents().get(1); - Assert.assertEquals("link<2", event1.getLinkId().toString()); - Assert.assertEquals("vehicle>3", event1.getVehicleId().toString()); + Assertions.assertEquals("link<2", event1.getLinkId().toString()); + Assertions.assertEquals("vehicle>3", event1.getVehicleId().toString()); - Assert.assertEquals("link'3", event2.getLinkId().toString()); - Assert.assertEquals("vehicle\"4", event2.getVehicleId().toString()); + Assertions.assertEquals("link'3", event2.getLinkId().toString()); + Assertions.assertEquals("vehicle\"4", event2.getVehicleId().toString()); } @Test @@ -75,10 +75,10 @@ void testNullAttribute() { new MatsimEventsReader(events).readStream(bios, ControllerConfigGroup.EventsFileFormat.json); events.finishProcessing(); - Assert.assertEquals("there must be 1 event.", 1, collector.getEvents().size()); + Assertions.assertEquals(1, collector.getEvents().size(), "there must be 1 event."); GenericEvent event1 = (GenericEvent) collector.getEvents().get(0); - Assert.assertTrue(event1.getAttributes().containsKey("dummy")); - Assert.assertNull(event1.getAttributes().get("dummy")); + Assertions.assertTrue(event1.getAttributes().containsKey("dummy")); + Assertions.assertNull(event1.getAttributes().get("dummy")); } } diff --git a/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java b/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java index 114d27637b1..8ad04f9e371 100644 --- a/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java +++ b/matsim/src/test/java/org/matsim/core/events/algorithms/EventWriterXMLTest.java @@ -21,7 +21,7 @@ import java.io.File; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -54,7 +54,7 @@ void testSpecialCharacters() { writer.handleEvent(new LinkLeaveEvent(3600.0, Id.create("vehicle>3", Vehicle.class), Id.create("link<2", Link.class))); writer.handleEvent(new LinkLeaveEvent(3601.0, Id.create("vehicle\"4", Vehicle.class), Id.create("link'3", Link.class))); writer.closeFile(); - Assert.assertTrue(new File(filename).exists()); + Assertions.assertTrue(new File(filename).exists()); EventsManager events = EventsUtils.createEventsManager(); EventsCollector collector = new EventsCollector(); @@ -64,15 +64,15 @@ void testSpecialCharacters() { new MatsimEventsReader(events).readFile(filename); events.finishProcessing(); - Assert.assertEquals("there must be 2 events.", 2, collector.getEvents().size()); + Assertions.assertEquals(2, collector.getEvents().size(), "there must be 2 events."); LinkLeaveEvent event1 = (LinkLeaveEvent) collector.getEvents().get(0); LinkLeaveEvent event2 = (LinkLeaveEvent) collector.getEvents().get(1); - Assert.assertEquals("link<2", event1.getLinkId().toString()); - Assert.assertEquals("vehicle>3", event1.getVehicleId().toString()); + Assertions.assertEquals("link<2", event1.getLinkId().toString()); + Assertions.assertEquals("vehicle>3", event1.getVehicleId().toString()); - Assert.assertEquals("link'3", event2.getLinkId().toString()); - Assert.assertEquals("vehicle\"4", event2.getVehicleId().toString()); + Assertions.assertEquals("link'3", event2.getLinkId().toString()); + Assertions.assertEquals("vehicle\"4", event2.getVehicleId().toString()); } @Test @@ -84,7 +84,7 @@ void testNullAttribute() { event.getAttributes().put("dummy", null); writer.handleEvent(event); writer.closeFile(); - Assert.assertTrue(new File(filename).exists()); + Assertions.assertTrue(new File(filename).exists()); EventsManager events = EventsUtils.createEventsManager(); EventsCollector collector = new EventsCollector(); @@ -94,6 +94,6 @@ void testNullAttribute() { new MatsimEventsReader(events).readFile(filename); events.finishProcessing(); - Assert.assertEquals("there must be 1 event.", 1, collector.getEvents().size()); + Assertions.assertEquals(1, collector.getEvents().size(), "there must be 1 event."); } } diff --git a/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java b/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java index 741469401ff..bbce6168394 100644 --- a/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java +++ b/matsim/src/test/java/org/matsim/core/gbl/MatsimRandomTest.java @@ -20,8 +20,8 @@ package org.matsim.core.gbl; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.Random; @@ -131,7 +131,7 @@ void testLocalInstances_distribution() { */ private void assertEqualRandomNumberGenerators(final Random rng1, final Random rng2) { for (int i = 0; i < 10; i++) { - assertEquals("different element at position " + i, rng1.nextDouble(), rng2.nextDouble(), MatsimTestUtils.EPSILON); + assertEquals(rng1.nextDouble(), rng2.nextDouble(), MatsimTestUtils.EPSILON, "different element at position " + i); } } } diff --git a/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java b/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java index a47adfa7e6c..46329aa09c4 100644 --- a/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java +++ b/matsim/src/test/java/org/matsim/core/gbl/MatsimResourceTest.java @@ -20,11 +20,11 @@ package org.matsim.core.gbl; -import static org.junit.Assert.assertEquals; - import java.awt.Image; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/AbstractMobsimModuleTest.java b/matsim/src/test/java/org/matsim/core/mobsim/AbstractMobsimModuleTest.java index 9675beba522..cb9a538bb03 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/AbstractMobsimModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/AbstractMobsimModuleTest.java @@ -23,7 +23,7 @@ import java.util.Collections; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; @@ -32,7 +32,7 @@ import com.google.inject.Guice; import com.google.inject.Injector; - public class AbstractMobsimModuleTest { + public class AbstractMobsimModuleTest { @Test void testOverrides() { AbstractMobsimModule moduleA = new AbstractMobsimModule() { @@ -59,9 +59,9 @@ protected void configureMobsim() { Injector injector = Guice.createInjector(composite); - Assert.assertTrue(config.getModules().containsKey("testA")); - Assert.assertTrue(config.getModules().containsKey("testB")); + Assertions.assertTrue(config.getModules().containsKey("testA")); + Assertions.assertTrue(config.getModules().containsKey("testB")); - Assert.assertEquals("testBString", injector.getInstance(String.class)); + Assertions.assertEquals("testBString", injector.getInstance(String.class)); } } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/AgentTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/AgentTest.java index 2a571c61146..4bc46d2d22a 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/AgentTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/AgentTest.java @@ -19,9 +19,10 @@ package org.matsim.core.mobsim.hermes; +import static org.junit.jupiter.api.Assertions.assertEquals; + import org.junit.jupiter.api.Test; import org.locationtech.jts.util.Assert; -import static org.junit.Assert.assertEquals; public class AgentTest { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java index 83a4f62d0d4..60ca78d0d54 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java @@ -20,8 +20,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.analysis.VolumesAnalyzer; import org.matsim.api.core.v01.Id; @@ -119,10 +119,10 @@ void testFlowCapacityDriving() { System.out.println("#vehicles 7-8: " + volume[7]); System.out.println("#vehicles 8-9: " + volume[8]); - Assert.assertEquals(0, volume[5], 1); // no vehicles - Assert.assertEquals(3004, volume[6], 1); // we should have half of the maximum flow in this hour - Assert.assertEquals(6000, volume[7], 1); // we should have maximum flow in this hour - Assert.assertEquals(2996, volume[8], 1); // all the rest + Assertions.assertEquals(0, volume[5], 1); // no vehicles + Assertions.assertEquals(3004, volume[6], 1); // we should have half of the maximum flow in this hour + Assertions.assertEquals(6000, volume[7], 1); // we should have maximum flow in this hour + Assertions.assertEquals(2996, volume[8], 1); // all the rest } @@ -176,10 +176,10 @@ void testFlowCapacityDrivingFlowCapacityFactors() { System.out.println("#vehicles 7-8: " + volume[7]); System.out.println("#vehicles 8-9: " + volume[8]); - Assert.assertEquals(0, volume[5], 1); // no vehicles - Assert.assertEquals(301, volume[6], 1); // we should have half of the maximum flow in this hour - Assert.assertEquals(600, volume[7], 1); // we should have maximum flow in this hour - Assert.assertEquals(299, volume[8], 1); // all the rest + Assertions.assertEquals(0, volume[5], 1); // no vehicles + Assertions.assertEquals(301, volume[6], 1); // we should have half of the maximum flow in this hour + Assertions.assertEquals(600, volume[7], 1); // we should have maximum flow in this hour + Assertions.assertEquals(299, volume[8], 1); // all the rest } @@ -241,10 +241,10 @@ void testFlowCapacityDrivingFlowEfficiencyFactors() { System.out.println("#vehicles 8-9: " + volume[8]); - Assert.assertEquals(0, volume[5]); // no vehicles - Assert.assertEquals(4005, volume[6]); // we should have half of the maximum flow in this hour * 1.5, because every second vehicle is super flowy - Assert.assertEquals(7995, volume[7]); // all the rest - Assert.assertEquals(0, volume[8]); // nothing + Assertions.assertEquals(0, volume[5]); // no vehicles + Assertions.assertEquals(4005, volume[6]); // we should have half of the maximum flow in this hour * 1.5, because every second vehicle is super flowy + Assertions.assertEquals(7995, volume[7]); // all the rest + Assertions.assertEquals(0, volume[8]); // nothing } @@ -306,10 +306,10 @@ void testFlowCapacityDrivingFlowEfficiencyFactorsWithDownscaling() { System.out.println("#vehicles 7-8: " + volume[7]); System.out.println("#vehicles 8-9: " + volume[8]); - Assert.assertEquals(0, volume[5], 1); // no vehicles - Assert.assertEquals(401, volume[6], 1); // we should have half of the maximum flow in this hour * 1.3333, because every second vehicle is super flowy - Assert.assertEquals(799, volume[7], 1); // all the rest - Assert.assertEquals(0, volume[8], 1); // nothing + Assertions.assertEquals(0, volume[5], 1); // no vehicles + Assertions.assertEquals(401, volume[6], 1); // we should have half of the maximum flow in this hour * 1.3333, because every second vehicle is super flowy + Assertions.assertEquals(799, volume[7], 1); // all the rest + Assertions.assertEquals(0, volume[8], 1); // nothing } /** @@ -369,11 +369,11 @@ void testFlowCapacityEfficiencyFactorWithLowValueAndDownscaling() { System.out.println("#vehicles 6-7: " + volume[6]); System.out.println("#vehicles 7-8: " + volume[7]); System.out.println("#vehicles 8-9: " + volume[8]); - Assert.assertEquals(0, volume[5], 1); // no vehicles - Assert.assertEquals(201, volume[6], 1); // we should have half of the maximum flow in this hour * 1.3333, because every second vehicle is super flowy - Assert.assertEquals(400, volume[7], 1); - Assert.assertEquals(400, volume[8], 1); - Assert.assertEquals(199, volume[9], 1); + Assertions.assertEquals(0, volume[5], 1); // no vehicles + Assertions.assertEquals(201, volume[6], 1); // we should have half of the maximum flow in this hour * 1.3333, because every second vehicle is super flowy + Assertions.assertEquals(400, volume[7], 1); + Assertions.assertEquals(400, volume[8], 1); + Assertions.assertEquals(199, volume[9], 1); } @@ -425,9 +425,9 @@ void testFlowCapacityDrivingFraction() { /* finish */ int[] volume = vAnalyzer.getVolumesForLink(f.link2.getId()); - Assert.assertEquals(1, volume[7*3600 - 1801]); // First vehicle - Assert.assertEquals(1, volume[7*3600 - 1801 + 4]); // Second vehicle - Assert.assertEquals(1, volume[7*3600 - 1801 + 8]); // Third vehicle + Assertions.assertEquals(1, volume[7*3600 - 1801]); // First vehicle + Assertions.assertEquals(1, volume[7*3600 - 1801 + 4]); // Second vehicle + Assertions.assertEquals(1, volume[7*3600 - 1801 + 8]); // Third vehicle } } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java index 69fc3bfbd3e..8d6dce636f6 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java @@ -26,8 +26,8 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -142,9 +142,9 @@ void testSingleAgent() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 2, collector.events.size()); - Assert.assertEquals("wrong time in first event.", 6.0*3600, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in second event.", 6.0*3600 + 11, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(6.0*3600, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in first event."); + Assertions.assertEquals(6.0*3600 + 11, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in second event."); } @@ -190,9 +190,9 @@ void testSingleAgentWithEndOnLeg() { createHermes(f, events).run(); // // /* finish */ - Assert.assertEquals("wrong number of link enter events.", 2, collector.events.size()); - Assert.assertEquals("wrong time in first event.", 6.0*3600, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in second event.", 6.0*3600 + 11, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(6.0*3600, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in first event."); + Assertions.assertEquals(6.0*3600 + 11, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in second event."); } /** @@ -230,11 +230,11 @@ void testTwoAgent() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 4, collector.events.size()); - Assert.assertEquals("wrong time in first event.", 6.0*3600, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in second event.", 6.0*3600 + 11, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in first event.", 7.0*3600, collector.events.get(2).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in second event.", 7.0*3600 + 11, collector.events.get(3).getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(6.0*3600, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in first event."); + Assertions.assertEquals(6.0*3600 + 11, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in second event."); + Assertions.assertEquals(7.0*3600, collector.events.get(2).getTime(), MatsimTestUtils.EPSILON, "wrong time in first event."); + Assertions.assertEquals(7.0*3600 + 11, collector.events.get(3).getTime(), MatsimTestUtils.EPSILON, "wrong time in second event."); } /** @@ -269,16 +269,16 @@ void testTeleportationSingleAgent() { sim.run(); List allEvents = collector.getEvents(); - Assert.assertEquals("wrong number of events.", 5, collector.getEvents().size()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", TeleportationArrivalEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(4).getClass()); - Assert.assertEquals("wrong time in event.", 6.0 * 3600 + 0, allEvents.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in event.", 6.0 * 3600 + 0, allEvents.get(1).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in event.", 6.0 * 3600 + 13, allEvents.get(2).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in event.", 6.0 * 3600 + 13, allEvents.get(3).getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5, collector.getEvents().size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of event."); + Assertions.assertEquals(TeleportationArrivalEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(4).getClass(), "wrong type of event."); + Assertions.assertEquals(6.0 * 3600 + 0, allEvents.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in event."); + Assertions.assertEquals(6.0 * 3600 + 0, allEvents.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in event."); + Assertions.assertEquals(6.0 * 3600 + 13, allEvents.get(2).getTime(), MatsimTestUtils.EPSILON, "wrong time in event."); + Assertions.assertEquals(6.0 * 3600 + 13, allEvents.get(3).getTime(), MatsimTestUtils.EPSILON, "wrong time in event."); } /** @@ -317,9 +317,9 @@ void testSingleAgentImmediateDeparture() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 2, collector.events.size()); - Assert.assertEquals("wrong time in first event.", 0.0*3600, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in second event.", 0.0*3600 + 11, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(0.0*3600, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in first event."); + Assertions.assertEquals(0.0*3600 + 11, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in second event."); } /** @@ -365,40 +365,44 @@ void testSingleAgent_EmptyRoute() { for (Event event : allEvents) { System.out.println(event); } - Assert.assertEquals("wrong number of events.", 8, allEvents.size()); - - - Assert.assertEquals("wrong type of 1st event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of 2nd event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of 3rd event.", PersonEntersVehicleEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of 4th event.", VehicleEntersTrafficEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of 5th event.", VehicleLeavesTrafficEvent.class, allEvents.get(4).getClass()); - Assert.assertEquals("wrong type of 6th event.", PersonLeavesVehicleEvent.class, allEvents.get(5).getClass()); - Assert.assertEquals("wrong type of 7th event.", PersonArrivalEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of 8th event.", ActivityStartEvent.class, allEvents.get(7).getClass()); - - - Assert.assertEquals("wrong time in 1st event.", 6.0*3600 + 0, allEvents.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 2nd event.", 6.0*3600 + 0, allEvents.get(1).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 3rd event.", 6.0*3600 + 0, allEvents.get(2).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 4th event.", 6.0*3600 + 0, allEvents.get(3).getTime(), MatsimTestUtils.EPSILON); - - Assert.assertEquals("wrong time in 5th event.", 6.0 * 3600 + 0, allEvents.get(4).getTime(), - MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 6th event.", 6.0 * 3600 + 0, allEvents.get(5).getTime(), - MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 7th event.", 6.0 * 3600 + 0, allEvents.get(6).getTime(), - MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 8th event.", 6.0 * 3600 + 0, allEvents.get(7).getTime(), - MatsimTestUtils.EPSILON); - - - Assert.assertEquals("wrong link in 1st event.", f.link1.getId(), ((ActivityEndEvent) allEvents.get(0)).getLinkId() ); - Assert.assertEquals("wrong link in 2nd event.", f.link1.getId(), ((PersonDepartureEvent) allEvents.get(1)).getLinkId() ); - Assert.assertEquals("wrong link in 4th event.", f.link1.getId(), ((VehicleEntersTrafficEvent) allEvents.get(3)).getLinkId() ); - Assert.assertEquals("wrong link in 5th event.", f.link1.getId(), ((VehicleLeavesTrafficEvent) allEvents.get(4)).getLinkId() ); - Assert.assertEquals("wrong link in 7th event.", f.link1.getId(), ((PersonArrivalEvent) allEvents.get(6)).getLinkId() ); - Assert.assertEquals("wrong link in 8th event.", f.link1.getId(), ((ActivityStartEvent) allEvents.get(7)).getLinkId() ); + Assertions.assertEquals(8, allEvents.size(), "wrong number of events."); + + + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of 1st event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of 2nd event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(2).getClass(), "wrong type of 3rd event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(3).getClass(), "wrong type of 4th event."); + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(4).getClass(), "wrong type of 5th event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(5).getClass(), "wrong type of 6th event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(6).getClass(), "wrong type of 7th event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(7).getClass(), "wrong type of 8th event."); + + + Assertions.assertEquals(6.0*3600 + 0, allEvents.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in 1st event."); + Assertions.assertEquals(6.0*3600 + 0, allEvents.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in 2nd event."); + Assertions.assertEquals(6.0*3600 + 0, allEvents.get(2).getTime(), MatsimTestUtils.EPSILON, "wrong time in 3rd event."); + Assertions.assertEquals(6.0*3600 + 0, allEvents.get(3).getTime(), MatsimTestUtils.EPSILON, "wrong time in 4th event."); + + Assertions.assertEquals(6.0 * 3600 + 0, allEvents.get(4).getTime(), + MatsimTestUtils.EPSILON, + "wrong time in 5th event."); + Assertions.assertEquals(6.0 * 3600 + 0, allEvents.get(5).getTime(), + MatsimTestUtils.EPSILON, + "wrong time in 6th event."); + Assertions.assertEquals(6.0 * 3600 + 0, allEvents.get(6).getTime(), + MatsimTestUtils.EPSILON, + "wrong time in 7th event."); + Assertions.assertEquals(6.0 * 3600 + 0, allEvents.get(7).getTime(), + MatsimTestUtils.EPSILON, + "wrong time in 8th event."); + + + Assertions.assertEquals(f.link1.getId(), ((ActivityEndEvent) allEvents.get(0)).getLinkId(), "wrong link in 1st event." ); + Assertions.assertEquals(f.link1.getId(), ((PersonDepartureEvent) allEvents.get(1)).getLinkId(), "wrong link in 2nd event." ); + Assertions.assertEquals(f.link1.getId(), ((VehicleEntersTrafficEvent) allEvents.get(3)).getLinkId(), "wrong link in 4th event." ); + Assertions.assertEquals(f.link1.getId(), ((VehicleLeavesTrafficEvent) allEvents.get(4)).getLinkId(), "wrong link in 5th event." ); + Assertions.assertEquals(f.link1.getId(), ((PersonArrivalEvent) allEvents.get(6)).getLinkId(), "wrong link in 7th event." ); + Assertions.assertEquals(f.link1.getId(), ((ActivityStartEvent) allEvents.get(7)).getLinkId(), "wrong link in 8th event." ); } /** @@ -443,21 +447,21 @@ void testSingleAgent_LastLinkIsLoop() { for (Event event : allEvents) { System.out.println(event); } - Assert.assertEquals("wrong number of events.", 14, allEvents.size()); - Assert.assertEquals("wrong type of 1st event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of 2nd event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", PersonEntersVehicleEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", VehicleEntersTrafficEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(4).getClass()); // link 1 - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(5).getClass()); // link 2 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(7).getClass()); // link 3 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(8).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(9).getClass()); // loop link - Assert.assertEquals("wrong type of event.", VehicleLeavesTrafficEvent.class, allEvents.get(10).getClass()); - Assert.assertEquals("wrong type of event.", PersonLeavesVehicleEvent.class, allEvents.get(11).getClass()); - Assert.assertEquals("wrong type of 11th event.", PersonArrivalEvent.class, allEvents.get(12).getClass()); - Assert.assertEquals("wrong type of 12th event.", ActivityStartEvent.class, allEvents.get(13).getClass()); + Assertions.assertEquals(14, allEvents.size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of 1st event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of 2nd event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(4).getClass(), "wrong type of event."); // link 1 + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(5).getClass(), "wrong type of event."); // link 2 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(6).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(7).getClass(), "wrong type of event."); // link 3 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(8).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(9).getClass(), "wrong type of event."); // loop link + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(10).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(11).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(12).getClass(), "wrong type of 11th event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(13).getClass(), "wrong type of 12th event."); } /*package*/ static class LinkEnterEventCollector implements LinkEnterEventHandler { @@ -496,7 +500,7 @@ void testAgentWithoutLeg() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 0, collector.events.size()); + Assertions.assertEquals(0, collector.events.size(), "wrong number of link enter events."); } /** @@ -524,7 +528,7 @@ void testAgentWithoutLegWithEndtime() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 0, collector.events.size()); + Assertions.assertEquals(0, collector.events.size(), "wrong number of link enter events."); } /** @@ -558,7 +562,7 @@ void testAgentWithLastActWithEndtime() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 0, collector.events.size()); + Assertions.assertEquals(0, collector.events.size(), "wrong number of link enter events."); } /** @@ -597,22 +601,22 @@ void testVehicleTeleportationTrue() { sim.run(); List allEvents = collector.getEvents(); - Assert.assertEquals("wrong number of events.", 15, allEvents.size()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", TeleportationArrivalEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(4).getClass()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(5).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of event.", PersonEntersVehicleEvent.class, allEvents.get(7).getClass()); - Assert.assertEquals("wrong type of event.", VehicleEntersTrafficEvent.class, allEvents.get(8).getClass()); - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(9).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(10).getClass()); - Assert.assertEquals("wrong type of event.", VehicleLeavesTrafficEvent.class, allEvents.get(11).getClass()); - Assert.assertEquals("wrong type of event.", PersonLeavesVehicleEvent.class, allEvents.get(12).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(13).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(14).getClass()); + Assertions.assertEquals(15, allEvents.size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of event."); + Assertions.assertEquals(TeleportationArrivalEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(4).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(5).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(6).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(7).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(8).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(9).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(10).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(11).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(12).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(13).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(14).getClass(), "wrong type of event."); } /** @@ -656,23 +660,23 @@ void testCircleAsRoute() { System.out.println(event); } - Assert.assertEquals("wrong number of events.", 16, allEvents.size()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", PersonEntersVehicleEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", VehicleEntersTrafficEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(4).getClass()); // link1 - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(5).getClass()); // link2 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(7).getClass()); // link3 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(8).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(9).getClass()); // link4 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(10).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(11).getClass()); // link1 again - Assert.assertEquals("wrong type of event.", VehicleLeavesTrafficEvent.class, allEvents.get(12).getClass()); - Assert.assertEquals("wrong type of event.", PersonLeavesVehicleEvent.class, allEvents.get(13).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(14).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(15).getClass()); + Assertions.assertEquals(16, allEvents.size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(4).getClass(), "wrong type of event."); // link1 + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(5).getClass(), "wrong type of event."); // link2 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(6).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(7).getClass(), "wrong type of event."); // link3 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(8).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(9).getClass(), "wrong type of event."); // link4 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(10).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(11).getClass(), "wrong type of event."); // link1 again + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(12).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(13).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(14).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(15).getClass(), "wrong type of event."); } /** @@ -718,27 +722,27 @@ void testRouteWithEndLinkTwice() { System.out.println(event); } - Assert.assertEquals("wrong number of events.", 20, allEvents.size()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", PersonEntersVehicleEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", VehicleEntersTrafficEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(4).getClass()); // link1 - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(5).getClass()); // link2 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(7).getClass()); // link3 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(8).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(9).getClass()); // link4 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(10).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(11).getClass()); // link1 again - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(12).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(13).getClass()); // link2 again - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(14).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(15).getClass()); // link3 again - Assert.assertEquals("wrong type of event.", VehicleLeavesTrafficEvent.class, allEvents.get(16).getClass()); - Assert.assertEquals("wrong type of event.", PersonLeavesVehicleEvent.class, allEvents.get(17).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(18).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(19).getClass()); + Assertions.assertEquals(20, allEvents.size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(4).getClass(), "wrong type of event."); // link1 + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(5).getClass(), "wrong type of event."); // link2 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(6).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(7).getClass(), "wrong type of event."); // link3 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(8).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(9).getClass(), "wrong type of event."); // link4 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(10).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(11).getClass(), "wrong type of event."); // link1 again + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(12).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(13).getClass(), "wrong type of event."); // link2 again + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(14).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(15).getClass(), "wrong type of event."); // link3 again + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(16).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(17).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(18).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(19).getClass(), "wrong type of event."); } /** Prepares miscellaneous data for the testConsistentRoutes() tests: @@ -846,8 +850,8 @@ void testStartAndEndTime() { Hermes sim = createHermes(scenario, events); HermesConfigGroup.SIM_STEPS = 11 * 3600; sim.run(); - Assert.assertEquals(7.0*3600, collector.firstEvent.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(11.0*3600, collector.lastEvent.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(7.0*3600, collector.firstEvent.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(11.0*3600, collector.lastEvent.getTime(), MatsimTestUtils.EPSILON); } /** @@ -940,7 +944,7 @@ void testCleanupSim_EarlyEnd() { Hermes sim = createHermes(scenario, events); HermesConfigGroup.SIM_STEPS = (int) simEndTime; sim.run(); - Assert.assertEquals(simEndTime, collector.lastEvent.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(simEndTime, collector.lastEvent.getTime(), MatsimTestUtils.EPSILON); // besides this, the important thing is that no (Runtime)Exception is thrown during this test } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java index 332dbb4660a..4dfd0d0c319 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java @@ -1,7 +1,7 @@ package org.matsim.core.mobsim.hermes; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -190,9 +190,9 @@ void testSuperflousStopFacilities() { } // Not having an Exception here is already good :-) - Assert.assertEquals("wrong number of link enter events.", 2, collector.events.size()); - Assert.assertEquals("wrong link in first event.", f.link2.getId(), collector.events.get(0).getLinkId()); - Assert.assertEquals("wrong link in second event.", f.link3.getId(), collector.events.get(1).getLinkId()); + Assertions.assertEquals(2, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(f.link2.getId(), collector.events.get(0).getLinkId(), "wrong link in first event."); + Assertions.assertEquals(f.link3.getId(), collector.events.get(1).getLinkId(), "wrong link in second event."); } /** @@ -291,9 +291,9 @@ void testRepeatedRouteIds() { /* finish */ // Not having an Exception here is already good :-) - Assert.assertEquals("wrong number of link enter events.", 4, collector.events.size()); - Assert.assertEquals("wrong link in first event.", f.link2.getId(), collector.events.get(0).getLinkId()); - Assert.assertEquals("wrong link in second event.", f.link3.getId(), collector.events.get(1).getLinkId()); + Assertions.assertEquals(4, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(f.link2.getId(), collector.events.get(0).getLinkId(), "wrong link in first event."); + Assertions.assertEquals(f.link3.getId(), collector.events.get(1).getLinkId(), "wrong link in second event."); } /** @@ -377,14 +377,14 @@ void testConsecutiveStopsWithSameLink_1() { } } - Assert.assertEquals("wrong number of link enter events.", 2, collector.events.size()); - Assert.assertEquals("wrong link in first event.", f.link2.getId(), collector.events.get(0).getLinkId()); - Assert.assertEquals("wrong link in second event.", f.link3.getId(), collector.events.get(1).getLinkId()); + Assertions.assertEquals(2, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(f.link2.getId(), collector.events.get(0).getLinkId(), "wrong link in first event."); + Assertions.assertEquals(f.link3.getId(), collector.events.get(1).getLinkId(), "wrong link in second event."); - Assert.assertEquals("wrong number of stops served.", 3, stopArrivalEvents.size()); - Assert.assertEquals("wrong stop id at first stop.", stop1.getId(), stopArrivalEvents.get(0).getFacilityId()); - Assert.assertEquals("wrong stop id at 2nd stop.", stop2.getId(), stopArrivalEvents.get(1).getFacilityId()); - Assert.assertEquals("wrong stop id at 3rd stop.", stop3.getId(), stopArrivalEvents.get(2).getFacilityId()); + Assertions.assertEquals(3, stopArrivalEvents.size(), "wrong number of stops served."); + Assertions.assertEquals(stop1.getId(), stopArrivalEvents.get(0).getFacilityId(), "wrong stop id at first stop."); + Assertions.assertEquals(stop2.getId(), stopArrivalEvents.get(1).getFacilityId(), "wrong stop id at 2nd stop."); + Assertions.assertEquals(stop3.getId(), stopArrivalEvents.get(2).getFacilityId(), "wrong stop id at 3rd stop."); } @@ -474,9 +474,9 @@ void testConsecutiveStopsWithSameLink_2() { // System.out.println(event.toString()); // } - Assert.assertEquals("wrong number of link enter events.", 6, collector.events.size()); - Assert.assertEquals("wrong link in first event.", f.link2.getId(), collector.events.get(0).getLinkId()); - Assert.assertEquals("wrong link in second event.", f.link3.getId(), collector.events.get(1).getLinkId()); + Assertions.assertEquals(6, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(f.link2.getId(), collector.events.get(0).getLinkId(), "wrong link in first event."); + Assertions.assertEquals(f.link3.getId(), collector.events.get(1).getLinkId(), "wrong link in second event."); // Assert.assertEquals("wrong link in second event.", f.linkX.getId(), collector.events.get(2).getLinkId()); // Assert.assertEquals("wrong link in second event.", f.link1.getId(), collector.events.get(3).getLinkId()); // Assert.assertEquals("wrong link in second event.", f.link2.getId(), collector.events.get(4).getLinkId()); @@ -549,8 +549,8 @@ void testEarlyEnd() { } // Not having an Exception here is already good :-) - Assert.assertEquals("wrong number of link enter events.", 1, collector.events.size()); - Assert.assertEquals("wrong link in first event.", f.link2.getId(), collector.events.get(0).getLinkId()); + Assertions.assertEquals(1, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(f.link2.getId(), collector.events.get(0).getLinkId(), "wrong link in first event."); // there should be no more events after that, as at 30:00:00 the simulation should stop } @@ -619,7 +619,7 @@ void testLinksAtRouteStart() { } // Not having an Exception here is already good :-) - Assert.assertEquals("wrong number of link enter events.", 3, collector.events.size()); + Assertions.assertEquals(3, collector.events.size(), "wrong number of link enter events."); // Assert.assertEquals("wrong link in first event.", f.link2.getId(), collector.events.get(0).getLinkId()); // Assert.assertEquals("wrong link in 2nd event.", f.link3.getId(), collector.events.get(1).getLinkId()); } @@ -710,43 +710,43 @@ void testDeterministicCorrectTiming() { if (event instanceof LinkLeaveEvent) linkLeaveEvents.add((LinkLeaveEvent) event); } - Assert.assertEquals("wrong number of transit-driver-starts events.", 1, transitDriverStartsEvents.size()); - Assert.assertEquals("wrong number of link enter events.", 2, linkEnterEvents.size()); - Assert.assertEquals("wrong number of link leave events.", 2, linkLeaveEvents.size()); - Assert.assertEquals("wrong number of VehicleArrivesAtFacilityEvents.", 3, arrivesAtFacilityEvents.size()); - Assert.assertEquals("wrong number of VehicleDepartsAtFacilityEvents.", 3, departsAtFacilityEvents.size()); + Assertions.assertEquals(1, transitDriverStartsEvents.size(), "wrong number of transit-driver-starts events."); + Assertions.assertEquals(2, linkEnterEvents.size(), "wrong number of link enter events."); + Assertions.assertEquals(2, linkLeaveEvents.size(), "wrong number of link leave events."); + Assertions.assertEquals(3, arrivesAtFacilityEvents.size(), "wrong number of VehicleArrivesAtFacilityEvents."); + Assertions.assertEquals(3, departsAtFacilityEvents.size(), "wrong number of VehicleDepartsAtFacilityEvents."); - if (this.isDeterministic) Assert.assertEquals(997.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); + if (this.isDeterministic) Assertions.assertEquals(997.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); - if (this.isDeterministic) Assert.assertEquals(998.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(stop1.getId(), arrivesAtFacilityEvents.get(0).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(998.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(stop1.getId(), arrivesAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1000.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(stop1.getId(), departsAtFacilityEvents.get(0).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1000.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(stop1.getId(), departsAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(f.link1.getId(), linkLeaveEvents.get(0).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(f.link1.getId(), linkLeaveEvents.get(0).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(f.link2.getId(), linkEnterEvents.get(0).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(f.link2.getId(), linkEnterEvents.get(0).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1251.0, linkLeaveEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(f.link2.getId(), linkLeaveEvents.get(1).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1251.0, linkLeaveEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(f.link2.getId(), linkLeaveEvents.get(1).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1251.0, linkEnterEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(f.link3.getId(), linkEnterEvents.get(1).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1251.0, linkEnterEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(f.link3.getId(), linkEnterEvents.get(1).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1298.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(stop2.getId(), arrivesAtFacilityEvents.get(1).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1298.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(stop2.getId(), arrivesAtFacilityEvents.get(1).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1300.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(stop2.getId(), departsAtFacilityEvents.get(1).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1300.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(stop2.getId(), departsAtFacilityEvents.get(1).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1598.0, arrivesAtFacilityEvents.get(2).getTime(), 1e-8); - Assert.assertEquals(stop3.getId(), arrivesAtFacilityEvents.get(2).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1598.0, arrivesAtFacilityEvents.get(2).getTime(), 1e-8); + Assertions.assertEquals(stop3.getId(), arrivesAtFacilityEvents.get(2).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1600.0, departsAtFacilityEvents.get(2).getTime(), 1e-8); - Assert.assertEquals(stop3.getId(), departsAtFacilityEvents.get(2).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1600.0, departsAtFacilityEvents.get(2).getTime(), 1e-8); + Assertions.assertEquals(stop3.getId(), departsAtFacilityEvents.get(2).getFacilityId()); } /** @@ -835,37 +835,37 @@ void testDeterministicCorrectTiming_initialLinks() { if (event instanceof LinkLeaveEvent) linkLeaveEvents.add((LinkLeaveEvent) event); } - Assert.assertEquals("wrong number of transit-driver-starts events.", 1, transitDriverStartsEvents.size()); - Assert.assertEquals("wrong number of link enter events.", 2, linkEnterEvents.size()); - Assert.assertEquals("wrong number of link leave events.", 2, linkLeaveEvents.size()); - Assert.assertEquals("wrong number of VehicleArrivesAtFacilityEvents.", 2, arrivesAtFacilityEvents.size()); - Assert.assertEquals("wrong number of VehicleDepartsAtFacilityEvents.", 2, departsAtFacilityEvents.size()); + Assertions.assertEquals(1, transitDriverStartsEvents.size(), "wrong number of transit-driver-starts events."); + Assertions.assertEquals(2, linkEnterEvents.size(), "wrong number of link enter events."); + Assertions.assertEquals(2, linkLeaveEvents.size(), "wrong number of link leave events."); + Assertions.assertEquals(2, arrivesAtFacilityEvents.size(), "wrong number of VehicleArrivesAtFacilityEvents."); + Assertions.assertEquals(2, departsAtFacilityEvents.size(), "wrong number of VehicleDepartsAtFacilityEvents."); - Assert.assertEquals(1000.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(1000.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); - if (this.isDeterministic) Assert.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(f.link1.getId(), linkLeaveEvents.get(0).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(f.link1.getId(), linkLeaveEvents.get(0).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(f.link2.getId(), linkEnterEvents.get(0).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(f.link2.getId(), linkEnterEvents.get(0).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1058.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(stop2.getId(), arrivesAtFacilityEvents.get(0).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1058.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(stop2.getId(), arrivesAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1060.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(stop2.getId(), departsAtFacilityEvents.get(0).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1060.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(stop2.getId(), departsAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1061.0, linkLeaveEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(f.link2.getId(), linkLeaveEvents.get(1).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1061.0, linkLeaveEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(f.link2.getId(), linkLeaveEvents.get(1).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1061.0, linkEnterEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(f.link3.getId(), linkEnterEvents.get(1).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1061.0, linkEnterEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(f.link3.getId(), linkEnterEvents.get(1).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1598.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(stop3.getId(), arrivesAtFacilityEvents.get(1).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1598.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(stop3.getId(), arrivesAtFacilityEvents.get(1).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1600.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(stop3.getId(), departsAtFacilityEvents.get(1).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1600.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(stop3.getId(), departsAtFacilityEvents.get(1).getFacilityId()); } /** @@ -955,45 +955,45 @@ void testTrailingLinksInRoute() { if (event instanceof PersonLeavesVehicleEvent) personLeavesVehicleEvents.add((PersonLeavesVehicleEvent) event); } - Assert.assertEquals("wrong number of transit-driver-starts events.", 1, transitDriverStartsEvents.size()); - Assert.assertEquals("wrong number of link enter events.", 2, linkEnterEvents.size()); - Assert.assertEquals("wrong number of link leave events.", 2, linkLeaveEvents.size()); - Assert.assertEquals("wrong number of VehicleArrivesAtFacilityEvents.", 2, arrivesAtFacilityEvents.size()); - Assert.assertEquals("wrong number of VehicleDepartsAtFacilityEvents.", 2, departsAtFacilityEvents.size()); - Assert.assertEquals("wrong number of PersonLeavesVehicleEvents.", 2, personLeavesVehicleEvents.size()); + Assertions.assertEquals(1, transitDriverStartsEvents.size(), "wrong number of transit-driver-starts events."); + Assertions.assertEquals(2, linkEnterEvents.size(), "wrong number of link enter events."); + Assertions.assertEquals(2, linkLeaveEvents.size(), "wrong number of link leave events."); + Assertions.assertEquals(2, arrivesAtFacilityEvents.size(), "wrong number of VehicleArrivesAtFacilityEvents."); + Assertions.assertEquals(2, departsAtFacilityEvents.size(), "wrong number of VehicleDepartsAtFacilityEvents."); + Assertions.assertEquals(2, personLeavesVehicleEvents.size(), "wrong number of PersonLeavesVehicleEvents."); - if (this.isDeterministic) Assert.assertEquals(997.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); + if (this.isDeterministic) Assertions.assertEquals(997.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); Id transitDriverId = transitDriverStartsEvents.get(0).getDriverId(); - if (this.isDeterministic) Assert.assertEquals(998.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(stop1.getId(), arrivesAtFacilityEvents.get(0).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(998.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(stop1.getId(), arrivesAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1000.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(stop1.getId(), departsAtFacilityEvents.get(0).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1000.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(stop1.getId(), departsAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(f.link1.getId(), linkLeaveEvents.get(0).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(f.link1.getId(), linkLeaveEvents.get(0).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(f.link2.getId(), linkEnterEvents.get(0).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(f.link2.getId(), linkEnterEvents.get(0).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1298.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(stop2.getId(), arrivesAtFacilityEvents.get(1).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1298.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(stop2.getId(), arrivesAtFacilityEvents.get(1).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1299.0, personLeavesVehicleEvents.get(0).getTime(), 1e-8); - Assert.assertEquals(person.getId(), personLeavesVehicleEvents.get(0).getPersonId()); + if (this.isDeterministic) Assertions.assertEquals(1299.0, personLeavesVehicleEvents.get(0).getTime(), 1e-8); + Assertions.assertEquals(person.getId(), personLeavesVehicleEvents.get(0).getPersonId()); - if (this.isDeterministic) Assert.assertEquals(1300.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(stop2.getId(), departsAtFacilityEvents.get(1).getFacilityId()); + if (this.isDeterministic) Assertions.assertEquals(1300.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(stop2.getId(), departsAtFacilityEvents.get(1).getFacilityId()); - if (this.isDeterministic) Assert.assertEquals(1301.0, linkLeaveEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(f.link2.getId(), linkLeaveEvents.get(1).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1301.0, linkLeaveEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(f.link2.getId(), linkLeaveEvents.get(1).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1301.0, linkEnterEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(f.link3.getId(), linkEnterEvents.get(1).getLinkId()); + if (this.isDeterministic) Assertions.assertEquals(1301.0, linkEnterEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(f.link3.getId(), linkEnterEvents.get(1).getLinkId()); - if (this.isDeterministic) Assert.assertEquals(1312.0, personLeavesVehicleEvents.get(1).getTime(), 1e-8); - Assert.assertEquals(transitDriverId, personLeavesVehicleEvents.get(1).getPersonId()); + if (this.isDeterministic) Assertions.assertEquals(1312.0, personLeavesVehicleEvents.get(1).getTime(), 1e-8); + Assertions.assertEquals(transitDriverId, personLeavesVehicleEvents.get(1).getPersonId()); } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/StorageCapacityTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/StorageCapacityTest.java index 2f331bc9f8e..fd7958999fb 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/StorageCapacityTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/StorageCapacityTest.java @@ -22,7 +22,8 @@ import java.util.List; import java.util.Map; import java.util.Set; -import org.junit.Assert; + +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -101,9 +102,9 @@ void testStorageCapacity() { System.out.println(counter3.currentMax); System.out.println(counter2.currentMax); System.out.println(counter1.currentMax); - Assert.assertEquals(14, counter3.currentMax); // the bottleneck link can store 14 vehicles - Assert.assertEquals(100, counter2.currentMax); //spillback 100 vehicles - Assert.assertEquals(100, counter1.currentMax); // spillback + Assertions.assertEquals(14, counter3.currentMax); // the bottleneck link can store 14 vehicles + Assertions.assertEquals(100, counter2.currentMax); //spillback 100 vehicles + Assertions.assertEquals(100, counter1.currentMax); // spillback } @@ -153,9 +154,9 @@ void testStorageCapacityDownscaling() { System.out.println(counter3.currentMax); System.out.println(counter2.currentMax); System.out.println(counter1.currentMax); - Assert.assertEquals(1, counter3.currentMax); // the bottleneck link can store 14 vehicles, but one vehicle counts for 10, so only 1 works - Assert.assertEquals(10, counter2.currentMax); //spillback 100 vehicles - Assert.assertEquals(10, counter1.currentMax); // spillback + Assertions.assertEquals(1, counter3.currentMax); // the bottleneck link can store 14 vehicles, but one vehicle counts for 10, so only 1 works + Assertions.assertEquals(10, counter2.currentMax); //spillback 100 vehicles + Assertions.assertEquals(10, counter1.currentMax); // spillback } @@ -218,8 +219,8 @@ void testStorageCapacityWithDifferentPCUs() { System.out.println(counter3.currentMax); System.out.println(counter2.currentMax); - Assert.assertEquals(10, counter3.currentMax); // the bottleneck link can store 14 vehicles - Assert.assertEquals(67, counter2.currentMax); //spillback 100 vehicles + Assertions.assertEquals(10, counter3.currentMax); // the bottleneck link can store 14 vehicles + Assertions.assertEquals(67, counter2.currentMax); //spillback 100 vehicles } @@ -303,8 +304,8 @@ void testStorageCapacityWithVaryingPCUs() { System.out.println(counter2.currentMax); System.out.println(counter3pm.currentMax); System.out.println(counter2pm.currentMax); - Assert.assertEquals(14, counter3.currentMax); // the bottleneck link can store 14 cars - Assert.assertEquals(100, counter2.currentMax); //spillback 100 cars + Assertions.assertEquals(14, counter3.currentMax); // the bottleneck link can store 14 cars + Assertions.assertEquals(100, counter2.currentMax); //spillback 100 cars //the following asserts fail on jenkins, but work on appveyor and travis //Assert.assertEquals(7, counter3pm.currentMax); // the bottleneck link can store 7 tractors diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/TravelTimeTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/TravelTimeTest.java index e75676a0ae5..5d8abf8fa14 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/TravelTimeTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/TravelTimeTest.java @@ -22,7 +22,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -68,13 +68,13 @@ void testEquilOneAgent() { .run(); Map, Double> travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(180.0, travelTimes.get(Id.create(15, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(180.0, travelTimes.get(Id.create(15, Link.class)).intValue(), MatsimTestUtils.EPSILON); // this one is NOT a travel time (it includes two activities and a zero-length trip) - Assert.assertEquals(13558.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(358.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1251.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(358.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(13558.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1251.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); } /** @@ -108,7 +108,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); Map, Double> travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); // Travel time 359.9712023038 scenario.getNetwork().getLinks().get(Id.createLinkId("6")).setFreespeed(27.85); @@ -120,7 +120,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); // Travel time 359.066427289 scenario.getNetwork().getLinks().get(Id.createLinkId("6")).setFreespeed(27.85); @@ -132,7 +132,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); // Travel time 358.4229390681 scenario.getNetwork().getLinks().get(Id.createLinkId("6")).setFreespeed(27.9); @@ -144,7 +144,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); // Travel time 360.3603603604 scenario.getNetwork().getLinks().get(Id.createLinkId("6")).setFreespeed(27.75); @@ -156,7 +156,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); // Travel time 400.0 scenario.getNetwork().getLinks().get(Id.createLinkId("6")).setLength(10000.0); @@ -169,7 +169,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(401.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(401.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); } @Test @@ -194,23 +194,23 @@ void testEquilTwoAgents() { .run(); Map, Double> travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(180.0, travelTimes.get(Id.create(15, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(180.0, travelTimes.get(Id.create(15, Link.class)).intValue(), MatsimTestUtils.EPSILON); // this one is NOT a travel time (it includes two activities and a zero-length trip) - Assert.assertEquals(13558.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(358.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1251.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(358.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(13558.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1251.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); travelTimes = agentTravelTimes.get(Id.create("2", Vehicle.class)); - Assert.assertEquals(358.0, travelTimes.get(Id.create(5, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(180.0, travelTimes.get(Id.create(14, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(5, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(180.0, travelTimes.get(Id.create(14, Link.class)).intValue(), MatsimTestUtils.EPSILON); // this one is NOT a travel time (it includes two activities and a zero-length trip) - Assert.assertEquals(13558.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(358.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1251.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(358.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(13558.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1251.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(358.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java index cd7c0b8a0da..a9220f145a8 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java @@ -21,7 +21,7 @@ package org.matsim.core.mobsim.jdeqsim; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; import java.util.HashMap; @@ -67,7 +67,7 @@ import org.matsim.testcases.MatsimTestUtils; import org.matsim.vehicles.Vehicle; -public abstract class AbstractJDEQSimTest { + public abstract class AbstractJDEQSimTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); @@ -228,7 +228,7 @@ protected void compareToDEQSimEvents(final String deqsimEventsFile) { ArrayList deqSimLog=CppEventFileParser.parseFile(deqsimEventsFile); for (int i=0;i 0); + Assertions.assertTrue(value.get() > 0); } @Test @@ -127,8 +127,8 @@ void testOverrideAgentFactoryTwice() { controler.addOverridingQSimModule(new TestQSimModule(value2)); controler.run(); - Assert.assertTrue(value1.get() == 0); - Assert.assertTrue(value2.get() > 0); + Assertions.assertTrue(value1.get() == 0); + Assertions.assertTrue(value2.get() > 0); } private class TestQSimModule extends AbstractQSimModule { @@ -187,7 +187,7 @@ protected void configureQSim() { controler.run(); - Assert.assertTrue(engine.called); + Assertions.assertTrue(engine.called); } static private class TestEngine implements MobsimEngine { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java index 5dd21d977ed..7577f729919 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java @@ -23,7 +23,8 @@ package org.matsim.core.mobsim.qsim; import java.util.*; -import org.junit.Assert; + +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.runner.RunWith; @@ -136,7 +137,7 @@ public void handleEvent(PersonEntersVehicleEvent event) { if (event.getVehicleId().equals(vehicleOfPerson.get(this.testAgent4)) && event.getLinkId().equals(this.linkId2)) { // if(this.isUsingFastCapacityUpdate) { - Assert.assertEquals("wrong link leave time.", 169., event.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(169., event.getTime(), MatsimTestUtils.EPSILON, "wrong link leave time."); // } else { // Assert.assertEquals("wrong link leave time.", 170., event.getTime(), MatsimTestCase.EPSILON); // } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/MobsimListenerManagerTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/MobsimListenerManagerTest.java index 1c4930b1271..8637093e879 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/MobsimListenerManagerTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/MobsimListenerManagerTest.java @@ -19,7 +19,7 @@ package org.matsim.core.mobsim.qsim; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.mobsim.framework.events.MobsimInitializedEvent; import org.matsim.core.mobsim.framework.listeners.MobsimInitializedListener; @@ -41,10 +41,10 @@ void testAddQueueSimulationListener() { manager.addQueueSimulationListener(extendedListener); manager.addQueueSimulationListener(doubleListener); manager.fireQueueSimulationInitializedEvent(); - Assert.assertEquals(1, simpleListener.count); - Assert.assertEquals(1, subListener.count); - Assert.assertEquals(1, extendedListener.count); - Assert.assertEquals(1, doubleListener.count); + Assertions.assertEquals(1, simpleListener.count); + Assertions.assertEquals(1, subListener.count); + Assertions.assertEquals(1, extendedListener.count); + Assertions.assertEquals(1, doubleListener.count); } @Test @@ -59,20 +59,20 @@ void testRemoveQueueSimulationListener() { manager.addQueueSimulationListener(extendedListener); manager.addQueueSimulationListener(doubleListener); manager.fireQueueSimulationInitializedEvent(); - Assert.assertEquals(1, simpleListener.count); - Assert.assertEquals(1, subListener.count); - Assert.assertEquals(1, extendedListener.count); - Assert.assertEquals(1, doubleListener.count); + Assertions.assertEquals(1, simpleListener.count); + Assertions.assertEquals(1, subListener.count); + Assertions.assertEquals(1, extendedListener.count); + Assertions.assertEquals(1, doubleListener.count); manager.removeQueueSimulationListener(simpleListener); manager.removeQueueSimulationListener(subListener); manager.removeQueueSimulationListener(extendedListener); manager.removeQueueSimulationListener(doubleListener); manager.fireQueueSimulationInitializedEvent(); - Assert.assertEquals(1, simpleListener.count); // should stay at 1 - Assert.assertEquals(1, subListener.count); - Assert.assertEquals(1, extendedListener.count); - Assert.assertEquals(1, doubleListener.count); + Assertions.assertEquals(1, simpleListener.count); // should stay at 1 + Assertions.assertEquals(1, subListener.count); + Assertions.assertEquals(1, extendedListener.count); + Assertions.assertEquals(1, doubleListener.count); } /*package*/ static class TestSimListener implements MobsimInitializedListener { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/NetsimRoutingConsistencyTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/NetsimRoutingConsistencyTest.java index 94d1ed9b117..1253b79ec74 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/NetsimRoutingConsistencyTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/NetsimRoutingConsistencyTest.java @@ -25,7 +25,7 @@ import java.util.Collections; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -64,7 +64,7 @@ import org.matsim.vehicles.Vehicle; import org.matsim.vehicles.VehicleUtils; - public class NetsimRoutingConsistencyTest { + public class NetsimRoutingConsistencyTest { /* * This test shows that the travel time that is predicted with the * NetworkRoutingModule is NOT equivalent to the travel time that is produced by @@ -202,8 +202,8 @@ void testRoutingVsSimulation() { // +1s per link double adjustedRoutingTravelTime = routingTravelTime + 2.0; - Assert.assertEquals(netsimTravelTime, 303.0, 1e-3); - Assert.assertEquals(adjustedRoutingTravelTime, 202.0, 1e-3); + Assertions.assertEquals(netsimTravelTime, 303.0, 1e-3); + Assertions.assertEquals(adjustedRoutingTravelTime, 202.0, 1e-3); } /* @@ -290,8 +290,8 @@ public void install() { // +1s per link double adjustedRoutingTravelTime = routingTravelTime + 2.0; - Assert.assertEquals(netsimTravelTime, 303.0, 1e-3); - Assert.assertEquals(adjustedRoutingTravelTime, 202.0, 1e-3); + Assertions.assertEquals(netsimTravelTime, 303.0, 1e-3); + Assertions.assertEquals(adjustedRoutingTravelTime, 202.0, 1e-3); } class DepartureArrivalListener implements PersonDepartureEventHandler, PersonArrivalEventHandler { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java index 23711c823b1..ac40a182b9d 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java @@ -26,7 +26,7 @@ import java.util.Map; import java.util.TreeMap; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -133,18 +133,18 @@ void testMergeSituationWithEmptyBufferAfterBufferRandomDistribution() { // test throughput for the first time interval /* the downstream link is not full, i.e. the links can send vehicles with their full outflow capacity. * the commodity on link 6_7 has not begun to send vehicles, i.e. the corresponding throughput should be 0 */ - Assert.assertEquals("Troughput on link 2_7 is wrong", 1, avgThroughputFreeFlow.get(Id.createLinkId("2_7")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 4_7 is wrong", 2, avgThroughputFreeFlow.get(Id.createLinkId("4_7")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 6_7 is wrong", 0, avgThroughputFreeFlow.get(Id.createLinkId("6_7")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, avgThroughputFreeFlow.get(Id.createLinkId("2_7")), MatsimTestUtils.EPSILON, "Troughput on link 2_7 is wrong"); + Assertions.assertEquals(2, avgThroughputFreeFlow.get(Id.createLinkId("4_7")), MatsimTestUtils.EPSILON, "Troughput on link 4_7 is wrong"); + Assertions.assertEquals(0, avgThroughputFreeFlow.get(Id.createLinkId("6_7")), MatsimTestUtils.EPSILON, "Troughput on link 6_7 is wrong"); // test throughput for the second time interval /* with probability of 2/3 link 4_7 is selected and sends all vehicles from its buffer, i.e. 2; * with probability of 1/3 link 2_7 is selected and sends all vehicles from its buffer, i.e. 1 and afterwards link 4_7 can send the remaining 1. * this means, the expected average throughput of link 2_7 is 1/3 and the expected average throughput of link 4_7 is 2*2/3 + 1/3 = 5/3. */ - Assert.assertEquals("Troughput on link 2_7 is wrong", 1./3, avgThroughputCongestedTwoLinks.get(Id.createLinkId("2_7")), delta); // 0.25384615384615383 - Assert.assertEquals("Troughput on link 4_7 is wrong", 5./3, avgThroughputCongestedTwoLinks.get(Id.createLinkId("4_7")), delta); // 1.7461538461538462 - Assert.assertEquals("Troughput on link 6_7 is wrong", 0, avgThroughputCongestedTwoLinks.get(Id.createLinkId("6_7")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1./3, avgThroughputCongestedTwoLinks.get(Id.createLinkId("2_7")), delta, "Troughput on link 2_7 is wrong"); // 0.25384615384615383 + Assertions.assertEquals(5./3, avgThroughputCongestedTwoLinks.get(Id.createLinkId("4_7")), delta, "Troughput on link 4_7 is wrong"); // 1.7461538461538462 + Assertions.assertEquals(0, avgThroughputCongestedTwoLinks.get(Id.createLinkId("6_7")), MatsimTestUtils.EPSILON, "Troughput on link 6_7 is wrong"); // test throughput for the third time interval /* with probability of 2/5 link 4_7 is selected and sends all vehicles from its buffer, i.e. 2; @@ -152,9 +152,9 @@ void testMergeSituationWithEmptyBufferAfterBufferRandomDistribution() { * with probability of 1/5 link 2_7 is selected and sends all vehicles from its buffer, i.e. 1 and afterwards link 4_7 or link 6_7 can send the remaining 1. * this means, the expected average throughput of link 2_7 is 1/5 and the expected average throughput of link 4_7 and link 6_7 is 2*2/5 + 1/10 = 9/10. */ - Assert.assertEquals("Troughput on link 2_7 is wrong", 1./5, avgThroughputCongestedThreeLinks.get(Id.createLinkId("2_7")), delta); // 0.17857142857142858 - Assert.assertEquals("Troughput on link 4_7 is wrong", 9./10, avgThroughputCongestedThreeLinks.get(Id.createLinkId("4_7")), delta); // 0.8928571428571429 - Assert.assertEquals("Troughput on link 6_7 is wrong", 9./10, avgThroughputCongestedThreeLinks.get(Id.createLinkId("6_7")), delta); // 0.9285714285714286 + Assertions.assertEquals(1./5, avgThroughputCongestedThreeLinks.get(Id.createLinkId("2_7")), delta, "Troughput on link 2_7 is wrong"); // 0.17857142857142858 + Assertions.assertEquals(9./10, avgThroughputCongestedThreeLinks.get(Id.createLinkId("4_7")), delta, "Troughput on link 4_7 is wrong"); // 0.8928571428571429 + Assertions.assertEquals(9./10, avgThroughputCongestedThreeLinks.get(Id.createLinkId("6_7")), delta, "Troughput on link 6_7 is wrong"); // 0.9285714285714286 } @Test @@ -202,9 +202,9 @@ void testMergeSituationWithMoveVehByVehRandomDistribution() { // test throughput for the first time interval /* the downstream link is not full, i.e. the links can send vehicles with their full outflow capacity. * the commodity on link 6_7 has not begun to send vehicles, i.e. the corresponding throughput should be 0 */ - Assert.assertEquals("Troughput on link 2_7 is wrong", 1, avgThroughputFreeFlow.get(Id.createLinkId("2_7")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 4_7 is wrong", 2, avgThroughputFreeFlow.get(Id.createLinkId("4_7")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 6_7 is wrong", 0, avgThroughputFreeFlow.get(Id.createLinkId("6_7")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, avgThroughputFreeFlow.get(Id.createLinkId("2_7")), MatsimTestUtils.EPSILON, "Troughput on link 2_7 is wrong"); + Assertions.assertEquals(2, avgThroughputFreeFlow.get(Id.createLinkId("4_7")), MatsimTestUtils.EPSILON, "Troughput on link 4_7 is wrong"); + Assertions.assertEquals(0, avgThroughputFreeFlow.get(Id.createLinkId("6_7")), MatsimTestUtils.EPSILON, "Troughput on link 6_7 is wrong"); // test throughput for the second time interval /* with probability of 2/3 link 4_7 is selected and sends one vehicle; afterwards with probability of 2/3 link 4_7 is allowed to send the second vehicle, with probability 1/3 link 2_7 is allowed to send one. @@ -214,9 +214,9 @@ void testMergeSituationWithMoveVehByVehRandomDistribution() { * the numbers are as follows: the expected average throughput of link 2_7 is 2/3*1/3*1 + 1/3*1 = 5/9 * and the expected average throughput of link 4_7 is 2/3*2/3*2 + 2/3*1/3*1 + 1/3*1 = 13/9 */ - Assert.assertEquals("Troughput on link 2_7 is wrong", 5./9, avgThroughputCongestedTwoLinks.get(Id.createLinkId("2_7")), delta); // 0.5307692307692308 - Assert.assertEquals("Troughput on link 4_7 is wrong", 13./9, avgThroughputCongestedTwoLinks.get(Id.createLinkId("4_7")), delta); // 1.4692307692307693 - Assert.assertEquals("Troughput on link 6_7 is wrong", 0, avgThroughputCongestedTwoLinks.get(Id.createLinkId("6_7")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5./9, avgThroughputCongestedTwoLinks.get(Id.createLinkId("2_7")), delta, "Troughput on link 2_7 is wrong"); // 0.5307692307692308 + Assertions.assertEquals(13./9, avgThroughputCongestedTwoLinks.get(Id.createLinkId("4_7")), delta, "Troughput on link 4_7 is wrong"); // 1.4692307692307693 + Assertions.assertEquals(0, avgThroughputCongestedTwoLinks.get(Id.createLinkId("6_7")), MatsimTestUtils.EPSILON, "Troughput on link 6_7 is wrong"); // test throughput for the third time interval /* the first vehicle is send by link 2_7 with probability of 1/5 and by one of the other two links with probability 2/5. @@ -227,9 +227,9 @@ void testMergeSituationWithMoveVehByVehRandomDistribution() { * the numbers are as follows: the expected average throughput of link 2_7 is 1/5*1/2*1 + 1/5*1/2*1 + 2/5*1/5*1 + 2/5*1/5*1 = 9/25 = 0.36 * and the expected average throughput of link 4_7 and 6_7 is 1/5*1/2*1 + 2/5*2/5*2 + 2/5*1/5*1 + 2/5*2/5*1 + 2/5*2/5*1 = 41/50 */ - Assert.assertEquals("Troughput on link 2_7 is wrong", 9./25, avgThroughputCongestedThreeLinks.get(Id.createLinkId("2_7")), delta); // 0.34285714285714286 - Assert.assertEquals("Troughput on link 4_7 is wrong", 41./50, avgThroughputCongestedThreeLinks.get(Id.createLinkId("4_7")), delta); // 0.8 - Assert.assertEquals("Troughput on link 6_7 is wrong", 41./50, avgThroughputCongestedThreeLinks.get(Id.createLinkId("6_7")), delta); // 0.8571428571428571 + Assertions.assertEquals(9./25, avgThroughputCongestedThreeLinks.get(Id.createLinkId("2_7")), delta, "Troughput on link 2_7 is wrong"); // 0.34285714285714286 + Assertions.assertEquals(41./50, avgThroughputCongestedThreeLinks.get(Id.createLinkId("4_7")), delta, "Troughput on link 4_7 is wrong"); // 0.8 + Assertions.assertEquals(41./50, avgThroughputCongestedThreeLinks.get(Id.createLinkId("6_7")), delta, "Troughput on link 6_7 is wrong"); // 0.8571428571428571 } @Test @@ -280,25 +280,25 @@ void testMergeSituationWithMoveVehByVehDeterministicPriorities() { // test throughput for the first time interval /* the downstream link is not full, i.e. the links can send vehicles with their full outflow capacity. * the commodity on link 6_7 has not begun to send vehicles, i.e. the corresponding throughput should be 0 */ - Assert.assertEquals("Troughput on link 2_7 is wrong", 1, avgThroughputFreeFlow.get(Id.createLinkId("2_7")), delta); - Assert.assertEquals("Troughput on link 4_7 is wrong", 2, avgThroughputFreeFlow.get(Id.createLinkId("4_7")), delta); - Assert.assertEquals("Troughput on link 6_7 is wrong", 0, avgThroughputFreeFlow.get(Id.createLinkId("6_7")), delta); + Assertions.assertEquals(1, avgThroughputFreeFlow.get(Id.createLinkId("2_7")), delta, "Troughput on link 2_7 is wrong"); + Assertions.assertEquals(2, avgThroughputFreeFlow.get(Id.createLinkId("4_7")), delta, "Troughput on link 4_7 is wrong"); + Assertions.assertEquals(0, avgThroughputFreeFlow.get(Id.createLinkId("6_7")), delta, "Troughput on link 6_7 is wrong"); // test throughput for the second time interval /* the deterministic node transition should distribute the free slots on the downstream link exactly proportional to the outflow capacity of the links, * i.e. 1:2 in this case */ - Assert.assertEquals("Troughput on link 2_7 is wrong", 1./3 * 2, avgThroughputCongestedTwoLinks.get(Id.createLinkId("2_7")), deltaPeriodic); // 0.6692307692307692 - Assert.assertEquals("Troughput on link 4_7 is wrong", 2./3 * 2, avgThroughputCongestedTwoLinks.get(Id.createLinkId("4_7")), deltaPeriodic); // 1.3307692307692307 - Assert.assertEquals("Troughput on link 6_7 is wrong", 0, avgThroughputCongestedTwoLinks.get(Id.createLinkId("6_7")), delta); + Assertions.assertEquals(1./3 * 2, avgThroughputCongestedTwoLinks.get(Id.createLinkId("2_7")), deltaPeriodic, "Troughput on link 2_7 is wrong"); // 0.6692307692307692 + Assertions.assertEquals(2./3 * 2, avgThroughputCongestedTwoLinks.get(Id.createLinkId("4_7")), deltaPeriodic, "Troughput on link 4_7 is wrong"); // 1.3307692307692307 + Assertions.assertEquals(0, avgThroughputCongestedTwoLinks.get(Id.createLinkId("6_7")), delta, "Troughput on link 6_7 is wrong"); // test throughput for the third time interval /* the deterministic node transition should distribute the free slots on the downstream link exactly proportional to the outflow capacity of the links, * i.e. 1:2:2 in this case. */ - Assert.assertEquals("Troughput on link 2_7 is wrong", 1./5 * 2, avgThroughputCongestedThreeLinks.get(Id.createLinkId("2_7")), delta); // 0.4 - Assert.assertEquals("Troughput on link 4_7 is wrong", 2./5 * 2, avgThroughputCongestedThreeLinks.get(Id.createLinkId("4_7")), delta); // 0.8 - Assert.assertEquals("Troughput on link 6_7 is wrong", 2./5 * 2, avgThroughputCongestedThreeLinks.get(Id.createLinkId("6_7")), delta); // 0.8 + Assertions.assertEquals(1./5 * 2, avgThroughputCongestedThreeLinks.get(Id.createLinkId("2_7")), delta, "Troughput on link 2_7 is wrong"); // 0.4 + Assertions.assertEquals(2./5 * 2, avgThroughputCongestedThreeLinks.get(Id.createLinkId("4_7")), delta, "Troughput on link 4_7 is wrong"); // 0.8 + Assertions.assertEquals(2./5 * 2, avgThroughputCongestedThreeLinks.get(Id.createLinkId("6_7")), delta, "Troughput on link 6_7 is wrong"); // 0.8 } @Test @@ -357,18 +357,18 @@ void testBlockedNodeSituationWithEmptyBufferAfterBufferRandomDistribution() { /* the downstream link is not full, i.e. the links can send vehicles with their full outflow capacity. * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be zero here. */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 2, avgThroughputFreeFlow.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 4_5 is wrong", 1, avgThroughputFreeFlow.get(Id.createLinkId("4_5")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 5_8 is wrong", 0, avgThroughputFreeFlow.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, avgThroughputFreeFlow.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(1, avgThroughputFreeFlow.get(Id.createLinkId("4_5")), MatsimTestUtils.EPSILON, "Troughput on link 4_5 is wrong"); + Assertions.assertEquals(0, avgThroughputFreeFlow.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON, "Troughput on link 5_8 is wrong"); // test throughput for the second time interval /* with probability 1/3 link 4_5 is selected first and can send all its vehicles from the buffer (i.e. one) before link 2_5 blocks the intersection. * if link 2_5 is selected first the intersection is blocked immediately. * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be zero here. */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 4_5 is wrong", 1./3, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("4_5")), delta); // 0.36666666666666664 - Assert.assertEquals("Troughput on link 5_8 is wrong", 0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(1./3, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("4_5")), delta, "Troughput on link 4_5 is wrong"); // 0.36666666666666664 + Assertions.assertEquals(0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON, "Troughput on link 5_8 is wrong"); // test throughput for the third time interval /* with probability 1/3 link 4_5 is selected first and can send all its vehicles from the buffer (i.e. one) before link 2_5 sends its first one and blocks the intersection. @@ -377,9 +377,9 @@ void testBlockedNodeSituationWithEmptyBufferAfterBufferRandomDistribution() { * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be equal to the flow * capacity of link 5_8 here, i.e. 1 veh per time step (=sec). */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 4_5 is wrong", 1./3, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("4_5")), delta); // 0.3263157894736842 - Assert.assertEquals("Troughput on link 5_8 is wrong", 1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(1./3, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("4_5")), delta, "Troughput on link 4_5 is wrong"); // 0.3263157894736842 + Assertions.assertEquals(1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON, "Troughput on link 5_8 is wrong"); } @Test @@ -438,18 +438,18 @@ void testBlockedNodeSituationWithMoveVehByVehRandomDistribution() { /* the downstream link is not full, i.e. the links can send vehicles with their full outflow capacity. * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be zero here. */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 2, avgThroughputFreeFlow.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 4_5 is wrong", 1, avgThroughputFreeFlow.get(Id.createLinkId("4_5")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 5_8 is wrong", 0, avgThroughputFreeFlow.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, avgThroughputFreeFlow.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(1, avgThroughputFreeFlow.get(Id.createLinkId("4_5")), MatsimTestUtils.EPSILON, "Troughput on link 4_5 is wrong"); + Assertions.assertEquals(0, avgThroughputFreeFlow.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON, "Troughput on link 5_8 is wrong"); // test throughput for the second time interval /* with probability 1/3 link 4_5 is selected first and can send one vehicle before link 2_5 blocks the intersection. * if link 2_5 is selected first the intersection is blocked immediately. * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be zero here. */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 4_5 is wrong", 1./3, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("4_5")), delta); // 0.3333333333333333 - Assert.assertEquals("Troughput on link 5_8 is wrong", 0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(1./3, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("4_5")), delta, "Troughput on link 4_5 is wrong"); // 0.3333333333333333 + Assertions.assertEquals(0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON, "Troughput on link 5_8 is wrong"); // test throughput for the third time interval /* with probability 1/3 link 4_5 is selected first and can send one vehicle before link 2_5 sends its first one and blocks the intersection. @@ -459,9 +459,9 @@ void testBlockedNodeSituationWithMoveVehByVehRandomDistribution() { * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be equal to the flow * capacity of link 5_8 here, i.e. 1 veh per time step (=sec). */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON); - Assert.assertEquals("Troughput on link 4_5 is wrong", 5./9, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("4_5")), delta); // 0.5736842105263158 - Assert.assertEquals("Troughput on link 5_8 is wrong", 1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("2_5")), MatsimTestUtils.EPSILON, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(5./9, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("4_5")), delta, "Troughput on link 4_5 is wrong"); // 0.5736842105263158 + Assertions.assertEquals(1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON, "Troughput on link 5_8 is wrong"); } @Test @@ -521,9 +521,9 @@ void testBlockedNodeSituationWithMoveVehByVehDeterministicPriorities() { /* the downstream link is not full, i.e. the links can send vehicles with their full outflow capacity. * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be zero here. */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 2, avgThroughputFreeFlow.get(Id.createLinkId("2_5")), delta); - Assert.assertEquals("Troughput on link 4_5 is wrong", 1, avgThroughputFreeFlow.get(Id.createLinkId("4_5")), delta); - Assert.assertEquals("Troughput on link 5_8 is wrong", 0, avgThroughputFreeFlow.get(Id.createLinkId("5_8")), delta); + Assertions.assertEquals(2, avgThroughputFreeFlow.get(Id.createLinkId("2_5")), delta, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(1, avgThroughputFreeFlow.get(Id.createLinkId("4_5")), delta, "Troughput on link 4_5 is wrong"); + Assertions.assertEquals(0, avgThroughputFreeFlow.get(Id.createLinkId("5_8")), delta, "Troughput on link 5_8 is wrong"); // test throughput for the second time interval /* the deterministic node transition should reduce the outflow of all links by the same percentage with which the outflow of links has to be reduced that lead to congested links. @@ -531,9 +531,9 @@ void testBlockedNodeSituationWithMoveVehByVehDeterministicPriorities() { * this works because the link with downstream congestion has and keeps the minimal priority (i.e. is always selected first) as soon as the move node step is stopped because of downstream congestion. * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be zero here. */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("2_5")), delta); - Assert.assertEquals("Troughput on link 4_5 is wrong", 0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("4_5")), delta); - Assert.assertEquals("Troughput on link 5_8 is wrong", 0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("5_8")), delta); + Assertions.assertEquals(0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("2_5")), delta, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("4_5")), delta, "Troughput on link 4_5 is wrong"); + Assertions.assertEquals(0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("5_8")), delta, "Troughput on link 5_8 is wrong"); // test throughput for the third time interval /* the deterministic node transition should reduce the outflow of all links by the same percentage with which the outflow of links has to be reduced that lead to congested links. @@ -541,9 +541,9 @@ void testBlockedNodeSituationWithMoveVehByVehDeterministicPriorities() { * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be equal to the flow * capacity of link 5_8 here, i.e. 1 veh per time step (=sec). */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 1./2 * 2, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("2_5")), delta); - Assert.assertEquals("Troughput on link 4_5 is wrong", 1./2 * 1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("4_5")), delta); - Assert.assertEquals("Troughput on link 5_8 is wrong", 1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("5_8")), delta); + Assertions.assertEquals(1./2 * 2, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("2_5")), delta, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(1./2 * 1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("4_5")), delta, "Troughput on link 4_5 is wrong"); + Assertions.assertEquals(1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("5_8")), delta, "Troughput on link 5_8 is wrong"); } /** @@ -611,18 +611,18 @@ void testNodeTransitionWithTimeStepSizeSmallerOne() { /* the downstream link is not full, i.e. the links can send vehicles with their full outflow capacity. * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be zero here. */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 1, avgThroughputFreeFlow.get(Id.createLinkId("2_5")), delta); - Assert.assertEquals("Troughput on link 4_5 is wrong", 0.5, avgThroughputFreeFlow.get(Id.createLinkId("4_5")), delta); - Assert.assertEquals("Troughput on link 5_8 is wrong", 0.0, avgThroughputFreeFlow.get(Id.createLinkId("5_8")), delta); + Assertions.assertEquals(1, avgThroughputFreeFlow.get(Id.createLinkId("2_5")), delta, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(0.5, avgThroughputFreeFlow.get(Id.createLinkId("4_5")), delta, "Troughput on link 4_5 is wrong"); + Assertions.assertEquals(0.0, avgThroughputFreeFlow.get(Id.createLinkId("5_8")), delta, "Troughput on link 5_8 is wrong"); // test throughput for the second time interval /* the downstream link of 2_5 is full, i.e. no vehicles can leave 2_5 in this time interval. * link 4_5 is not affected by this, because blockNodeWhenSingleOutlinkFull is set to false. * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be zero here. */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("2_5")), delta); - Assert.assertEquals("Troughput on link 4_5 is wrong", 0.5, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("4_5")), delta); - Assert.assertEquals("Troughput on link 5_8 is wrong", 0.0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("5_8")), delta); + Assertions.assertEquals(0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("2_5")), delta, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(0.5, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("4_5")), delta, "Troughput on link 4_5 is wrong"); + Assertions.assertEquals(0.0, avgThroughputCongestedNodeBlocked.get(Id.createLinkId("5_8")), delta, "Troughput on link 5_8 is wrong"); // test throughput for the third time interval /* the downstream link of 2_5 lets 1 veh in every two time steps, i.e. throughput of link 2_5 should be 0.5 per time step. @@ -630,9 +630,9 @@ void testNodeTransitionWithTimeStepSizeSmallerOne() { * the first vehicles reach the end of link 5_8 around sec 300, i.e. throughput of link 5_8 should be equal to the flow * capacity of link 5_8 here, i.e. 0.5 veh per time step. */ - Assert.assertEquals("Troughput on link 2_5 is wrong", 0.5, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("2_5")), delta); - Assert.assertEquals("Troughput on link 4_5 is wrong", 0.5, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("4_5")), delta); - Assert.assertEquals("Troughput on link 5_8 is wrong", 0.5, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("5_8")), delta); + Assertions.assertEquals(0.5, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("2_5")), delta, "Troughput on link 2_5 is wrong"); + Assertions.assertEquals(0.5, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("4_5")), delta, "Troughput on link 4_5 is wrong"); + Assertions.assertEquals(0.5, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("5_8")), delta, "Troughput on link 5_8 is wrong"); } private static final class Fixture { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java index b27f758dfb3..fcded837c33 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java @@ -29,7 +29,7 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -170,9 +170,9 @@ void testSingleAgent() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 2, collector.events.size()); - Assert.assertEquals("wrong time in first event.", 6.0*3600 + 1, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in second event.", 6.0*3600 + 12, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(6.0*3600 + 1, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in first event."); + Assertions.assertEquals(6.0*3600 + 12, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in second event."); } @@ -238,9 +238,9 @@ void testSingleAgentWithEndOnLeg() { } // // /* finish */ - Assert.assertEquals("wrong number of link enter events.", 2, collector.events.size()); - Assert.assertEquals("wrong time in first event.", 6.0*3600 + 1, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in second event.", 6.0*3600 + 12, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(6.0*3600 + 1, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in first event."); + Assertions.assertEquals(6.0*3600 + 12, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in second event."); } /** @@ -278,11 +278,11 @@ void testTwoAgent() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 4, collector.events.size()); - Assert.assertEquals("wrong time in first event.", 6.0*3600 + 1, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in second event.", 6.0*3600 + 12, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in first event.", 7.0*3600 + 1, collector.events.get(2).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in second event.", 7.0*3600 + 12, collector.events.get(3).getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(6.0*3600 + 1, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in first event."); + Assertions.assertEquals(6.0*3600 + 12, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in second event."); + Assertions.assertEquals(7.0*3600 + 1, collector.events.get(2).getTime(), MatsimTestUtils.EPSILON, "wrong time in first event."); + Assertions.assertEquals(7.0*3600 + 12, collector.events.get(3).getTime(), MatsimTestUtils.EPSILON, "wrong time in second event."); } /** @@ -317,16 +317,16 @@ void testTeleportationSingleAgent() { sim.run(); List allEvents = collector.getEvents(); - Assert.assertEquals("wrong number of events.", 5, collector.getEvents().size()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", TeleportationArrivalEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(4).getClass()); - Assert.assertEquals("wrong time in event.", 6.0*3600 + 0, allEvents.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in event.", 6.0*3600 + 0, allEvents.get(1).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in event.", 6.0*3600 + 15, allEvents.get(2).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in event.", 6.0*3600 + 15, allEvents.get(3).getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(5, collector.getEvents().size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of event."); + Assertions.assertEquals(TeleportationArrivalEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(4).getClass(), "wrong type of event."); + Assertions.assertEquals(6.0*3600 + 0, allEvents.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in event."); + Assertions.assertEquals(6.0*3600 + 0, allEvents.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in event."); + Assertions.assertEquals(6.0*3600 + 15, allEvents.get(2).getTime(), MatsimTestUtils.EPSILON, "wrong time in event."); + Assertions.assertEquals(6.0*3600 + 15, allEvents.get(3).getTime(), MatsimTestUtils.EPSILON, "wrong time in event."); } /** @@ -365,9 +365,9 @@ void testSingleAgentImmediateDeparture() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 2, collector.events.size()); - Assert.assertEquals("wrong time in first event.", 0.0*3600 + 1, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in second event.", 0.0*3600 + 12, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, collector.events.size(), "wrong number of link enter events."); + Assertions.assertEquals(0.0*3600 + 1, collector.events.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in first event."); + Assertions.assertEquals(0.0*3600 + 12, collector.events.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in second event."); } /** @@ -413,40 +413,44 @@ void testSingleAgent_EmptyRoute() { for (Event event : allEvents) { System.out.println(event); } - Assert.assertEquals("wrong number of events.", 8, allEvents.size()); - - - Assert.assertEquals("wrong type of 1st event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of 2nd event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of 3rd event.", PersonEntersVehicleEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of 4th event.", VehicleEntersTrafficEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of 5th event.", VehicleLeavesTrafficEvent.class, allEvents.get(4).getClass()); - Assert.assertEquals("wrong type of 6th event.", PersonLeavesVehicleEvent.class, allEvents.get(5).getClass()); - Assert.assertEquals("wrong type of 7th event.", PersonArrivalEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of 8th event.", ActivityStartEvent.class, allEvents.get(7).getClass()); - - - Assert.assertEquals("wrong time in 1st event.", 6.0*3600 + 0, allEvents.get(0).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 2nd event.", 6.0*3600 + 0, allEvents.get(1).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 3rd event.", 6.0*3600 + 0, allEvents.get(2).getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 4th event.", 6.0*3600 + 0, allEvents.get(3).getTime(), MatsimTestUtils.EPSILON); - - Assert.assertEquals("wrong time in 5th event.", 6.0 * 3600 + 0, allEvents.get(4).getTime(), - MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 6th event.", 6.0 * 3600 + 0, allEvents.get(5).getTime(), - MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 7th event.", 6.0 * 3600 + 0, allEvents.get(6).getTime(), - MatsimTestUtils.EPSILON); - Assert.assertEquals("wrong time in 8th event.", 6.0 * 3600 + 0, allEvents.get(7).getTime(), - MatsimTestUtils.EPSILON); - - - Assert.assertEquals("wrong link in 1st event.", f.link1.getId(), ((ActivityEndEvent) allEvents.get(0)).getLinkId() ); - Assert.assertEquals("wrong link in 2nd event.", f.link1.getId(), ((PersonDepartureEvent) allEvents.get(1)).getLinkId() ); - Assert.assertEquals("wrong link in 4th event.", f.link1.getId(), ((VehicleEntersTrafficEvent) allEvents.get(3)).getLinkId() ); - Assert.assertEquals("wrong link in 5th event.", f.link1.getId(), ((VehicleLeavesTrafficEvent) allEvents.get(4)).getLinkId() ); - Assert.assertEquals("wrong link in 7th event.", f.link1.getId(), ((PersonArrivalEvent) allEvents.get(6)).getLinkId() ); - Assert.assertEquals("wrong link in 8th event.", f.link1.getId(), ((ActivityStartEvent) allEvents.get(7)).getLinkId() ); + Assertions.assertEquals(8, allEvents.size(), "wrong number of events."); + + + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of 1st event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of 2nd event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(2).getClass(), "wrong type of 3rd event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(3).getClass(), "wrong type of 4th event."); + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(4).getClass(), "wrong type of 5th event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(5).getClass(), "wrong type of 6th event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(6).getClass(), "wrong type of 7th event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(7).getClass(), "wrong type of 8th event."); + + + Assertions.assertEquals(6.0*3600 + 0, allEvents.get(0).getTime(), MatsimTestUtils.EPSILON, "wrong time in 1st event."); + Assertions.assertEquals(6.0*3600 + 0, allEvents.get(1).getTime(), MatsimTestUtils.EPSILON, "wrong time in 2nd event."); + Assertions.assertEquals(6.0*3600 + 0, allEvents.get(2).getTime(), MatsimTestUtils.EPSILON, "wrong time in 3rd event."); + Assertions.assertEquals(6.0*3600 + 0, allEvents.get(3).getTime(), MatsimTestUtils.EPSILON, "wrong time in 4th event."); + + Assertions.assertEquals(6.0 * 3600 + 0, allEvents.get(4).getTime(), + MatsimTestUtils.EPSILON, + "wrong time in 5th event."); + Assertions.assertEquals(6.0 * 3600 + 0, allEvents.get(5).getTime(), + MatsimTestUtils.EPSILON, + "wrong time in 6th event."); + Assertions.assertEquals(6.0 * 3600 + 0, allEvents.get(6).getTime(), + MatsimTestUtils.EPSILON, + "wrong time in 7th event."); + Assertions.assertEquals(6.0 * 3600 + 0, allEvents.get(7).getTime(), + MatsimTestUtils.EPSILON, + "wrong time in 8th event."); + + + Assertions.assertEquals(f.link1.getId(), ((ActivityEndEvent) allEvents.get(0)).getLinkId(), "wrong link in 1st event." ); + Assertions.assertEquals(f.link1.getId(), ((PersonDepartureEvent) allEvents.get(1)).getLinkId(), "wrong link in 2nd event." ); + Assertions.assertEquals(f.link1.getId(), ((VehicleEntersTrafficEvent) allEvents.get(3)).getLinkId(), "wrong link in 4th event." ); + Assertions.assertEquals(f.link1.getId(), ((VehicleLeavesTrafficEvent) allEvents.get(4)).getLinkId(), "wrong link in 5th event." ); + Assertions.assertEquals(f.link1.getId(), ((PersonArrivalEvent) allEvents.get(6)).getLinkId(), "wrong link in 7th event." ); + Assertions.assertEquals(f.link1.getId(), ((ActivityStartEvent) allEvents.get(7)).getLinkId(), "wrong link in 8th event." ); } /** @@ -491,21 +495,21 @@ void testSingleAgent_LastLinkIsLoop() { for (Event event : allEvents) { System.out.println(event); } - Assert.assertEquals("wrong number of events.", 14, allEvents.size()); - Assert.assertEquals("wrong type of 1st event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of 2nd event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", PersonEntersVehicleEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", VehicleEntersTrafficEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(4).getClass()); // link 1 - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(5).getClass()); // link 2 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(7).getClass()); // link 3 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(8).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(9).getClass()); // loop link - Assert.assertEquals("wrong type of event.", VehicleLeavesTrafficEvent.class, allEvents.get(10).getClass()); - Assert.assertEquals("wrong type of event.", PersonLeavesVehicleEvent.class, allEvents.get(11).getClass()); - Assert.assertEquals("wrong type of 11th event.", PersonArrivalEvent.class, allEvents.get(12).getClass()); - Assert.assertEquals("wrong type of 12th event.", ActivityStartEvent.class, allEvents.get(13).getClass()); + Assertions.assertEquals(14, allEvents.size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of 1st event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of 2nd event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(4).getClass(), "wrong type of event."); // link 1 + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(5).getClass(), "wrong type of event."); // link 2 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(6).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(7).getClass(), "wrong type of event."); // link 3 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(8).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(9).getClass(), "wrong type of event."); // loop link + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(10).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(11).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(12).getClass(), "wrong type of 11th event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(13).getClass(), "wrong type of 12th event."); } /*package*/ static class LinkEnterEventCollector implements LinkEnterEventHandler { @@ -544,7 +548,7 @@ void testAgentWithoutLeg() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 0, collector.events.size()); + Assertions.assertEquals(0, collector.events.size(), "wrong number of link enter events."); } /** @@ -572,7 +576,7 @@ void testAgentWithoutLegWithEndtime() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 0, collector.events.size()); + Assertions.assertEquals(0, collector.events.size(), "wrong number of link enter events."); } /** @@ -606,7 +610,7 @@ void testAgentWithLastActWithEndtime() { sim.run(); /* finish */ - Assert.assertEquals("wrong number of link enter events.", 0, collector.events.size()); + Assertions.assertEquals(0, collector.events.size(), "wrong number of link enter events."); } /** @@ -663,9 +667,9 @@ void testFlowCapacityDriving() { System.out.println("#vehicles 8-9: " + Integer.toString(volume[8])); // if(this.isUsingFastCapacityUpdate) { - Assert.assertEquals(3001, volume[6]); // we should have half of the maximum flow in this hour - Assert.assertEquals(6000, volume[7]); // we should have maximum flow in this hour - Assert.assertEquals(999, volume[8]); // all the rest + Assertions.assertEquals(3001, volume[6]); // we should have half of the maximum flow in this hour + Assertions.assertEquals(6000, volume[7]); // we should have maximum flow in this hour + Assertions.assertEquals(999, volume[8]); // all the rest // } else { // Assert.assertEquals(3000, volume[6]); // we should have half of the maximum flow in this hour // Assert.assertEquals(6000, volume[7]); // we should have maximum flow in this hour @@ -722,9 +726,9 @@ void testFlowCapacityDrivingFraction() { /* finish */ int[] volume = vAnalyzer.getVolumesForLink(f.link2.getId()); - Assert.assertEquals(1, volume[7*3600 - 1800]); // First vehicle - Assert.assertEquals(1, volume[7*3600 - 1800 + 4]); // Second vehicle - Assert.assertEquals(1, volume[7*3600 - 1800 + 8]); // Third vehicle + Assertions.assertEquals(1, volume[7*3600 - 1800]); // First vehicle + Assertions.assertEquals(1, volume[7*3600 - 1800 + 4]); // Second vehicle + Assertions.assertEquals(1, volume[7*3600 - 1800 + 8]); // Third vehicle } /** @@ -773,9 +777,9 @@ void testFlowCapacityStarting() { System.out.println("#vehicles 8-9: " + Integer.toString(volume[8])); // if(this.isUsingFastCapacityUpdate) { - Assert.assertEquals(3001, volume[6]); // we should have half of the maximum flow in this hour - Assert.assertEquals(6000, volume[7]); // we should have maximum flow in this hour - Assert.assertEquals(999, volume[8]); // all the rest + Assertions.assertEquals(3001, volume[6]); // we should have half of the maximum flow in this hour + Assertions.assertEquals(6000, volume[7]); // we should have maximum flow in this hour + Assertions.assertEquals(999, volume[8]); // all the rest // } else { // Assert.assertEquals(3000, volume[6]); // we should have half of the maximum flow in this hour // Assert.assertEquals(6000, volume[7]); // we should have maximum flow in this hour @@ -842,9 +846,9 @@ void testFlowCapacityMixed() { System.out.println("#vehicles 8-9: " + Integer.toString(volume[8])); // if(this.isUsingFastCapacityUpdate) { - Assert.assertEquals(3001, volume[6]); // we should have half of the maximum flow in this hour - Assert.assertEquals(6000, volume[7]); // we should have maximum flow in this hour - Assert.assertEquals(999, volume[8]); // all the rest + Assertions.assertEquals(3001, volume[6]); // we should have half of the maximum flow in this hour + Assertions.assertEquals(6000, volume[7]); // we should have maximum flow in this hour + Assertions.assertEquals(999, volume[8]); // all the rest // } else { // Assert.assertEquals(3000, volume[6]); // we should have half of the maximum flow in this hour // Assert.assertEquals(6000, volume[7]); // we should have maximum flow in this hour @@ -889,22 +893,22 @@ void testVehicleTeleportationTrue() { sim.run(); List allEvents = collector.getEvents(); - Assert.assertEquals("wrong number of events.", 15, allEvents.size()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", TeleportationArrivalEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(4).getClass()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(5).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of event.", PersonEntersVehicleEvent.class, allEvents.get(7).getClass()); - Assert.assertEquals("wrong type of event.", VehicleEntersTrafficEvent.class, allEvents.get(8).getClass()); - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(9).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(10).getClass()); - Assert.assertEquals("wrong type of event.", VehicleLeavesTrafficEvent.class, allEvents.get(11).getClass()); - Assert.assertEquals("wrong type of event.", PersonLeavesVehicleEvent.class, allEvents.get(12).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(13).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(14).getClass()); + Assertions.assertEquals(15, allEvents.size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of event."); + Assertions.assertEquals(TeleportationArrivalEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(4).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(5).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(6).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(7).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(8).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(9).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(10).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(11).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(12).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(13).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(14).getClass(), "wrong type of event."); } @@ -970,37 +974,37 @@ void testWaitingForCar() { for (Event event : allEvents) { System.out.println(event); } - Assert.assertEquals("wrong number of events.", 30, allEvents.size()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", TeleportationArrivalEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(4).getClass()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(5).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(7).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(8).getClass()); - Assert.assertEquals("wrong type of event.", PersonEntersVehicleEvent.class, allEvents.get(9).getClass()); - Assert.assertEquals("wrong type of event.", VehicleEntersTrafficEvent.class, allEvents.get(10).getClass()); - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(11).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(12).getClass()); - Assert.assertEquals("wrong type of event.", VehicleLeavesTrafficEvent.class, allEvents.get(13).getClass()); - Assert.assertEquals("wrong type of event.", PersonLeavesVehicleEvent.class, allEvents.get(14).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(15).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(16).getClass()); - Assert.assertEquals("wrong type of event.", PersonEntersVehicleEvent.class, allEvents.get(17).getClass()); - Assert.assertEquals("wrong type of event.", VehicleEntersTrafficEvent.class, allEvents.get(18).getClass()); - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(19).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(20).getClass()); - Assert.assertEquals("wrong type of event.", VehicleLeavesTrafficEvent.class, allEvents.get(21).getClass()); - Assert.assertEquals("wrong type of event.", PersonLeavesVehicleEvent.class, allEvents.get(22).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(23).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(24).getClass()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(25).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(26).getClass()); - Assert.assertEquals("wrong type of event.", TeleportationArrivalEvent.class, allEvents.get(27).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(28).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(29).getClass()); + Assertions.assertEquals(30, allEvents.size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of event."); + Assertions.assertEquals(TeleportationArrivalEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(4).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(5).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(6).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(7).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(8).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(9).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(10).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(11).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(12).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(13).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(14).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(15).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(16).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(17).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(18).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(19).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(20).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(21).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(22).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(23).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(24).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(25).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(26).getClass(), "wrong type of event."); + Assertions.assertEquals(TeleportationArrivalEvent.class, allEvents.get(27).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(28).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(29).getClass(), "wrong type of event."); } /** @@ -1039,20 +1043,20 @@ void testVehicleTeleportationFalse() { QSim sim = createQSim(f, events); try { sim.run(); - Assert.fail("expected RuntimeException, but there was none."); + Assertions.fail("expected RuntimeException, but there was none."); } catch (RuntimeException e) { log.info("catched expected RuntimeException: " + e.getMessage()); } List allEvents = collector.getEvents(); - Assert.assertEquals("wrong number of events.", 7, allEvents.size()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", TeleportationArrivalEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(4).getClass()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(5).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(6).getClass()); + Assertions.assertEquals(7, allEvents.size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of event."); + Assertions.assertEquals(TeleportationArrivalEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(4).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(5).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(6).getClass(), "wrong type of event."); } /** @@ -1104,12 +1108,12 @@ void testAssignedVehicles() { events.finishProcessing(); Collection vehicles = qlink3.getAllVehicles(); - Assert.assertEquals(1, vehicles.size()); - Assert.assertEquals(Id.create(2, Vehicle.class), vehicles.toArray(new MobsimVehicle[1])[0].getVehicle().getId()); + Assertions.assertEquals(1, vehicles.size()); + Assertions.assertEquals(Id.create(2, Vehicle.class), vehicles.toArray(new MobsimVehicle[1])[0].getVehicle().getId()); // vehicle 1 should still stay on qlink2 vehicles = qlink2.getAllVehicles(); - Assert.assertEquals(1, vehicles.size()); - Assert.assertEquals(Id.create(1, Vehicle.class), vehicles.toArray(new MobsimVehicle[1])[0].getVehicle().getId()); + Assertions.assertEquals(1, vehicles.size()); + Assertions.assertEquals(Id.create(1, Vehicle.class), vehicles.toArray(new MobsimVehicle[1])[0].getVehicle().getId()); } /** @@ -1149,23 +1153,23 @@ void testCircleAsRoute() { /* finish */ List allEvents = collector.getEvents(); - Assert.assertEquals("wrong number of events.", 16, allEvents.size()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", PersonEntersVehicleEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", VehicleEntersTrafficEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(4).getClass()); // link1 - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(5).getClass()); // link2 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(7).getClass()); // link3 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(8).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(9).getClass()); // link4 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(10).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(11).getClass()); // link1 again - Assert.assertEquals("wrong type of event.", VehicleLeavesTrafficEvent.class, allEvents.get(12).getClass()); - Assert.assertEquals("wrong type of event.", PersonLeavesVehicleEvent.class, allEvents.get(13).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(14).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(15).getClass()); + Assertions.assertEquals(16, allEvents.size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(4).getClass(), "wrong type of event."); // link1 + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(5).getClass(), "wrong type of event."); // link2 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(6).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(7).getClass(), "wrong type of event."); // link3 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(8).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(9).getClass(), "wrong type of event."); // link4 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(10).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(11).getClass(), "wrong type of event."); // link1 again + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(12).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(13).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(14).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(15).getClass(), "wrong type of event."); } /** @@ -1207,27 +1211,27 @@ void testRouteWithEndLinkTwice() { /* finish */ List allEvents = collector.getEvents(); - Assert.assertEquals("wrong number of events.", 20, allEvents.size()); - Assert.assertEquals("wrong type of event.", ActivityEndEvent.class, allEvents.get(0).getClass()); - Assert.assertEquals("wrong type of event.", PersonDepartureEvent.class, allEvents.get(1).getClass()); - Assert.assertEquals("wrong type of event.", PersonEntersVehicleEvent.class, allEvents.get(2).getClass()); - Assert.assertEquals("wrong type of event.", VehicleEntersTrafficEvent.class, allEvents.get(3).getClass()); - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(4).getClass()); // link1 - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(5).getClass()); // link2 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(6).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(7).getClass()); // link3 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(8).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(9).getClass()); // link4 - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(10).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(11).getClass()); // link1 again - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(12).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(13).getClass()); // link2 again - Assert.assertEquals("wrong type of event.", LinkLeaveEvent.class, allEvents.get(14).getClass()); - Assert.assertEquals("wrong type of event.", LinkEnterEvent.class, allEvents.get(15).getClass()); // link3 again - Assert.assertEquals("wrong type of event.", VehicleLeavesTrafficEvent.class, allEvents.get(16).getClass()); - Assert.assertEquals("wrong type of event.", PersonLeavesVehicleEvent.class, allEvents.get(17).getClass()); - Assert.assertEquals("wrong type of event.", PersonArrivalEvent.class, allEvents.get(18).getClass()); - Assert.assertEquals("wrong type of event.", ActivityStartEvent.class, allEvents.get(19).getClass()); + Assertions.assertEquals(20, allEvents.size(), "wrong number of events."); + Assertions.assertEquals(ActivityEndEvent.class, allEvents.get(0).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonDepartureEvent.class, allEvents.get(1).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonEntersVehicleEvent.class, allEvents.get(2).getClass(), "wrong type of event."); + Assertions.assertEquals(VehicleEntersTrafficEvent.class, allEvents.get(3).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(4).getClass(), "wrong type of event."); // link1 + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(5).getClass(), "wrong type of event."); // link2 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(6).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(7).getClass(), "wrong type of event."); // link3 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(8).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(9).getClass(), "wrong type of event."); // link4 + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(10).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(11).getClass(), "wrong type of event."); // link1 again + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(12).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(13).getClass(), "wrong type of event."); // link2 again + Assertions.assertEquals(LinkLeaveEvent.class, allEvents.get(14).getClass(), "wrong type of event."); + Assertions.assertEquals(LinkEnterEvent.class, allEvents.get(15).getClass(), "wrong type of event."); // link3 again + Assertions.assertEquals(VehicleLeavesTrafficEvent.class, allEvents.get(16).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonLeavesVehicleEvent.class, allEvents.get(17).getClass(), "wrong type of event."); + Assertions.assertEquals(PersonArrivalEvent.class, allEvents.get(18).getClass(), "wrong type of event."); + Assertions.assertEquals(ActivityStartEvent.class, allEvents.get(19).getClass(), "wrong type of event."); } /** @@ -1242,8 +1246,8 @@ void testConsistentRoutes_WrongRoute() { EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); LogCounter logger = runConsistentRoutesTestSim("1", "2 3", "5", events); // route should continue on link 4 - Assert.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there - Assert.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning + Assertions.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there + Assertions.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning } /** @@ -1258,8 +1262,8 @@ void testConsistentRoutes_WrongStartLink() { EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); LogCounter logger = runConsistentRoutesTestSim("2", "3 4", "5", events); // first act is on link 1, not 2 - Assert.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there - Assert.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning + Assertions.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there + Assertions.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning } /** @@ -1274,8 +1278,8 @@ void testConsistentRoutes_WrongEndLink() { EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); LogCounter logger = runConsistentRoutesTestSim("1", "2 3", "4", events); // second act is on link 5, not 4 - Assert.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there - Assert.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning + Assertions.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there + Assertions.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning } /** @@ -1291,8 +1295,8 @@ void testConsistentRoutes_ImpossibleRoute() { EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); LogCounter logger = runConsistentRoutesTestSim("1", "2 4", "5", events); // link 3 is missing - Assert.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there - Assert.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning + Assertions.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there + Assertions.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning } /** @@ -1307,8 +1311,8 @@ void testConsistentRoutes_MissingRoute() { EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); LogCounter logger = runConsistentRoutesTestSim("1", "", "5", events); // no links at all - Assert.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there - Assert.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning + Assertions.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there + Assertions.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning } /** Prepares miscellaneous data for the testConsistentRoutes() tests: @@ -1417,8 +1421,8 @@ void testStartAndEndTime() { // first test without special settings QSim sim = createQSim(scenario, events); sim.run(); - Assert.assertEquals(act1.getEndTime().seconds(), collector.firstEvent.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(act1.getEndTime().seconds() + leg.getRoute().getTravelTime().seconds(), collector.lastEvent.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(act1.getEndTime().seconds(), collector.firstEvent.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(act1.getEndTime().seconds() + leg.getRoute().getTravelTime().seconds(), collector.lastEvent.getTime(), MatsimTestUtils.EPSILON); collector.reset(0); // second test with special start/end times @@ -1426,8 +1430,8 @@ void testStartAndEndTime() { config.qsim().setEndTime(11.0*3600); sim = createQSim(scenario, events); sim.run(); - Assert.assertEquals(8.0*3600, collector.firstEvent.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(11.0*3600, collector.lastEvent.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(8.0*3600, collector.firstEvent.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(11.0*3600, collector.lastEvent.getTime(), MatsimTestUtils.EPSILON); } /** @@ -1523,7 +1527,7 @@ void testCleanupSim_EarlyEnd() { config.qsim().setEndTime(simEndTime); QSim sim = createQSim(scenario, events); sim.run(); - Assert.assertEquals(simEndTime, collector.lastEvent.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(simEndTime, collector.lastEvent.getTime(), MatsimTestUtils.EPSILON); // besides this, the important thing is that no (Runtime)Exception is thrown during this test } @@ -1583,8 +1587,8 @@ void testFlowCapacityDrivingKinematicWavesWithFlowReductionCorrectionBehavior() System.out.println("#vehicles 7-8: " + Integer.toString(volume[7])); System.out.println("#vehicles 8-9: " + Integer.toString(volume[8])); - Assert.assertEquals(1920, volume[6]); // because of the kinematic waves and the 'reduce flow capacity behavior' we should have much less than half of the maximum flow in this hour - Assert.assertEquals(3840, volume[7]); // because of the kinematic waves and the 'reduce flow capacity behavior' we should have much less than the maximum flow in this hour + Assertions.assertEquals(1920, volume[6]); // because of the kinematic waves and the 'reduce flow capacity behavior' we should have much less than half of the maximum flow in this hour + Assertions.assertEquals(3840, volume[7]); // because of the kinematic waves and the 'reduce flow capacity behavior' we should have much less than the maximum flow in this hour } /** @@ -1643,8 +1647,8 @@ void testFlowCapacityDrivingKinematicWavesWithLaneIncreaseCorrectionBehavior() { System.out.println("#vehicles 7-8: " + Integer.toString(volume[7])); System.out.println("#vehicles 8-9: " + Integer.toString(volume[8])); - Assert.assertEquals(2979, volume[6]); // because of the kinematic waves and the 'increase lanes behavior' we should only have slightly less than half of the maximum flow in this hour - Assert.assertEquals(5958, volume[7]); // because of the kinematic waves and the 'increase lanes behavior' we should only have slightly less than the maximum flow in this hour + Assertions.assertEquals(2979, volume[6]); // because of the kinematic waves and the 'increase lanes behavior' we should only have slightly less than half of the maximum flow in this hour + Assertions.assertEquals(5958, volume[7]); // because of the kinematic waves and the 'increase lanes behavior' we should only have slightly less than the maximum flow in this hour } /** @@ -1703,8 +1707,8 @@ void testFlowCapacityDrivingKinematicWavesWithInflowEqualToMaxCapForOneLane() { System.out.println("#vehicles 7-8: " + Integer.toString(volume[7])); System.out.println("#vehicles 8-9: " + Integer.toString(volume[8])); - Assert.assertEquals(961, volume[6]); // because of the kinematic waves and the 'use inflow capacity of one lane only behavior' we should have less than a quarter of the maximum flow in this hour - Assert.assertEquals(1920, volume[7]); // because of the kinematic waves and the 'use inflow capacity of one lane only behavior' we should have less than half of the maximum flow in this hour + Assertions.assertEquals(961, volume[6]); // because of the kinematic waves and the 'use inflow capacity of one lane only behavior' we should have less than a quarter of the maximum flow in this hour + Assertions.assertEquals(1920, volume[7]); // because of the kinematic waves and the 'use inflow capacity of one lane only behavior' we should have less than half of the maximum flow in this hour } /** diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TransitQueueNetworkTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TransitQueueNetworkTest.java index deb611bbab7..5d4a6fb0072 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TransitQueueNetworkTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TransitQueueNetworkTest.java @@ -20,8 +20,6 @@ package org.matsim.core.mobsim.qsim; -import static org.junit.Assert.assertEquals; - import java.lang.reflect.InvocationTargetException; import java.util.ArrayList; import java.util.Collection; @@ -29,6 +27,8 @@ import java.util.List; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TravelTimeTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TravelTimeTest.java index 6670ac30280..0fbba6e7926 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/TravelTimeTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/TravelTimeTest.java @@ -22,7 +22,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -69,13 +69,13 @@ void testEquilOneAgent() { .run(); Map, Double> travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(360.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(180.0, travelTimes.get(Id.create(15, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(180.0, travelTimes.get(Id.create(15, Link.class)).intValue(), MatsimTestUtils.EPSILON); // this one is NOT a travel time (it includes two activities and a zero-length trip) - Assert.assertEquals(13560.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(360.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1260.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(360.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(13560.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1260.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); } /** @@ -109,7 +109,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); Map, Double> travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(360.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); // Travel time 359.9712023038 scenario.getNetwork().getLinks().get(Id.createLinkId("6")).setFreespeed(27.85); @@ -121,7 +121,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(360.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); // Travel time 359.066427289 scenario.getNetwork().getLinks().get(Id.createLinkId("6")).setFreespeed(27.85); @@ -133,7 +133,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(360.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); // Travel time 358.4229390681 scenario.getNetwork().getLinks().get(Id.createLinkId("6")).setFreespeed(27.9); @@ -145,7 +145,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(359.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(359.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); // Travel time 360.3603603604 scenario.getNetwork().getLinks().get(Id.createLinkId("6")).setFreespeed(27.75); @@ -157,7 +157,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(361.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(361.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); // Travel time 400.0 scenario.getNetwork().getLinks().get(Id.createLinkId("6")).setLength(10000.0); @@ -170,7 +170,7 @@ void testEquilOneAgentTravelTimeRounding() { .run(); travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(401.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(401.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); } @Test @@ -196,23 +196,23 @@ void testEquilTwoAgents() { .run(); Map, Double> travelTimes = agentTravelTimes.get(Id.create("1", Vehicle.class)); - Assert.assertEquals(360.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(180.0, travelTimes.get(Id.create(15, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(6, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(180.0, travelTimes.get(Id.create(15, Link.class)).intValue(), MatsimTestUtils.EPSILON); // this one is NOT a travel time (it includes two activities and a zero-length trip) - Assert.assertEquals(13560.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(360.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1260.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(360.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(13560.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1260.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); travelTimes = agentTravelTimes.get(Id.create("2", Vehicle.class)); - Assert.assertEquals(360.0, travelTimes.get(Id.create(5, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(180.0, travelTimes.get(Id.create(14, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(5, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(180.0, travelTimes.get(Id.create(14, Link.class)).intValue(), MatsimTestUtils.EPSILON); // this one is NOT a travel time (it includes two activities and a zero-length trip) - Assert.assertEquals(13560.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(360.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1260.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); - Assert.assertEquals(360.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(13560.0, travelTimes.get(Id.create(20, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(21, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1260.0, travelTimes.get(Id.create(22, Link.class)).intValue(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(360.0, travelTimes.get(Id.create(23, Link.class)).intValue(), MatsimTestUtils.EPSILON); } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java index 6b84f956f3f..f91acc6e562 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.core.mobsim.qsim; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.runner.RunWith; @@ -165,9 +165,9 @@ public void install() { } } if ( providingVehiclesInPerson ) { - Assert.assertFalse( expectedException ); + Assertions.assertFalse( expectedException ); } else { - Assert.assertTrue( expectedException ); + Assertions.assertTrue( expectedException ); return ; } @@ -189,12 +189,11 @@ public void install() { switch (this.vehiclesSource ) { case defaultVehicle: // both bike and car are default vehicles (i.e. identical) - Assert.assertEquals("Both car, bike are default vehicles (i.e. identical), thus should have same travel time.", - 0, bikeTravelTime - carTravelTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0, bikeTravelTime - carTravelTime, MatsimTestUtils.EPSILON, "Both car, bike are default vehicles (i.e. identical), thus should have same travel time."); break; case modeVehicleTypesFromVehiclesData: case fromVehiclesData: - Assert.assertEquals("Passing is not executed.", 150, bikeTravelTime - carTravelTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(150, bikeTravelTime - carTravelTime, MatsimTestUtils.EPSILON, "Passing is not executed."); break; default: throw new RuntimeException("not implemented yet."); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/changeeventsengine/NetworkChangeEventsEngineTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/changeeventsengine/NetworkChangeEventsEngineTest.java index 6eb210f684d..1cb8f2e7000 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/changeeventsengine/NetworkChangeEventsEngineTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/changeeventsengine/NetworkChangeEventsEngineTest.java @@ -21,7 +21,7 @@ package org.matsim.core.mobsim.qsim.changeeventsengine; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -46,7 +46,7 @@ import java.util.List; - /** + /** * @author mrieser / Simunto GmbH */ public class NetworkChangeEventsEngineTest { @@ -81,7 +81,7 @@ void testActivation_inactive() { try { engine.addNetworkChangeEvent(changeEvent); - Assert.fail("Expected exception due to links not being time dependent, but got none."); + Assertions.fail("Expected exception due to links not being time dependent, but got none."); } catch (Exception expected) { } } @@ -115,11 +115,11 @@ void testActivation_timedepOnly_freespeed() { changeEvent.addLink(link1); changeEvent.setFreespeedChange(new NetworkChangeEvent.ChangeValue(NetworkChangeEvent.ChangeType.ABSOLUTE_IN_SI_UNITS, 50)); engine.addNetworkChangeEvent(changeEvent); - Assert.assertEquals("it should still be 20 now.", 20, link1.getFreespeed(30), 0); + Assertions.assertEquals(20, link1.getFreespeed(30), 0, "it should still be 20 now."); for (int i = 30; i < 40; i++) { engine.doSimStep(i); } - Assert.assertEquals("it should be 50 now.", 50, link1.getFreespeed(40), 0); + Assertions.assertEquals(50, link1.getFreespeed(40), 0, "it should be 50 now."); } @Test @@ -151,11 +151,11 @@ void testActivation_timedepOnly_capacity() { changeEvent.addLink(link1); changeEvent.setFlowCapacityChange(new NetworkChangeEvent.ChangeValue(NetworkChangeEvent.ChangeType.FACTOR, 2)); engine.addNetworkChangeEvent(changeEvent); - Assert.assertEquals("it should still be 20 now.", 20, link1.getCapacity(30), 0); + Assertions.assertEquals(20, link1.getCapacity(30), 0, "it should still be 20 now."); for (int i = 30; i < 40; i++) { engine.doSimStep(i); } - Assert.assertEquals("it should be 40 now.", 40, link1.getCapacity(40), 0); + Assertions.assertEquals(40, link1.getCapacity(40), 0, "it should be 40 now."); } private static class DummyInternalInterfaceImpl implements InternalInterface { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/QSimComponentsTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/QSimComponentsTest.java index 3e97d857a17..c3355a063ce 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/QSimComponentsTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/QSimComponentsTest.java @@ -31,7 +31,7 @@ import com.google.inject.ProvisionException; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.events.Event; @@ -96,7 +96,7 @@ void testAddComponentViaString() { .build(scenario, eventsManager) // .run(); - Assert.assertTrue( "MockMobsimListener was not added to QSim", handler.hasBeenCalled() ) ; + Assertions.assertTrue( handler.hasBeenCalled(), "MockMobsimListener was not added to QSim" ) ; } /** @@ -139,7 +139,7 @@ void testAddModuleOnly() { .build(scenario, eventsManager) // .run(); - Assert.assertFalse( "MockMobsimListener was added to QSim although it should not have been added", handler.hasBeenCalled() ) ; + Assertions.assertFalse( handler.hasBeenCalled(), "MockMobsimListener was added to QSim although it should not have been added" ) ; } /** @@ -231,7 +231,7 @@ void testAddComponentViaStringTwice() { .build(scenario, eventsManager) // .run(); - Assert.assertTrue( "MockMobsimListener was not added to QSim", handler.hasBeenCalled() ) ; + Assertions.assertTrue( handler.hasBeenCalled(), "MockMobsimListener was not added to QSim" ) ; } @@ -262,7 +262,7 @@ void testGenericAddComponentMethod() { .build(scenario, eventsManager) // .run(); - Assert.assertTrue( handler.hasBeenCalled() ) ; + Assertions.assertTrue( handler.hasBeenCalled() ) ; } @Test @@ -285,7 +285,7 @@ void testGenericAddComponentMethodWithoutConfiguringIt() { .build(scenario, eventsManager) // .run(); - Assert.assertFalse( handler.hasBeenCalled() ) ; + Assertions.assertFalse( handler.hasBeenCalled() ) ; } @Test @@ -311,8 +311,8 @@ protected void configureQSim() { .build(scenario, eventsManager) // .run(); - Assert.assertTrue(mockEngineA.isCalled); - Assert.assertTrue(mockEngineB.isCalled); + Assertions.assertTrue(mockEngineA.isCalled); + Assertions.assertTrue(mockEngineB.isCalled); } @Test @@ -336,7 +336,7 @@ protected void configureQSim() { .build(scenario, eventsManager) // .run(); - Assert.assertTrue(mockEngine.isCalled); + Assertions.assertTrue(mockEngine.isCalled); } @Test @@ -360,7 +360,7 @@ protected void configureQSim() { .build(scenario, eventsManager) // .run(); - Assert.assertTrue(mockEngine.isCalled); + Assertions.assertTrue(mockEngine.isCalled); } @Test @@ -388,7 +388,7 @@ protected void configureQSim() { .build(scenario, eventsManager) // .run(); - Assert.assertTrue(mockEngine.isCalled); + Assertions.assertTrue(mockEngine.isCalled); } // --- diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/ExplicitBindingsRequiredTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/ExplicitBindingsRequiredTest.java index d750d1e2efc..56da02d7c72 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/ExplicitBindingsRequiredTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/ExplicitBindingsRequiredTest.java @@ -20,8 +20,7 @@ * *********************************************************************** */ package org.matsim.core.mobsim.qsim.components.guice; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import com.google.inject.AbstractModule; import com.google.inject.CreationException; @@ -29,7 +28,7 @@ import com.google.inject.Inject; import com.google.inject.Injector; - /** + /** * This test shows how Guice works with child injectors and explicit bindings. * In the test there is a ParentScopeObject in a parent injector. Then a child * injector is created which contains a ChildScopeObject, which has the @@ -83,6 +82,6 @@ protected void configure() { exceptionOccured = true; } - Assert.assertTrue(exceptionOccured); + Assertions.assertTrue(exceptionOccured); } } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/MultipleBindingsTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/MultipleBindingsTest.java index b558b40965a..76def156998 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/MultipleBindingsTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/components/guice/MultipleBindingsTest.java @@ -20,8 +20,7 @@ * *********************************************************************** */ package org.matsim.core.mobsim.qsim.components.guice; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import com.google.inject.AbstractModule; import com.google.inject.Guice; @@ -29,7 +28,7 @@ import com.google.inject.Key; import com.google.inject.name.Names; - /** + /** * This test shows that Guice creates Singletons solely based on the *class * name*. So as shown in the example one can bind the same class to different * interfaces, even with different names. If the class is declared in the @@ -60,6 +59,6 @@ protected void configure() { InterfaceA implA = injector.getInstance(Key.get(InterfaceA.class, Names.named("abc1"))); InterfaceB implB = injector.getInstance(Key.get(InterfaceB.class, Names.named("abc2"))); - Assert.assertSame(implA, implB); + Assertions.assertSame(implA, implB); } } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/QSimIntegrationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/QSimIntegrationTest.java index b85534b5e04..25234b89cd0 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/QSimIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/QSimIntegrationTest.java @@ -25,7 +25,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -107,17 +107,17 @@ void test_twoStopsOnFirstLink() throws SAXException, ParserConfigurationExceptio coll.printEvents(); List events = coll.getEvents(); - Assert.assertEquals("wrong number of events", 10, events.size()); - Assert.assertTrue(events.get(0) instanceof TransitDriverStartsEvent); - Assert.assertTrue(events.get(1) instanceof PersonDepartureEvent); - Assert.assertTrue(events.get(2) instanceof VehicleArrivesAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(3) instanceof VehicleDepartsAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(4) instanceof VehicleArrivesAtFacilityEvent); // stop 2 - Assert.assertTrue(events.get(5) instanceof VehicleDepartsAtFacilityEvent); // stop 2 - Assert.assertTrue(events.get(6) instanceof LinkEnterEvent); - Assert.assertTrue(events.get(7) instanceof VehicleArrivesAtFacilityEvent); // stop 3 - Assert.assertTrue(events.get(8) instanceof VehicleDepartsAtFacilityEvent); // stop 3 - Assert.assertTrue(events.get(9) instanceof PersonArrivalEvent); + Assertions.assertEquals(10, events.size(), "wrong number of events"); + Assertions.assertTrue(events.get(0) instanceof TransitDriverStartsEvent); + Assertions.assertTrue(events.get(1) instanceof PersonDepartureEvent); + Assertions.assertTrue(events.get(2) instanceof VehicleArrivesAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(3) instanceof VehicleDepartsAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(4) instanceof VehicleArrivesAtFacilityEvent); // stop 2 + Assertions.assertTrue(events.get(5) instanceof VehicleDepartsAtFacilityEvent); // stop 2 + Assertions.assertTrue(events.get(6) instanceof LinkEnterEvent); + Assertions.assertTrue(events.get(7) instanceof VehicleArrivesAtFacilityEvent); // stop 3 + Assertions.assertTrue(events.get(8) instanceof VehicleDepartsAtFacilityEvent); // stop 3 + Assertions.assertTrue(events.get(9) instanceof PersonArrivalEvent); } @Test @@ -169,18 +169,18 @@ void test_multipleStopsOnFirstLink_singleLinkRoute_noPassengers() throws SAXExce coll.printEvents(); List events = coll.getEvents(); - Assert.assertEquals("wrong number of events", 11, events.size()); - Assert.assertTrue(events.get(0) instanceof TransitDriverStartsEvent); - Assert.assertTrue(events.get(1) instanceof PersonDepartureEvent); - Assert.assertTrue(events.get(2) instanceof VehicleArrivesAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(3) instanceof VehicleDepartsAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(4) instanceof VehicleArrivesAtFacilityEvent); // stop 2 - Assert.assertTrue(events.get(5) instanceof VehicleDepartsAtFacilityEvent); // stop 2 - Assert.assertTrue(events.get(6) instanceof VehicleArrivesAtFacilityEvent); // stop 3 - Assert.assertTrue(events.get(7) instanceof VehicleDepartsAtFacilityEvent); // stop 3 - Assert.assertTrue(events.get(8) instanceof VehicleArrivesAtFacilityEvent); // stop 4 - Assert.assertTrue(events.get(9) instanceof VehicleDepartsAtFacilityEvent); // stop 4 - Assert.assertTrue(events.get(10) instanceof PersonArrivalEvent); + Assertions.assertEquals(11, events.size(), "wrong number of events"); + Assertions.assertTrue(events.get(0) instanceof TransitDriverStartsEvent); + Assertions.assertTrue(events.get(1) instanceof PersonDepartureEvent); + Assertions.assertTrue(events.get(2) instanceof VehicleArrivesAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(3) instanceof VehicleDepartsAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(4) instanceof VehicleArrivesAtFacilityEvent); // stop 2 + Assertions.assertTrue(events.get(5) instanceof VehicleDepartsAtFacilityEvent); // stop 2 + Assertions.assertTrue(events.get(6) instanceof VehicleArrivesAtFacilityEvent); // stop 3 + Assertions.assertTrue(events.get(7) instanceof VehicleDepartsAtFacilityEvent); // stop 3 + Assertions.assertTrue(events.get(8) instanceof VehicleArrivesAtFacilityEvent); // stop 4 + Assertions.assertTrue(events.get(9) instanceof VehicleDepartsAtFacilityEvent); // stop 4 + Assertions.assertTrue(events.get(10) instanceof PersonArrivalEvent); } @Test @@ -247,25 +247,25 @@ void test_multipleStopsOnFirstLink_singleLinkRoute_withPassengersAtFirstStop() t coll.printEvents(); List events = coll.getEvents(); - Assert.assertEquals("wrong number of events", 17, events.size()); + Assertions.assertEquals(17, events.size(), "wrong number of events"); int idx = 0; - Assert.assertTrue(events.get(idx++) instanceof PersonDepartureEvent); // passenger - Assert.assertTrue(events.get(idx++) instanceof TransitDriverStartsEvent); - Assert.assertTrue(events.get(idx++) instanceof PersonDepartureEvent); // pt-driver - Assert.assertTrue(events.get(idx++) instanceof PersonEntersVehicleEvent); // pt-driver - Assert.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(idx++) instanceof PersonEntersVehicleEvent); - Assert.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 2 - Assert.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 2 - Assert.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 3 - Assert.assertTrue(events.get(idx++) instanceof PersonLeavesVehicleEvent); - Assert.assertTrue(events.get(idx++) instanceof PersonArrivalEvent); // passenger - Assert.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 3 - Assert.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 4 - Assert.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 4 - Assert.assertTrue(events.get(idx++) instanceof PersonLeavesVehicleEvent); // pt-driver - Assert.assertTrue(events.get(idx++) instanceof PersonArrivalEvent); + Assertions.assertTrue(events.get(idx++) instanceof PersonDepartureEvent); // passenger + Assertions.assertTrue(events.get(idx++) instanceof TransitDriverStartsEvent); + Assertions.assertTrue(events.get(idx++) instanceof PersonDepartureEvent); // pt-driver + Assertions.assertTrue(events.get(idx++) instanceof PersonEntersVehicleEvent); // pt-driver + Assertions.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(idx++) instanceof PersonEntersVehicleEvent); + Assertions.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 2 + Assertions.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 2 + Assertions.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 3 + Assertions.assertTrue(events.get(idx++) instanceof PersonLeavesVehicleEvent); + Assertions.assertTrue(events.get(idx++) instanceof PersonArrivalEvent); // passenger + Assertions.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 3 + Assertions.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 4 + Assertions.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 4 + Assertions.assertTrue(events.get(idx++) instanceof PersonLeavesVehicleEvent); // pt-driver + Assertions.assertTrue(events.get(idx++) instanceof PersonArrivalEvent); } @Test @@ -332,25 +332,25 @@ void test_multipleStopsOnFirstLink_singleLinkRoute_withPassengersAtSecondStop() coll.printEvents(); List events = coll.getEvents(); - Assert.assertEquals("wrong number of events", 17, events.size()); + Assertions.assertEquals(17, events.size(), "wrong number of events"); int idx = 0; - Assert.assertTrue(events.get(idx++) instanceof PersonDepartureEvent); // passenger - Assert.assertTrue(events.get(idx++) instanceof TransitDriverStartsEvent); - Assert.assertTrue(events.get(idx++) instanceof PersonDepartureEvent); // pt-driver - Assert.assertTrue(events.get(idx++) instanceof PersonEntersVehicleEvent); // pt-driver - Assert.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 2 - Assert.assertTrue(events.get(idx++) instanceof PersonEntersVehicleEvent); - Assert.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 2 - Assert.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 3 - Assert.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 3 - Assert.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 4 - Assert.assertTrue(events.get(idx++) instanceof PersonLeavesVehicleEvent); - Assert.assertTrue(events.get(idx++) instanceof PersonArrivalEvent); // passenger - Assert.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 4 - Assert.assertTrue(events.get(idx++) instanceof PersonLeavesVehicleEvent); // pt-driver - Assert.assertTrue(events.get(idx++) instanceof PersonArrivalEvent); + Assertions.assertTrue(events.get(idx++) instanceof PersonDepartureEvent); // passenger + Assertions.assertTrue(events.get(idx++) instanceof TransitDriverStartsEvent); + Assertions.assertTrue(events.get(idx++) instanceof PersonDepartureEvent); // pt-driver + Assertions.assertTrue(events.get(idx++) instanceof PersonEntersVehicleEvent); // pt-driver + Assertions.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 2 + Assertions.assertTrue(events.get(idx++) instanceof PersonEntersVehicleEvent); + Assertions.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 2 + Assertions.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 3 + Assertions.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 3 + Assertions.assertTrue(events.get(idx++) instanceof VehicleArrivesAtFacilityEvent); // stop 4 + Assertions.assertTrue(events.get(idx++) instanceof PersonLeavesVehicleEvent); + Assertions.assertTrue(events.get(idx++) instanceof PersonArrivalEvent); // passenger + Assertions.assertTrue(events.get(idx++) instanceof VehicleDepartsAtFacilityEvent); // stop 4 + Assertions.assertTrue(events.get(idx++) instanceof PersonLeavesVehicleEvent); // pt-driver + Assertions.assertTrue(events.get(idx++) instanceof PersonArrivalEvent); } /** @@ -409,14 +409,14 @@ void test_circularEmptyRoute_singleLinkRoute_noPassengers() throws SAXException, coll.printEvents(); List events = coll.getEvents(); - Assert.assertEquals("wrong number of events", 7, events.size()); - Assert.assertTrue(events.get(0) instanceof TransitDriverStartsEvent); - Assert.assertTrue(events.get(1) instanceof PersonDepartureEvent); - Assert.assertTrue(events.get(2) instanceof VehicleArrivesAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(3) instanceof VehicleDepartsAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(4) instanceof VehicleArrivesAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(5) instanceof VehicleDepartsAtFacilityEvent); // stop 1 - Assert.assertTrue(events.get(6) instanceof PersonArrivalEvent); + Assertions.assertEquals(7, events.size(), "wrong number of events"); + Assertions.assertTrue(events.get(0) instanceof TransitDriverStartsEvent); + Assertions.assertTrue(events.get(1) instanceof PersonDepartureEvent); + Assertions.assertTrue(events.get(2) instanceof VehicleArrivesAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(3) instanceof VehicleDepartsAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(4) instanceof VehicleArrivesAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(5) instanceof VehicleDepartsAtFacilityEvent); // stop 1 + Assertions.assertTrue(events.get(6) instanceof PersonArrivalEvent); } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitAgentTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitAgentTest.java index 6ec86bdcb5b..59c7341e27e 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitAgentTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitAgentTest.java @@ -20,8 +20,8 @@ package org.matsim.core.mobsim.qsim.pt; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertFalse; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.Arrays; import java.util.Collections; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitDriverTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitDriverTest.java index 13b7f743fb8..64219008ac3 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitDriverTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitDriverTest.java @@ -20,7 +20,7 @@ package org.matsim.core.mobsim.qsim.pt; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; import java.util.Collections; @@ -304,16 +304,12 @@ void testHandleStop_EnterPassengers() { assertEquals(stop1, driver.getNextTransitStop()); assertTrue(driver.handleTransitStop(stop1, 50) > 0); assertEquals(2, queueVehicle.getPassengers().size()); - assertEquals("driver must not proceed in stop list when persons entered.", - stop1, driver.getNextTransitStop()); + assertEquals(stop1, driver.getNextTransitStop(), "driver must not proceed in stop list when persons entered."); assertEquals(0, tracker.getAgentsAtFacility(stop1.getId()).size()); - assertEquals("stop time must be 0 when nobody enters or leaves", - 0.0, driver.handleTransitStop(stop1, 60), MatsimTestUtils.EPSILON); + assertEquals(0.0, driver.handleTransitStop(stop1, 60), MatsimTestUtils.EPSILON, "stop time must be 0 when nobody enters or leaves"); assertEquals(2, queueVehicle.getPassengers().size()); - assertEquals("driver must proceed in stop list when no persons entered.", - stop2, driver.getNextTransitStop()); - assertEquals("driver must return same stop again when queried again without handling stop.", - stop2, driver.getNextTransitStop()); + assertEquals(stop2, driver.getNextTransitStop(), "driver must proceed in stop list when no persons entered."); + assertEquals(stop2, driver.getNextTransitStop(), "driver must return same stop again when queried again without handling stop."); tracker.addAgentToStop(100, agent3, stop2.getId()); double stoptime1 = driver.handleTransitStop(stop2, 150); @@ -324,11 +320,10 @@ void testHandleStop_EnterPassengers() { double stoptime2 = driver.handleTransitStop(stop2, 160); assertTrue(stoptime2 > 0); assertEquals(4, queueVehicle.getPassengers().size()); - assertTrue("The first stoptime should be larger as it contains door-opening/closing times as well. stoptime1=" + stoptime1 + " stoptime2=" + stoptime2, - stoptime1 > stoptime2); + assertTrue(stoptime1 > stoptime2, + "The first stoptime should be larger as it contains door-opening/closing times as well. stoptime1=" + stoptime1 + " stoptime2=" + stoptime2); tracker.addAgentToStop(163, agent5, stop2.getId()); - assertEquals("vehicle should have reached capacity, so not more passenger can enter.", - 0.0, driver.handleTransitStop(stop2, 170), MatsimTestUtils.EPSILON); + assertEquals(0.0, driver.handleTransitStop(stop2, 170), MatsimTestUtils.EPSILON, "vehicle should have reached capacity, so not more passenger can enter."); eventsManager.finishProcessing(); assertTrue(handler.isOk); @@ -402,15 +397,11 @@ void testHandleStop_ExitPassengers() { assertEquals(4, queueVehicle.getPassengers().size()); assertEquals(stop1, driver.getNextTransitStop()); assertTrue(driver.handleTransitStop(stop1, 50) > 0); - assertEquals("driver must not proceed in stop list when persons entered.", - stop1, driver.getNextTransitStop()); + assertEquals(stop1, driver.getNextTransitStop(), "driver must not proceed in stop list when persons entered."); assertEquals(2, queueVehicle.getPassengers().size()); - assertEquals("stop time must be 0 when nobody enters or leaves", - 0.0, driver.handleTransitStop(stop1, 60), MatsimTestUtils.EPSILON); - assertEquals("driver must proceed in stop list when no persons entered.", - stop2, driver.getNextTransitStop()); - assertEquals("driver must return same stop again when queried again without handling stop.", - stop2, driver.getNextTransitStop()); + assertEquals(0.0, driver.handleTransitStop(stop1, 60), MatsimTestUtils.EPSILON, "stop time must be 0 when nobody enters or leaves"); + assertEquals(stop2, driver.getNextTransitStop(), "driver must proceed in stop list when no persons entered."); + assertEquals(stop2, driver.getNextTransitStop(), "driver must return same stop again when queried again without handling stop."); assertTrue(driver.handleTransitStop(stop2, 150) > 0); assertEquals(0, queueVehicle.getPassengers().size()); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitQueueSimulationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitQueueSimulationTest.java index 9424a078021..914190b0228 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitQueueSimulationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitQueueSimulationTest.java @@ -20,9 +20,7 @@ package org.matsim.core.mobsim.qsim.pt; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; -import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; import java.util.Collections; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitStopAgentTrackerTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitStopAgentTrackerTest.java index fe957af3ece..de2089883b5 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitStopAgentTrackerTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitStopAgentTrackerTest.java @@ -20,7 +20,7 @@ package org.matsim.core.mobsim.qsim.pt; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitVehicleTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitVehicleTest.java index dcc4082886c..50974030a15 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitVehicleTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/TransitVehicleTest.java @@ -20,7 +20,7 @@ package org.matsim.core.mobsim.qsim.pt; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java index bf5bd5adb2c..e73ea8ae49f 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java @@ -20,7 +20,7 @@ package org.matsim.core.mobsim.qsim.pt; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; import java.util.Collections; @@ -301,16 +301,12 @@ void testHandleStop_EnterPassengers() { assertEquals(stop1, driver.getNextTransitStop()); assertTrue(driver.handleTransitStop(stop1, 50) > 0); assertEquals(2, queueVehicle.getPassengers().size()); - assertEquals("driver must not proceed in stop list when persons entered.", - stop1, driver.getNextTransitStop()); + assertEquals(stop1, driver.getNextTransitStop(), "driver must not proceed in stop list when persons entered."); assertEquals(0, tracker.getAgentsAtFacility(stop1.getId()).size()); - assertEquals("stop time must be 0 when nobody enters or leaves", - 0.0, driver.handleTransitStop(stop1, 60), MatsimTestUtils.EPSILON); + assertEquals(0.0, driver.handleTransitStop(stop1, 60), MatsimTestUtils.EPSILON, "stop time must be 0 when nobody enters or leaves"); assertEquals(2, queueVehicle.getPassengers().size()); - assertEquals("driver must proceed in stop list when no persons entered.", - stop2, driver.getNextTransitStop()); - assertEquals("driver must return same stop again when queried again without handling stop.", - stop2, driver.getNextTransitStop()); + assertEquals(stop2, driver.getNextTransitStop(), "driver must proceed in stop list when no persons entered."); + assertEquals(stop2, driver.getNextTransitStop(), "driver must return same stop again when queried again without handling stop."); tracker.addAgentToStop(110, agent3, stop2.getId()); double stoptime1 = driver.handleTransitStop(stop2, 150); @@ -321,11 +317,10 @@ void testHandleStop_EnterPassengers() { double stoptime2 = driver.handleTransitStop(stop2, 160); assertTrue(stoptime2 > 0); assertEquals(4, queueVehicle.getPassengers().size()); - assertTrue("The first stoptime should be larger as it contains door-opening/closing times as well. stoptime1=" + stoptime1 + " stoptime2=" + stoptime2, - stoptime1 > stoptime2); + assertTrue(stoptime1 > stoptime2, + "The first stoptime should be larger as it contains door-opening/closing times as well. stoptime1=" + stoptime1 + " stoptime2=" + stoptime2); tracker.addAgentToStop(163, agent5, stop2.getId()); - assertEquals("vehicle should have reached capacity, so not more passenger can enter.", - 0.0, driver.handleTransitStop(stop2, 170), MatsimTestUtils.EPSILON); + assertEquals(0.0, driver.handleTransitStop(stop2, 170), MatsimTestUtils.EPSILON, "vehicle should have reached capacity, so not more passenger can enter."); } @Test @@ -381,15 +376,11 @@ void testHandleStop_ExitPassengers() { assertEquals(4, queueVehicle.getPassengers().size()); assertEquals(stop1, driver.getNextTransitStop()); assertTrue(driver.handleTransitStop(stop1, 50) > 0); - assertEquals("driver must not proceed in stop list when persons entered.", - stop1, driver.getNextTransitStop()); + assertEquals(stop1, driver.getNextTransitStop(), "driver must not proceed in stop list when persons entered."); assertEquals(2, queueVehicle.getPassengers().size()); - assertEquals("stop time must be 0 when nobody enters or leaves", - 0.0, driver.handleTransitStop(stop1, 60), MatsimTestUtils.EPSILON); - assertEquals("driver must proceed in stop list when no persons entered.", - stop2, driver.getNextTransitStop()); - assertEquals("driver must return same stop again when queried again without handling stop.", - stop2, driver.getNextTransitStop()); + assertEquals(0.0, driver.handleTransitStop(stop1, 60), MatsimTestUtils.EPSILON, "stop time must be 0 when nobody enters or leaves"); + assertEquals(stop2, driver.getNextTransitStop(), "driver must proceed in stop list when no persons entered."); + assertEquals(stop2, driver.getNextTransitStop(), "driver must return same stop again when queried again without handling stop."); assertTrue(driver.handleTransitStop(stop2, 150) > 0); assertEquals(0, queueVehicle.getPassengers().size()); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/DeparturesOnSameLinkSameTimeTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/DeparturesOnSameLinkSameTimeTest.java index 69911b6e800..e26d72120ad 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/DeparturesOnSameLinkSameTimeTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/DeparturesOnSameLinkSameTimeTest.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.core.mobsim.qsim.qnetsimengine; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -71,16 +71,16 @@ void test4LinkEnterTimeOfCarAndBike() { Map,Map, Double>> carLinkLeaveTime = getLinkEnterTime(TransportMode.car,3600); double diff_carAgents_departureLink_LeaveTimes = carLinkLeaveTime.get(secondAgent).get(departureLink) - carLinkLeaveTime.get(firstAgent).get(departureLink); - Assert.assertEquals("Both car agents should leave at the gap of 1 sec.", 1., Math.abs(diff_carAgents_departureLink_LeaveTimes), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(1., Math.abs(diff_carAgents_departureLink_LeaveTimes), MatsimTestUtils.EPSILON, "Both car agents should leave at the gap of 1 sec." ); double diff_motorbikeAgents_departureLink_LeaveTimes = motorbikeLinkLeaveTime.get(secondAgent).get(departureLink) - motorbikeLinkLeaveTime.get(firstAgent).get(departureLink); - Assert.assertEquals("Both motorbike agents should leave at the same time.", 0., diff_motorbikeAgents_departureLink_LeaveTimes, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0., diff_motorbikeAgents_departureLink_LeaveTimes, MatsimTestUtils.EPSILON, "Both motorbike agents should leave at the same time." ); // for flow cap more than 3600, both cars also should leave link l_1 at the same time. carLinkLeaveTime = getLinkEnterTime(TransportMode.car,3601); diff_carAgents_departureLink_LeaveTimes = carLinkLeaveTime.get(secondAgent).get(departureLink) - carLinkLeaveTime.get(firstAgent).get(departureLink); - Assert.assertEquals("Both car agents should leave at the same time", 0., diff_carAgents_departureLink_LeaveTimes, MatsimTestUtils.EPSILON ); + Assertions.assertEquals(0., diff_carAgents_departureLink_LeaveTimes, MatsimTestUtils.EPSILON, "Both car agents should leave at the same time" ); } private Map,Map, Double>> getLinkEnterTime (String travelMode, double departureLinkCapacity){ diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/EquiDistAgentSnapshotInfoBuilderTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/EquiDistAgentSnapshotInfoBuilderTest.java index 21566dda480..5af56c62d44 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/EquiDistAgentSnapshotInfoBuilderTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/EquiDistAgentSnapshotInfoBuilderTest.java @@ -28,7 +28,7 @@ import java.util.*; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; public class EquiDistAgentSnapshotInfoBuilderTest { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowCapacityVariationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowCapacityVariationTest.java index 644fab1765f..66f3d0000b6 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowCapacityVariationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowCapacityVariationTest.java @@ -20,7 +20,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -108,8 +108,8 @@ private void vehiclesLeavingSameTime(String travelMode, double linkCapacity){ int linkLeaveTime1 = (int)times1.get(Id.create("2", Link.class))[1]; int linkLeaveTime2 = (int)times2.get(Id.create("2", Link.class))[1]; - Assert.assertEquals(travelMode+ " entered at different time", 0, linkEnterTime1-linkEnterTime2); - Assert.assertEquals(travelMode +" entered at same time but not leaving the link at the same time.", 0, linkLeaveTime1-linkLeaveTime2); + Assertions.assertEquals(0, linkEnterTime1-linkEnterTime2, travelMode+ " entered at different time"); + Assertions.assertEquals(0, linkLeaveTime1-linkLeaveTime2, travelMode +" entered at same time but not leaving the link at the same time."); } private static final class PseudoInputs{ diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowEfficiencyCalculatorTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowEfficiencyCalculatorTest.java index aaf251d8c0d..714d3e0452b 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowEfficiencyCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/FlowEfficiencyCalculatorTest.java @@ -22,7 +22,7 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; import com.google.inject.Provides; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -60,16 +60,16 @@ void testFlowEfficiencyCalculator() { double latestArrivalTime; latestArrivalTime = runTestScenario(Double.POSITIVE_INFINITY); - Assert.assertEquals(1003.0, latestArrivalTime, 1e-3); + Assertions.assertEquals(1003.0, latestArrivalTime, 1e-3); latestArrivalTime = runTestScenario(1.0); - Assert.assertEquals(8195.0, latestArrivalTime, 1e-3); + Assertions.assertEquals(8195.0, latestArrivalTime, 1e-3); latestArrivalTime = runTestScenario(2.0); - Assert.assertEquals(4599.0, latestArrivalTime, 1e-3); + Assertions.assertEquals(4599.0, latestArrivalTime, 1e-3); latestArrivalTime = runTestScenario(0.5); - Assert.assertEquals(15388.0, latestArrivalTime, 1e-3); + Assertions.assertEquals(15388.0, latestArrivalTime, 1e-3); } public double runTestScenario(double factor) { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/JavaRoundingErrorInQsimTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/JavaRoundingErrorInQsimTest.java index bf1b8ee6733..e7342fff755 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/JavaRoundingErrorInQsimTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/JavaRoundingErrorInQsimTest.java @@ -24,7 +24,7 @@ import java.util.Map; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -97,10 +97,10 @@ void testToCheckTravelTime() { .run(); //agent 2 is departed first so will have free speed time = 1000/25 +1 = 41 sec - Assert.assertEquals( "Wrong travel time for on link 2 for vehicle 2" , 41.0 , vehicleLinkTravelTime.get(Id.createVehicleId(2)) , MatsimTestUtils.EPSILON); + Assertions.assertEquals( 41.0 , vehicleLinkTravelTime.get(Id.createVehicleId(2)) , MatsimTestUtils.EPSILON, "Wrong travel time for on link 2 for vehicle 2"); // agent 1 should have 1000/25 +1 + 10 = 51 but, it may be 52 sec sometimes due to rounding errors in java. Rounding errors is eliminated at the moment if accumulating flow to zero instead of one. - Assert.assertEquals( "Wrong travel time for on link 2 for vehicle 1" , 51.0 , vehicleLinkTravelTime.get(Id.createVehicleId(1)) , MatsimTestUtils.EPSILON); + Assertions.assertEquals( 51.0 , vehicleLinkTravelTime.get(Id.createVehicleId(1)) , MatsimTestUtils.EPSILON, "Wrong travel time for on link 2 for vehicle 1"); LogManager.getLogger(JavaRoundingErrorInQsimTest.class).warn("Although the test is passing instead of failing for vehicle 1. This is done intentionally in order to keep this in mind for future."); } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java index f72301f3fd0..2a6554df93d 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/LinkSpeedCalculatorIntegrationTest.java @@ -22,7 +22,7 @@ import java.util.*; import jakarta.inject.Inject; import jakarta.inject.Provider; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -74,18 +74,18 @@ void testIntegration_Default() { .run(); List events = collector.getEvents(); - Assert.assertTrue(events.get(5) instanceof LinkEnterEvent); + Assertions.assertTrue(events.get(5) instanceof LinkEnterEvent); LinkEnterEvent lee = (LinkEnterEvent) events.get(5); - Assert.assertEquals("1", lee.getVehicleId().toString()); - Assert.assertEquals("2", lee.getLinkId().toString()); + Assertions.assertEquals("1", lee.getVehicleId().toString()); + Assertions.assertEquals("2", lee.getLinkId().toString()); - Assert.assertTrue(events.get(6) instanceof LinkLeaveEvent); + Assertions.assertTrue(events.get(6) instanceof LinkLeaveEvent); LinkLeaveEvent lle = (LinkLeaveEvent) events.get(6); - Assert.assertEquals("1", lle.getVehicleId().toString()); - Assert.assertEquals("2", lle.getLinkId().toString()); + Assertions.assertEquals("1", lle.getVehicleId().toString()); + Assertions.assertEquals("2", lle.getLinkId().toString()); // by default, the link takes 10 seconds to travel along, plus 1 second in the buffer, makes total of 11 seconds - Assert.assertEquals(11, lle.getTime() - lee.getTime(), 1e-8); + Assertions.assertEquals(11, lle.getTime() - lee.getTime(), 1e-8); } @SuppressWarnings("static-method") @@ -126,18 +126,18 @@ void testIntegration_Slow() { builder.build( scenario, eventsManager ).run() ; List events = collector.getEvents(); - Assert.assertTrue(events.get(5) instanceof LinkEnterEvent); + Assertions.assertTrue(events.get(5) instanceof LinkEnterEvent); LinkEnterEvent lee = (LinkEnterEvent) events.get(5); - Assert.assertEquals("1", lee.getVehicleId().toString()); - Assert.assertEquals("2", lee.getLinkId().toString()); + Assertions.assertEquals("1", lee.getVehicleId().toString()); + Assertions.assertEquals("2", lee.getLinkId().toString()); - Assert.assertTrue(events.get(6) instanceof LinkLeaveEvent); + Assertions.assertTrue(events.get(6) instanceof LinkLeaveEvent); LinkLeaveEvent lle = (LinkLeaveEvent) events.get(6); - Assert.assertEquals("1", lle.getVehicleId().toString()); - Assert.assertEquals("2", lle.getLinkId().toString()); + Assertions.assertEquals("1", lle.getVehicleId().toString()); + Assertions.assertEquals("2", lle.getLinkId().toString()); // with 5 per second, the link takes 20 seconds to travel along, plus 1 second in the buffer, makes total of 21 seconds - Assert.assertEquals(21, lle.getTime() - lee.getTime(), 1e-8); + Assertions.assertEquals(21, lle.getTime() - lee.getTime(), 1e-8); } @SuppressWarnings("static-method") @@ -183,18 +183,18 @@ void testIntegration_Fast() { new QSimBuilder( config ).useDefaults().addOverridingQSimModule( overrides ).build( scenario, eventsManager ).run() ; List events = collector.getEvents(); - Assert.assertTrue(events.get(5) instanceof LinkEnterEvent); + Assertions.assertTrue(events.get(5) instanceof LinkEnterEvent); LinkEnterEvent lee = (LinkEnterEvent) events.get(5); - Assert.assertEquals("1", lee.getVehicleId().toString()); - Assert.assertEquals("2", lee.getLinkId().toString()); + Assertions.assertEquals("1", lee.getVehicleId().toString()); + Assertions.assertEquals("2", lee.getLinkId().toString()); - Assert.assertTrue(events.get(6) instanceof LinkLeaveEvent); + Assertions.assertTrue(events.get(6) instanceof LinkLeaveEvent); LinkLeaveEvent lle = (LinkLeaveEvent) events.get(6); - Assert.assertEquals("1", lle.getVehicleId().toString()); - Assert.assertEquals("2", lle.getLinkId().toString()); + Assertions.assertEquals("1", lle.getVehicleId().toString()); + Assertions.assertEquals("2", lle.getLinkId().toString()); // the link should take 5 seconds to travel along, plus 1 second in the buffer, makes total of 6 seconds - Assert.assertEquals(6, lle.getTime() - lee.getTime(), 1e-8); + Assertions.assertEquals(6, lle.getTime() - lee.getTime(), 1e-8); } static class CustomLinkSpeedCalculator implements LinkSpeedCalculator { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java index ceac270a514..111b37cc82c 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/PassingTest.java @@ -20,7 +20,7 @@ import java.util.*; import jakarta.inject.Inject; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -119,9 +119,9 @@ void test4PassingInFreeFlowState(){ int bikeTravelTime = travelTime1.get(Id.create("2", Link.class)).intValue(); int carTravelTime = travelTime2.get(Id.create("2", Link.class)).intValue(); - Assert.assertEquals("Wrong car travel time", 51, carTravelTime); - Assert.assertEquals("Wrong bike travel time", 201, bikeTravelTime); - Assert.assertEquals("Passing is not implemented", 150, bikeTravelTime-carTravelTime); + Assertions.assertEquals(51, carTravelTime, "Wrong car travel time"); + Assertions.assertEquals(201, bikeTravelTime, "Wrong bike travel time"); + Assertions.assertEquals(150, bikeTravelTime-carTravelTime, "Passing is not implemented"); } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java index 76e0c77788b..53794c1f44a 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkLanesTest.java @@ -19,8 +19,8 @@ * *********************************************************************** */ package org.matsim.core.mobsim.qsim.qnetsimengine; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java index 9ccdd910c12..6bcba7b34bc 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java @@ -19,7 +19,7 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; import java.util.Arrays; @@ -184,7 +184,7 @@ void testGetVehicle_Driving() { f.qlink1.getAcceptingQLane().addFromUpstream(veh); assertTrue(f.qlink1.isNotOfferingVehicle()); assertEquals(1, ((QueueWithBuffer) f.qlink1.getAcceptingQLane()).getAllVehicles().size()); - assertEquals("vehicle not found on link.", veh, f.qlink1.getVehicle(id1)); + assertEquals(veh, f.qlink1.getVehicle(id1), "vehicle not found on link."); assertEquals(1, f.qlink1.getAllVehicles().size()); now = 1. ; @@ -208,7 +208,7 @@ void testGetVehicle_Driving() { assertEquals(veh, f.qlink1.getOfferingQLanes().get(0).popFirstVehicle()); assertTrue(f.qlink1.isNotOfferingVehicle()); // assertEquals(0, ((QueueWithBuffer) f.qlink1.qlane).vehInQueueCount()); - assertNull("vehicle should not be on link anymore.", f.qlink1.getVehicle(id1)); + assertNull(f.qlink1.getVehicle(id1), "vehicle should not be on link anymore."); assertEquals(0, f.qlink1.getAllVehicles().size()); } @@ -239,14 +239,14 @@ void testGetVehicle_Parking() { f.qlink1.addParkedVehicle(veh); assertTrue(f.qlink1.isNotOfferingVehicle()); assertEquals(0, ((QueueWithBuffer) f.qlink1.getAcceptingQLane()).getAllVehicles().size()); // vehicle not on _lane_ - assertEquals("vehicle not found in parking list.", veh, f.qlink1.getVehicle(id1)); + assertEquals(veh, f.qlink1.getVehicle(id1), "vehicle not found in parking list."); assertEquals(1, f.qlink1.getAllVehicles().size()); // vehicle indeed on _link_ assertEquals(veh, f.qlink1.getAllVehicles().iterator().next()); - assertEquals("removed wrong vehicle.", veh, f.qlink1.removeParkedVehicle(veh.getId())); + assertEquals(veh, f.qlink1.removeParkedVehicle(veh.getId()), "removed wrong vehicle."); assertTrue(f.qlink1.isNotOfferingVehicle()); assertEquals(0, ((QueueWithBuffer) f.qlink1.getAcceptingQLane()).getAllVehicles().size()); - assertNull("vehicle not found in parking list.", f.qlink1.getVehicle(id1)); + assertNull(f.qlink1.getVehicle(id1), "vehicle not found in parking list."); assertEquals(0, f.qlink1.getAllVehicles().size()); } @@ -291,7 +291,7 @@ void testGetVehicle_Departing() { f.queueNetwork.simEngine.getNetsimInternalInterface().arrangeNextAgentState(driver) ; // i.e. driver departs, should now be in wait queue assertTrue(f.qlink1.isNotOfferingVehicle()); // veh not in buffer assertEquals(0, ((QueueWithBuffer) f.qlink1.getAcceptingQLane()).getAllVehicles().size()); // veh not on lane - assertEquals("vehicle not found in waiting list.", veh, f.qlink1.getVehicle(id1)); // veh _should_ be on link (in waiting list) + assertEquals(veh, f.qlink1.getVehicle(id1), "vehicle not found in waiting list."); // veh _should_ be on link (in waiting list) assertEquals(1, f.qlink1.getAllVehicles().size()); // dto assertEquals(veh, f.qlink1.getAllVehicles().iterator().next()); // dto @@ -302,7 +302,7 @@ void testGetVehicle_Departing() { f.qlink1.doSimStep(); assertFalse(f.qlink1.isNotOfferingVehicle()); // i.e. is offering the vehicle assertEquals(1, ((QueueWithBuffer) f.qlink1.getAcceptingQLane()).getAllVehicles().size()); // somewhere on lane - assertEquals("vehicle not found in buffer.", veh, f.qlink1.getVehicle(id1)); // somewhere on link + assertEquals(veh, f.qlink1.getVehicle(id1), "vehicle not found in buffer."); // somewhere on link assertEquals(1, f.qlink1.getAllVehicles().size()); // somewhere on link now = 2. ; @@ -312,7 +312,7 @@ void testGetVehicle_Departing() { assertEquals(veh, f.qlink1.getOfferingQLanes().get(0).popFirstVehicle()); assertTrue(f.qlink1.isNotOfferingVehicle()); assertEquals(0, ((QueueWithBuffer) f.qlink1.getAcceptingQLane()).getAllVehicles().size()); - assertNull("vehicle should not be on link anymore.", f.qlink1.getVehicle(id1)); + assertNull(f.qlink1.getVehicle(id1), "vehicle should not be on link anymore."); assertEquals(0, f.qlink1.getAllVehicles().size()); } @@ -479,7 +479,7 @@ void testStorageSpaceDifferentVehicleSizes() { driver5.setVehicle(veh5); driver5.endActivityAndComputeNextState( now ); - assertEquals("wrong initial storage capacity.", 10.0, f.qlink2.getSpaceCap(), MatsimTestUtils.EPSILON); + assertEquals(10.0, f.qlink2.getSpaceCap(), MatsimTestUtils.EPSILON, "wrong initial storage capacity."); f.qlink2.getAcceptingQLane().addFromUpstream(veh5); // used vehicle equivalents: 5 assertTrue(f.qlink2.getAcceptingQLane().isAcceptingFromUpstream()); f.qlink2.getAcceptingQLane().addFromUpstream(veh5); // used vehicle equivalents: 10 diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QueueAgentSnapshotInfoBuilderTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QueueAgentSnapshotInfoBuilderTest.java index 325ef2996c1..b81a8fb91a0 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QueueAgentSnapshotInfoBuilderTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QueueAgentSnapshotInfoBuilderTest.java @@ -1,5 +1,7 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; +import static org.junit.jupiter.api.Assertions.assertEquals; + import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -28,8 +30,6 @@ import java.util.*; -import static org.junit.Assert.assertEquals; - public class QueueAgentSnapshotInfoBuilderTest { @Test diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java index 6a18868b17d..8cfe3e14e1e 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java @@ -20,7 +20,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -156,9 +156,9 @@ void seepageOfWalkInCongestedRegime(){ int carTravelTime = travelTime2.get(Id.createLinkId("2")).intValue(); // if(this.isUsingFastCapacityUpdate) { - Assert.assertEquals("Wrong car travel time", 115, carTravelTime); - Assert.assertEquals("Wrong walk travel time.", 1009, walkTravelTime); - Assert.assertEquals("Seepage is not implemented", 894, walkTravelTime-carTravelTime); + Assertions.assertEquals(115, carTravelTime, "Wrong car travel time"); + Assertions.assertEquals(1009, walkTravelTime, "Wrong walk travel time."); + Assertions.assertEquals(894, walkTravelTime-carTravelTime, "Seepage is not implemented"); // } else { // Assert.assertEquals("Wrong car travel time", 116, carTravelTime); // Assert.assertEquals("Wrong walk travel time.", 1010, walkTravelTime); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java index 92e225da500..8fc3a972827 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SimulatedLaneFlowCapacityTest.java @@ -21,13 +21,13 @@ */ package org.matsim.core.mobsim.qsim.qnetsimengine; -import static org.junit.Assert.assertEquals; - import java.util.Collections; import java.util.HashMap; import java.util.Map; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java index cc4b76d055c..ed394e4bd46 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SpeedCalculatorTest.java @@ -26,8 +26,8 @@ import java.util.UUID; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; public class SpeedCalculatorTest{ // This originally comes from the bicycle contrib. One now needs access to AbstractQLink to properly test this functionality. In contrast, the diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java index 765d3875106..19f03965a02 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java @@ -19,7 +19,8 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; import java.util.*; -import org.junit.Assert; + +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -123,8 +124,7 @@ void testVehicleSpeed(){ double carTravelTime = travelTime1.get(desiredLink.getId()); // 1000 / min(25, vehSpeed) double speedUsedInSimulation = Math.round( desiredLink.getLength() / (carTravelTime - 1) ); - Assert.assertEquals("In the simulation minimum of vehicle speed and link speed should be used.", - Math.min(vehSpeed, MAX_SPEED_ON_LINK), speedUsedInSimulation, MatsimTestUtils.EPSILON); + Assertions.assertEquals(Math.min(vehSpeed, MAX_SPEED_ON_LINK), speedUsedInSimulation, MatsimTestUtils.EPSILON, "In the simulation minimum of vehicle speed and link speed should be used."); } private static final class SimpleNetwork{ diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java index b258f338ef5..7a9d4e656ad 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleHandlerTest.java @@ -22,8 +22,7 @@ package org.matsim.core.mobsim.qsim.qnetsimengine; import java.util.Arrays; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -76,20 +75,20 @@ void testVehicleHandler() { Result result; result = runTestScenario(4); - Assert.assertEquals(20203.0, result.latestArrivalTime, 1e-3); - Assert.assertEquals(3, result.initialCount); + Assertions.assertEquals(20203.0, result.latestArrivalTime, 1e-3); + Assertions.assertEquals(3, result.initialCount); result = runTestScenario(3); - Assert.assertEquals(20203.0, result.latestArrivalTime, 1e-3); - Assert.assertEquals(3, result.initialCount); + Assertions.assertEquals(20203.0, result.latestArrivalTime, 1e-3); + Assertions.assertEquals(3, result.initialCount); result = runTestScenario(2); - Assert.assertEquals(23003.0, result.latestArrivalTime, 1e-3); - Assert.assertEquals(3, result.initialCount); + Assertions.assertEquals(23003.0, result.latestArrivalTime, 1e-3); + Assertions.assertEquals(3, result.initialCount); result = runTestScenario(1); - Assert.assertEquals(33003.0, result.latestArrivalTime, 1e-3); - Assert.assertEquals(3, result.initialCount); + Assertions.assertEquals(33003.0, result.latestArrivalTime, 1e-3); + Assertions.assertEquals(3, result.initialCount); } public Result runTestScenario(long capacity) { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleWaitingTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleWaitingTest.java index 133dd1d9ed9..d960b437f88 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleWaitingTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehicleWaitingTest.java @@ -25,7 +25,7 @@ import java.util.List; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -187,13 +187,13 @@ public void handleEvent(final PersonArrivalEvent event) { .run(); for ( Id id : personIds ) { - Assert.assertNotNull( - "no arrivals for person "+id, - arrivalCounts.get( id ) ); - Assert.assertEquals( - "unexpected number of arrivals for person "+id, + Assertions.assertNotNull( + arrivalCounts.get( id ), + "no arrivals for person "+id ); + Assertions.assertEquals( nLaps * 2, - arrivalCounts.get( id ).intValue()); + arrivalCounts.get( id ).intValue(), + "unexpected number of arrivals for person "+id); } } } diff --git a/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java b/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java index 33464907505..b3c47aecbf7 100644 --- a/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/network/AbstractNetworkWriterReaderTest.java @@ -20,7 +20,7 @@ package org.matsim.core.network; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; @@ -33,7 +33,7 @@ import java.util.List; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -163,10 +163,10 @@ void testNodes_IdSpecialCharacters() { Node nodeA2 = network2.getNodes().get(nodeA1.getId()); Node nodeB2 = network2.getNodes().get(nodeB1.getId()); - Assert.assertNotNull(nodeA2); - Assert.assertNotNull(nodeB2); - Assert.assertNotSame(nodeA1, nodeA2); - Assert.assertNotSame(nodeB1, nodeB2); + Assertions.assertNotNull(nodeA2); + Assertions.assertNotNull(nodeB2); + Assertions.assertNotSame(nodeA1, nodeA2); + Assertions.assertNotSame(nodeB1, nodeB2); } @Test @@ -190,10 +190,10 @@ void testLinks_IdSpecialCharacters() { Link linkA2 = network2.getLinks().get(linkA1.getId()); Link linkB2 = network2.getLinks().get(linkB1.getId()); - Assert.assertNotNull(linkA2); - Assert.assertNotNull(linkB2); - Assert.assertNotSame(linkA1, linkA2); - Assert.assertNotSame(linkB1, linkB2); + Assertions.assertNotNull(linkA2); + Assertions.assertNotNull(linkB2); + Assertions.assertNotSame(linkA1, linkA2); + Assertions.assertNotSame(linkB1, linkB2); // Assert.assertEquals(NetworkUtils.getType(linkA1), NetworkUtils.getType(linkA2)); // type is not supported anymore in v2 // Assert.assertEquals(NetworkUtils.getOrigId(linkB1), NetworkUtils.getOrigId(linkB2)); // origId is not supported anymore in v2 } @@ -216,8 +216,8 @@ void testNetwork_NameSpecialCharacters() { Network network2 = doIOTest(network1); - Assert.assertNotSame(network1, network2); - Assert.assertEquals(network1.getName(), network2.getName()); + Assertions.assertNotSame(network1, network2); + Assertions.assertEquals(network1.getName(), network2.getName()); } private void doTestAllowedModes(final Set modes, final String filename) { @@ -232,19 +232,19 @@ private void doTestAllowedModes(final Set modes, final String filename) writeNetwork(network1, filename); File networkFile = new File(filename); - assertTrue("written network file doesn't exist.", networkFile.exists()); - assertTrue("written network file seems to be empty.", networkFile.length() > 0); + assertTrue(networkFile.exists(), "written network file doesn't exist."); + assertTrue(networkFile.length() > 0, "written network file seems to be empty."); Scenario scenario2 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network2 = scenario2.getNetwork(); readNetwork(scenario2, filename); Link link1 = network2.getLinks().get(Id.create("1", Link.class)); - assertNotNull("link not found in read-in network.", link1); + assertNotNull(link1, "link not found in read-in network."); Set modes2 = link1.getAllowedModes(); - assertEquals("wrong number of allowed modes.", modes.size(), modes2.size()); - assertTrue("wrong mode.", modes2.containsAll(modes)); + assertEquals(modes.size(), modes2.size(), "wrong number of allowed modes."); + assertTrue(modes2.containsAll(modes), "wrong mode."); } private static Set createHashSet(T... mode) { @@ -262,15 +262,15 @@ private void doTestNodes(List nodes, final String filename) { writeNetwork(network1, filename); File networkFile = new File(filename); - assertTrue("written network file doesn't exist.", networkFile.exists()); - assertTrue("written network file seems to be empty.", networkFile.length() > 0); + assertTrue(networkFile.exists(), "written network file doesn't exist."); + assertTrue(networkFile.length() > 0, "written network file seems to be empty."); Scenario scenario2 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network2 = scenario2.getNetwork(); readNetwork(scenario2, filename); for(Node n : nodes){ - assertEquals("Coordinates are not equal.", n.getCoord(), network2.getNodes().get(n.getId()).getCoord()); + assertEquals(n.getCoord(), network2.getNodes().get(n.getId()).getCoord(), "Coordinates are not equal."); } } diff --git a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java index c4e230ce20f..c1c37f3f96e 100644 --- a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java +++ b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java @@ -7,7 +7,7 @@ import java.util.List; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; @@ -33,19 +33,19 @@ void testEquals() { dnl0.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1"))); dnl1.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1"))); - Assert.assertEquals(dnl0, dnl1); - Assert.assertEquals(dnl1, dnl0); + Assertions.assertEquals(dnl0, dnl1); + Assertions.assertEquals(dnl1, dnl0); dnl1.addDisallowedLinkSequence("bike", List.of(Id.createLinkId("0"))); - Assert.assertNotEquals(dnl0, dnl1); - Assert.assertNotEquals(dnl1, dnl0); + Assertions.assertNotEquals(dnl0, dnl1); + Assertions.assertNotEquals(dnl1, dnl0); } @Test void testIsEmpty() { DisallowedNextLinks dnl= new DisallowedNextLinks(); - Assert.assertTrue(dnl.isEmpty()); + Assertions.assertTrue(dnl.isEmpty()); } @Test @@ -58,7 +58,7 @@ void testAdding() { Map>>> map = Map.of( "bike", List.of(List.of(Id.createLinkId("0"))), "car", List.of(List.of(Id.createLinkId("0"), Id.createLinkId("1")), List.of(Id.createLinkId("0")))); - Assert.assertEquals(map, dnl.getAsMap()); + Assertions.assertEquals(map, dnl.getAsMap()); } @Test @@ -72,30 +72,30 @@ void testRemoving() { Map>>> map = Map.of( "car", List.of(List.of(Id.createLinkId("0"), Id.createLinkId("1")), List.of(Id.createLinkId("0")))); - Assert.assertEquals(map, dnl.getAsMap()); + Assertions.assertEquals(map, dnl.getAsMap()); } @Test void testNotAddingDuplicates() { DisallowedNextLinks dnl = new DisallowedNextLinks(); - Assert.assertTrue(dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1")))); - Assert.assertFalse(dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1")))); - Assert.assertFalse(dnl.addDisallowedLinkSequence("car", Collections.emptyList())); + Assertions.assertTrue(dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1")))); + Assertions.assertFalse(dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1")))); + Assertions.assertFalse(dnl.addDisallowedLinkSequence("car", Collections.emptyList())); } @Test void testNotAddingEmpty() { DisallowedNextLinks dnl = new DisallowedNextLinks(); - Assert.assertFalse(dnl.addDisallowedLinkSequence("car", Collections.emptyList())); + Assertions.assertFalse(dnl.addDisallowedLinkSequence("car", Collections.emptyList())); } @Test void testNotAddingSequenceWithDuplicates() { DisallowedNextLinks dnl = new DisallowedNextLinks(); - Assert.assertFalse(dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("0")))); + Assertions.assertFalse(dnl.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("0")))); } @Test @@ -107,8 +107,8 @@ void testEqualAndHashCode() { dnl1.addDisallowedLinkSequence("car", List.of(Id.createLinkId("4"), Id.createLinkId("5"))); dnl1.addDisallowedLinkSequence("car", List.of(Id.createLinkId("0"), Id.createLinkId("1"))); - Assert.assertEquals(dnl0, dnl1); - Assert.assertEquals(dnl0.hashCode(), dnl1.hashCode()); + Assertions.assertEquals(dnl0, dnl1); + Assertions.assertEquals(dnl0.hashCode(), dnl1.hashCode()); } @Test @@ -122,10 +122,10 @@ void testSerialization() { String s = ac.convertToString(dnl0); DisallowedNextLinks dnl1 = ac.convert(s); - Assert.assertEquals("{\"car\":[[\"0\",\"1\",\"2\"],[\"0\",\"3\"]],\"bike\":[[\"10\",\"11\"]]}", s); - Assert.assertEquals(dnl0, dnl1); - Assert.assertEquals(dnl0.hashCode(), dnl1.hashCode()); - Assert.assertSame(dnl0.getDisallowedLinkSequences("car").get(0).get(0), + Assertions.assertEquals("{\"car\":[[\"0\",\"1\",\"2\"],[\"0\",\"3\"]],\"bike\":[[\"10\",\"11\"]]}", s); + Assertions.assertEquals(dnl0, dnl1); + Assertions.assertEquals(dnl0.hashCode(), dnl1.hashCode()); + Assertions.assertSame(dnl0.getDisallowedLinkSequences("car").get(0).get(0), dnl1.getDisallowedLinkSequences("car").get(0).get(0)); } @@ -143,9 +143,9 @@ void testNetworkWritingAndReading() throws IOException { new MatsimNetworkReader(network).readFile(tempFile.toString()); DisallowedNextLinks dnl1 = NetworkUtils.getDisallowedNextLinks(network.getLinks().get(l1.getId())); - Assert.assertEquals(dnl0, dnl1); - Assert.assertEquals(dnl0.hashCode(), dnl1.hashCode()); - Assert.assertSame(l1.getId(), dnl1.getDisallowedLinkSequences("car").get(0).get(0)); + Assertions.assertEquals(dnl0, dnl1); + Assertions.assertEquals(dnl0.hashCode(), dnl1.hashCode()); + Assertions.assertSame(l1.getId(), dnl1.getDisallowedLinkSequences("car").get(0).get(0)); } static Network createNetwork() { diff --git a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksUtilsTest.java b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksUtilsTest.java index 42ea61a6022..41f9a1205ac 100644 --- a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksUtilsTest.java @@ -3,7 +3,7 @@ import java.util.List; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -15,7 +15,7 @@ public class DisallowedNextLinksUtilsTest { @Test void testNoDisallowedNextLinks() { - Assert.assertTrue(DisallowedNextLinksUtils.isValid(n)); + Assertions.assertTrue(DisallowedNextLinksUtils.isValid(n)); } @Test @@ -28,7 +28,7 @@ void testIsNotValid1() { dnl.addDisallowedLinkSequence("car", List.of(l1.getId(), l3.getId())); dnl.addDisallowedLinkSequence("bike", List.of(l1.getId())); - Assert.assertFalse(DisallowedNextLinksUtils.isValid(n)); + Assertions.assertFalse(DisallowedNextLinksUtils.isValid(n)); } @Test @@ -41,7 +41,7 @@ void testIsNotValid2() { dnl.addDisallowedLinkSequence("car", List.of(l1.getId(), l3.getId())); dnl.addDisallowedLinkSequence("bike", List.of(Id.createLinkId("a"))); - Assert.assertFalse(DisallowedNextLinksUtils.isValid(n)); + Assertions.assertFalse(DisallowedNextLinksUtils.isValid(n)); } @Test @@ -55,6 +55,6 @@ void testIsValid() { dnl.addDisallowedLinkSequence("car", List.of(l3.getId(), l5.getId())); dnl.addDisallowedLinkSequence("bike", List.of(l3.getId())); - Assert.assertTrue(DisallowedNextLinksUtils.isValid(n)); + Assertions.assertTrue(DisallowedNextLinksUtils.isValid(n)); } } diff --git a/matsim/src/test/java/org/matsim/core/network/LinkImplTest.java b/matsim/src/test/java/org/matsim/core/network/LinkImplTest.java index 26257dffe0a..e71bc1c731c 100644 --- a/matsim/src/test/java/org/matsim/core/network/LinkImplTest.java +++ b/matsim/src/test/java/org/matsim/core/network/LinkImplTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -85,98 +85,98 @@ void testCalcDistance() { // do the following cases for each link // case 1: point is orthogonal next to link.fromNode, test both sides of link - Assert.assertEquals(10.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(10.0, 0.0)), EPSILON); + Assertions.assertEquals(10.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(10.0, 0.0)), EPSILON); final double x7 = -12.5; - Assert.assertEquals(12.5, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(x7, 0.0)), EPSILON); - Assert.assertEquals(Math.sqrt(2*65.4*65.4), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(65.4, 1000.0 - 65.4)), EPSILON); + Assertions.assertEquals(12.5, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(x7, 0.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(2*65.4*65.4), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(65.4, 1000.0 - 65.4)), EPSILON); final double x6 = -76.5; - Assert.assertEquals(Math.sqrt(2*76.5*76.5), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(x6, 1000.0 + 76.5)), EPSILON); - Assert.assertEquals(123.987, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(1000.0, 2000.0 - 123.987)), EPSILON); - Assert.assertEquals(23.87, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(1000.0, 2000.0 + 23.87)), EPSILON); - Assert.assertEquals(Math.sqrt(32.4*32.4*1.25), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2000.0 + 32.4, 2000 - 32.4 / 2.0)), EPSILON); - Assert.assertEquals(Math.sqrt(56.8*56.8*1.25), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2000.0 - 56.8, 2000 + 56.8 / 2.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(2*76.5*76.5), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(x6, 1000.0 + 76.5)), EPSILON); + Assertions.assertEquals(123.987, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(1000.0, 2000.0 - 123.987)), EPSILON); + Assertions.assertEquals(23.87, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(1000.0, 2000.0 + 23.87)), EPSILON); + Assertions.assertEquals(Math.sqrt(32.4*32.4*1.25), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2000.0 + 32.4, 2000 - 32.4 / 2.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(56.8*56.8*1.25), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2000.0 - 56.8, 2000 + 56.8 / 2.0)), EPSILON); // case 2: point is behind link, but exactly on extension of the link's line final double y6 = -15.0; - Assert.assertEquals(15.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(0.0, y6)), EPSILON); + Assertions.assertEquals(15.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(0.0, y6)), EPSILON); final double x5 = -5.0; - Assert.assertEquals(Math.sqrt(50.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(x5, 995.0)), EPSILON); - Assert.assertEquals(12.35, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(987.65, 2000.0)), EPSILON); - Assert.assertEquals(Math.sqrt(250.0*250.0 + 500.0*500.0), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2250.0, 2500.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(50.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(x5, 995.0)), EPSILON); + Assertions.assertEquals(12.35, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(987.65, 2000.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(250.0*250.0 + 500.0*500.0), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2250.0, 2500.0)), EPSILON); // case 3: point is behind and on the side of link, test both sides of link final double y5 = -15.0; - Assert.assertEquals(Math.sqrt(325.0), CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(10.0, y5)), EPSILON); + Assertions.assertEquals(Math.sqrt(325.0), CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(10.0, y5)), EPSILON); final double x4 = -15.0; final double y4 = -20.0; - Assert.assertEquals(Math.sqrt(625.0), CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(x4, y4)), EPSILON); - Assert.assertEquals(50.5, CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(0.0, 949.5)), EPSILON); + Assertions.assertEquals(Math.sqrt(625.0), CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(x4, y4)), EPSILON); + Assertions.assertEquals(50.5, CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(0.0, 949.5)), EPSILON); final double x3 = -51.5; - Assert.assertEquals(51.5, CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(x3, 1000.0)), EPSILON); - Assert.assertEquals(Math.sqrt(1300.0), CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(970.0, 1980.0)), EPSILON); - Assert.assertEquals(Math.sqrt(1300.0), CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(980.0, 2030.0)), EPSILON); - Assert.assertEquals(145.7, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2000.0, 2145.7)), EPSILON); - Assert.assertEquals(89.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2089.0, 2000.0)), EPSILON); + Assertions.assertEquals(51.5, CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(x3, 1000.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(1300.0), CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(970.0, 1980.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(1300.0), CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(980.0, 2030.0)), EPSILON); + Assertions.assertEquals(145.7, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2000.0, 2145.7)), EPSILON); + Assertions.assertEquals(89.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2089.0, 2000.0)), EPSILON); // case 4: point is orthogonal next to link.toNode, test both sides of link final double x2 = -5.0; - Assert.assertEquals(5.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(x2, 1000.0)), EPSILON); - Assert.assertEquals(7.5, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(7.5, 1000.0)), EPSILON); - Assert.assertEquals(Math.sqrt(2*234.5*234.5), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(1234.5, 2000.0 - 234.5)), EPSILON); - Assert.assertEquals(Math.sqrt(2*11.1*11.1), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(1000.0 - 11.1, 2000.0 + 11.1)), EPSILON); - Assert.assertEquals(43.3, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(2000.0, 1956.7)), EPSILON); - Assert.assertEquals(10.3, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(2000.0, 2010.3)), EPSILON); + Assertions.assertEquals(5.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(x2, 1000.0)), EPSILON); + Assertions.assertEquals(7.5, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(7.5, 1000.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(2*234.5*234.5), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(1234.5, 2000.0 - 234.5)), EPSILON); + Assertions.assertEquals(Math.sqrt(2*11.1*11.1), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(1000.0 - 11.1, 2000.0 + 11.1)), EPSILON); + Assertions.assertEquals(43.3, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(2000.0, 1956.7)), EPSILON); + Assertions.assertEquals(10.3, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(2000.0, 2010.3)), EPSILON); final double y3 = +22.2; - Assert.assertEquals(Math.sqrt(44.4*44.4*1.25), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(1000 - 44.4, y3)), EPSILON); + Assertions.assertEquals(Math.sqrt(44.4*44.4*1.25), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(1000 - 44.4, y3)), EPSILON); final double y2 = -33.3; - Assert.assertEquals(Math.sqrt(66.6*66.6*1.25), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(1000 + 66.6, y2)), EPSILON); + Assertions.assertEquals(Math.sqrt(66.6*66.6*1.25), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(1000 + 66.6, y2)), EPSILON); // case 5: point is in front of link, but exactly on extension of the link's line - Assert.assertEquals(23.4, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord((double) 0, 1023.4)), EPSILON); - Assert.assertEquals(Math.sqrt(200.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord((double) 1010, 2010.0)), EPSILON); - Assert.assertEquals(987.6, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(2987.6, 2000.0)), EPSILON); + Assertions.assertEquals(23.4, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord((double) 0, 1023.4)), EPSILON); + Assertions.assertEquals(Math.sqrt(200.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord((double) 1010, 2010.0)), EPSILON); + Assertions.assertEquals(987.6, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(2987.6, 2000.0)), EPSILON); final double y1 = -500.0; - Assert.assertEquals(Math.sqrt(250.0*250.0 + 500.0*500.0), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(750.0, y1)), EPSILON); + Assertions.assertEquals(Math.sqrt(250.0*250.0 + 500.0*500.0), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(750.0, y1)), EPSILON); // case 6: point is in front of link and on side of link, test both sides of link final double x1 = -3.0; - Assert.assertEquals(5.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(x1, 1004.0)), EPSILON); - Assert.assertEquals(Math.sqrt(113.0), CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(8.0, 1007.0)), EPSILON); - Assert.assertEquals(Math.sqrt(100.0*100.0+50.0*50.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(1100.0, 2050.0)), EPSILON); - Assert.assertEquals(Math.sqrt(50.0*50.0+100.0*100.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(1050.0, 2100.0)), EPSILON); - Assert.assertEquals(Math.sqrt(100.0*100.0+50.0*50.0), CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(2100.0, 2050.0)), EPSILON); - Assert.assertEquals(Math.sqrt(50.0*50.0+100.0*100.0), CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(2050.0, 1900.0)), EPSILON); + Assertions.assertEquals(5.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(x1, 1004.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(113.0), CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(8.0, 1007.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(100.0*100.0+50.0*50.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(1100.0, 2050.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(50.0*50.0+100.0*100.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(1050.0, 2100.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(100.0*100.0+50.0*50.0), CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(2100.0, 2050.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(50.0*50.0+100.0*100.0), CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(2050.0, 1900.0)), EPSILON); final double y = -50.0; - Assert.assertEquals(50.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(1000.0, y)), EPSILON); - Assert.assertEquals(49.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(951.0, 0.0)), EPSILON); + Assertions.assertEquals(50.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(1000.0, y)), EPSILON); + Assertions.assertEquals(49.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(951.0, 0.0)), EPSILON); // case 7: point is on the side of link, between from- and to-Node, test both sides of link final double x = -42.0; - Assert.assertEquals(42.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(x, 987.65)), EPSILON); - Assert.assertEquals(123.4, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(123.4, 98.765)), EPSILON); - Assert.assertEquals(Math.sqrt(2*125.0*125.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(500.0, 1250.0)), EPSILON); - Assert.assertEquals(Math.sqrt(2*250.0*250.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(500.0, 2000.0)), EPSILON); - Assert.assertEquals(658.3, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(1234.5, 2000.0 - 658.3)), EPSILON); - Assert.assertEquals(422.1, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(1846.3, 2422.1)), EPSILON); - Assert.assertEquals(Math.sqrt(250.0*250.0+125.0*125.0), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2000.0, 1375.0)), EPSILON); - Assert.assertEquals(Math.sqrt(500.0*500.0+250.0*250.0), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(1000.0, 1250.0)), EPSILON); + Assertions.assertEquals(42.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(x, 987.65)), EPSILON); + Assertions.assertEquals(123.4, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(123.4, 98.765)), EPSILON); + Assertions.assertEquals(Math.sqrt(2*125.0*125.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(500.0, 1250.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(2*250.0*250.0), CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(500.0, 2000.0)), EPSILON); + Assertions.assertEquals(658.3, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(1234.5, 2000.0 - 658.3)), EPSILON); + Assertions.assertEquals(422.1, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(1846.3, 2422.1)), EPSILON); + Assertions.assertEquals(Math.sqrt(250.0*250.0+125.0*125.0), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(2000.0, 1375.0)), EPSILON); + Assertions.assertEquals(Math.sqrt(500.0*500.0+250.0*250.0), CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(1000.0, 1250.0)), EPSILON); // case 8: point is *on* the link (exactly on fromnode, exactly on tonode, exactly between somewhere) - Assert.assertEquals("point = link1.fromNode", 0.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), link1.getFromNode().getCoord()), EPSILON); - Assert.assertEquals("point = link1.toNode", 0.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), link1.getToNode().getCoord()), EPSILON); - Assert.assertEquals("point on link1", 0.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(0.0, 135.79)), EPSILON); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), link1.getFromNode().getCoord()), EPSILON, "point = link1.fromNode"); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), link1.getToNode().getCoord()), EPSILON, "point = link1.toNode"); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link1.getFromNode().getCoord(), link1.getToNode().getCoord(), new Coord(0.0, 135.79)), EPSILON, "point on link1"); - Assert.assertEquals("point = link2.fromNode", 0.0, CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), link2.getFromNode().getCoord()), EPSILON); - Assert.assertEquals("point = link2.toNode", 0.0, CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), link2.getToNode().getCoord()), EPSILON); - Assert.assertEquals("point on link2", 0.0, CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(65.43, 1065.43)), EPSILON); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), link2.getFromNode().getCoord()), EPSILON, "point = link2.fromNode"); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), link2.getToNode().getCoord()), EPSILON, "point = link2.toNode"); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link2.getFromNode().getCoord(), link2.getToNode().getCoord(), new Coord(65.43, 1065.43)), EPSILON, "point on link2"); - Assert.assertEquals("point = link3.fromNode", 0.0, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), link3.getFromNode().getCoord()), EPSILON); - Assert.assertEquals("point = link3.toNode", 0.0, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), link3.getToNode().getCoord()), EPSILON); - Assert.assertEquals("point on link3", 0.0, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(1234.5678, 2000.0)), EPSILON); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), link3.getFromNode().getCoord()), EPSILON, "point = link3.fromNode"); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), link3.getToNode().getCoord()), EPSILON, "point = link3.toNode"); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link3.getFromNode().getCoord(), link3.getToNode().getCoord(), new Coord(1234.5678, 2000.0)), EPSILON, "point on link3"); - Assert.assertEquals("point = link4.fromNode", 0.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), link4.getFromNode().getCoord()), EPSILON); - Assert.assertEquals("point = link4.toNode", 0.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), link4.getToNode().getCoord()), EPSILON); - Assert.assertEquals("point on link4", 0.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(1750.0, 1500.0)), EPSILON); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), link4.getFromNode().getCoord()), EPSILON, "point = link4.fromNode"); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), link4.getToNode().getCoord()), EPSILON, "point = link4.toNode"); + Assertions.assertEquals(0.0, CoordUtils.distancePointLinesegment(link4.getFromNode().getCoord(), link4.getToNode().getCoord(), new Coord(1750.0, 1500.0)), EPSILON, "point on link4"); } @Test @@ -188,11 +188,11 @@ void testSetAttributes() { final Node fromNode = node1; final Node toNode = node2; Link link1 = (Link) NetworkUtils.createAndAddLink(network,Id.create(1, Link.class), fromNode, toNode, 500.0, 10.0, 1000.0, 1.0 ); - Assert.assertEquals("wrong freespeed traveltime.", 50.0, NetworkUtils.getFreespeedTravelTime(link1), EPSILON); + Assertions.assertEquals(50.0, NetworkUtils.getFreespeedTravelTime(link1), EPSILON, "wrong freespeed traveltime."); link1.setLength(1000.0); - Assert.assertEquals("wrong freespeed traveltime.", 100.0, NetworkUtils.getFreespeedTravelTime(link1), EPSILON); + Assertions.assertEquals(100.0, NetworkUtils.getFreespeedTravelTime(link1), EPSILON, "wrong freespeed traveltime."); link1.setFreespeed(20.0); - Assert.assertEquals("wrong freespeed traveltime.", 50.0, NetworkUtils.getFreespeedTravelTime(link1), EPSILON); + Assertions.assertEquals(50.0, NetworkUtils.getFreespeedTravelTime(link1), EPSILON, "wrong freespeed traveltime."); } /** @@ -210,13 +210,13 @@ void testAllowedModes() { // test default Set modes = l.getAllowedModes(); - Assert.assertEquals("wrong number of default entries.", 1, modes.size()); - Assert.assertTrue("wrong default.", modes.contains(TransportMode.car)); + Assertions.assertEquals(1, modes.size(), "wrong number of default entries."); + Assertions.assertTrue(modes.contains(TransportMode.car), "wrong default."); // test set/get empty list l.setAllowedModes(new HashSet()); modes = l.getAllowedModes(); - Assert.assertEquals("wrong number of allowed modes.", 0, modes.size()); + Assertions.assertEquals(0, modes.size(), "wrong number of allowed modes."); // test set/get list with entries modes = new HashSet(); @@ -225,10 +225,10 @@ void testAllowedModes() { modes.add(TransportMode.bike); l.setAllowedModes(modes); modes = l.getAllowedModes(); - Assert.assertEquals("wrong number of allowed modes", 3, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); - Assert.assertTrue(modes.contains(TransportMode.car)); - Assert.assertTrue(modes.contains(TransportMode.bike)); + Assertions.assertEquals(3, modes.size(), "wrong number of allowed modes"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertTrue(modes.contains(TransportMode.bike)); } @@ -239,36 +239,36 @@ void testHashSetCache_get_unmodifiable() { s1.add("B"); Set s = HashSetCache.get(s1); - Assert.assertTrue(s != s1); - Assert.assertEquals(2, s.size()); - Assert.assertTrue(s.contains("A")); - Assert.assertTrue(s.contains("B")); - Assert.assertFalse(s.contains("C")); - Assert.assertFalse(s.contains("D")); + Assertions.assertTrue(s != s1); + Assertions.assertEquals(2, s.size()); + Assertions.assertTrue(s.contains("A")); + Assertions.assertTrue(s.contains("B")); + Assertions.assertFalse(s.contains("C")); + Assertions.assertFalse(s.contains("D")); try { s.add("D"); - Assert.fail("Expected Exception, but got none"); + Assertions.fail("Expected Exception, but got none"); } catch (UnsupportedOperationException e) { log.info("catched expected exception.", e); } s1.add("C"); - Assert.assertEquals("the returned set must be independent of the given, original set.", 2, s.size()); + Assertions.assertEquals(2, s.size(), "the returned set must be independent of the given, original set."); } @Test void testHashSetCache_get_null() { Set s = HashSetCache.get((Set) null); - Assert.assertNull(s); + Assertions.assertNull(s); } @Test void testHashSetCache_get_emptySet() { Set s = HashSetCache.get(new TreeSet()); - Assert.assertNotNull(s); - Assert.assertEquals(0, s.size()); + Assertions.assertNotNull(s); + Assertions.assertEquals(0, s.size()); } @@ -287,27 +287,27 @@ void testHashSetCache_get() { s4.add("A"); Set s_1 = HashSetCache.get(s1); - Assert.assertTrue(s_1 != s1); - Assert.assertEquals(2, s_1.size()); - Assert.assertTrue(s_1.contains("A")); - Assert.assertTrue(s_1.contains("B")); - Assert.assertFalse(s_1.contains("C")); - Assert.assertFalse(s_1.contains("D")); + Assertions.assertTrue(s_1 != s1); + Assertions.assertEquals(2, s_1.size()); + Assertions.assertTrue(s_1.contains("A")); + Assertions.assertTrue(s_1.contains("B")); + Assertions.assertFalse(s_1.contains("C")); + Assertions.assertFalse(s_1.contains("D")); Set s_2 = HashSetCache.get(s2); - Assert.assertTrue(s_1 == s_2); + Assertions.assertTrue(s_1 == s_2); Set s_3 = HashSetCache.get(s3); - Assert.assertTrue(s_3 != s3); - Assert.assertEquals(2, s_3.size()); - Assert.assertFalse(s_3.contains("A")); - Assert.assertTrue(s_3.contains("B")); - Assert.assertTrue(s_3.contains("C")); - Assert.assertFalse(s_3.contains("D")); + Assertions.assertTrue(s_3 != s3); + Assertions.assertEquals(2, s_3.size()); + Assertions.assertFalse(s_3.contains("A")); + Assertions.assertTrue(s_3.contains("B")); + Assertions.assertTrue(s_3.contains("C")); + Assertions.assertFalse(s_3.contains("D")); Set s_4 = HashSetCache.get(s4); - Assert.assertTrue(s_4 != s4); - Assert.assertEquals(1, s_4.size()); + Assertions.assertTrue(s_4 != s4); + Assertions.assertEquals(1, s_4.size()); } @@ -325,15 +325,15 @@ void testHashSetCache_get_identicalObjects() { s3.add("A"); Set s_1 = HashSetCache.get(s1); - Assert.assertTrue(s_1 != s1); - Assert.assertEquals(2, s_1.size()); + Assertions.assertTrue(s_1 != s1); + Assertions.assertEquals(2, s_1.size()); Set s_2 = HashSetCache.get(s2); - Assert.assertTrue(s_1 == s_2); + Assertions.assertTrue(s_1 == s_2); Set s_3 = HashSetCache.get(s3); - Assert.assertTrue(s_3 != s3); - Assert.assertEquals(3, s_3.size()); + Assertions.assertTrue(s_3 != s3); + Assertions.assertEquals(3, s_3.size()); } } diff --git a/matsim/src/test/java/org/matsim/core/network/LinkQuadTreeTest.java b/matsim/src/test/java/org/matsim/core/network/LinkQuadTreeTest.java index 897e0d47506..87cab0bfe54 100644 --- a/matsim/src/test/java/org/matsim/core/network/LinkQuadTreeTest.java +++ b/matsim/src/test/java/org/matsim/core/network/LinkQuadTreeTest.java @@ -21,7 +21,7 @@ package org.matsim.core.network; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -32,7 +32,7 @@ import org.matsim.core.config.ConfigUtils; import org.matsim.core.scenario.ScenarioUtils; - /** + /** * @author mrieser / senozon */ public class LinkQuadTreeTest { @@ -56,16 +56,16 @@ void testGetNearest() { qt.put(b); qt.put(c); - Assert.assertEquals(foo, qt.getNearest(200, 200)); - Assert.assertEquals(foo, qt.getNearest(300, 300)); - Assert.assertEquals(bar, qt.getNearest(390, 300)); - Assert.assertEquals(fbr, qt.getNearest(1000, 1100)); - Assert.assertEquals(foo, qt.getNearest(-50, -50)); - Assert.assertEquals(a, qt.getNearest(1105, 1104)); - Assert.assertEquals(a, qt.getNearest(1105, 1103)); - Assert.assertEquals(b, qt.getNearest(1105, 1102)); - Assert.assertEquals(b, qt.getNearest(1105, 1101)); - Assert.assertEquals(c, qt.getNearest(1205, 1101)); + Assertions.assertEquals(foo, qt.getNearest(200, 200)); + Assertions.assertEquals(foo, qt.getNearest(300, 300)); + Assertions.assertEquals(bar, qt.getNearest(390, 300)); + Assertions.assertEquals(fbr, qt.getNearest(1000, 1100)); + Assertions.assertEquals(foo, qt.getNearest(-50, -50)); + Assertions.assertEquals(a, qt.getNearest(1105, 1104)); + Assertions.assertEquals(a, qt.getNearest(1105, 1103)); + Assertions.assertEquals(b, qt.getNearest(1105, 1102)); + Assertions.assertEquals(b, qt.getNearest(1105, 1101)); + Assertions.assertEquals(c, qt.getNearest(1205, 1101)); } @Test @@ -93,10 +93,10 @@ void testGetNearest_longNear_smallFarAway() { qt.put(a); qt.put(b); - Assert.assertEquals(b, qt.getNearest(600, 0)); - Assert.assertEquals(a, qt.getNearest(600, 210)); - Assert.assertEquals(b, qt.getNearest(300, 210)); // outside of segment (1)-(2), thus (3)-(4) is closer - Assert.assertEquals(a, qt.getNearest(400, 210)); // distance to (1) is smaller than to (3)-(4) + Assertions.assertEquals(b, qt.getNearest(600, 0)); + Assertions.assertEquals(a, qt.getNearest(600, 210)); + Assertions.assertEquals(b, qt.getNearest(300, 210)); // outside of segment (1)-(2), thus (3)-(4) is closer + Assertions.assertEquals(a, qt.getNearest(400, 210)); // distance to (1) is smaller than to (3)-(4) } @Test @@ -141,7 +141,7 @@ void testPut_zeroLengthLink() { qt.put(l34); // mostly check that there is no exception like StackOverflowError - Assert.assertEquals(l13, qt.getNearest(100, 800)); + Assertions.assertEquals(l13, qt.getNearest(100, 800)); } @Test @@ -166,7 +166,7 @@ void testPut_zeroLengthLink_negativeCoords() { qt.put(l34); // mostly check that there is no exception like StackOverflowError - Assert.assertEquals(l13, qt.getNearest(-100, -800)); + Assertions.assertEquals(l13, qt.getNearest(-100, -800)); } @Test @@ -183,10 +183,10 @@ void testRemove() { qt.put(l53); qt.put(l63); - Assert.assertEquals(l13, qt.getNearest(100, 800)); + Assertions.assertEquals(l13, qt.getNearest(100, 800)); qt.remove(l13); - Assert.assertEquals(l23, qt.getNearest(100, 800)); + Assertions.assertEquals(l23, qt.getNearest(100, 800)); } /** @@ -202,10 +202,10 @@ void testRemove_inSubNode() { qt.put(lInTop1); qt.put(lInChildSW1); - Assert.assertEquals(lInChildSW1, qt.getNearest(100, 80)); + Assertions.assertEquals(lInChildSW1, qt.getNearest(100, 80)); qt.remove(lInChildSW1); - Assert.assertEquals(lInTop1, qt.getNearest(100, 80)); + Assertions.assertEquals(lInTop1, qt.getNearest(100, 80)); } private Link createLink(Scenario s, double fromX, double fromY, double toX, double toY) { diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java index f3d135ce74e..407d57d09c8 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java @@ -20,7 +20,7 @@ package org.matsim.core.network; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -38,8 +38,8 @@ import java.util.List; import static org.hamcrest.core.IsCollectionContaining.hasItem; -import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertThat; +import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertThrows; public class NetworkChangeEventsParserWriterTest { @@ -116,7 +116,7 @@ void testWriteReadZeroChangeEvents() { new NetworkChangeEventsParser(network, changeEvents2).readFile(fileName); // the main test is that there is no exception - Assert.assertTrue(changeEvents2.isEmpty()); + Assertions.assertTrue(changeEvents2.isEmpty()); } @Test @@ -139,12 +139,12 @@ void testAbsoluteChangeEvents() { List changeEvents2 = new ArrayList<>(); new NetworkChangeEventsParser(network, changeEvents2).readFile(fileName); - Assert.assertFalse(changeEvents2.isEmpty()); - Assert.assertEquals(1, changeEvents2.size()); + Assertions.assertFalse(changeEvents2.isEmpty()); + Assertions.assertEquals(1, changeEvents2.size()); NetworkChangeEvent event2 = changeEvents2.get(0); - Assert.assertEquals(event.getStartTime(), event2.getStartTime(), 0.0); - Assert.assertEquals(NetworkChangeEvent.ChangeType.ABSOLUTE_IN_SI_UNITS, event2.getFlowCapacityChange().getType()); - Assert.assertEquals(event.getFlowCapacityChange().getValue(), event2.getFlowCapacityChange().getValue(), 1e-10); + Assertions.assertEquals(event.getStartTime(), event2.getStartTime(), 0.0); + Assertions.assertEquals(NetworkChangeEvent.ChangeType.ABSOLUTE_IN_SI_UNITS, event2.getFlowCapacityChange().getType()); + Assertions.assertEquals(event.getFlowCapacityChange().getValue(), event2.getFlowCapacityChange().getValue(), 1e-10); } @Test @@ -167,12 +167,12 @@ void testScaleFactorChangeEvents() { List changeEvents2 = new ArrayList<>(); new NetworkChangeEventsParser(network, changeEvents2).readFile(fileName); - Assert.assertFalse(changeEvents2.isEmpty()); - Assert.assertEquals(1, changeEvents2.size()); + Assertions.assertFalse(changeEvents2.isEmpty()); + Assertions.assertEquals(1, changeEvents2.size()); NetworkChangeEvent event2 = changeEvents2.get(0); - Assert.assertEquals(event.getStartTime(), event2.getStartTime(), 0.0); - Assert.assertEquals(NetworkChangeEvent.ChangeType.FACTOR, event2.getLanesChange().getType()); - Assert.assertEquals(event.getLanesChange().getValue(), event2.getLanesChange().getValue(), 1e-10); + Assertions.assertEquals(event.getStartTime(), event2.getStartTime(), 0.0); + Assertions.assertEquals(NetworkChangeEvent.ChangeType.FACTOR, event2.getLanesChange().getType()); + Assertions.assertEquals(event.getLanesChange().getValue(), event2.getLanesChange().getValue(), 1e-10); } @Test @@ -195,12 +195,12 @@ void testPositiveOffsetChangeEvents() { List changeEvents2 = new ArrayList<>(); new NetworkChangeEventsParser(network, changeEvents2).readFile(fileName); - Assert.assertFalse(changeEvents2.isEmpty()); - Assert.assertEquals(1, changeEvents2.size()); + Assertions.assertFalse(changeEvents2.isEmpty()); + Assertions.assertEquals(1, changeEvents2.size()); NetworkChangeEvent event2 = changeEvents2.get(0); - Assert.assertEquals(event.getStartTime(), event2.getStartTime(), 0.0); - Assert.assertEquals(NetworkChangeEvent.ChangeType.OFFSET_IN_SI_UNITS, event2.getFreespeedChange().getType()); - Assert.assertEquals(event.getFreespeedChange().getValue(), event2.getFreespeedChange().getValue(), 1e-10); + Assertions.assertEquals(event.getStartTime(), event2.getStartTime(), 0.0); + Assertions.assertEquals(NetworkChangeEvent.ChangeType.OFFSET_IN_SI_UNITS, event2.getFreespeedChange().getType()); + Assertions.assertEquals(event.getFreespeedChange().getValue(), event2.getFreespeedChange().getValue(), 1e-10); } @Test @@ -223,12 +223,12 @@ void testNegativeOffsetChangeEvents() { List changeEvents2 = new ArrayList<>(); new NetworkChangeEventsParser(network, changeEvents2).readFile(fileName); - Assert.assertFalse(changeEvents2.isEmpty()); - Assert.assertEquals(1, changeEvents2.size()); + Assertions.assertFalse(changeEvents2.isEmpty()); + Assertions.assertEquals(1, changeEvents2.size()); NetworkChangeEvent event2 = changeEvents2.get(0); - Assert.assertEquals(event.getStartTime(), event2.getStartTime(), 0.0); - Assert.assertEquals(NetworkChangeEvent.ChangeType.OFFSET_IN_SI_UNITS, event2.getFreespeedChange().getType()); - Assert.assertEquals(event.getFreespeedChange().getValue(), event2.getFreespeedChange().getValue(), 1e-10); + Assertions.assertEquals(event.getStartTime(), event2.getStartTime(), 0.0); + Assertions.assertEquals(NetworkChangeEvent.ChangeType.OFFSET_IN_SI_UNITS, event2.getFreespeedChange().getType()); + Assertions.assertEquals(event.getFreespeedChange().getValue(), event2.getFreespeedChange().getValue(), 1e-10); } } diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkCollectorTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkCollectorTest.java index 36184ddc30d..ea391caa49c 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkCollectorTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkCollectorTest.java @@ -8,8 +8,8 @@ import org.matsim.core.utils.io.IOUtils; import org.matsim.examples.ExamplesUtils; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertFalse; +import static org.junit.jupiter.api.Assertions.assertTrue; public class NetworkCollectorTest { diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkImplTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkImplTest.java index 1a4de57b8aa..4eeef809488 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkImplTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkImplTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -51,9 +51,9 @@ public Network getEmptyTestNetwork() { @Test void testDefaultValues(){ Network net = new NetworkImpl(new LinkFactoryImpl()); - Assert.assertEquals(7.5, net.getEffectiveCellSize(), 0.0); - Assert.assertEquals(3.75, net.getEffectiveLaneWidth(), 0.0); - Assert.assertEquals(3600.0, net.getCapacityPeriod(), 0.0); + Assertions.assertEquals(7.5, net.getEffectiveCellSize(), 0.0); + Assertions.assertEquals(3.75, net.getEffectiveLaneWidth(), 0.0); + Assertions.assertEquals(3600.0, net.getCapacityPeriod(), 0.0); Node node1 = NetworkUtils.createNode(Id.create(1, Node.class), new Coord((double) 0, (double) 0)); Node node2 = NetworkUtils.createNode(Id.create(2, Node.class), new Coord((double) 1000, (double) 0)); @@ -62,8 +62,8 @@ void testDefaultValues(){ final NetworkFactory nf = net.getFactory(); Gbl.assertNotNull(nf); Link link = nf.createLink(Id.create(1, Link.class), node1, node2); - Assert.assertEquals(1, link.getAllowedModes().size()); - Assert.assertEquals("car", link.getAllowedModes().iterator().next()); + Assertions.assertEquals(1, link.getAllowedModes().size()); + Assertions.assertEquals("car", link.getAllowedModes().iterator().next()); } /** @@ -88,19 +88,19 @@ void testAddLink_existingId() { Link link1b = NetworkUtils.createLink(Id.create(1, Link.class), node2, node3, network, 1000, 100.0, 2000.0, 1.0); Link link2 = NetworkUtils.createLink(Id.create(2, Link.class), node2, node4, network, 1000, 100.0, 2000.0, 1.0); network.addLink(link1); - Assert.assertEquals(1, network.getLinks().size()); + Assertions.assertEquals(1, network.getLinks().size()); try { network.addLink(link1b); - Assert.fail("missing exception. Should not be able to add different link with existing id."); + Assertions.fail("missing exception. Should not be able to add different link with existing id."); } catch (IllegalArgumentException e) { log.info("catched expected exception.", e); } - Assert.assertEquals(1, network.getLinks().size()); + Assertions.assertEquals(1, network.getLinks().size()); network.addLink(link2); - Assert.assertEquals(2, network.getLinks().size()); + Assertions.assertEquals(2, network.getLinks().size()); network.addLink(link2); // adding the same link again should just be ignored - Assert.assertEquals(2, network.getLinks().size()); + Assertions.assertEquals(2, network.getLinks().size()); } /** @@ -118,7 +118,7 @@ void testAddLink_noNodes(){ Link ab = n.getFactory().createLink(Id.create("ab", Link.class), a, b); try{ n.addLink(ab); - Assert.fail("Should have thrown exception as fromNode was not in network."); + Assertions.fail("Should have thrown exception as fromNode was not in network."); } catch (IllegalArgumentException e){ log.info("Caught expected exception: fromNode not in network.", e); } @@ -126,7 +126,7 @@ void testAddLink_noNodes(){ n.addNode(a); try{ n.addLink(ab); - Assert.fail("Should have thrown exception as toNode was not in network."); + Assertions.fail("Should have thrown exception as toNode was not in network."); } catch (IllegalArgumentException e){ log.info("Caught expected exception: toNode not in network.", e); } @@ -136,13 +136,13 @@ void testAddLink_noNodes(){ n.addLink(ab); log.info("Link added correctly. Both nodes in the network."); } catch (IllegalArgumentException e){ - Assert.fail("Should not have thrown exception as both nodes are in network."); + Assertions.fail("Should not have thrown exception as both nodes are in network."); } Link ac = n.getFactory().createLink(Id.create("ac", Link.class), a, c); try{ n.addLink(ac); - Assert.fail("Should have thrown exception as toNode was not in network."); + Assertions.fail("Should have thrown exception as toNode was not in network."); } catch (IllegalArgumentException e){ log.info("Caught expected exception: toNode not in network.", e); } @@ -152,7 +152,7 @@ void testAddLink_noNodes(){ n.addLink(ac); log.info("Link added correctly. Both nodes in the network."); } catch (IllegalArgumentException e){ - Assert.fail("Should not have thrown exception as both nodes are in network."); + Assertions.fail("Should not have thrown exception as both nodes are in network."); } } @@ -166,19 +166,19 @@ void testAddNode_existingId() { Node node1b = NetworkUtils.createNode(Id.create(1, Node.class), new Coord((double) 2000, (double) 0)); network.addNode(node1); network.addNode(node2); - Assert.assertEquals(2, network.getNodes().size()); + Assertions.assertEquals(2, network.getNodes().size()); try { network.addNode(node1b); - Assert.fail("missing exception. Should not be able to add different node with existing id."); + Assertions.fail("missing exception. Should not be able to add different node with existing id."); } catch (IllegalArgumentException e) { log.info("catched expected exception.", e); } - Assert.assertEquals(2, network.getNodes().size()); + Assertions.assertEquals(2, network.getNodes().size()); network.addNode(node1); // adding the same node again should just be ignored - Assert.assertEquals(2, network.getNodes().size()); + Assertions.assertEquals(2, network.getNodes().size()); network.addNode(node3); - Assert.assertEquals(3, network.getNodes().size()); + Assertions.assertEquals(3, network.getNodes().size()); } /** @@ -193,15 +193,15 @@ void testAddNode_singleNodeFirstOnly() { Node node2 = NetworkUtils.createNode(Id.create(2, Node.class), new Coord((double) 600, (double) 500)); network.addNode(node1); - Assert.assertEquals(1, network.getNodes().size()); + Assertions.assertEquals(1, network.getNodes().size()); Node n = NetworkUtils.getNearestNode(network,new Coord((double) 550, (double) 450)); - Assert.assertEquals(node1, n); + Assertions.assertEquals(node1, n); network.addNode(node2); - Assert.assertEquals(2, network.getNodes().size()); + Assertions.assertEquals(2, network.getNodes().size()); n = NetworkUtils.getNearestNode(network,new Coord((double) 590, (double) 490)); - Assert.assertEquals(node2, n); + Assertions.assertEquals(node2, n); } /** @@ -216,18 +216,18 @@ void testAddTwoNodes_initializedEmptyQuadtree() { Node node2 = NetworkUtils.createNode(Id.create(2, Node.class), new Coord((double) 600, (double) 500)); Node n = NetworkUtils.getNearestNode(network,new Coord((double) 550, (double) 450)); - Assert.assertNull(n); + Assertions.assertNull(n); network.addNode(node1); - Assert.assertEquals(1, network.getNodes().size()); + Assertions.assertEquals(1, network.getNodes().size()); n = NetworkUtils.getNearestNode(network,new Coord((double) 550, (double) 450)); - Assert.assertEquals(node1, n); + Assertions.assertEquals(node1, n); network.addNode(node2); - Assert.assertEquals(2, network.getNodes().size()); + Assertions.assertEquals(2, network.getNodes().size()); n = NetworkUtils.getNearestNode(network,new Coord((double) 590, (double) 490)); - Assert.assertEquals(node2, n); + Assertions.assertEquals(node2, n); } @Test @@ -246,26 +246,26 @@ void testRemoveLink_alsoInQuadTrees() { network.addLink(link2); network.addLink(link3); - Assert.assertEquals(3, network.getLinks().size()); - Assert.assertEquals(link1, NetworkUtils.getNearestLink(network, new Coord(300, 200))); - Assert.assertEquals(link1, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); + Assertions.assertEquals(3, network.getLinks().size()); + Assertions.assertEquals(link1, NetworkUtils.getNearestLink(network, new Coord(300, 200))); + Assertions.assertEquals(link1, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); network.removeLink(link1.getId()); - Assert.assertEquals(2, network.getLinks().size()); - Assert.assertEquals(link3, NetworkUtils.getNearestLink(network, new Coord(300, 200))); - Assert.assertEquals(link3, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); + Assertions.assertEquals(2, network.getLinks().size()); + Assertions.assertEquals(link3, NetworkUtils.getNearestLink(network, new Coord(300, 200))); + Assertions.assertEquals(link3, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); network.removeLink(link3.getId()); - Assert.assertEquals(1, network.getLinks().size()); - Assert.assertEquals(link2, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); + Assertions.assertEquals(1, network.getLinks().size()); + Assertions.assertEquals(link2, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); network.removeLink(link2.getId()); - Assert.assertEquals(0, network.getLinks().size()); - Assert.assertNull(NetworkUtils.getNearestLink(network, new Coord(300, 200))); - Assert.assertNull(NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); + Assertions.assertEquals(0, network.getLinks().size()); + Assertions.assertNull(NetworkUtils.getNearestLink(network, new Coord(300, 200))); + Assertions.assertNull(NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); } @Test @@ -284,24 +284,24 @@ void testAddLink_alsoInQuadTrees() { network.addLink(link2); network.addLink(link3); - Assert.assertEquals(2, network.getLinks().size()); - Assert.assertEquals(link3, NetworkUtils.getNearestLink(network, new Coord(300, 200))); - Assert.assertEquals(link3, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); // this will force the LinkQuadTree to be built + Assertions.assertEquals(2, network.getLinks().size()); + Assertions.assertEquals(link3, NetworkUtils.getNearestLink(network, new Coord(300, 200))); + Assertions.assertEquals(link3, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); // this will force the LinkQuadTree to be built network.addLink(link1); - Assert.assertEquals(3, network.getLinks().size()); + Assertions.assertEquals(3, network.getLinks().size()); // check that the quad trees were correctly updated with the new link - Assert.assertEquals(link1, NetworkUtils.getNearestLink(network, new Coord(300, 200))); - Assert.assertEquals(link1, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); // this will force the LinkQuadTree to be built + Assertions.assertEquals(link1, NetworkUtils.getNearestLink(network, new Coord(300, 200))); + Assertions.assertEquals(link1, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); // this will force the LinkQuadTree to be built } @Test void testAddLink_intoEmptyQuadTree() { Network network = new NetworkImpl(new LinkFactoryImpl()); - Assert.assertEquals(0, network.getLinks().size()); - Assert.assertNull(NetworkUtils.getNearestLink(network, new Coord(300, 200))); // this will force the node QuadTree to be built - Assert.assertNull(NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); // this will force the LinkQuadTree to be built + Assertions.assertEquals(0, network.getLinks().size()); + Assertions.assertNull(NetworkUtils.getNearestLink(network, new Coord(300, 200))); // this will force the node QuadTree to be built + Assertions.assertNull(NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); // this will force the LinkQuadTree to be built Node node1 = NetworkUtils.createNode(Id.create(1, Node.class), new Coord(100, 100)); Node node2 = NetworkUtils.createNode(Id.create(2, Node.class), new Coord(1000, 200)); @@ -317,8 +317,8 @@ void testAddLink_intoEmptyQuadTree() { network.addLink(link2); network.addLink(link3); - Assert.assertEquals(3, network.getLinks().size()); - Assert.assertEquals(link1, NetworkUtils.getNearestLink(network, new Coord(300, 200))); - Assert.assertEquals(link1, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); // this will force the LinkQuadTree to be built + Assertions.assertEquals(3, network.getLinks().size()); + Assertions.assertEquals(link1, NetworkUtils.getNearestLink(network, new Coord(300, 200))); + Assertions.assertEquals(link1, NetworkUtils.getNearestLinkExactly(network, new Coord(300, 200))); // this will force the LinkQuadTree to be built } } diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java index 9144ea61f59..c65497cb5d4 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkUtilsTest.java @@ -18,9 +18,11 @@ * *********************************************************************** */ package org.matsim.core.network; +import static org.junit.jupiter.api.Assertions.assertEquals; + import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -38,8 +40,6 @@ import java.util.List; import java.util.TreeMap; -import static org.junit.Assert.assertEquals; - /** * @author nagel * @@ -63,7 +63,7 @@ final void testIsMultimodal() { Network network = scenario.getNetwork() ; - Assert.assertTrue( NetworkUtils.isMultimodal( network ) ); + Assertions.assertTrue( NetworkUtils.isMultimodal( network ) ); } @@ -127,7 +127,7 @@ final void getOutLinksSortedByAngleTest() { Link[] actuals = result.values().toArray( new Link[result.size()] ) ; Link[] expecteds = {liNE,liE,liSE,liS,liSW,liW,liNW} ; - Assert.assertArrayEquals(expecteds, actuals); + Assertions.assertArrayEquals(expecteds, actuals); } log.info("==="); @@ -140,7 +140,7 @@ final void getOutLinksSortedByAngleTest() { } Link[] actuals = result.values().toArray( new Link[result.size()] ) ; Link[] expecteds = {liSW,liW,liNW,liN,liNE,liE,liSE} ; - Assert.assertArrayEquals(expecteds, actuals); + Assertions.assertArrayEquals(expecteds, actuals); } log.info("==="); } diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java index a3d9ddb7587..097ebf21c1f 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkV2IOTest.java @@ -21,7 +21,7 @@ package org.matsim.core.network; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -33,7 +33,7 @@ import org.matsim.core.scenario.ScenarioUtils; import org.matsim.testcases.MatsimTestUtils; - /** + /** * @author thibautd */ public class NetworkV2IOTest { @@ -49,9 +49,9 @@ void testNetworkAttributes() { final Scenario read = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); new MatsimNetworkReader( read.getNetwork() ).readFile( utils.getOutputDirectory()+"network.xml" ); - Assert.assertEquals( "unexpected year in network metadata", - sc.getNetwork().getAttributes().getAttribute( "year" ), - read.getNetwork().getAttributes().getAttribute( "year" ) ); + Assertions.assertEquals( sc.getNetwork().getAttributes().getAttribute( "year" ), + read.getNetwork().getAttributes().getAttribute( "year" ), + "unexpected year in network metadata" ); } @Test @@ -65,13 +65,13 @@ void testNodesAttributes() { final Id id = Id.createNodeId( "Zurich" ); - Assert.assertEquals( "unexpected internet attribute in node metadata", - "good", - read.getNetwork().getNodes().get( id ).getAttributes().getAttribute( "Internet" ) ); + Assertions.assertEquals( "good", + read.getNetwork().getNodes().get( id ).getAttributes().getAttribute( "Internet" ), + "unexpected internet attribute in node metadata" ); - Assert.assertEquals( "unexpected meeting attribute in node metadata", - false, - read.getNetwork().getNodes().get( id ).getAttributes().getAttribute( "Developper Meeting" ) ); + Assertions.assertEquals( false, + read.getNetwork().getNodes().get( id ).getAttributes().getAttribute( "Developper Meeting" ), + "unexpected meeting attribute in node metadata" ); } @Test @@ -88,8 +88,8 @@ void testNo3DCoord() { final Coord zhCoord = read.getNetwork().getNodes().get( zh ).getCoord(); - Assert.assertFalse( "did not expect Z", - zhCoord.hasZ() ); + Assertions.assertFalse( zhCoord.hasZ(), + "did not expect Z" ); } @Test @@ -106,13 +106,13 @@ void test3DCoord() { final Coord zhCoord = read.getNetwork().getNodes().get( zh ).getCoord(); - Assert.assertTrue( "did expect Z", - zhCoord.hasZ() ); + Assertions.assertTrue( zhCoord.hasZ(), + "did expect Z" ); - Assert.assertEquals( "unexpected Z value", - 400, + Assertions.assertEquals( 400, zhCoord.getZ() , - MatsimTestUtils.EPSILON ); + MatsimTestUtils.EPSILON, + "unexpected Z value" ); } @Test @@ -126,9 +126,9 @@ void testLinksAttributes() { final Id id = Id.createLinkId( "trip" ); - Assert.assertEquals( "unexpected mode attribute in link metadata", - 3, - read.getNetwork().getLinks().get( id ).getAttributes().getAttribute( "number of modes" ) ); + Assertions.assertEquals( 3, + read.getNetwork().getLinks().get( id ).getAttributes().getAttribute( "number of modes" ), + "unexpected mode attribute in link metadata" ); } private Scenario createTestNetwork( boolean threeD) { diff --git a/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java b/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java index 6ee99a6bbe7..8086bbdea20 100644 --- a/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java +++ b/matsim/src/test/java/org/matsim/core/network/TimeVariantLinkImplTest.java @@ -20,7 +20,7 @@ package org.matsim.core.network; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java b/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java index f7cc016d101..3f6af219ffc 100644 --- a/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/network/TravelTimeCalculatorIntegrationTest.java @@ -20,7 +20,7 @@ package org.matsim.core.network; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/CalcBoundingBoxTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/CalcBoundingBoxTest.java index fa57c2fb070..88b089bccc7 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/CalcBoundingBoxTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/CalcBoundingBoxTest.java @@ -19,7 +19,7 @@ package org.matsim.core.network.algorithms; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -64,10 +64,10 @@ void testRun() { CalcBoundingBox bbox = new CalcBoundingBox(); bbox.run(net); - Assert.assertEquals(100, bbox.getMinX(), 1e-9); - Assert.assertEquals(600, bbox.getMaxX(), 1e-9); - Assert.assertEquals(200, bbox.getMinY(), 1e-9); - Assert.assertEquals(700, bbox.getMaxY(), 1e-9); + Assertions.assertEquals(100, bbox.getMinX(), 1e-9); + Assertions.assertEquals(600, bbox.getMaxX(), 1e-9); + Assertions.assertEquals(200, bbox.getMinY(), 1e-9); + Assertions.assertEquals(700, bbox.getMaxY(), 1e-9); } @Test @@ -110,9 +110,9 @@ void testRun_allNegative() { CalcBoundingBox bbox = new CalcBoundingBox(); bbox.run(net); - Assert.assertEquals(-600, bbox.getMinX(), 1e-9); - Assert.assertEquals(-100, bbox.getMaxX(), 1e-9); - Assert.assertEquals(-700, bbox.getMinY(), 1e-9); - Assert.assertEquals(-200, bbox.getMaxY(), 1e-9); + Assertions.assertEquals(-600, bbox.getMinX(), 1e-9); + Assertions.assertEquals(-100, bbox.getMaxX(), 1e-9); + Assertions.assertEquals(-700, bbox.getMinY(), 1e-9); + Assertions.assertEquals(-200, bbox.getMaxY(), 1e-9); } } diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/MultimodalNetworkCleanerTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/MultimodalNetworkCleanerTest.java index 7021557104f..2665b2d4096 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/MultimodalNetworkCleanerTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/MultimodalNetworkCleanerTest.java @@ -23,7 +23,7 @@ import java.util.HashSet; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -48,16 +48,16 @@ void testRun_singleMode() { MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); cleaner.run(createHashSet(TransportMode.car)); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); } @Test @@ -76,32 +76,32 @@ void testRun_singleMode_separateLink() { MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); cleaner.run(createHashSet(TransportMode.car)); - Assert.assertEquals("wrong number of links.", 9, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[10]).getAllowedModes()); - Assert.assertNull(network.getLinks().get(f.linkIds[11])); + Assertions.assertEquals(9, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[10]).getAllowedModes()); + Assertions.assertNull(network.getLinks().get(f.linkIds[11])); cleaner.run(createHashSet(TransportMode.walk)); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertNull(network.getLinks().get(f.linkIds[10])); - Assert.assertNull(network.getLinks().get(f.linkIds[11])); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertNull(network.getLinks().get(f.linkIds[10])); + Assertions.assertNull(network.getLinks().get(f.linkIds[11])); } @Test @@ -112,16 +112,16 @@ void testRun_singleInexistantMode() { MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); cleaner.run(createHashSet("other")); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); } @Test @@ -140,41 +140,41 @@ void testRun_singleMode_singleSink() { network.getLinks().get(f.linkIds[11]).setAllowedModes(f.modesW); MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); - Assert.assertEquals("wrong number of links.", 10, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 8, network.getNodes().size()); + Assertions.assertEquals(10, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(8, network.getNodes().size(), "wrong number of nodes."); cleaner.run(createHashSet(TransportMode.car)); - Assert.assertEquals("wrong number of links.", 9, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 7, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[11]).getAllowedModes()); - Assert.assertNull(network.getLinks().get(f.linkIds[10])); - - Assert.assertEquals("wrong number of links.", 9, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 7, network.getNodes().size()); + Assertions.assertEquals(9, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(7, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[11]).getAllowedModes()); + Assertions.assertNull(network.getLinks().get(f.linkIds[10])); + + Assertions.assertEquals(9, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(7, network.getNodes().size(), "wrong number of nodes."); cleaner.run(createHashSet(TransportMode.walk)); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertNull(network.getLinks().get(f.linkIds[11])); - - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertNull(network.getLinks().get(f.linkIds[11])); + + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); } @Test @@ -185,38 +185,38 @@ void testRun_singleMode_singleSinkIntegrated() { network.getLinks().get(f.linkIds[8]).setAllowedModes(f.modesCW); MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); cleaner.run(createHashSet(TransportMode.car)); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesCW, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); // only remove mode, not link! - - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesCW, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); // only remove mode, not link! + + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); cleaner.run(createHashSet(TransportMode.walk)); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); // only remove mode, not link! - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); // only remove mode, not link! + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); } @Test @@ -240,39 +240,39 @@ void testRun_singleMode_doubleSink() { network.getLinks().get(f.linkIds[13]).setAllowedModes(f.modesW); MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); - Assert.assertEquals("wrong number of links.", 12, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 8, network.getNodes().size()); + Assertions.assertEquals(12, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(8, network.getNodes().size(), "wrong number of nodes."); cleaner.run(createHashSet(TransportMode.walk)); - Assert.assertEquals("wrong number of links.", 10, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 7, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[10]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[11]).getAllowedModes()); - Assert.assertNull(network.getLinks().get(f.linkIds[12])); - Assert.assertNull(network.getLinks().get(f.linkIds[13])); + Assertions.assertEquals(10, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(7, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[10]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[11]).getAllowedModes()); + Assertions.assertNull(network.getLinks().get(f.linkIds[12])); + Assertions.assertNull(network.getLinks().get(f.linkIds[13])); cleaner.run(createHashSet(TransportMode.car)); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertNull(network.getLinks().get(f.linkIds[10])); - Assert.assertNull(network.getLinks().get(f.linkIds[11])); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertNull(network.getLinks().get(f.linkIds[10])); + Assertions.assertNull(network.getLinks().get(f.linkIds[11])); } @@ -292,41 +292,41 @@ void testRun_singleMode_singleSource() { network.getLinks().get(f.linkIds[11]).setAllowedModes(f.modesW); MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); - Assert.assertEquals("wrong number of links.", 10, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 8, network.getNodes().size()); + Assertions.assertEquals(10, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(8, network.getNodes().size(), "wrong number of nodes."); cleaner.run(createHashSet(TransportMode.car)); - Assert.assertEquals("wrong number of links.", 9, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 7, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[11]).getAllowedModes()); - Assert.assertNull(network.getLinks().get(f.linkIds[10])); - - Assert.assertEquals("wrong number of links.", 9, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 7, network.getNodes().size()); + Assertions.assertEquals(9, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(7, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[11]).getAllowedModes()); + Assertions.assertNull(network.getLinks().get(f.linkIds[10])); + + Assertions.assertEquals(9, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(7, network.getNodes().size(), "wrong number of nodes."); cleaner.run(createHashSet(TransportMode.walk)); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertNull(network.getLinks().get(f.linkIds[11])); - - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertNull(network.getLinks().get(f.linkIds[11])); + + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); } @Test @@ -335,18 +335,18 @@ void testRemoveNodesWithoutLinks() { Network network = f.scenario.getNetwork(); network.addNode(network.getFactory().createNode(f.nodeIds[10], new Coord((double) 300, (double) 300))); MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 7, network.getNodes().size()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(7, network.getNodes().size(), "wrong number of nodes."); cleaner.run(createHashSet(TransportMode.walk)); - Assert.assertEquals("wrong number of links after cleaning.", 8, network.getLinks().size()); - Assert.assertEquals("empty node should not be removed by cleaning.", 7, network.getNodes().size()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links after cleaning."); + Assertions.assertEquals(7, network.getNodes().size(), "empty node should not be removed by cleaning."); cleaner.removeNodesWithoutLinks(); - Assert.assertEquals("wrong number of links after cleaning.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes after cleaning.", 6, network.getNodes().size()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links after cleaning."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes after cleaning."); } @Test @@ -370,39 +370,39 @@ void testRun_singleMode_doubleSource() { network.getLinks().get(f.linkIds[13]).setAllowedModes(f.modesW); MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); - Assert.assertEquals("wrong number of links.", 12, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 8, network.getNodes().size()); + Assertions.assertEquals(12, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(8, network.getNodes().size(), "wrong number of nodes."); cleaner.run(createHashSet(TransportMode.walk)); - Assert.assertEquals("wrong number of links.", 10, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 7, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[10]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[11]).getAllowedModes()); - Assert.assertNull(network.getLinks().get(f.linkIds[12])); - Assert.assertNull(network.getLinks().get(f.linkIds[13])); + Assertions.assertEquals(10, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(7, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[10]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[11]).getAllowedModes()); + Assertions.assertNull(network.getLinks().get(f.linkIds[12])); + Assertions.assertNull(network.getLinks().get(f.linkIds[13])); cleaner.run(createHashSet(TransportMode.car)); - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertNull(network.getLinks().get(f.linkIds[10])); - Assert.assertNull(network.getLinks().get(f.linkIds[11])); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertNull(network.getLinks().get(f.linkIds[10])); + Assertions.assertNull(network.getLinks().get(f.linkIds[11])); } @Test @@ -413,20 +413,20 @@ void testRun_multipleModes() { MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); cleaner.run(createHashSet(TransportMode.car, TransportMode.walk)); - Assert.assertEquals("wrong number of links.", 12, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 9, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[9]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[10]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[11]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[12]).getAllowedModes()); + Assertions.assertEquals(12, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(9, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[9]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[10]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[11]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[12]).getAllowedModes()); } @Test @@ -441,26 +441,26 @@ void testRun_multipleModes_doubleSink() { network.addLink(network.getFactory().createLink(f.linkIds[18], node2, node10)); network.addLink(network.getFactory().createLink(f.linkIds[19], node3, node10)); - Assert.assertEquals("wrong number of links.", 14, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 10, network.getNodes().size()); + Assertions.assertEquals(14, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(10, network.getNodes().size(), "wrong number of nodes."); MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); cleaner.run(createHashSet(TransportMode.car, TransportMode.walk)); - Assert.assertEquals("wrong number of links.", 12, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 9, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[9]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[10]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[11]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[12]).getAllowedModes()); + Assertions.assertEquals(12, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(9, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[9]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[10]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[11]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[12]).getAllowedModes()); } @Test @@ -475,26 +475,26 @@ void testRun_multipleModes_doubleSource() { network.addLink(network.getFactory().createLink(f.linkIds[18], node10, node2)); network.addLink(network.getFactory().createLink(f.linkIds[19], node10, node3)); - Assert.assertEquals("wrong number of links.", 14, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 10, network.getNodes().size()); + Assertions.assertEquals(14, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(10, network.getNodes().size(), "wrong number of nodes."); MultimodalNetworkCleaner cleaner = new MultimodalNetworkCleaner(network); cleaner.run(createHashSet(TransportMode.car, TransportMode.walk)); - Assert.assertEquals("wrong number of links.", 12, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 9, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[9]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[10]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[11]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[12]).getAllowedModes()); + Assertions.assertEquals(12, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(9, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[9]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[10]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[11]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[12]).getAllowedModes()); } @Test @@ -506,16 +506,16 @@ void testRun_emptyModes() { cleaner.run(new HashSet()); // nothing should have changed from the initialization - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); } @Test @@ -527,16 +527,16 @@ void testRun_unknownMode() { cleaner.run(Collections.singleton(TransportMode.pt)); // nothing should have changed from the initialization - Assert.assertEquals("wrong number of links.", 8, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 6, network.getNodes().size()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(8, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(6, network.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, network.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesW, network.getLinks().get(f.linkIds[8]).getAllowedModes()); } @Test @@ -560,19 +560,19 @@ void testRun_singleLinkNetwork() { /* a single link is no complete network, as the link's * from-node cannot be reached by the link's to-node * */ - Assert.assertEquals("wrong number of links.", 0, network.getLinks().size()); - Assert.assertEquals("wrong number of nodes.", 0, network.getNodes().size()); + Assertions.assertEquals(0, network.getLinks().size(), "wrong number of links."); + Assertions.assertEquals(0, network.getNodes().size(), "wrong number of nodes."); } @Test void testRun_singleModeWithConnectivity() { MultimodalFixture2 f = new MultimodalFixture2(); Network network = f.scenario.getNetwork(); - Assert.assertEquals(6, network.getNodes().size()); - Assert.assertEquals(8, network.getLinks().size()); + Assertions.assertEquals(6, network.getNodes().size()); + Assertions.assertEquals(8, network.getLinks().size()); new MultimodalNetworkCleaner(network).run(Collections.singleton(TransportMode.walk), Collections.singleton(TransportMode.pt)); - Assert.assertEquals(6, network.getNodes().size()); - Assert.assertEquals(8, network.getLinks().size()); + Assertions.assertEquals(6, network.getNodes().size()); + Assertions.assertEquals(8, network.getLinks().size()); } @Test @@ -588,11 +588,11 @@ void testRun_withConnectivity_connectedSource() { network.addLink(nf.createLink(f.linkIds[11], node7, node5)); network.getLinks().get(f.linkIds[10]).setAllowedModes(f.modesT); network.getLinks().get(f.linkIds[11]).setAllowedModes(f.modesW); - Assert.assertEquals(7, network.getNodes().size()); - Assert.assertEquals(10, network.getLinks().size()); + Assertions.assertEquals(7, network.getNodes().size()); + Assertions.assertEquals(10, network.getLinks().size()); new MultimodalNetworkCleaner(network).run(Collections.singleton(TransportMode.walk), Collections.singleton(TransportMode.pt)); - Assert.assertEquals(7, network.getNodes().size()); - Assert.assertEquals(10, network.getLinks().size()); + Assertions.assertEquals(7, network.getNodes().size()); + Assertions.assertEquals(10, network.getLinks().size()); } @Test @@ -608,11 +608,11 @@ void testRun_withConnectivity_connectedSink() { network.addLink(nf.createLink(f.linkIds[11], node7, node5)); network.getLinks().get(f.linkIds[10]).setAllowedModes(f.modesW); network.getLinks().get(f.linkIds[11]).setAllowedModes(f.modesT); - Assert.assertEquals(7, network.getNodes().size()); - Assert.assertEquals(10, network.getLinks().size()); + Assertions.assertEquals(7, network.getNodes().size()); + Assertions.assertEquals(10, network.getLinks().size()); new MultimodalNetworkCleaner(network).run(Collections.singleton(TransportMode.walk), Collections.singleton(TransportMode.pt)); - Assert.assertEquals(7, network.getNodes().size()); - Assert.assertEquals(10, network.getLinks().size()); + Assertions.assertEquals(7, network.getNodes().size()); + Assertions.assertEquals(10, network.getLinks().size()); } @Test @@ -628,12 +628,12 @@ void testRun_withConnectivity_unconnectedSource() { network.addLink(nf.createLink(f.linkIds[11], node7, node5)); network.getLinks().get(f.linkIds[10]).setAllowedModes(Collections.singleton("bike")); network.getLinks().get(f.linkIds[11]).setAllowedModes(f.modesW); - Assert.assertEquals(7, network.getNodes().size()); - Assert.assertEquals(10, network.getLinks().size()); + Assertions.assertEquals(7, network.getNodes().size()); + Assertions.assertEquals(10, network.getLinks().size()); new MultimodalNetworkCleaner(network).run(Collections.singleton(TransportMode.walk), Collections.singleton(TransportMode.pt)); - Assert.assertEquals(7, network.getNodes().size()); - Assert.assertEquals(9, network.getLinks().size()); - Assert.assertNull(network.getLinks().get(f.linkIds[11])); + Assertions.assertEquals(7, network.getNodes().size()); + Assertions.assertEquals(9, network.getLinks().size()); + Assertions.assertNull(network.getLinks().get(f.linkIds[11])); } @Test @@ -649,12 +649,12 @@ void testRun_withConnectivity_unconnectedSink() { network.addLink(nf.createLink(f.linkIds[11], node7, node5)); network.getLinks().get(f.linkIds[10]).setAllowedModes(f.modesW); network.getLinks().get(f.linkIds[11]).setAllowedModes(Collections.singleton("bike")); - Assert.assertEquals(7, network.getNodes().size()); - Assert.assertEquals(10, network.getLinks().size()); + Assertions.assertEquals(7, network.getNodes().size()); + Assertions.assertEquals(10, network.getLinks().size()); new MultimodalNetworkCleaner(network).run(Collections.singleton(TransportMode.walk), Collections.singleton(TransportMode.pt)); - Assert.assertEquals(7, network.getNodes().size()); - Assert.assertEquals(9, network.getLinks().size()); - Assert.assertNull(network.getLinks().get(f.linkIds[10])); + Assertions.assertEquals(7, network.getNodes().size()); + Assertions.assertEquals(9, network.getLinks().size()); + Assertions.assertNull(network.getLinks().get(f.linkIds[10])); } @Test @@ -678,15 +678,15 @@ void testRun_withConnectivity_unconnectedLink() { network.addLink(nf.createLink(f.linkIds[13], node10, node9)); network.getLinks().get(f.linkIds[12]).setAllowedModes(f.modesW); network.getLinks().get(f.linkIds[13]).setAllowedModes(f.modesT); - Assert.assertEquals(10, network.getNodes().size()); - Assert.assertEquals(12, network.getLinks().size()); + Assertions.assertEquals(10, network.getNodes().size()); + Assertions.assertEquals(12, network.getLinks().size()); new MultimodalNetworkCleaner(network).run(Collections.singleton(TransportMode.walk), Collections.singleton(TransportMode.pt)); - Assert.assertEquals(8, network.getNodes().size()); - Assert.assertEquals(9, network.getLinks().size()); - Assert.assertNull(network.getLinks().get(f.linkIds[10])); - Assert.assertNull(network.getLinks().get(f.linkIds[11])); - Assert.assertNull(network.getLinks().get(f.linkIds[12])); - Assert.assertNotNull(network.getLinks().get(f.linkIds[13])); + Assertions.assertEquals(8, network.getNodes().size()); + Assertions.assertEquals(9, network.getLinks().size()); + Assertions.assertNull(network.getLinks().get(f.linkIds[10])); + Assertions.assertNull(network.getLinks().get(f.linkIds[11])); + Assertions.assertNull(network.getLinks().get(f.linkIds[12])); + Assertions.assertNotNull(network.getLinks().get(f.linkIds[13])); } /** diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkCleanerTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkCleanerTest.java index 82612458c85..db870267bcc 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkCleanerTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkCleanerTest.java @@ -20,7 +20,7 @@ package org.matsim.core.network.algorithms; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -65,14 +65,14 @@ void testSink() { NetworkUtils.createAndAddLink(network,Id.create("5", Link.class), fromNode4, toNode4, (double) 100, (double) 100, (double) 100, (double) 1 ); // link 5 is a sink / dead end! - assertEquals("# nodes", 5, network.getNodes().size()); - assertEquals("# links", 5, network.getLinks().size()); + assertEquals(5, network.getNodes().size(), "# nodes"); + assertEquals(5, network.getLinks().size(), "# links"); NetworkCleaner cleaner = new NetworkCleaner(); cleaner.run(network); - assertEquals("# nodes", 4, network.getNodes().size()); - assertEquals("# links", 4, network.getLinks().size()); + assertEquals(4, network.getNodes().size(), "# nodes"); + assertEquals(4, network.getLinks().size(), "# links"); } @Test @@ -104,14 +104,14 @@ void testDoubleSink() { NetworkUtils.createAndAddLink(network,Id.create("6", Link.class), fromNode5, toNode5, (double) 100, (double) 100, (double) 100, (double) 1 ); // link 5 is a sink / dead end! - assertEquals("# nodes", 5, network.getNodes().size()); - assertEquals("# links", 6, network.getLinks().size()); + assertEquals(5, network.getNodes().size(), "# nodes"); + assertEquals(6, network.getLinks().size(), "# links"); NetworkCleaner cleaner = new NetworkCleaner(); cleaner.run(network); - assertEquals("# nodes", 4, network.getNodes().size()); - assertEquals("# links", 4, network.getLinks().size()); + assertEquals(4, network.getNodes().size(), "# nodes"); + assertEquals(4, network.getLinks().size(), "# links"); } @Test @@ -140,14 +140,14 @@ void testSource() { NetworkUtils.createAndAddLink(network,Id.create("5", Link.class), fromNode4, toNode4, (double) 100, (double) 100, (double) 100, (double) 1 ); // link 5 is a source / dead end! - assertEquals("# nodes", 5, network.getNodes().size()); - assertEquals("# links", 5, network.getLinks().size()); + assertEquals(5, network.getNodes().size(), "# nodes"); + assertEquals(5, network.getLinks().size(), "# links"); NetworkCleaner cleaner = new NetworkCleaner(); cleaner.run(network); - assertEquals("# nodes", 4, network.getNodes().size()); - assertEquals("# links", 4, network.getLinks().size()); + assertEquals(4, network.getNodes().size(), "# nodes"); + assertEquals(4, network.getLinks().size(), "# links"); } @Test @@ -179,14 +179,14 @@ void testDoubleSource() { NetworkUtils.createAndAddLink(network,Id.create("6", Link.class), fromNode5, toNode5, (double) 100, (double) 100, (double) 100, (double) 1 ); // link 5 is a source / dead end! - assertEquals("# nodes", 5, network.getNodes().size()); - assertEquals("# links", 6, network.getLinks().size()); + assertEquals(5, network.getNodes().size(), "# nodes"); + assertEquals(6, network.getLinks().size(), "# links"); NetworkCleaner cleaner = new NetworkCleaner(); cleaner.run(network); - assertEquals("# nodes", 4, network.getNodes().size()); - assertEquals("# links", 4, network.getLinks().size()); + assertEquals(4, network.getNodes().size(), "# nodes"); + assertEquals(4, network.getLinks().size(), "# links"); } } diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkExpandNodeTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkExpandNodeTest.java index 582e14d9a15..fde53bf90fc 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkExpandNodeTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkExpandNodeTest.java @@ -23,7 +23,7 @@ import java.util.HashSet; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -57,98 +57,98 @@ void testExpandNode() { exp.expandNode(Id.create("3", Node.class), turns); Network n = f.scenario.getNetwork(); - Assert.assertEquals(12, n.getLinks().size()); - Assert.assertEquals(10, n.getNodes().size()); - Assert.assertNotNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("6", Link.class))); - Assert.assertNotNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("6", Link.class))); - Assert.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("2", Link.class))); - Assert.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("4", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("2", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("4", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("2", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("4", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("6", Link.class))); + Assertions.assertEquals(12, n.getLinks().size()); + Assertions.assertEquals(10, n.getNodes().size()); + Assertions.assertNotNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("6", Link.class))); + Assertions.assertNotNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("6", Link.class))); + Assertions.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("2", Link.class))); + Assertions.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("4", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("2", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("4", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("2", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("4", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("6", Link.class))); // test correct attributes on new links Link l = findLinkBetween(n, Id.create("1", Link.class), Id.create("6", Link.class)); - Assert.assertEquals("Capacity attribute is not correct", 1800.0, l.getCapacity(), 1e-8); - Assert.assertEquals("Number of lanes is not correct", 2.0, l.getNumberOfLanes(), 1e-8); - Assert.assertEquals("Freespeed is not correct", 10.0, l.getFreespeed(), 1e-8); + Assertions.assertEquals(1800.0, l.getCapacity(), 1e-8, "Capacity attribute is not correct"); + Assertions.assertEquals(2.0, l.getNumberOfLanes(), 1e-8, "Number of lanes is not correct"); + Assertions.assertEquals(10.0, l.getFreespeed(), 1e-8, "Freespeed is not correct"); Set modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 2, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); - Assert.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertEquals(2, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertTrue(modes.contains(TransportMode.car)); // test correct attributes on modified in-links l = n.getLinks().get(Id.create("3", Link.class)); - Assert.assertEquals("Capacity attribute is not correct", 1800.0, l.getCapacity(), 1e-8); - Assert.assertEquals("Number of lanes is not correct", 2.0, l.getNumberOfLanes(), 1e-8); - Assert.assertEquals("Freespeed is not correct", 10.0, l.getFreespeed(), 1e-8); + Assertions.assertEquals(1800.0, l.getCapacity(), 1e-8, "Capacity attribute is not correct"); + Assertions.assertEquals(2.0, l.getNumberOfLanes(), 1e-8, "Number of lanes is not correct"); + Assertions.assertEquals(10.0, l.getFreespeed(), 1e-8, "Freespeed is not correct"); modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 2, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); - Assert.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertEquals(2, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertTrue(modes.contains(TransportMode.car)); // test correct attributes on modified out-links l = n.getLinks().get(Id.create("6", Link.class)); - Assert.assertEquals("Capacity attribute is not correct", 1800.0, l.getCapacity(), 1e-8); - Assert.assertEquals("Number of lanes is not correct", 2.0, l.getNumberOfLanes(), 1e-8); - Assert.assertEquals("Freespeed is not correct", 10.0, l.getFreespeed(), 1e-8); + Assertions.assertEquals(1800.0, l.getCapacity(), 1e-8, "Capacity attribute is not correct"); + Assertions.assertEquals(2.0, l.getNumberOfLanes(), 1e-8, "Number of lanes is not correct"); + Assertions.assertEquals(10.0, l.getFreespeed(), 1e-8, "Freespeed is not correct"); modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 2, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); - Assert.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertEquals(2, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertTrue(modes.contains(TransportMode.car)); // test coordinates of new nodes l = n.getLinks().get(Id.create("1", Link.class)); Coord c = l.getToNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("2", Link.class)); c = l.getFromNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("3", Link.class)); c = l.getToNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("4", Link.class)); c = l.getFromNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("5", Link.class)); c = l.getToNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("6", Link.class)); c = l.getFromNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); } @Test @@ -169,98 +169,98 @@ void testExpandNode_sameCoordinateLinks() { exp.expandNode(Id.create("3", Node.class), turns); Network n = f.scenario.getNetwork(); - Assert.assertEquals(12, n.getLinks().size()); - Assert.assertEquals(10, n.getNodes().size()); - Assert.assertNotNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("6", Link.class))); - Assert.assertNotNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("6", Link.class))); - Assert.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("2", Link.class))); - Assert.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("4", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("2", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("4", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("2", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("4", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("6", Link.class))); + Assertions.assertEquals(12, n.getLinks().size()); + Assertions.assertEquals(10, n.getNodes().size()); + Assertions.assertNotNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("6", Link.class))); + Assertions.assertNotNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("6", Link.class))); + Assertions.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("2", Link.class))); + Assertions.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("4", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("2", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("4", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("2", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("4", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("6", Link.class))); // test correct attributes on new links Link l = findLinkBetween(n, Id.create("1", Link.class), Id.create("6", Link.class)); - Assert.assertEquals("Capacity attribute is not correct", 1800.0, l.getCapacity(), 1e-8); - Assert.assertEquals("Number of lanes is not correct", 2.0, l.getNumberOfLanes(), 1e-8); - Assert.assertEquals("Freespeed is not correct", 10.0, l.getFreespeed(), 1e-8); + Assertions.assertEquals(1800.0, l.getCapacity(), 1e-8, "Capacity attribute is not correct"); + Assertions.assertEquals(2.0, l.getNumberOfLanes(), 1e-8, "Number of lanes is not correct"); + Assertions.assertEquals(10.0, l.getFreespeed(), 1e-8, "Freespeed is not correct"); Set modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 2, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); - Assert.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertEquals(2, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertTrue(modes.contains(TransportMode.car)); // test correct attributes on modified in-links l = n.getLinks().get(Id.create("3", Link.class)); - Assert.assertEquals("Capacity attribute is not correct", 1800.0, l.getCapacity(), 1e-8); - Assert.assertEquals("Number of lanes is not correct", 2.0, l.getNumberOfLanes(), 1e-8); - Assert.assertEquals("Freespeed is not correct", 10.0, l.getFreespeed(), 1e-8); + Assertions.assertEquals(1800.0, l.getCapacity(), 1e-8, "Capacity attribute is not correct"); + Assertions.assertEquals(2.0, l.getNumberOfLanes(), 1e-8, "Number of lanes is not correct"); + Assertions.assertEquals(10.0, l.getFreespeed(), 1e-8, "Freespeed is not correct"); modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 2, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); - Assert.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertEquals(2, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertTrue(modes.contains(TransportMode.car)); // test correct attributes on modified out-links l = n.getLinks().get(Id.create("6", Link.class)); - Assert.assertEquals("Capacity attribute is not correct", 1800.0, l.getCapacity(), 1e-8); - Assert.assertEquals("Number of lanes is not correct", 2.0, l.getNumberOfLanes(), 1e-8); - Assert.assertEquals("Freespeed is not correct", 10.0, l.getFreespeed(), 1e-8); + Assertions.assertEquals(1800.0, l.getCapacity(), 1e-8, "Capacity attribute is not correct"); + Assertions.assertEquals(2.0, l.getNumberOfLanes(), 1e-8, "Number of lanes is not correct"); + Assertions.assertEquals(10.0, l.getFreespeed(), 1e-8, "Freespeed is not correct"); modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 2, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); - Assert.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertEquals(2, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertTrue(modes.contains(TransportMode.car)); // test coordinates of new nodes l = n.getLinks().get(Id.create("1", Link.class)); c = l.getToNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("2", Link.class)); c = l.getFromNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("3", Link.class)); c = l.getToNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("4", Link.class)); c = l.getFromNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("5", Link.class)); c = l.getToNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("6", Link.class)); c = l.getFromNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); } @Test @@ -282,108 +282,108 @@ void testExpandNode_specificModes() { exp.expandNode(Id.create("3", Node.class), turns); Network n = f.scenario.getNetwork(); - Assert.assertEquals(12, n.getLinks().size()); - Assert.assertEquals(10, n.getNodes().size()); - Assert.assertNotNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("6", Link.class))); - Assert.assertNotNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("6", Link.class))); - Assert.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("2", Link.class))); - Assert.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("4", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("2", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("4", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("2", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("4", Link.class))); - Assert.assertNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("6", Link.class))); + Assertions.assertEquals(12, n.getLinks().size()); + Assertions.assertEquals(10, n.getNodes().size()); + Assertions.assertNotNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("6", Link.class))); + Assertions.assertNotNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("6", Link.class))); + Assertions.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("2", Link.class))); + Assertions.assertNotNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("4", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("2", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("1", Link.class), Id.create("4", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("2", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("3", Link.class), Id.create("4", Link.class))); + Assertions.assertNull(findLinkBetween(n, Id.create("5", Link.class), Id.create("6", Link.class))); // test correct attributes on new links Link l = findLinkBetween(n, Id.create("1", Link.class), Id.create("6", Link.class)); - Assert.assertEquals("Capacity attribute is not correct", 1800.0, l.getCapacity(), 1e-8); - Assert.assertEquals("Number of lanes is not correct", 2.0, l.getNumberOfLanes(), 1e-8); - Assert.assertEquals("Freespeed is not correct", 10.0, l.getFreespeed(), 1e-8); + Assertions.assertEquals(1800.0, l.getCapacity(), 1e-8, "Capacity attribute is not correct"); + Assertions.assertEquals(2.0, l.getNumberOfLanes(), 1e-8, "Number of lanes is not correct"); + Assertions.assertEquals(10.0, l.getFreespeed(), 1e-8, "Freespeed is not correct"); Set modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 2, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); - Assert.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertEquals(2, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertTrue(modes.contains(TransportMode.car)); l = findLinkBetween(n, Id.create("5", Link.class), Id.create("2", Link.class)); modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 1, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertEquals(1, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); l = findLinkBetween(n, Id.create("5", Link.class), Id.create("4", Link.class)); modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 1, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertEquals(1, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.car)); // test correct attributes on modified in-links l = n.getLinks().get(Id.create("3", Link.class)); - Assert.assertEquals("Capacity attribute is not correct", 1800.0, l.getCapacity(), 1e-8); - Assert.assertEquals("Number of lanes is not correct", 2.0, l.getNumberOfLanes(), 1e-8); - Assert.assertEquals("Freespeed is not correct", 10.0, l.getFreespeed(), 1e-8); + Assertions.assertEquals(1800.0, l.getCapacity(), 1e-8, "Capacity attribute is not correct"); + Assertions.assertEquals(2.0, l.getNumberOfLanes(), 1e-8, "Number of lanes is not correct"); + Assertions.assertEquals(10.0, l.getFreespeed(), 1e-8, "Freespeed is not correct"); modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 2, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); - Assert.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertEquals(2, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertTrue(modes.contains(TransportMode.car)); // test correct attributes on modified out-links l = n.getLinks().get(Id.create("6", Link.class)); - Assert.assertEquals("Capacity attribute is not correct", 1800.0, l.getCapacity(), 1e-8); - Assert.assertEquals("Number of lanes is not correct", 2.0, l.getNumberOfLanes(), 1e-8); - Assert.assertEquals("Freespeed is not correct", 10.0, l.getFreespeed(), 1e-8); + Assertions.assertEquals(1800.0, l.getCapacity(), 1e-8, "Capacity attribute is not correct"); + Assertions.assertEquals(2.0, l.getNumberOfLanes(), 1e-8, "Number of lanes is not correct"); + Assertions.assertEquals(10.0, l.getFreespeed(), 1e-8, "Freespeed is not correct"); modes = l.getAllowedModes(); - Assert.assertEquals("Allowed modes are not correct", 2, modes.size()); - Assert.assertTrue(modes.contains(TransportMode.walk)); - Assert.assertTrue(modes.contains(TransportMode.car)); + Assertions.assertEquals(2, modes.size(), "Allowed modes are not correct"); + Assertions.assertTrue(modes.contains(TransportMode.walk)); + Assertions.assertTrue(modes.contains(TransportMode.car)); // test coordinates of new nodes l = n.getLinks().get(Id.create("1", Link.class)); Coord c = l.getToNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("2", Link.class)); c = l.getFromNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("3", Link.class)); c = l.getToNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("4", Link.class)); c = l.getFromNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("5", Link.class)); c = l.getToNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); l = n.getLinks().get(Id.create("6", Link.class)); c = l.getFromNode().getCoord(); - Assert.assertFalse(Double.isNaN(c.getX())); - Assert.assertFalse(Double.isNaN(c.getY())); - Assert.assertFalse(Double.isInfinite(c.getX())); - Assert.assertFalse(Double.isInfinite(c.getY())); - Assert.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); + Assertions.assertFalse(Double.isNaN(c.getX())); + Assertions.assertFalse(Double.isNaN(c.getY())); + Assertions.assertFalse(Double.isInfinite(c.getX())); + Assertions.assertFalse(Double.isInfinite(c.getY())); + Assertions.assertTrue(CoordUtils.calcEuclideanDistance(c, new Coord((double) 1000, (double) 0)) < 30); } @Test @@ -408,7 +408,7 @@ void testTurnsAreSameAsSingleNode_IncludeUTurns() { turns.add(new TurnInfo(Id.create("5", Link.class), Id.create("4", Link.class), carOnly)); Id nodeId = Id.create("3", Node.class); - Assert.assertFalse(exp.turnsAreSameAsSingleNode(nodeId, turns, false)); + Assertions.assertFalse(exp.turnsAreSameAsSingleNode(nodeId, turns, false)); turns.clear(); turns.add(new TurnInfo(Id.create("1", Link.class), Id.create("2", Link.class))); @@ -421,7 +421,7 @@ void testTurnsAreSameAsSingleNode_IncludeUTurns() { turns.add(new TurnInfo(Id.create("5", Link.class), Id.create("4", Link.class))); turns.add(new TurnInfo(Id.create("5", Link.class), Id.create("6", Link.class))); - Assert.assertTrue(exp.turnsAreSameAsSingleNode(nodeId, turns, false)); + Assertions.assertTrue(exp.turnsAreSameAsSingleNode(nodeId, turns, false)); } @Test @@ -447,7 +447,7 @@ void testTurnsAreSameAsSingleNode_IgnoreUTurns() { turns.add(new TurnInfo(Id.create("5", Link.class), Id.create("4", Link.class), carOnly)); Id nodeId = Id.create("3", Node.class); - Assert.assertFalse(exp.turnsAreSameAsSingleNode(nodeId, turns, true)); + Assertions.assertFalse(exp.turnsAreSameAsSingleNode(nodeId, turns, true)); turns.clear(); turns.add(new TurnInfo(Id.create("1", Link.class), Id.create("2", Link.class))); // u-turn @@ -460,7 +460,7 @@ void testTurnsAreSameAsSingleNode_IgnoreUTurns() { turns.add(new TurnInfo(Id.create("5", Link.class), Id.create("4", Link.class))); turns.add(new TurnInfo(Id.create("5", Link.class), Id.create("6", Link.class), emptySet)); // u-turn - Assert.assertTrue(exp.turnsAreSameAsSingleNode(nodeId, turns, true)); + Assertions.assertTrue(exp.turnsAreSameAsSingleNode(nodeId, turns, true)); } @Test @@ -481,22 +481,22 @@ void testTurnInfo_equals() { TurnInfo ti22 = new TurnInfo(id1, id2, modes1); TurnInfo ti44 = new TurnInfo(id2, id1); - Assert.assertNotNull(ti1); - Assert.assertFalse(ti1.equals(ti2)); - Assert.assertFalse(ti1.equals(ti3)); - Assert.assertFalse(ti1.equals(ti4)); - Assert.assertFalse(ti1.equals(ti5)); - Assert.assertFalse(ti1.equals(ti6)); - - Assert.assertNotNull(ti2); - Assert.assertFalse(ti2.equals(ti1)); - Assert.assertFalse(ti2.equals(ti3)); - Assert.assertFalse(ti2.equals(ti4)); - Assert.assertFalse(ti2.equals(ti5)); - Assert.assertFalse(ti2.equals(ti6)); - - Assert.assertTrue(ti2.equals(ti22)); - Assert.assertTrue(ti4.equals(ti44)); + Assertions.assertNotNull(ti1); + Assertions.assertFalse(ti1.equals(ti2)); + Assertions.assertFalse(ti1.equals(ti3)); + Assertions.assertFalse(ti1.equals(ti4)); + Assertions.assertFalse(ti1.equals(ti5)); + Assertions.assertFalse(ti1.equals(ti6)); + + Assertions.assertNotNull(ti2); + Assertions.assertFalse(ti2.equals(ti1)); + Assertions.assertFalse(ti2.equals(ti3)); + Assertions.assertFalse(ti2.equals(ti4)); + Assertions.assertFalse(ti2.equals(ti5)); + Assertions.assertFalse(ti2.equals(ti6)); + + Assertions.assertTrue(ti2.equals(ti22)); + Assertions.assertTrue(ti4.equals(ti44)); } private static Link findLinkBetween(final Network network, final Id fromLinkId, final Id toLinkId) { diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkMergeDoubleLinksTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkMergeDoubleLinksTest.java index c5d32dbbc18..89e8564f44d 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkMergeDoubleLinksTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkMergeDoubleLinksTest.java @@ -19,7 +19,7 @@ package org.matsim.core.network.algorithms; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -43,29 +43,29 @@ void testRun_remove() { NetworkMergeDoubleLinks merger = new NetworkMergeDoubleLinks(NetworkMergeDoubleLinks.MergeType.REMOVE); merger.run(f.network); - Assert.assertEquals("wrong number of links.", 3, f.network.getLinks().size()); - Assert.assertNotNull(f.network.getLinks().get(f.linkIds[0])); - Assert.assertNull(f.network.getLinks().get(f.linkIds[10])); - Assert.assertNotNull(f.network.getLinks().get(f.linkIds[1])); - Assert.assertNull(f.network.getLinks().get(f.linkIds[11])); - Assert.assertNotNull(f.network.getLinks().get(f.linkIds[2])); - Assert.assertNull(f.network.getLinks().get(f.linkIds[12])); + Assertions.assertEquals(3, f.network.getLinks().size(), "wrong number of links."); + Assertions.assertNotNull(f.network.getLinks().get(f.linkIds[0])); + Assertions.assertNull(f.network.getLinks().get(f.linkIds[10])); + Assertions.assertNotNull(f.network.getLinks().get(f.linkIds[1])); + Assertions.assertNull(f.network.getLinks().get(f.linkIds[11])); + Assertions.assertNotNull(f.network.getLinks().get(f.linkIds[2])); + Assertions.assertNull(f.network.getLinks().get(f.linkIds[12])); // attributes should be unchanged - Assert.assertEquals(100.0, f.network.getLinks().get(f.linkIds[0]).getLength(), MatsimTestUtils.EPSILON); - Assert.assertEquals(200.0, f.network.getLinks().get(f.linkIds[0]).getCapacity(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1, f.network.getLinks().get(f.linkIds[0]).getNumberOfLanes(), MatsimTestUtils.EPSILON); - Assert.assertEquals(30.0/3.6, f.network.getLinks().get(f.linkIds[0]).getFreespeed(), MatsimTestUtils.EPSILON); - - Assert.assertEquals(500.0, f.network.getLinks().get(f.linkIds[1]).getLength(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2000.0, f.network.getLinks().get(f.linkIds[1]).getCapacity(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, f.network.getLinks().get(f.linkIds[1]).getNumberOfLanes(), MatsimTestUtils.EPSILON); - Assert.assertEquals(70.0/3.6, f.network.getLinks().get(f.linkIds[1]).getFreespeed(), MatsimTestUtils.EPSILON); - - Assert.assertEquals(700.0, f.network.getLinks().get(f.linkIds[2]).getLength(), MatsimTestUtils.EPSILON); - Assert.assertEquals(500.0, f.network.getLinks().get(f.linkIds[2]).getCapacity(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, f.network.getLinks().get(f.linkIds[2]).getNumberOfLanes(), MatsimTestUtils.EPSILON); - Assert.assertEquals(50.0/3.6, f.network.getLinks().get(f.linkIds[2]).getFreespeed(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(100.0, f.network.getLinks().get(f.linkIds[0]).getLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(200.0, f.network.getLinks().get(f.linkIds[0]).getCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, f.network.getLinks().get(f.linkIds[0]).getNumberOfLanes(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(30.0/3.6, f.network.getLinks().get(f.linkIds[0]).getFreespeed(), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(500.0, f.network.getLinks().get(f.linkIds[1]).getLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2000.0, f.network.getLinks().get(f.linkIds[1]).getCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, f.network.getLinks().get(f.linkIds[1]).getNumberOfLanes(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(70.0/3.6, f.network.getLinks().get(f.linkIds[1]).getFreespeed(), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(700.0, f.network.getLinks().get(f.linkIds[2]).getLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(500.0, f.network.getLinks().get(f.linkIds[2]).getCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, f.network.getLinks().get(f.linkIds[2]).getNumberOfLanes(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(50.0/3.6, f.network.getLinks().get(f.linkIds[2]).getFreespeed(), MatsimTestUtils.EPSILON); } @Test @@ -74,29 +74,29 @@ void testRun_additive() { NetworkMergeDoubleLinks merger = new NetworkMergeDoubleLinks(NetworkMergeDoubleLinks.MergeType.ADDITIVE); merger.run(f.network); - Assert.assertEquals("wrong number of links.", 3, f.network.getLinks().size()); - Assert.assertNotNull(f.network.getLinks().get(f.linkIds[0])); - Assert.assertNull(f.network.getLinks().get(f.linkIds[10])); - Assert.assertNotNull(f.network.getLinks().get(f.linkIds[1])); - Assert.assertNull(f.network.getLinks().get(f.linkIds[11])); - Assert.assertNotNull(f.network.getLinks().get(f.linkIds[2])); - Assert.assertNull(f.network.getLinks().get(f.linkIds[12])); + Assertions.assertEquals(3, f.network.getLinks().size(), "wrong number of links."); + Assertions.assertNotNull(f.network.getLinks().get(f.linkIds[0])); + Assertions.assertNull(f.network.getLinks().get(f.linkIds[10])); + Assertions.assertNotNull(f.network.getLinks().get(f.linkIds[1])); + Assertions.assertNull(f.network.getLinks().get(f.linkIds[11])); + Assertions.assertNotNull(f.network.getLinks().get(f.linkIds[2])); + Assertions.assertNull(f.network.getLinks().get(f.linkIds[12])); // additive merge (sum cap, max freespeed, sum lanes, max length) - Assert.assertEquals(500.0, f.network.getLinks().get(f.linkIds[0]).getLength(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2200.0, f.network.getLinks().get(f.linkIds[0]).getCapacity(), MatsimTestUtils.EPSILON); - Assert.assertEquals(3, f.network.getLinks().get(f.linkIds[0]).getNumberOfLanes(), MatsimTestUtils.EPSILON); - Assert.assertEquals(70.0/3.6, f.network.getLinks().get(f.linkIds[0]).getFreespeed(), MatsimTestUtils.EPSILON); - - Assert.assertEquals(500.0, f.network.getLinks().get(f.linkIds[1]).getLength(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2200.0, f.network.getLinks().get(f.linkIds[1]).getCapacity(), MatsimTestUtils.EPSILON); - Assert.assertEquals(3, f.network.getLinks().get(f.linkIds[1]).getNumberOfLanes(), MatsimTestUtils.EPSILON); - Assert.assertEquals(70.0/3.6, f.network.getLinks().get(f.linkIds[1]).getFreespeed(), MatsimTestUtils.EPSILON); - - Assert.assertEquals(700.0, f.network.getLinks().get(f.linkIds[2]).getLength(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1500.0, f.network.getLinks().get(f.linkIds[2]).getCapacity(), MatsimTestUtils.EPSILON); - Assert.assertEquals(3, f.network.getLinks().get(f.linkIds[2]).getNumberOfLanes(), MatsimTestUtils.EPSILON); - Assert.assertEquals(80.0/3.6, f.network.getLinks().get(f.linkIds[2]).getFreespeed(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(500.0, f.network.getLinks().get(f.linkIds[0]).getLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2200.0, f.network.getLinks().get(f.linkIds[0]).getCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, f.network.getLinks().get(f.linkIds[0]).getNumberOfLanes(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(70.0/3.6, f.network.getLinks().get(f.linkIds[0]).getFreespeed(), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(500.0, f.network.getLinks().get(f.linkIds[1]).getLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2200.0, f.network.getLinks().get(f.linkIds[1]).getCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, f.network.getLinks().get(f.linkIds[1]).getNumberOfLanes(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(70.0/3.6, f.network.getLinks().get(f.linkIds[1]).getFreespeed(), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(700.0, f.network.getLinks().get(f.linkIds[2]).getLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1500.0, f.network.getLinks().get(f.linkIds[2]).getCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(3, f.network.getLinks().get(f.linkIds[2]).getNumberOfLanes(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(80.0/3.6, f.network.getLinks().get(f.linkIds[2]).getFreespeed(), MatsimTestUtils.EPSILON); } @Test @@ -105,29 +105,29 @@ void testRun_maximum() { NetworkMergeDoubleLinks merger = new NetworkMergeDoubleLinks(NetworkMergeDoubleLinks.MergeType.MAXIMUM); merger.run(f.network); - Assert.assertEquals("wrong number of links.", 3, f.network.getLinks().size()); - Assert.assertNotNull(f.network.getLinks().get(f.linkIds[0])); - Assert.assertNull(f.network.getLinks().get(f.linkIds[10])); - Assert.assertNotNull(f.network.getLinks().get(f.linkIds[1])); - Assert.assertNull(f.network.getLinks().get(f.linkIds[11])); - Assert.assertNotNull(f.network.getLinks().get(f.linkIds[2])); - Assert.assertNull(f.network.getLinks().get(f.linkIds[12])); + Assertions.assertEquals(3, f.network.getLinks().size(), "wrong number of links."); + Assertions.assertNotNull(f.network.getLinks().get(f.linkIds[0])); + Assertions.assertNull(f.network.getLinks().get(f.linkIds[10])); + Assertions.assertNotNull(f.network.getLinks().get(f.linkIds[1])); + Assertions.assertNull(f.network.getLinks().get(f.linkIds[11])); + Assertions.assertNotNull(f.network.getLinks().get(f.linkIds[2])); + Assertions.assertNull(f.network.getLinks().get(f.linkIds[12])); // max merge (max cap, max freespeed, max langes, max length - Assert.assertEquals(500.0, f.network.getLinks().get(f.linkIds[0]).getLength(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2000.0, f.network.getLinks().get(f.linkIds[0]).getCapacity(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, f.network.getLinks().get(f.linkIds[0]).getNumberOfLanes(), MatsimTestUtils.EPSILON); - Assert.assertEquals(70.0/3.6, f.network.getLinks().get(f.linkIds[0]).getFreespeed(), MatsimTestUtils.EPSILON); - - Assert.assertEquals(500.0, f.network.getLinks().get(f.linkIds[1]).getLength(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2000.0, f.network.getLinks().get(f.linkIds[1]).getCapacity(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, f.network.getLinks().get(f.linkIds[1]).getNumberOfLanes(), MatsimTestUtils.EPSILON); - Assert.assertEquals(70.0/3.6, f.network.getLinks().get(f.linkIds[1]).getFreespeed(), MatsimTestUtils.EPSILON); - - Assert.assertEquals(700.0, f.network.getLinks().get(f.linkIds[2]).getLength(), MatsimTestUtils.EPSILON); - Assert.assertEquals(1000.0, f.network.getLinks().get(f.linkIds[2]).getCapacity(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2, f.network.getLinks().get(f.linkIds[2]).getNumberOfLanes(), MatsimTestUtils.EPSILON); - Assert.assertEquals(80.0/3.6, f.network.getLinks().get(f.linkIds[2]).getFreespeed(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(500.0, f.network.getLinks().get(f.linkIds[0]).getLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2000.0, f.network.getLinks().get(f.linkIds[0]).getCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, f.network.getLinks().get(f.linkIds[0]).getNumberOfLanes(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(70.0/3.6, f.network.getLinks().get(f.linkIds[0]).getFreespeed(), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(500.0, f.network.getLinks().get(f.linkIds[1]).getLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2000.0, f.network.getLinks().get(f.linkIds[1]).getCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, f.network.getLinks().get(f.linkIds[1]).getNumberOfLanes(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(70.0/3.6, f.network.getLinks().get(f.linkIds[1]).getFreespeed(), MatsimTestUtils.EPSILON); + + Assertions.assertEquals(700.0, f.network.getLinks().get(f.linkIds[2]).getLength(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1000.0, f.network.getLinks().get(f.linkIds[2]).getCapacity(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, f.network.getLinks().get(f.linkIds[2]).getNumberOfLanes(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(80.0/3.6, f.network.getLinks().get(f.linkIds[2]).getFreespeed(), MatsimTestUtils.EPSILON); } private static class Fixture { diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierPass2WayTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierPass2WayTest.java index 94feb8bcf41..af826adadc6 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierPass2WayTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierPass2WayTest.java @@ -19,8 +19,9 @@ package org.matsim.core.network.algorithms; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; + import java.util.ArrayList; import java.util.Arrays; import java.util.Collections; @@ -48,7 +49,7 @@ void testSimplifying(){ int counter = 0; for (Network network : networks) { System.out.println("Running simplifier on network "+counter); - assertEquals("Wrong number of links", 10, network.getLinks().size()); + assertEquals(10, network.getLinks().size(), "Wrong number of links"); NetworkSimplifier networkSimplifier = new NetworkSimplifier(); networkSimplifier.setMergeLinkStats(false); @@ -56,13 +57,13 @@ void testSimplifying(){ network.getLinks().values().stream().forEach(l ->System.out.println(l.toString())); - assertEquals("Wrong number of links", 4, network.getLinks().size()); - assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("AB-BC-CD-DE-EF"))); + assertEquals(4, network.getLinks().size(), "Wrong number of links"); + assertNotNull(network.getLinks().get(Id.createLinkId("AB-BC-CD-DE-EF")), "Expected link not found."); - assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("CB"))); - assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("BA"))); + assertNotNull(network.getLinks().get(Id.createLinkId("CB")), "Expected link not found."); + assertNotNull(network.getLinks().get(Id.createLinkId("BA")), "Expected link not found."); - assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("FE-ED-DC"))); + assertNotNull(network.getLinks().get(Id.createLinkId("FE-ED-DC")), "Expected link not found."); } diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java index 542823a3ad4..ae5d22abaf3 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java @@ -20,13 +20,13 @@ package org.matsim.core.network.algorithms; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; import java.util.Map; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -46,8 +46,8 @@ public void setUp() { @Test void testBuildNetwork() { Network network = buildNetwork(); - assertEquals("Wrong number of nodes.", 6, network.getNodes().size()); - assertEquals("Wrong number of links.", 5, network.getLinks().size()); + assertEquals(6, network.getNodes().size(), "Wrong number of nodes."); + assertEquals(5, network.getLinks().size(), "Wrong number of links."); } @Test @@ -56,10 +56,10 @@ void testRun() { NetworkSimplifier nst = new NetworkSimplifier(); nst.run(network, 20.0); - assertEquals("Wrong number of links", 3, network.getLinks().size()); - assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("AB-BC"))); - assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("CD"))); - assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("DE-EF"))); + assertEquals(3, network.getLinks().size(), "Wrong number of links"); + assertNotNull(network.getLinks().get(Id.createLinkId("AB-BC")), "Expected link not found."); + assertNotNull(network.getLinks().get(Id.createLinkId("CD")), "Expected link not found."); + assertNotNull(network.getLinks().get(Id.createLinkId("DE-EF")), "Expected link not found."); } @@ -70,18 +70,18 @@ void testRunMergeLinkStats() { NetworkSimplifier nst = new NetworkSimplifier(); nst.setMergeLinkStats(true); nst.run(network, 20.0); - assertEquals("Wrong number of links", 2, network.getLinks().size()); - assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("AB-BC"))); - assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("CD-DE-EF"))); + assertEquals(2, network.getLinks().size(), "Wrong number of links"); + assertNotNull(network.getLinks().get(Id.createLinkId("AB-BC")), "Expected link not found."); + assertNotNull(network.getLinks().get(Id.createLinkId("CD-DE-EF")), "Expected link not found."); network = buildNetwork(); nst.run(network, 40.0); - assertEquals("Wrong number of links", 1, network.getLinks().size()); - assertNotNull("Expected link not found.", network.getLinks().get(Id.createLinkId("AB-BC-CD-DE-EF"))); + assertEquals(1, network.getLinks().size(), "Wrong number of links"); + assertNotNull(network.getLinks().get(Id.createLinkId("AB-BC-CD-DE-EF")), "Expected link not found."); network = buildNetwork(); nst.run(network, 5.0); - assertEquals("Wrong number of links", 5, network.getLinks().size()); + assertEquals(5, network.getLinks().size(), "Wrong number of links"); } @Test @@ -166,37 +166,37 @@ void testDifferentAttributesPerDirection() { Id idHGGF = Id.create("HG-GF", Link.class); Id idFEED = Id.create("FE-ED", Link.class); - Assert.assertEquals("Wrong number of links.", 12, links.size()); - Assert.assertNotNull("Expected link not found.", links.get(idAC)); - Assert.assertNotNull("Expected link not found.", links.get(idCA)); - Assert.assertNotNull("Expected link not found.", links.get(idBC)); - Assert.assertNotNull("Expected link not found.", links.get(idCB)); - - Assert.assertNotNull("Expected link not found.", links.get(idHJ)); - Assert.assertNotNull("Expected link not found.", links.get(idJH)); - Assert.assertNotNull("Expected link not found.", links.get(idHK)); - Assert.assertNotNull("Expected link not found.", links.get(idKH)); - - Assert.assertNotNull("Expected link not found.", links.get(idCDDEEFFGGH)); - - Assert.assertNotNull("Expected link not found.", links.get(idHGGF)); - Assert.assertNotNull("Expected link not found.", links.get(idFEED)); - Assert.assertNotNull("Expected link not found.", links.get(idDC)); - - Assert.assertEquals(10.0, links.get(idAC).getLength(), 1e-8); - Assert.assertEquals(50.0, links.get(idCDDEEFFGGH).getLength(), 1e-8); - Assert.assertEquals(20.0, links.get(idHGGF).getLength(), 1e-8); - Assert.assertEquals(20.0, links.get(idFEED).getLength(), 1e-8); - - Assert.assertEquals(1000.0, links.get(idAC).getCapacity(), 1e-8); - Assert.assertEquals(2000.0, links.get(idCDDEEFFGGH).getCapacity(), 1e-8); - Assert.assertEquals(2000.0, links.get(idFEED).getCapacity(), 1e-8); - Assert.assertEquals(1000.0, links.get(idHGGF).getCapacity(), 1e-8); - - Assert.assertEquals(10.0, links.get(idAC).getFreespeed(), 1e-8); - Assert.assertEquals(10.0, links.get(idCDDEEFFGGH).getFreespeed(), 1e-8); - Assert.assertEquals(10.0, links.get(idHGGF).getFreespeed(), 1e-8); - Assert.assertEquals(10.0, links.get(idFEED).getFreespeed(), 1e-8); + Assertions.assertEquals(12, links.size(), "Wrong number of links."); + Assertions.assertNotNull(links.get(idAC), "Expected link not found."); + Assertions.assertNotNull(links.get(idCA), "Expected link not found."); + Assertions.assertNotNull(links.get(idBC), "Expected link not found."); + Assertions.assertNotNull(links.get(idCB), "Expected link not found."); + + Assertions.assertNotNull(links.get(idHJ), "Expected link not found."); + Assertions.assertNotNull(links.get(idJH), "Expected link not found."); + Assertions.assertNotNull(links.get(idHK), "Expected link not found."); + Assertions.assertNotNull(links.get(idKH), "Expected link not found."); + + Assertions.assertNotNull(links.get(idCDDEEFFGGH), "Expected link not found."); + + Assertions.assertNotNull(links.get(idHGGF), "Expected link not found."); + Assertions.assertNotNull(links.get(idFEED), "Expected link not found."); + Assertions.assertNotNull(links.get(idDC), "Expected link not found."); + + Assertions.assertEquals(10.0, links.get(idAC).getLength(), 1e-8); + Assertions.assertEquals(50.0, links.get(idCDDEEFFGGH).getLength(), 1e-8); + Assertions.assertEquals(20.0, links.get(idHGGF).getLength(), 1e-8); + Assertions.assertEquals(20.0, links.get(idFEED).getLength(), 1e-8); + + Assertions.assertEquals(1000.0, links.get(idAC).getCapacity(), 1e-8); + Assertions.assertEquals(2000.0, links.get(idCDDEEFFGGH).getCapacity(), 1e-8); + Assertions.assertEquals(2000.0, links.get(idFEED).getCapacity(), 1e-8); + Assertions.assertEquals(1000.0, links.get(idHGGF).getCapacity(), 1e-8); + + Assertions.assertEquals(10.0, links.get(idAC).getFreespeed(), 1e-8); + Assertions.assertEquals(10.0, links.get(idCDDEEFFGGH).getFreespeed(), 1e-8); + Assertions.assertEquals(10.0, links.get(idHGGF).getFreespeed(), 1e-8); + Assertions.assertEquals(10.0, links.get(idFEED).getFreespeed(), 1e-8); } diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/TransportModeNetworkFilterTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/TransportModeNetworkFilterTest.java index 1bfe470b9c8..a62e147d2f1 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/TransportModeNetworkFilterTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/TransportModeNetworkFilterTest.java @@ -23,7 +23,7 @@ import java.util.HashSet; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -55,89 +55,89 @@ void testFilter_SingleMode() { Network subNetwork = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); filter.filter(subNetwork, createHashSet(TransportMode.car)); - Assert.assertEquals("wrong number of nodes.", 13, subNetwork.getNodes().size()); - Assert.assertEquals("wrong number of links", 14, subNetwork.getLinks().size()); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[1])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[2])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[3])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[4])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[5])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[6])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[7])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[8])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[9])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[10])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[11])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[12])); - Assert.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[13])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[14])); - Assert.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[15])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[9]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[10]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[11]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[12]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[14]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().get(f.linkIds[3])); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[7]).getOutLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[7]).getOutLinks().get(f.linkIds[7])); + Assertions.assertEquals(13, subNetwork.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(14, subNetwork.getLinks().size(), "wrong number of links"); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[1])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[2])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[3])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[4])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[5])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[6])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[7])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[8])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[9])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[10])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[11])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[12])); + Assertions.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[13])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[14])); + Assertions.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[15])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[9]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[10]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[11]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[12]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[14]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().get(f.linkIds[3])); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[7]).getOutLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[7]).getOutLinks().get(f.linkIds[7])); subNetwork = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); filter.filter(subNetwork, createHashSet(TransportMode.bike)); - Assert.assertEquals("wrong number of nodes.", 9, subNetwork.getNodes().size()); - Assert.assertEquals("wrong number of links", 8, subNetwork.getLinks().size()); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[13])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[4])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[5])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[6])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[7])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[8])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[9])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[13]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[9]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().get(f.linkIds[13])); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().get(f.linkIds[4])); + Assertions.assertEquals(9, subNetwork.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(8, subNetwork.getLinks().size(), "wrong number of links"); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[13])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[4])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[5])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[6])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[7])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[8])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[9])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[13]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[9]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().get(f.linkIds[13])); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().get(f.linkIds[4])); subNetwork = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); filter.filter(subNetwork, createHashSet(TransportMode.walk)); - Assert.assertEquals("wrong number of nodes.", 5, subNetwork.getNodes().size()); - Assert.assertEquals("wrong number of links", 4, subNetwork.getLinks().size()); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[13])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[14])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[15])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); - Assert.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[1])); - Assert.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[4])); - Assert.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[7])); - Assert.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[10])); - Assert.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[13])); - Assert.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[13]).getAllowedModes()); - Assert.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[14]).getAllowedModes()); - Assert.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[15]).getAllowedModes()); - Assert.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().get(f.linkIds[13])); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().get(f.linkIds[14])); + Assertions.assertEquals(5, subNetwork.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(4, subNetwork.getLinks().size(), "wrong number of links"); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[13])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[14])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[15])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); + Assertions.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[1])); + Assertions.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[4])); + Assertions.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[7])); + Assertions.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[10])); + Assertions.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[13])); + Assertions.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[13]).getAllowedModes()); + Assertions.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[14]).getAllowedModes()); + Assertions.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[15]).getAllowedModes()); + Assertions.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().get(f.linkIds[13])); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().get(f.linkIds[14])); } @Test @@ -147,78 +147,78 @@ void testFilter_MultipleModes() { Network subNetwork = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); filter.filter(subNetwork, createHashSet(TransportMode.car, TransportMode.bike)); - Assert.assertEquals("wrong number of nodes.", 13, subNetwork.getNodes().size()); - Assert.assertEquals("wrong number of links", 15, subNetwork.getLinks().size()); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[1])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[2])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[3])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[4])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[5])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[6])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[7])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[8])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[9])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[10])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[11])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[12])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[13])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[14])); - Assert.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[15])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[1]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[2]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[3]).getAllowedModes()); - Assert.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[9]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[10]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[11]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[12]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[13]).getAllowedModes()); - Assert.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[14]).getAllowedModes()); - Assert.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[7]).getOutLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[7]).getOutLinks().get(f.linkIds[7])); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[10]).getInLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[10]).getInLinks().get(f.linkIds[9])); + Assertions.assertEquals(13, subNetwork.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(15, subNetwork.getLinks().size(), "wrong number of links"); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[1])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[2])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[3])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[4])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[5])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[6])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[7])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[8])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[9])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[10])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[11])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[12])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[13])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[14])); + Assertions.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[15])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[1]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[2]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[3]).getAllowedModes()); + Assertions.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[9]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[10]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[11]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[12]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[13]).getAllowedModes()); + Assertions.assertEquals(f.modesC, subNetwork.getLinks().get(f.linkIds[14]).getAllowedModes()); + Assertions.assertEquals(f.modesCB, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[7]).getOutLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[7]).getOutLinks().get(f.linkIds[7])); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[10]).getInLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[10]).getInLinks().get(f.linkIds[9])); subNetwork = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); filter.filter(subNetwork, createHashSet(TransportMode.bike, TransportMode.walk)); - Assert.assertEquals("wrong number of nodes.", 9, subNetwork.getNodes().size()); - Assert.assertEquals("wrong number of links", 10, subNetwork.getLinks().size()); - Assert.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[1])); - Assert.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[2])); - Assert.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[3])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[4])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[5])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[6])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[7])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[8])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[9])); - Assert.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[10])); - Assert.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[11])); - Assert.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[12])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[13])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[14])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[15])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[4]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[5]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[6]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[7]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[8]).getAllowedModes()); - Assert.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[9]).getAllowedModes()); - Assert.assertEquals(f.modesWB, subNetwork.getLinks().get(f.linkIds[13]).getAllowedModes()); - Assert.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[14]).getAllowedModes()); - Assert.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[15]).getAllowedModes()); - Assert.assertEquals(f.modesWB, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().get(f.linkIds[13])); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[10]).getOutLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[10]).getOutLinks().get(f.linkIds[16])); + Assertions.assertEquals(9, subNetwork.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(10, subNetwork.getLinks().size(), "wrong number of links"); + Assertions.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[1])); + Assertions.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[2])); + Assertions.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[3])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[4])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[5])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[6])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[7])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[8])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[9])); + Assertions.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[10])); + Assertions.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[11])); + Assertions.assertFalse(subNetwork.getLinks().containsKey(f.linkIds[12])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[13])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[14])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[15])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[4]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[5]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[6]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[7]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[8]).getAllowedModes()); + Assertions.assertEquals(f.modesB, subNetwork.getLinks().get(f.linkIds[9]).getAllowedModes()); + Assertions.assertEquals(f.modesWB, subNetwork.getLinks().get(f.linkIds[13]).getAllowedModes()); + Assertions.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[14]).getAllowedModes()); + Assertions.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[15]).getAllowedModes()); + Assertions.assertEquals(f.modesWB, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().get(f.linkIds[13])); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[10]).getOutLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[10]).getOutLinks().get(f.linkIds[16])); } @Test @@ -228,8 +228,8 @@ void testFilter_NoModes() { Network subNetwork = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); filter.filter(subNetwork, new HashSet()); - Assert.assertEquals("wrong number of nodes.", 0, subNetwork.getNodes().size()); - Assert.assertEquals("wrong number of links", 0, subNetwork.getLinks().size()); + Assertions.assertEquals(0, subNetwork.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(0, subNetwork.getLinks().size(), "wrong number of links"); } @Test @@ -239,25 +239,25 @@ void testFilter_AdditionalModes() { Network subNetwork = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); filter.filter(subNetwork, createHashSet(TransportMode.walk, TransportMode.pt, "motorbike")); - Assert.assertEquals("wrong number of nodes.", 5, subNetwork.getNodes().size()); - Assert.assertEquals("wrong number of links", 4, subNetwork.getLinks().size()); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[13])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[14])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[15])); - Assert.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); - Assert.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[1])); - Assert.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[4])); - Assert.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[7])); - Assert.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[10])); - Assert.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[13])); - Assert.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[13]).getAllowedModes()); - Assert.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[14]).getAllowedModes()); - Assert.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[15]).getAllowedModes()); - Assert.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().get(f.linkIds[13])); - Assert.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().size()); - Assert.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().get(f.linkIds[14])); + Assertions.assertEquals(5, subNetwork.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(4, subNetwork.getLinks().size(), "wrong number of links"); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[13])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[14])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[15])); + Assertions.assertTrue(subNetwork.getLinks().containsKey(f.linkIds[16])); + Assertions.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[1])); + Assertions.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[4])); + Assertions.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[7])); + Assertions.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[10])); + Assertions.assertTrue(subNetwork.getNodes().containsKey(f.nodeIds[13])); + Assertions.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[13]).getAllowedModes()); + Assertions.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[14]).getAllowedModes()); + Assertions.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[15]).getAllowedModes()); + Assertions.assertEquals(f.modesW, subNetwork.getLinks().get(f.linkIds[16]).getAllowedModes()); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getInLinks().get(f.linkIds[13])); + Assertions.assertEquals(1, subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().size()); + Assertions.assertNotNull(subNetwork.getNodes().get(f.nodeIds[4]).getOutLinks().get(f.linkIds[14])); } @Test @@ -267,8 +267,8 @@ void testFilter_NoCommonModes() { Network subNetwork = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); filter.filter(subNetwork, createHashSet(TransportMode.pt, "motorbike")); - Assert.assertEquals("wrong number of nodes.", 0, subNetwork.getNodes().size()); - Assert.assertEquals("wrong number of links", 0, subNetwork.getLinks().size()); + Assertions.assertEquals(0, subNetwork.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(0, subNetwork.getLinks().size(), "wrong number of links"); } /** @@ -298,9 +298,9 @@ void testFilter_SingleMode_loop() { Network subNetwork = ScenarioUtils.createScenario(ConfigUtils.createConfig()).getNetwork(); filter.filter(subNetwork, createHashSet(TransportMode.car)); - Assert.assertEquals("wrong number of nodes.", 1, subNetwork.getNodes().size()); - Assert.assertEquals("wrong number of links", 1, subNetwork.getLinks().size()); - Assert.assertTrue(subNetwork.getLinks().containsKey(Id.create(1, Link.class))); + Assertions.assertEquals(1, subNetwork.getNodes().size(), "wrong number of nodes."); + Assertions.assertEquals(1, subNetwork.getLinks().size(), "wrong number of links"); + Assertions.assertTrue(subNetwork.getLinks().containsKey(Id.create(1, Link.class))); } /** @@ -327,18 +327,18 @@ void testFilter_timeVariant() { changeEvent.addLink(sourceLink); ((TimeDependentNetwork) sourceNetwork).addNetworkChangeEvent(changeEvent); - Assert.assertEquals(50.0, sourceLink.getFreespeed(), 1e-3); - Assert.assertEquals(50.0, sourceLink.getFreespeed(0.0), 1e-3); - Assert.assertEquals(100.0, sourceLink.getFreespeed(120.0), 1e-3); + Assertions.assertEquals(50.0, sourceLink.getFreespeed(), 1e-3); + Assertions.assertEquals(50.0, sourceLink.getFreespeed(0.0), 1e-3); + Assertions.assertEquals(100.0, sourceLink.getFreespeed(120.0), 1e-3); Network targetNetwork = NetworkUtils.createNetwork(config); new TransportModeNetworkFilter(sourceNetwork).filter(targetNetwork, Collections.singleton("car")); Link targetLink = targetNetwork.getLinks().get(sourceLink.getId()); - Assert.assertEquals(50.0, targetLink.getFreespeed(), 1e-3); - Assert.assertEquals(50.0, targetLink.getFreespeed(0.0), 1e-3); - Assert.assertEquals(100.0, targetLink.getFreespeed(120.0), 1e-3); + Assertions.assertEquals(50.0, targetLink.getFreespeed(), 1e-3); + Assertions.assertEquals(50.0, targetLink.getFreespeed(0.0), 1e-3); + Assertions.assertEquals(100.0, targetLink.getFreespeed(120.0), 1e-3); } /** diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/DensityClusterTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/DensityClusterTest.java index 6299e3dd572..b469de5af5b 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/DensityClusterTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/DensityClusterTest.java @@ -23,7 +23,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -51,13 +51,13 @@ void testDJCluster(){ DensityCluster djc = new DensityCluster(al, false); djc.clusterInput(2, 3); - Assert.assertEquals("There should only be two clusters", 2, djc.getClusterList().size()); + Assertions.assertEquals(2, djc.getClusterList().size(), "There should only be two clusters"); int small = Math.min(djc.getClusterList().get(0).getPoints().size(), djc.getClusterList().get(1).getPoints().size()); int large = Math.max(djc.getClusterList().get(0).getPoints().size(), djc.getClusterList().get(1).getPoints().size()); - Assert.assertEquals("The small cluster must have 4 points.", 4, small); - Assert.assertEquals("The large cluster must have 8 points.", 8, large); + Assertions.assertEquals(4, small, "The small cluster must have 4 points."); + Assertions.assertEquals(8, large, "The large cluster must have 8 points."); } diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/HullConverterTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/HullConverterTest.java index b5964c3c526..1cb622d8654 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/HullConverterTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/HullConverterTest.java @@ -19,7 +19,7 @@ package org.matsim.core.network.algorithms.intersectionSimplifier; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.GeometryFactory; @@ -49,7 +49,7 @@ void testConvertString(){ Object o = new Integer(0); HullConverter hc = new HullConverter(); String s = hc.convertToString(o); - Assert.assertTrue("Should receive empty string", s.isEmpty()); + Assertions.assertTrue(s.isEmpty(), "Should receive empty string"); /* Check String. */ GeometryFactory gf = new GeometryFactory(); @@ -64,7 +64,7 @@ void testConvertString(){ Point point = gf.createPoint(ca[0]); s = hc.convertToString(point); String pointString = "(0.0;0.0)"; - Assert.assertTrue("Wrong string for point.", pointString.equalsIgnoreCase(s)); + Assertions.assertTrue(pointString.equalsIgnoreCase(s), "Wrong string for point."); /* Line */ Coordinate[] ca2 = new Coordinate[2]; @@ -73,13 +73,13 @@ void testConvertString(){ LineString line = gf.createLineString(ca2); s = hc.convertToString(line); String lineString = "(0.0;0.0),(5.0;0.0)"; - Assert.assertTrue("Wrong string for line.", lineString.equalsIgnoreCase(s)); + Assertions.assertTrue(lineString.equalsIgnoreCase(s), "Wrong string for line."); /* Polygon */ Polygon polygon = gf.createPolygon(ca); s = hc.convertToString(polygon); String polygonString = "(0.0;0.0),(5.0;0.0),(5.0;5.0),(0.0;5.0),(0.0;0.0)"; - Assert.assertTrue("Wrong string for polygon.", polygonString.equalsIgnoreCase(s)); + Assertions.assertTrue(polygonString.equalsIgnoreCase(s), "Wrong string for polygon."); } @@ -104,18 +104,18 @@ void testConstructor(){ /* Point */ Point point = gf.createPoint(ca[0]); - Assert.assertEquals("Wrong point.", point, hc.convert(hc.convertToString(point))); + Assertions.assertEquals(point, hc.convert(hc.convertToString(point)), "Wrong point."); /* Line */ Coordinate[] ca2 = new Coordinate[2]; ca2[0] = ca[0]; ca2[1] = ca[1]; LineString line = gf.createLineString(ca2); - Assert.assertEquals("Wrong line.", line, hc.convert(hc.convertToString(line))); + Assertions.assertEquals(line, hc.convert(hc.convertToString(line)), "Wrong line."); /* Polygon */ Polygon polygon = gf.createPolygon(ca); - Assert.assertEquals("Wrong polygon.", polygon, hc.convert(hc.convertToString(polygon))); + Assertions.assertEquals(polygon, hc.convert(hc.convertToString(polygon)), "Wrong polygon."); } diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java index 035a913d729..e1022df371a 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/IntersectionSimplifierTest.java @@ -24,7 +24,7 @@ import java.util.Iterator; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -50,11 +50,11 @@ void testComplexIntersection() { network = buildComplexIntersection(); new NetworkWriter(network).write(utils.getOutputDirectory() + "network.xml.gz"); } catch (Exception e) { - Assert.fail("Should build and write without exception."); + Assertions.fail("Should build and write without exception."); } - Assert.assertEquals("Wrong number of nodes", 28, network.getNodes().size()); - Assert.assertEquals("Wrong number of links", 50, network.getLinks().size()); + Assertions.assertEquals(28, network.getNodes().size(), "Wrong number of nodes"); + Assertions.assertEquals(50, network.getLinks().size(), "Wrong number of links"); } @Test @@ -65,12 +65,12 @@ void testSimplifyCallOnlyOnce() { is.simplify(network); is.writeClustersToFile(utils.getOutputDirectory() + "clusters.csv"); } catch(Exception e) { - Assert.fail("Should not throw exceptions when simplifying network."); + Assertions.fail("Should not throw exceptions when simplifying network."); } try { is.simplify(network); - Assert.fail("Should not allow to simplify a network more than once"); + Assertions.fail("Should not allow to simplify a network more than once"); } catch(Exception e) { /* Pass. */ e.printStackTrace(); @@ -85,17 +85,17 @@ void testGetClusteredNode() { /* Test before simplifying. */ Node n = network.getNodes().get(Id.createNodeId(5)); - Assert.assertNull("Cannot be clustered before simplification was done.", is.getClusteredNode(n)); + Assertions.assertNull(is.getClusteredNode(n), "Cannot be clustered before simplification was done."); /* Test after simplifying. */ is.simplify(network); is.writeClustersToFile(utils.getOutputDirectory() + "clusters.csv"); Node centroid = is.getClusteredNode(n); - Assert.assertNotNull("Must be associated with a cluster.", centroid); + Assertions.assertNotNull(centroid, "Must be associated with a cluster."); Coord centroidCoord = CoordUtils.createCoord(85.0, 85.0); - Assert.assertTrue("Wrong centroid Coord.", centroidCoord.equals(centroid.getCoord())); - Assert.assertTrue("Wrong centroid Id (does not contain \"-\" separator between merged node ids).", centroid.getId().toString().contains("-")); + Assertions.assertTrue(centroidCoord.equals(centroid.getCoord()), "Wrong centroid Coord."); + Assertions.assertTrue(centroid.getId().toString().contains("-"), "Wrong centroid Id (does not contain \"-\" separator between merged node ids)."); } @@ -106,16 +106,16 @@ void testSimplifyOne() { Network simpleNetwork = is.simplify(network); is.writeClustersToFile(utils.getOutputDirectory() + "clusters.csv"); List clusters = is.getClusters(); - Assert.assertEquals("Wrong number of clusters", 6l, clusters.size()); + Assertions.assertEquals(6l, clusters.size(), "Wrong number of clusters"); /* Check some clusters. */ Cluster c1 = findCluster(clusters, CoordUtils.createCoord(85.0, 85.0)); - Assert.assertNotNull("Could not find a cluster with centroid (85.0,85.0)", c1); - Assert.assertEquals("Wrong number of points", 4, c1.getPoints().size()); + Assertions.assertNotNull(c1, "Could not find a cluster with centroid (85.0,85.0)"); + Assertions.assertEquals(4, c1.getPoints().size(), "Wrong number of points"); Cluster c2 = findCluster(clusters, CoordUtils.createCoord(225.0, 85.0)); - Assert.assertNotNull("Could not find cluster with centroid (225.0,85.0)", c2); - Assert.assertEquals("Wrong number of points", 4, c2.getPoints().size()); + Assertions.assertNotNull(c2, "Could not find cluster with centroid (225.0,85.0)"); + Assertions.assertEquals(4, c2.getPoints().size(), "Wrong number of points"); /* Write the cleaned network to file. */ new NetworkWriter(simpleNetwork).write(utils.getOutputDirectory() + "cleanNetwork.xml"); @@ -128,16 +128,16 @@ void testSimplifyTwo() { Network simpleNetwork = is.simplify(network); is.writeClustersToFile(utils.getOutputDirectory() + "clusters.csv"); List clusters = is.getClusters(); - Assert.assertEquals("Wrong number of clusters", 2l, clusters.size()); + Assertions.assertEquals(2l, clusters.size(), "Wrong number of clusters"); /* Check some clusters. */ Cluster c1 = findCluster(clusters, CoordUtils.createCoord(85.0, 85.0)); - Assert.assertNotNull("Could not find cluster with centroid (85.0,85.0)", c1); - Assert.assertEquals("Wrong number of points", 4, c1.getPoints().size()); + Assertions.assertNotNull(c1, "Could not find cluster with centroid (85.0,85.0)"); + Assertions.assertEquals(4, c1.getPoints().size(), "Wrong number of points"); Cluster c2 = findCluster(clusters, CoordUtils.createCoord(225.0, 85.0)); - Assert.assertNotNull("Could not find cluster with centroid (225.0,85.0)", c2); - Assert.assertEquals("Wrong number of points", 12, c2.getPoints().size()); + Assertions.assertNotNull(c2, "Could not find cluster with centroid (225.0,85.0)"); + Assertions.assertEquals(12, c2.getPoints().size(), "Wrong number of points"); /* Write the cleaned network to file. */ new NetworkWriter(simpleNetwork).write(utils.getOutputDirectory() + "cleanNetwork.xml"); @@ -157,28 +157,28 @@ void testNetworkCleaner() { new NetworkCleaner().run(simpleNetwork); new NetworkWriter(simpleNetwork).write(utils.getOutputDirectory() + "network2.xml"); - Assert.assertEquals("Wrong number of nodes.", 18l, simpleNetwork.getNodes().size()); - - Assert.assertNotNull("Should find node '1'", simpleNetwork.getNodes().get(Id.createNodeId("1"))); - Assert.assertNotNull("Should find node '3'", simpleNetwork.getNodes().get(Id.createNodeId("3"))); - Assert.assertNotNull("Should find node '10'", simpleNetwork.getNodes().get(Id.createNodeId("10"))); - Assert.assertNotNull("Should find node '11'", simpleNetwork.getNodes().get(Id.createNodeId("11"))); - Assert.assertNotNull("Should find node '26'", simpleNetwork.getNodes().get(Id.createNodeId("26"))); - Assert.assertNotNull("Should find node '28'", simpleNetwork.getNodes().get(Id.createNodeId("28"))); - - Assert.assertNotNull("Should find node '2'", simpleNetwork.getNodes().get(Id.createNodeId("2"))); - Assert.assertNotNull("Should find node '4'", simpleNetwork.getNodes().get(Id.createNodeId("4"))); - Assert.assertNotNull("Should find node '9'", simpleNetwork.getNodes().get(Id.createNodeId("9"))); - Assert.assertNotNull("Should find node '12'", simpleNetwork.getNodes().get(Id.createNodeId("12"))); - Assert.assertNotNull("Should find node '25'", simpleNetwork.getNodes().get(Id.createNodeId("25"))); - Assert.assertNotNull("Should find node '27'", simpleNetwork.getNodes().get(Id.createNodeId("27"))); - - Assert.assertNotNull("Should find simplified node '5-6-7-8'", simpleNetwork.getNodes().get(Id.createNodeId("5-6-7-8"))); - Assert.assertNotNull("Should find simplified node '13-14'", simpleNetwork.getNodes().get(Id.createNodeId("13-14"))); - Assert.assertNotNull("Should find simplified node '16-17-20-21'", simpleNetwork.getNodes().get(Id.createNodeId("16-17-20-21"))); - Assert.assertNotNull("Should find simplified node '18-22'", simpleNetwork.getNodes().get(Id.createNodeId("18-22"))); - Assert.assertNotNull("Should find simplified node '15-19'", simpleNetwork.getNodes().get(Id.createNodeId("15-19"))); - Assert.assertNotNull("Should find simplified node '23-24'", simpleNetwork.getNodes().get(Id.createNodeId("23-24"))); + Assertions.assertEquals(18l, simpleNetwork.getNodes().size(), "Wrong number of nodes."); + + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("1")), "Should find node '1'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("3")), "Should find node '3'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("10")), "Should find node '10'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("11")), "Should find node '11'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("26")), "Should find node '26'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("28")), "Should find node '28'"); + + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("2")), "Should find node '2'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("4")), "Should find node '4'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("9")), "Should find node '9'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("12")), "Should find node '12'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("25")), "Should find node '25'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("27")), "Should find node '27'"); + + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("5-6-7-8")), "Should find simplified node '5-6-7-8'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("13-14")), "Should find simplified node '13-14'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("16-17-20-21")), "Should find simplified node '16-17-20-21'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("18-22")), "Should find simplified node '18-22'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("15-19")), "Should find simplified node '15-19'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("23-24")), "Should find simplified node '23-24'"); } @Test @@ -195,28 +195,28 @@ void testNetworkSimplifier() { new NetworkCleaner().run(simpleNetwork); new NetworkWriter(simpleNetwork).write(utils.getOutputDirectory() + "network.xml"); - Assert.assertEquals("Wrong number of nodes.", 12l, simpleNetwork.getNodes().size()); - - Assert.assertNotNull("Should find node '1'", simpleNetwork.getNodes().get(Id.createNodeId("1"))); - Assert.assertNotNull("Should find node '3'", simpleNetwork.getNodes().get(Id.createNodeId("3"))); - Assert.assertNotNull("Should find node '10'", simpleNetwork.getNodes().get(Id.createNodeId("10"))); - Assert.assertNotNull("Should find node '11'", simpleNetwork.getNodes().get(Id.createNodeId("11"))); - Assert.assertNotNull("Should find node '26'", simpleNetwork.getNodes().get(Id.createNodeId("26"))); - Assert.assertNotNull("Should find node '28'", simpleNetwork.getNodes().get(Id.createNodeId("28"))); - - Assert.assertNull("Should NOT find node '2'", simpleNetwork.getNodes().get(Id.createNodeId("2"))); - Assert.assertNull("Should NOT find node '4'", simpleNetwork.getNodes().get(Id.createNodeId("4"))); - Assert.assertNull("Should NOT find node '9'", simpleNetwork.getNodes().get(Id.createNodeId("9"))); - Assert.assertNull("Should NOT find node '12'", simpleNetwork.getNodes().get(Id.createNodeId("12"))); - Assert.assertNull("Should NOT find node '25'", simpleNetwork.getNodes().get(Id.createNodeId("25"))); - Assert.assertNull("Should NOT find node '27'", simpleNetwork.getNodes().get(Id.createNodeId("27"))); - - Assert.assertNotNull("Should find simplified node '5-6-7-8'", simpleNetwork.getNodes().get(Id.createNodeId("5-6-7-8"))); - Assert.assertNotNull("Should find simplified node '13-14'", simpleNetwork.getNodes().get(Id.createNodeId("13-14"))); - Assert.assertNotNull("Should find simplified node '16-17-20-21'", simpleNetwork.getNodes().get(Id.createNodeId("16-17-20-21"))); - Assert.assertNotNull("Should find simplified node '18-22'", simpleNetwork.getNodes().get(Id.createNodeId("18-22"))); - Assert.assertNotNull("Should find simplified node '15-19'", simpleNetwork.getNodes().get(Id.createNodeId("15-19"))); - Assert.assertNotNull("Should find simplified node '23-24'", simpleNetwork.getNodes().get(Id.createNodeId("23-24"))); + Assertions.assertEquals(12l, simpleNetwork.getNodes().size(), "Wrong number of nodes."); + + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("1")), "Should find node '1'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("3")), "Should find node '3'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("10")), "Should find node '10'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("11")), "Should find node '11'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("26")), "Should find node '26'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("28")), "Should find node '28'"); + + Assertions.assertNull(simpleNetwork.getNodes().get(Id.createNodeId("2")), "Should NOT find node '2'"); + Assertions.assertNull(simpleNetwork.getNodes().get(Id.createNodeId("4")), "Should NOT find node '4'"); + Assertions.assertNull(simpleNetwork.getNodes().get(Id.createNodeId("9")), "Should NOT find node '9'"); + Assertions.assertNull(simpleNetwork.getNodes().get(Id.createNodeId("12")), "Should NOT find node '12'"); + Assertions.assertNull(simpleNetwork.getNodes().get(Id.createNodeId("25")), "Should NOT find node '25'"); + Assertions.assertNull(simpleNetwork.getNodes().get(Id.createNodeId("27")), "Should NOT find node '27'"); + + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("5-6-7-8")), "Should find simplified node '5-6-7-8'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("13-14")), "Should find simplified node '13-14'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("16-17-20-21")), "Should find simplified node '16-17-20-21'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("18-22")), "Should find simplified node '18-22'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("15-19")), "Should find simplified node '15-19'"); + Assertions.assertNotNull(simpleNetwork.getNodes().get(Id.createNodeId("23-24")), "Should find simplified node '23-24'"); } diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java index 35c3cfd024d..a8dd27702a6 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/intersectionSimplifier/containers/ConcaveHullTest.java @@ -19,7 +19,7 @@ package org.matsim.core.network.algorithms.intersectionSimplifier.containers; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.locationtech.jts.geom.Coordinate; @@ -38,11 +38,11 @@ public class ConcaveHullTest { void testConstructor(){ GeometryCollection gcIncorrect = setupWithDuplicates(); ConcaveHull ch1 = new ConcaveHull(gcIncorrect, 2); - Assert.assertEquals("Duplicates not removed.", 8, ch1.getInputPoints()); + Assertions.assertEquals(8, ch1.getInputPoints(), "Duplicates not removed."); GeometryCollection gcCorrect = setup(); ConcaveHull ch2 = new ConcaveHull(gcCorrect, 2); - Assert.assertEquals("Wrong number of input points.", 8, ch2.getInputPoints()); + Assertions.assertEquals(8, ch2.getInputPoints(), "Wrong number of input points."); } @@ -50,7 +50,7 @@ public void testGetConcaveHull(){ GeometryCollection gc = setup(); ConcaveHull ch = new ConcaveHull(gc, 1.0); Geometry g = ch.getConcaveHull(); - Assert.assertTrue("Wrong geometry created.", g instanceof Polygon); + Assertions.assertTrue(g instanceof Polygon, "Wrong geometry created."); } diff --git a/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java b/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java index 8796cc67bc4..16d9b4283cb 100644 --- a/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java +++ b/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java @@ -21,8 +21,8 @@ package org.matsim.core.network.filter; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -109,19 +109,19 @@ public boolean judgeLink(Link l) { Network filteredNetwork = networkFilterManager.applyFilters(); - Assert.assertEquals(2, filteredNetwork.getNodes().size()); - Assert.assertTrue("must be added by nodefilter", filteredNetwork.getNodes().containsKey(Id.createNodeId("a"))); - Assert.assertTrue("must be added for ab link", filteredNetwork.getNodes().containsKey(Id.createNodeId("b"))); + Assertions.assertEquals(2, filteredNetwork.getNodes().size()); + Assertions.assertTrue(filteredNetwork.getNodes().containsKey(Id.createNodeId("a")), "must be added by nodefilter"); + Assertions.assertTrue(filteredNetwork.getNodes().containsKey(Id.createNodeId("b")), "must be added for ab link"); - Assert.assertEquals(1, filteredNetwork.getLinks().size()); + Assertions.assertEquals(1, filteredNetwork.getLinks().size()); Link ab = filteredNetwork.getLinks().get(Id.createLinkId("ab")); - Assert.assertEquals(CAPACITY, ab.getCapacity(), DELTA); - Assert.assertEquals(FREESPEED, ab.getFreespeed(), DELTA); - Assert.assertEquals(LENGTH, ab.getLength(), DELTA); - Assert.assertEquals(NR_OF_LANES, ab.getNumberOfLanes(), DELTA); - Assert.assertEquals(ATTRIBUTE_VALUE, ab.getAttributes().getAttribute(ATTRIBUTE_KEY)); - Assert.assertEquals(ATTRIBUTE_VALUE2, ab.getAttributes().getAttribute(ATTRIBUTE_KEY2)); + Assertions.assertEquals(CAPACITY, ab.getCapacity(), DELTA); + Assertions.assertEquals(FREESPEED, ab.getFreespeed(), DELTA); + Assertions.assertEquals(LENGTH, ab.getLength(), DELTA); + Assertions.assertEquals(NR_OF_LANES, ab.getNumberOfLanes(), DELTA); + Assertions.assertEquals(ATTRIBUTE_VALUE, ab.getAttributes().getAttribute(ATTRIBUTE_KEY)); + Assertions.assertEquals(ATTRIBUTE_VALUE2, ab.getAttributes().getAttribute(ATTRIBUTE_KEY2)); } } diff --git a/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java b/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java index 313018fab00..9822c44b7e5 100644 --- a/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/core/network/io/NetworkAttributeConversionTest.java @@ -21,7 +21,7 @@ package org.matsim.core.network.io; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -34,7 +34,7 @@ import java.util.Objects; import java.util.function.Consumer; - public class NetworkAttributeConversionTest { + public class NetworkAttributeConversionTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @@ -73,10 +73,10 @@ public void testWriteAndReread( final Network readNetwork = readScenario.getNetwork(); final Object readAttribute = readNetwork.getAttributes().getAttribute("attribute"); - Assert.assertEquals( - "unexpected read attribute", + Assertions.assertEquals( attribute, - readAttribute); + readAttribute, + "unexpected read attribute"); } private static class CustomClass { diff --git a/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java b/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java index 05795477641..04d357f7286 100644 --- a/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java +++ b/matsim/src/test/java/org/matsim/core/network/io/NetworkReaderMatsimV1Test.java @@ -20,7 +20,7 @@ package org.matsim.core.network.io; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.Set; import java.util.Stack; @@ -53,14 +53,14 @@ public class NetworkReaderMatsimV1Test { void testAllowedModes_singleMode() { Link link = prepareTestAllowedModes("car"); Set modes = link.getAllowedModes(); - assertEquals("wrong number of allowed modes.", 1, modes.size()); - assertTrue("wrong mode.", modes.contains(TransportMode.car)); + assertEquals(1, modes.size(), "wrong number of allowed modes."); + assertTrue(modes.contains(TransportMode.car), "wrong mode."); // make sure we do not just get some default-value back... link = prepareTestAllowedModes("bike"); modes = link.getAllowedModes(); - assertEquals("wrong number of allowed modes.", 1, modes.size()); - assertTrue("wrong mode.", modes.contains(TransportMode.bike)); + assertEquals(1, modes.size(), "wrong number of allowed modes."); + assertTrue(modes.contains(TransportMode.bike), "wrong mode."); } /** @@ -70,7 +70,7 @@ void testAllowedModes_singleMode() { void testAllowedModes_emptyMode() { Link link = prepareTestAllowedModes(""); Set modes = link.getAllowedModes(); - assertEquals("wrong number of allowed modes.", 0, modes.size()); + assertEquals(0, modes.size(), "wrong number of allowed modes."); } /** @@ -80,22 +80,22 @@ void testAllowedModes_emptyMode() { void testAllowedModes_multipleModes() { Link link = prepareTestAllowedModes("car,bus"); Set modes = link.getAllowedModes(); - assertEquals("wrong number of allowed modes.", 2, modes.size()); - assertTrue("wrong mode.", modes.contains(TransportMode.car)); - assertTrue("wrong mode.", modes.contains("bus")); + assertEquals(2, modes.size(), "wrong number of allowed modes."); + assertTrue(modes.contains(TransportMode.car), "wrong mode."); + assertTrue(modes.contains("bus"), "wrong mode."); link = prepareTestAllowedModes("bike,bus,walk"); modes = link.getAllowedModes(); - assertEquals("wrong number of allowed modes.", 3, modes.size()); - assertTrue("wrong mode.", modes.contains(TransportMode.bike)); - assertTrue("wrong mode.", modes.contains("bus")); - assertTrue("wrong mode.", modes.contains(TransportMode.walk)); + assertEquals(3, modes.size(), "wrong number of allowed modes."); + assertTrue(modes.contains(TransportMode.bike), "wrong mode."); + assertTrue(modes.contains("bus"), "wrong mode."); + assertTrue(modes.contains(TransportMode.walk), "wrong mode."); link = prepareTestAllowedModes("pt, train"); // test with space after comma modes = link.getAllowedModes(); - assertEquals("wrong number of allowed modes.", 2, modes.size()); - assertTrue("wrong mode.", modes.contains(TransportMode.pt)); - assertTrue("wrong mode.", modes.contains("train")); + assertEquals(2, modes.size(), "wrong number of allowed modes."); + assertTrue(modes.contains(TransportMode.pt), "wrong mode."); + assertTrue(modes.contains("train"), "wrong mode."); } /** @@ -131,9 +131,9 @@ private Link prepareTestAllowedModes(final String modes) { reader.startTag("link", atts, context); // start test - assertEquals("expected one link.", 1, network.getLinks().size()); + assertEquals(1, network.getLinks().size(), "expected one link."); Link link = network.getLinks().get(Id.create("1", Link.class)); - assertNotNull("expected link with id=1.", link); + assertNotNull(link, "expected link with id=1."); return link; } diff --git a/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java b/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java index b57fd8ab3f5..8398f1a7db1 100644 --- a/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/core/network/io/NetworkReprojectionIOTest.java @@ -21,7 +21,7 @@ package org.matsim.core.network.io; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -40,7 +40,7 @@ import org.matsim.core.utils.geometry.transformations.TransformationFactory; import org.matsim.testcases.MatsimTestUtils; - /** + /** * @author thibautd */ public class NetworkReprojectionIOTest { @@ -67,17 +67,17 @@ void testInput() { INITIAL_CRS, TARGET_CRS, readNetwork ).readFile( networkFile ); - Assert.assertEquals( - "unexpected network size", + Assertions.assertEquals( 2, - readNetwork.getNodes().size() ); + readNetwork.getNodes().size(), + "unexpected network size" ); for ( Node n : readNetwork.getNodes().values() ) { Node initialNode = initialNetwork.getNodes().get(n.getId()); - Assert.assertEquals( "Unexpected coordinate", - transformation.transform(initialNode.getCoord()), - n.getCoord() ); + Assertions.assertEquals( transformation.transform(initialNode.getCoord()), + n.getCoord(), + "Unexpected coordinate" ); } } @@ -95,17 +95,17 @@ void testOutput() { new MatsimNetworkReader( readNetwork ).readFile( networkFile ); - Assert.assertEquals( - "unexpected network size", + Assertions.assertEquals( 2, - readNetwork.getNodes().size() ); + readNetwork.getNodes().size(), + "unexpected network size" ); for ( Node n : readNetwork.getNodes().values() ) { Node initialNode = initialNetwork.getNodes().get(n.getId()); - Assert.assertEquals( - "Unexpected coordinate", + Assertions.assertEquals( transformation.transform(initialNode.getCoord()), - n.getCoord() ); + n.getCoord(), + "Unexpected coordinate" ); } } @@ -132,16 +132,16 @@ void testWithControlerAndAttributes() { final Coord originalCoord = initialNetwork.getNodes().get( id ).getCoord(); final Coord internalCoord = scenario.getNetwork().getNodes().get( id ).getCoord(); - Assert.assertEquals( - "No coordinates transform performed!", + Assertions.assertEquals( transformation.transform(originalCoord), - internalCoord); + internalCoord, + "No coordinates transform performed!"); } - Assert.assertEquals( - "wrong CRS information after loading", + Assertions.assertEquals( TARGET_CRS, - ProjectionUtils.getCRS(scenario.getNetwork())); + ProjectionUtils.getCRS(scenario.getNetwork()), + "wrong CRS information after loading"); config.controller().setLastIteration( 0 ); final String outputDirectory = utils.getOutputDirectory()+"/output/"; @@ -156,10 +156,10 @@ void testWithControlerAndAttributes() { final Coord internalCoord = scenario.getNetwork().getNodes().get( id ).getCoord(); final Coord dumpedCoord = dumpedNetwork.getNodes().get( id ).getCoord(); - Assert.assertEquals( - "coordinates were reprojected for dump", + Assertions.assertEquals( internalCoord, - dumpedCoord); + dumpedCoord, + "coordinates were reprojected for dump"); } } @@ -185,16 +185,16 @@ void testWithControlerAndConfigParameters() { final Coord originalCoord = initialNetwork.getNodes().get( id ).getCoord(); final Coord internalCoord = scenario.getNetwork().getNodes().get( id ).getCoord(); - Assert.assertNotEquals( - "No coordinates transform performed!", + Assertions.assertNotEquals( originalCoord.getX(), internalCoord.getX(), - MatsimTestUtils.EPSILON ); - Assert.assertNotEquals( - "No coordinates transform performed!", + MatsimTestUtils.EPSILON, + "No coordinates transform performed!" ); + Assertions.assertNotEquals( originalCoord.getY(), internalCoord.getY(), - MatsimTestUtils.EPSILON ); + MatsimTestUtils.EPSILON, + "No coordinates transform performed!" ); } config.controller().setLastIteration( 0 ); @@ -210,16 +210,16 @@ void testWithControlerAndConfigParameters() { final Coord originalCoord = initialNetwork.getNodes().get( id ).getCoord(); final Coord dumpedCoord = dumpedNetwork.getNodes().get( id ).getCoord(); - Assert.assertNotEquals( - "coordinates were reprojected for dump", + Assertions.assertNotEquals( originalCoord.getX(), dumpedCoord.getX(), - MatsimTestUtils.EPSILON ); - Assert.assertNotEquals( - "coordinates were reprojected for dump", + MatsimTestUtils.EPSILON, + "coordinates were reprojected for dump" ); + Assertions.assertNotEquals( originalCoord.getY(), dumpedCoord.getY(), - MatsimTestUtils.EPSILON ); + MatsimTestUtils.EPSILON, + "coordinates were reprojected for dump" ); } } diff --git a/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java b/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java index 7b63c140391..66919058253 100644 --- a/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java +++ b/matsim/src/test/java/org/matsim/core/population/PersonImplTest.java @@ -20,7 +20,7 @@ package org.matsim.core.population; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -106,12 +106,12 @@ void testRemoveUnselectedPlans() { Plan selPlan = PersonUtils.createAndAddPlan(person, true); PersonUtils.createAndAddPlan(person, false); - assertEquals("person should have 4 plans.", 4, person.getPlans().size()); + assertEquals(4, person.getPlans().size(), "person should have 4 plans."); PersonUtils.removeUnselectedPlans(person); - assertEquals("person should have 1 plan.", 1, person.getPlans().size()); - assertEquals("remaining plan should be selPlan.", selPlan, person.getPlans().get(0)); + assertEquals(1, person.getPlans().size(), "person should have 1 plan."); + assertEquals(selPlan, person.getPlans().get(0), "remaining plan should be selPlan."); } @Test @@ -123,21 +123,21 @@ void testRemovePlan() { Plan p4 = PersonUtils.createAndAddPlan(person, false); Plan p5 = PopulationUtils.createPlan(null); - assertEquals("wrong number of plans.", 4, person.getPlans().size()); - assertEquals("expected different selected plan.", p2, person.getSelectedPlan()); + assertEquals(4, person.getPlans().size(), "wrong number of plans."); + assertEquals(p2, person.getSelectedPlan(), "expected different selected plan."); assertTrue(person.removePlan(p3)); - assertEquals("wrong number of plans.", 3, person.getPlans().size()); - assertEquals("expected different selected plan.", p2, person.getSelectedPlan()); + assertEquals(3, person.getPlans().size(), "wrong number of plans."); + assertEquals(p2, person.getSelectedPlan(), "expected different selected plan."); assertFalse(person.removePlan(p5)); - assertEquals("wrong number of plans.", 3, person.getPlans().size()); + assertEquals(3, person.getPlans().size(), "wrong number of plans."); assertTrue(person.removePlan(p2)); - assertEquals("wrong number of plans.", 2, person.getPlans().size()); - assertNotSame("removed plan still set as selected.", p2, person.getSelectedPlan()); - assertFalse("plan cannot be removed twice.", person.removePlan(p2)); - assertEquals("wrong number of plans.", 2, person.getPlans().size()); + assertEquals(2, person.getPlans().size(), "wrong number of plans."); + assertNotSame(p2, person.getSelectedPlan(), "removed plan still set as selected."); + assertFalse(person.removePlan(p2), "plan cannot be removed twice."); + assertEquals(2, person.getPlans().size(), "wrong number of plans."); assertTrue(person.removePlan(p1)); assertTrue(person.removePlan(p4)); - assertEquals("wrong number of plans.", 0, person.getPlans().size()); + assertEquals(0, person.getPlans().size(), "wrong number of plans."); } @Test diff --git a/matsim/src/test/java/org/matsim/core/population/PlanImplTest.java b/matsim/src/test/java/org/matsim/core/population/PlanImplTest.java index b818a7ec02c..fb76825f3d7 100644 --- a/matsim/src/test/java/org/matsim/core/population/PlanImplTest.java +++ b/matsim/src/test/java/org/matsim/core/population/PlanImplTest.java @@ -20,11 +20,11 @@ package org.matsim.core.population; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -235,8 +235,8 @@ void testCopyPlan_NetworkRoute() { Plan plan2 = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(2, Person.class))); PopulationUtils.copyFromTo(plan, plan2); - assertEquals("person must not be copied.", Id.create(2, Person.class), plan2.getPerson().getId()); - assertEquals("wrong number of plan elements.", plan.getPlanElements().size(), plan2.getPlanElements().size()); + assertEquals(Id.create(2, Person.class), plan2.getPerson().getId(), "person must not be copied."); + assertEquals(plan.getPlanElements().size(), plan2.getPlanElements().size(), "wrong number of plan elements."); Route route2 = ((Leg) plan.getPlanElements().get(1)).getRoute(); assertTrue(route2 instanceof NetworkRoute); assertEquals(98.76, route2.getTravelTime().seconds(), 1e-8); @@ -266,8 +266,8 @@ void testCopyPlan_GenericRoute() { Plan plan2 = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(2, Person.class))); PopulationUtils.copyFromTo(plan, plan2); - assertEquals("person must not be copied.", Id.create(2, Person.class), plan2.getPerson().getId()); - assertEquals("wrong number of plan elements.", plan.getPlanElements().size(), plan2.getPlanElements().size()); + assertEquals(Id.create(2, Person.class), plan2.getPerson().getId(), "person must not be copied."); + assertEquals(plan.getPlanElements().size(), plan2.getPlanElements().size(), "wrong number of plan elements."); Route route2 = ((Leg) plan.getPlanElements().get(1)).getRoute(); // assertTrue(route2 instanceof GenericRouteImpl); assertEquals(98.76, route2.getTravelTime().seconds(), 1e-8); @@ -321,12 +321,12 @@ void addMultipleLegs() { p.addLeg(PopulationUtils.createLeg(TransportMode.walk)); p.addActivity(new ActivityImpl("w")); - Assert.assertEquals(5, p.getPlanElements().size()); - Assert.assertTrue(p.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(p.getPlanElements().get(1) instanceof Leg); - Assert.assertTrue(p.getPlanElements().get(2) instanceof Leg); - Assert.assertTrue(p.getPlanElements().get(3) instanceof Leg); - Assert.assertTrue(p.getPlanElements().get(4) instanceof Activity); + Assertions.assertEquals(5, p.getPlanElements().size()); + Assertions.assertTrue(p.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(p.getPlanElements().get(1) instanceof Leg); + Assertions.assertTrue(p.getPlanElements().get(2) instanceof Leg); + Assertions.assertTrue(p.getPlanElements().get(3) instanceof Leg); + Assertions.assertTrue(p.getPlanElements().get(4) instanceof Activity); } @Test @@ -337,11 +337,11 @@ void addMultipleActs() { p.addActivity(new ActivityImpl("w")); p.addActivity(new ActivityImpl("l")); - Assert.assertEquals(4, p.getPlanElements().size()); - Assert.assertTrue(p.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(p.getPlanElements().get(1) instanceof Leg); - Assert.assertTrue(p.getPlanElements().get(2) instanceof Activity); - Assert.assertTrue(p.getPlanElements().get(3) instanceof Activity); + Assertions.assertEquals(4, p.getPlanElements().size()); + Assertions.assertTrue(p.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(p.getPlanElements().get(1) instanceof Leg); + Assertions.assertTrue(p.getPlanElements().get(2) instanceof Activity); + Assertions.assertTrue(p.getPlanElements().get(3) instanceof Activity); } @Test @@ -353,12 +353,12 @@ void createAndAddMultipleLegs() { PopulationUtils.createAndAddLeg( p, TransportMode.walk ); PopulationUtils.createAndAddActivity(p, "w"); - Assert.assertEquals(5, p.getPlanElements().size()); - Assert.assertTrue(p.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(p.getPlanElements().get(1) instanceof Leg); - Assert.assertTrue(p.getPlanElements().get(2) instanceof Leg); - Assert.assertTrue(p.getPlanElements().get(3) instanceof Leg); - Assert.assertTrue(p.getPlanElements().get(4) instanceof Activity); + Assertions.assertEquals(5, p.getPlanElements().size()); + Assertions.assertTrue(p.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(p.getPlanElements().get(1) instanceof Leg); + Assertions.assertTrue(p.getPlanElements().get(2) instanceof Leg); + Assertions.assertTrue(p.getPlanElements().get(3) instanceof Leg); + Assertions.assertTrue(p.getPlanElements().get(4) instanceof Activity); } @Test @@ -369,11 +369,11 @@ void createAndAddMultipleActs() { PopulationUtils.createAndAddActivity(p, "w"); PopulationUtils.createAndAddActivity(p, "l"); - Assert.assertEquals(4, p.getPlanElements().size()); - Assert.assertTrue(p.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(p.getPlanElements().get(1) instanceof Leg); - Assert.assertTrue(p.getPlanElements().get(2) instanceof Activity); - Assert.assertTrue(p.getPlanElements().get(3) instanceof Activity); + Assertions.assertEquals(4, p.getPlanElements().size()); + Assertions.assertTrue(p.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(p.getPlanElements().get(1) instanceof Leg); + Assertions.assertTrue(p.getPlanElements().get(2) instanceof Activity); + Assertions.assertTrue(p.getPlanElements().get(3) instanceof Activity); } } diff --git a/matsim/src/test/java/org/matsim/core/population/PopulationUtilsTest.java b/matsim/src/test/java/org/matsim/core/population/PopulationUtilsTest.java index 4b083a3fb9d..44520f6f8d0 100644 --- a/matsim/src/test/java/org/matsim/core/population/PopulationUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/population/PopulationUtilsTest.java @@ -21,7 +21,7 @@ package org.matsim.core.population; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -31,7 +31,7 @@ import org.matsim.core.population.io.PopulationReader; import org.matsim.core.scenario.ScenarioUtils; - /** + /** * @author thibautd */ public class PopulationUtilsTest { @@ -61,25 +61,25 @@ void testPlanAttributesCopy() { final Plan planCopy = population.getFactory().createPlan(); PopulationUtils.copyFromTo( plan , planCopy ); - Assert.assertEquals( "unexpected plan length", - plan.getPlanElements().size(), - planCopy.getPlanElements().size() ); + Assertions.assertEquals( plan.getPlanElements().size(), + planCopy.getPlanElements().size(), + "unexpected plan length" ); final Activity activityCopy = (Activity) planCopy.getPlanElements().get( 0 ); - Assert.assertEquals( "unexpected attribute", - act.getAttributes().getAttribute( "makes sense" ), - activityCopy.getAttributes().getAttribute( "makes sense" ) ); + Assertions.assertEquals( act.getAttributes().getAttribute( "makes sense" ), + activityCopy.getAttributes().getAttribute( "makes sense" ), + "unexpected attribute" ); - Assert.assertEquals( "unexpected attribute", - act.getAttributes().getAttribute( "length" ), - activityCopy.getAttributes().getAttribute( "length" ) ); + Assertions.assertEquals( act.getAttributes().getAttribute( "length" ), + activityCopy.getAttributes().getAttribute( "length" ), + "unexpected attribute" ); final Leg legCopy = (Leg) planCopy.getPlanElements().get( 1 ); - Assert.assertEquals( "unexpected attribute", - leg.getAttributes().getAttribute( "mpg" ), - legCopy.getAttributes().getAttribute( "mpg" ) ); + Assertions.assertEquals( leg.getAttributes().getAttribute( "mpg" ), + legCopy.getAttributes().getAttribute( "mpg" ), + "unexpected attribute" ); } } diff --git a/matsim/src/test/java/org/matsim/core/population/io/CompressedRoutesIntegrationTest.java b/matsim/src/test/java/org/matsim/core/population/io/CompressedRoutesIntegrationTest.java index 58072ae7794..8283432f096 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/CompressedRoutesIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/CompressedRoutesIntegrationTest.java @@ -19,7 +19,7 @@ package org.matsim.core.population.io; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -42,7 +42,7 @@ void testReadingPlansV4parallel() { Scenario s = ScenarioUtils.createScenario(config); new MatsimNetworkReader(s.getNetwork()).readFile("test/scenarios/equil/network.xml"); new ParallelPopulationReaderMatsimV4(s).readFile("test/scenarios/equil/plans1.xml"); - Assert.assertEquals(1, s.getPopulation().getPersons().size()); + Assertions.assertEquals(1, s.getPopulation().getPersons().size()); Leg firstPersonsLeg = (Leg) s.getPopulation().getPersons().get(Id.create("1", Person.class)).getSelectedPlan().getPlanElements().get(1); // Assert.assertTrue(firstPersonsLeg.getRoute() instanceof CompressedNetworkRouteImpl); } diff --git a/matsim/src/test/java/org/matsim/core/population/io/MatsimPopulationReaderTest.java b/matsim/src/test/java/org/matsim/core/population/io/MatsimPopulationReaderTest.java index 7bf327f170d..54dd30d5cd2 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/MatsimPopulationReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/MatsimPopulationReaderTest.java @@ -21,7 +21,7 @@ import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -44,92 +44,92 @@ public class MatsimPopulationReaderTest { @Test void testReadFile_v4() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - Assert.assertEquals(0, s.getPopulation().getPersons().size()); + Assertions.assertEquals(0, s.getPopulation().getPersons().size()); new MatsimNetworkReader(s.getNetwork()).readFile("test/scenarios/equil/network.xml"); new PopulationReader(s).readFile("test/scenarios/equil/plans1.xml"); - Assert.assertEquals(1, s.getPopulation().getPersons().size()); + Assertions.assertEquals(1, s.getPopulation().getPersons().size()); } @Test void testReadFile_v5() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - Assert.assertEquals(0, s.getPopulation().getPersons().size()); + Assertions.assertEquals(0, s.getPopulation().getPersons().size()); new PopulationReader(s).readFile("test/input/org/matsim/core/utils/io/MatsimFileTypeGuesserTest/population_v5_example.xml"); - Assert.assertEquals(1, s.getPopulation().getPersons().size()); + Assertions.assertEquals(1, s.getPopulation().getPersons().size()); Person person = s.getPopulation().getPersons().get(Id.create(1, Person.class)); - Assert.assertNotNull(person); + Assertions.assertNotNull(person); Plan plan = person.getSelectedPlan(); List planElements = plan.getPlanElements(); - Assert.assertEquals(3, planElements.size()); + Assertions.assertEquals(3, planElements.size()); - Assert.assertTrue(planElements.get(0) instanceof Activity); - Assert.assertTrue(planElements.get(1) instanceof Leg); - Assert.assertTrue(planElements.get(2) instanceof Activity); + Assertions.assertTrue(planElements.get(0) instanceof Activity); + Assertions.assertTrue(planElements.get(1) instanceof Leg); + Assertions.assertTrue(planElements.get(2) instanceof Activity); } @Test void testReadFile_v5_multipleSuccessiveLegs() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - Assert.assertEquals(0, s.getPopulation().getPersons().size()); + Assertions.assertEquals(0, s.getPopulation().getPersons().size()); new PopulationReader(s).readFile("test/input/org/matsim/core/utils/io/MatsimFileTypeGuesserTest/population_v5_multipleLegs.xml"); - Assert.assertEquals(1, s.getPopulation().getPersons().size()); + Assertions.assertEquals(1, s.getPopulation().getPersons().size()); Person person = s.getPopulation().getPersons().get(Id.create(1, Person.class)); - Assert.assertNotNull(person); + Assertions.assertNotNull(person); Plan plan = person.getSelectedPlan(); List planElements = plan.getPlanElements(); - Assert.assertEquals(5, planElements.size()); + Assertions.assertEquals(5, planElements.size()); - Assert.assertTrue(planElements.get(0) instanceof Activity); - Assert.assertTrue(planElements.get(1) instanceof Leg); - Assert.assertTrue(planElements.get(2) instanceof Leg); - Assert.assertTrue(planElements.get(3) instanceof Leg); - Assert.assertTrue(planElements.get(4) instanceof Activity); + Assertions.assertTrue(planElements.get(0) instanceof Activity); + Assertions.assertTrue(planElements.get(1) instanceof Leg); + Assertions.assertTrue(planElements.get(2) instanceof Leg); + Assertions.assertTrue(planElements.get(3) instanceof Leg); + Assertions.assertTrue(planElements.get(4) instanceof Activity); } @Test void testReadFile_v5_multipleSuccessiveLegsWithRoutes() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - Assert.assertEquals(0, s.getPopulation().getPersons().size()); + Assertions.assertEquals(0, s.getPopulation().getPersons().size()); new PopulationReader(s).readFile("test/input/org/matsim/core/utils/io/MatsimFileTypeGuesserTest/population_v5_multipleLegsWithRoutes.xml"); - Assert.assertEquals(1, s.getPopulation().getPersons().size()); + Assertions.assertEquals(1, s.getPopulation().getPersons().size()); Person person = s.getPopulation().getPersons().get(Id.create(1, Person.class)); - Assert.assertNotNull(person); + Assertions.assertNotNull(person); Plan plan = person.getSelectedPlan(); List planElements = plan.getPlanElements(); - Assert.assertEquals(5, planElements.size()); + Assertions.assertEquals(5, planElements.size()); - Assert.assertTrue(planElements.get(0) instanceof Activity); - Assert.assertTrue(planElements.get(1) instanceof Leg); - Assert.assertEquals(Id.create("1", Link.class), ((Leg) planElements.get(1)).getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("2", Link.class), ((Leg) planElements.get(1)).getRoute().getEndLinkId()); - Assert.assertTrue(planElements.get(2) instanceof Leg); - Assert.assertEquals(Id.create("2", Link.class), ((Leg) planElements.get(2)).getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("4", Link.class), ((Leg) planElements.get(2)).getRoute().getEndLinkId()); - Assert.assertTrue(planElements.get(3) instanceof Leg); - Assert.assertEquals(Id.create("4", Link.class), ((Leg) planElements.get(3)).getRoute().getStartLinkId()); - Assert.assertEquals(Id.create("6", Link.class), ((Leg) planElements.get(3)).getRoute().getEndLinkId()); - Assert.assertTrue(planElements.get(4) instanceof Activity); + Assertions.assertTrue(planElements.get(0) instanceof Activity); + Assertions.assertTrue(planElements.get(1) instanceof Leg); + Assertions.assertEquals(Id.create("1", Link.class), ((Leg) planElements.get(1)).getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("2", Link.class), ((Leg) planElements.get(1)).getRoute().getEndLinkId()); + Assertions.assertTrue(planElements.get(2) instanceof Leg); + Assertions.assertEquals(Id.create("2", Link.class), ((Leg) planElements.get(2)).getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("4", Link.class), ((Leg) planElements.get(2)).getRoute().getEndLinkId()); + Assertions.assertTrue(planElements.get(3) instanceof Leg); + Assertions.assertEquals(Id.create("4", Link.class), ((Leg) planElements.get(3)).getRoute().getStartLinkId()); + Assertions.assertEquals(Id.create("6", Link.class), ((Leg) planElements.get(3)).getRoute().getEndLinkId()); + Assertions.assertTrue(planElements.get(4) instanceof Activity); } @Test void testReadFile_v5_multipleSuccessiveLegsWithTeleportation() { Scenario s = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - Assert.assertEquals(0, s.getPopulation().getPersons().size()); + Assertions.assertEquals(0, s.getPopulation().getPersons().size()); new PopulationReader(s).readFile("test/input/org/matsim/core/utils/io/MatsimFileTypeGuesserTest/population_v5_multipleTeleportedLegs.xml"); - Assert.assertEquals(1, s.getPopulation().getPersons().size()); + Assertions.assertEquals(1, s.getPopulation().getPersons().size()); Person person = s.getPopulation().getPersons().get(Id.create(1, Person.class)); - Assert.assertNotNull(person); + Assertions.assertNotNull(person); Plan plan = person.getSelectedPlan(); List planElements = plan.getPlanElements(); - Assert.assertEquals(5, planElements.size()); + Assertions.assertEquals(5, planElements.size()); - Assert.assertTrue(planElements.get(0) instanceof Activity); - Assert.assertTrue(planElements.get(1) instanceof Leg); + Assertions.assertTrue(planElements.get(0) instanceof Activity); + Assertions.assertTrue(planElements.get(1) instanceof Leg); // Assert.assertTrue(((Leg) planElements.get(1)).getRoute() instanceof GenericRouteImpl); - Assert.assertTrue(planElements.get(2) instanceof Leg); - Assert.assertTrue(((Leg) planElements.get(2)).getRoute() instanceof NetworkRoute); - Assert.assertTrue(planElements.get(3) instanceof Leg); + Assertions.assertTrue(planElements.get(2) instanceof Leg); + Assertions.assertTrue(((Leg) planElements.get(2)).getRoute() instanceof NetworkRoute); + Assertions.assertTrue(planElements.get(3) instanceof Leg); // Assert.assertTrue(((Leg) planElements.get(3)).getRoute() instanceof GenericRouteImpl); - Assert.assertTrue(planElements.get(4) instanceof Activity); + Assertions.assertTrue(planElements.get(4) instanceof Activity); } } diff --git a/matsim/src/test/java/org/matsim/core/population/io/ParallelPopulationReaderTest.java b/matsim/src/test/java/org/matsim/core/population/io/ParallelPopulationReaderTest.java index 54e4e2fbd33..930ca275208 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/ParallelPopulationReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/ParallelPopulationReaderTest.java @@ -1,6 +1,6 @@ package org.matsim.core.population.io; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; import org.matsim.core.config.ConfigUtils; @@ -35,7 +35,7 @@ void testParallelPopulationReaderV4_escalateException() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); try { new ParallelPopulationReaderMatsimV4(scenario).readStream(stream); - Assert.fail("Expected exception"); + Assertions.fail("Expected exception"); } catch (Exception expected) { expected.printStackTrace(); } @@ -65,7 +65,7 @@ void testParallelPopulationReaderV6_escalateException() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); try { new ParallelPopulationReaderMatsimV6(null, null, scenario).readStream(stream); - Assert.fail("Expected exception"); + Assertions.fail("Expected exception"); } catch (Exception expected) { expected.printStackTrace(); } diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java index 86824f40ec2..7e28e75a7de 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationAttributeConversionTest.java @@ -21,7 +21,7 @@ package org.matsim.core.population.io; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -38,7 +38,7 @@ import java.util.Objects; import java.util.function.Consumer; - public class PopulationAttributeConversionTest { + public class PopulationAttributeConversionTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @@ -95,10 +95,10 @@ public void testWriteAndReread( final Person readPerson = readScenario.getPopulation().getPersons().get(personId); final Object readAttribute = readPerson.getAttributes().getAttribute("job"); - Assert.assertEquals( - "unexpected read attribute", + Assertions.assertEquals( attribute, - readAttribute); + readAttribute, + "unexpected read attribute"); } private static class CustomClass { diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV4Test.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV4Test.java index c406b80ada0..0fce80b3bda 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV4Test.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV4Test.java @@ -26,7 +26,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -118,32 +118,32 @@ void testReadRoute() throws SAXException, ParserConfigurationException, IOExcept tester.endTag(); - Assert.assertEquals("population size.", 2, population.getPersons().size()); + Assertions.assertEquals(2, population.getPersons().size(), "population size."); Person person1 = population.getPersons().get(Id.create("1", Person.class)); Plan plan1 = person1.getPlans().get(0); Leg leg1a = (Leg) plan1.getPlanElements().get(1); Route route1a = leg1a.getRoute(); - Assert.assertEquals("different startLink for first leg.", network.getLinks().get(Id.create("1", Link.class)).getId(), route1a.getStartLinkId()); - Assert.assertEquals("different endLink for first leg.", network.getLinks().get(Id.create("20", Link.class)).getId(), route1a.getEndLinkId()); + Assertions.assertEquals(network.getLinks().get(Id.create("1", Link.class)).getId(), route1a.getStartLinkId(), "different startLink for first leg."); + Assertions.assertEquals(network.getLinks().get(Id.create("20", Link.class)).getId(), route1a.getEndLinkId(), "different endLink for first leg."); Leg leg1b = (Leg) plan1.getPlanElements().get(3); Route route1b = leg1b.getRoute(); - Assert.assertEquals("different startLink for second leg.", network.getLinks().get(Id.create("20", Link.class)).getId(), route1b.getStartLinkId()); - Assert.assertEquals("different endLink for second leg.", network.getLinks().get(Id.create("20", Link.class)).getId(), route1b.getEndLinkId()); + Assertions.assertEquals(network.getLinks().get(Id.create("20", Link.class)).getId(), route1b.getStartLinkId(), "different startLink for second leg."); + Assertions.assertEquals(network.getLinks().get(Id.create("20", Link.class)).getId(), route1b.getEndLinkId(), "different endLink for second leg."); Leg leg1c = (Leg) plan1.getPlanElements().get(5); Route route1c = leg1c.getRoute(); - Assert.assertEquals("different startLink for third leg.", network.getLinks().get(Id.create("20", Link.class)).getId(), route1c.getStartLinkId()); - Assert.assertEquals("different endLink for third leg.", network.getLinks().get(Id.create("1", Link.class)).getId(), route1c.getEndLinkId()); + Assertions.assertEquals(network.getLinks().get(Id.create("20", Link.class)).getId(), route1c.getStartLinkId(), "different startLink for third leg."); + Assertions.assertEquals(network.getLinks().get(Id.create("1", Link.class)).getId(), route1c.getEndLinkId(), "different endLink for third leg."); Person person2 = population.getPersons().get(Id.create("2", Person.class)); Plan plan2 = person2.getPlans().get(0); Leg leg2a = (Leg) plan2.getPlanElements().get(1); Route route2a = leg2a.getRoute(); - Assert.assertEquals("different startLink for first leg.", network.getLinks().get(Id.create("2", Link.class)).getId(), route2a.getStartLinkId()); - Assert.assertEquals("different endLink for first leg.", network.getLinks().get(Id.create("20", Link.class)).getId(), route2a.getEndLinkId()); + Assertions.assertEquals(network.getLinks().get(Id.create("2", Link.class)).getId(), route2a.getStartLinkId(), "different startLink for first leg."); + Assertions.assertEquals(network.getLinks().get(Id.create("20", Link.class)).getId(), route2a.getEndLinkId(), "different endLink for first leg."); Leg leg2b = (Leg) plan2.getPlanElements().get(3); Route route2b = leg2b.getRoute(); - Assert.assertEquals("different startLink for third leg.", network.getLinks().get(Id.create("20", Link.class)).getId(), route2b.getStartLinkId()); - Assert.assertEquals("different endLink for third leg.", network.getLinks().get(Id.create("1", Link.class)).getId(), route2b.getEndLinkId()); + Assertions.assertEquals(network.getLinks().get(Id.create("20", Link.class)).getId(), route2b.getStartLinkId(), "different startLink for third leg."); + Assertions.assertEquals(network.getLinks().get(Id.create("1", Link.class)).getId(), route2b.getEndLinkId(), "different endLink for third leg."); } /** @@ -176,12 +176,12 @@ void testReadRouteWithoutActivityLinks() { parser.endTag("person", null, context); parser.endTag("plans", null, context); - Assert.assertEquals("population size.", 1, population.getPersons().size()); + Assertions.assertEquals(1, population.getPersons().size(), "population size."); Person person1 = population.getPersons().get(Id.create("981", Person.class)); Plan plan1 = person1.getPlans().get(0); Leg leg1 = (Leg) plan1.getPlanElements().get(1); Route route1 = leg1.getRoute(); - Assert.assertNotNull(route1); + Assertions.assertNotNull(route1); } /** @@ -213,11 +213,11 @@ void testReadActivity() { reader.endTag("person", "", context); reader.endTag("plans", "", context); - Assert.assertEquals(1, population.getPersons().size()); + Assertions.assertEquals(1, population.getPersons().size()); Person person = population.getPersons().get(Id.create("2", Person.class)); Plan plan = person.getPlans().get(0); - Assert.assertEquals(link3.getId(), ((Activity) plan.getPlanElements().get(0)).getLinkId()); - Assert.assertEquals(Id.create("2", Link.class), ((Activity) plan.getPlanElements().get(2)).getLinkId()); + Assertions.assertEquals(link3.getId(), ((Activity) plan.getPlanElements().get(0)).getLinkId()); + Assertions.assertEquals(Id.create("2", Link.class), ((Activity) plan.getPlanElements().get(2)).getLinkId()); } @Test @@ -254,14 +254,14 @@ void testReadingRoutesWithoutType() { reader.parse(new ByteArrayInputStream(str.getBytes())); Plan plan = population.getPersons().get(Id.create(1, Person.class)).getSelectedPlan(); - Assert.assertEquals(7, plan.getPlanElements().size()); - Assert.assertTrue(plan.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(1) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(2) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(3) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(4) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(5) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(6) instanceof Activity); + Assertions.assertEquals(7, plan.getPlanElements().size()); + Assertions.assertTrue(plan.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(1) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(2) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(3) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(4) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(5) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(6) instanceof Activity); Leg leg1 = (Leg) plan.getPlanElements().get(1); Route route1 = leg1.getRoute(); @@ -270,9 +270,9 @@ void testReadingRoutesWithoutType() { Leg leg3 = (Leg) plan.getPlanElements().get(5); Route route3 = leg3.getRoute(); - Assert.assertTrue(route1 instanceof NetworkRoute); + Assertions.assertTrue(route1 instanceof NetworkRoute); // Assert.assertTrue(route2 instanceof GenericRouteImpl); - Assert.assertTrue(route3 instanceof TransitPassengerRoute); + Assertions.assertTrue(route3 instanceof TransitPassengerRoute); } @Test @@ -297,12 +297,12 @@ void testRepeatingLegs() { reader.parse(new ByteArrayInputStream(str.getBytes())); Plan plan = population.getPersons().get(Id.create(1, Person.class)).getSelectedPlan(); - Assert.assertEquals(5, plan.getPlanElements().size()); - Assert.assertTrue(plan.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(1) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(2) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(3) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(4) instanceof Activity); + Assertions.assertEquals(5, plan.getPlanElements().size()); + Assertions.assertTrue(plan.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(1) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(2) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(3) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(4) instanceof Activity); } @Test @@ -326,11 +326,11 @@ void testRepeatingActs() { reader.parse(new ByteArrayInputStream(str.getBytes())); Plan plan = population.getPersons().get(Id.create(1, Person.class)).getSelectedPlan(); - Assert.assertEquals(4, plan.getPlanElements().size()); - Assert.assertTrue(plan.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(1) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(2) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(3) instanceof Activity); + Assertions.assertEquals(4, plan.getPlanElements().size()); + Assertions.assertTrue(plan.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(1) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(2) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(3) instanceof Activity); } private static class XmlParserTestHelper { diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV5Test.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV5Test.java index d6e6c4b31d9..af11666b729 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV5Test.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationReaderMatsimV5Test.java @@ -26,7 +26,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Activity; @@ -107,32 +107,32 @@ void testReadRoute() throws SAXException, ParserConfigurationException, IOExcept tester.endTag(); - Assert.assertEquals("population size.", 2, population.getPersons().size()); + Assertions.assertEquals(2, population.getPersons().size(), "population size."); Person person1 = population.getPersons().get(Id.create("1", Person.class)); Plan plan1 = person1.getPlans().get(0); Leg leg1a = (Leg) plan1.getPlanElements().get(1); Route route1a = leg1a.getRoute(); - Assert.assertEquals("different startLink for first leg.", "1", route1a.getStartLinkId().toString()); - Assert.assertEquals("different endLink for first leg.", "20", route1a.getEndLinkId().toString()); + Assertions.assertEquals("1", route1a.getStartLinkId().toString(), "different startLink for first leg."); + Assertions.assertEquals("20", route1a.getEndLinkId().toString(), "different endLink for first leg."); Leg leg1b = (Leg) plan1.getPlanElements().get(3); Route route1b = leg1b.getRoute(); - Assert.assertEquals("different startLink for second leg.", "20", route1b.getStartLinkId().toString()); - Assert.assertEquals("different endLink for second leg.", "20", route1b.getEndLinkId().toString()); + Assertions.assertEquals("20", route1b.getStartLinkId().toString(), "different startLink for second leg."); + Assertions.assertEquals("20", route1b.getEndLinkId().toString(), "different endLink for second leg."); Leg leg1c = (Leg) plan1.getPlanElements().get(5); Route route1c = leg1c.getRoute(); - Assert.assertEquals("different startLink for third leg.", "20", route1c.getStartLinkId().toString()); - Assert.assertEquals("different endLink for third leg.", "1", route1c.getEndLinkId().toString()); + Assertions.assertEquals("20", route1c.getStartLinkId().toString(), "different startLink for third leg."); + Assertions.assertEquals("1", route1c.getEndLinkId().toString(), "different endLink for third leg."); Person person2 = population.getPersons().get(Id.create("2", Person.class)); Plan plan2 = person2.getPlans().get(0); Leg leg2a = (Leg) plan2.getPlanElements().get(1); Route route2a = leg2a.getRoute(); - Assert.assertEquals("different startLink for first leg.", "2", route2a.getStartLinkId().toString()); - Assert.assertEquals("different endLink for first leg.", "20", route2a.getEndLinkId().toString()); + Assertions.assertEquals("2", route2a.getStartLinkId().toString(), "different startLink for first leg."); + Assertions.assertEquals("20", route2a.getEndLinkId().toString(), "different endLink for first leg."); Leg leg2b = (Leg) plan2.getPlanElements().get(3); Route route2b = leg2b.getRoute(); - Assert.assertEquals("different startLink for third leg.", "20", route2b.getStartLinkId().toString()); - Assert.assertEquals("different endLink for third leg.", "1", route2b.getEndLinkId().toString()); + Assertions.assertEquals("20", route2b.getStartLinkId().toString(), "different startLink for third leg."); + Assertions.assertEquals("1", route2b.getEndLinkId().toString(), "different endLink for third leg."); } @Test @@ -164,11 +164,11 @@ void testReadRoute_sameLinkRoute() throws SAXException, ParserConfigurationExcep Plan plan1 = person1.getPlans().get(0); Leg leg1a = (Leg) plan1.getPlanElements().get(1); Route route1a = leg1a.getRoute(); - Assert.assertEquals("different startLink for first leg.", "1", route1a.getStartLinkId().toString()); - Assert.assertEquals("different endLink for first leg.", "1", route1a.getEndLinkId().toString()); - Assert.assertTrue(route1a instanceof NetworkRoute); + Assertions.assertEquals("1", route1a.getStartLinkId().toString(), "different startLink for first leg."); + Assertions.assertEquals("1", route1a.getEndLinkId().toString(), "different endLink for first leg."); + Assertions.assertTrue(route1a instanceof NetworkRoute); NetworkRoute nr = (NetworkRoute) route1a; - Assert.assertEquals(0, nr.getLinkIds().size()); + Assertions.assertEquals(0, nr.getLinkIds().size()); } @Test @@ -200,11 +200,11 @@ void testReadRoute_consequentLinks() throws SAXException, ParserConfigurationExc Plan plan1 = person1.getPlans().get(0); Leg leg1a = (Leg) plan1.getPlanElements().get(1); Route route1a = leg1a.getRoute(); - Assert.assertEquals("different startLink for first leg.", "1", route1a.getStartLinkId().toString()); - Assert.assertEquals("different endLink for first leg.", "2", route1a.getEndLinkId().toString()); - Assert.assertTrue(route1a instanceof NetworkRoute); + Assertions.assertEquals("1", route1a.getStartLinkId().toString(), "different startLink for first leg."); + Assertions.assertEquals("2", route1a.getEndLinkId().toString(), "different endLink for first leg."); + Assertions.assertTrue(route1a instanceof NetworkRoute); NetworkRoute nr = (NetworkRoute) route1a; - Assert.assertEquals(0, nr.getLinkIds().size()); + Assertions.assertEquals(0, nr.getLinkIds().size()); } /** @@ -237,12 +237,12 @@ void testReadRouteWithoutActivityLinks() { parser.endTag("person", null, context); parser.endTag("population", null, context); - Assert.assertEquals("population size.", 1, population.getPersons().size()); + Assertions.assertEquals(1, population.getPersons().size(), "population size."); Person person1 = population.getPersons().get(Id.create("981", Person.class)); Plan plan1 = person1.getPlans().get(0); Leg leg1 = (Leg) plan1.getPlanElements().get(1); Route route1 = leg1.getRoute(); - Assert.assertNotNull(route1); + Assertions.assertNotNull(route1); } @Test @@ -280,14 +280,14 @@ void testReadingOldRoutesWithoutType() { reader.parse(new ByteArrayInputStream(str.getBytes())); Plan plan = population.getPersons().get(Id.create(1, Person.class)).getSelectedPlan(); - Assert.assertEquals(7, plan.getPlanElements().size()); - Assert.assertTrue(plan.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(1) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(2) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(3) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(4) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(5) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(6) instanceof Activity); + Assertions.assertEquals(7, plan.getPlanElements().size()); + Assertions.assertTrue(plan.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(1) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(2) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(3) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(4) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(5) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(6) instanceof Activity); Leg leg1 = (Leg) plan.getPlanElements().get(1); Route route1 = leg1.getRoute(); @@ -296,9 +296,9 @@ void testReadingOldRoutesWithoutType() { Leg leg3 = (Leg) plan.getPlanElements().get(5); Route route3 = leg3.getRoute(); - Assert.assertTrue(route1 instanceof NetworkRoute); + Assertions.assertTrue(route1 instanceof NetworkRoute); // Assert.assertTrue(route2 instanceof GenericRouteImpl); - Assert.assertTrue(route3 instanceof TransitPassengerRoute); + Assertions.assertTrue(route3 instanceof TransitPassengerRoute); } @@ -325,11 +325,11 @@ void testReadActivity() { reader.endTag("person", "", context); reader.endTag("population", "", context); - Assert.assertEquals(1, population.getPersons().size()); + Assertions.assertEquals(1, population.getPersons().size()); Person person = population.getPersons().get(Id.create("2", Person.class)); Plan plan = person.getPlans().get(0); - Assert.assertEquals("3", ((Activity) plan.getPlanElements().get(0)).getLinkId().toString()); - Assert.assertEquals("2", ((Activity) plan.getPlanElements().get(2)).getLinkId().toString()); + Assertions.assertEquals("3", ((Activity) plan.getPlanElements().get(0)).getLinkId().toString()); + Assertions.assertEquals("2", ((Activity) plan.getPlanElements().get(2)).getLinkId().toString()); } @Test @@ -354,12 +354,12 @@ void testRepeatingLegs() { reader.parse(new ByteArrayInputStream(str.getBytes())); Plan plan = population.getPersons().get(Id.create(1, Person.class)).getSelectedPlan(); - Assert.assertEquals(5, plan.getPlanElements().size()); - Assert.assertTrue(plan.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(1) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(2) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(3) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(4) instanceof Activity); + Assertions.assertEquals(5, plan.getPlanElements().size()); + Assertions.assertTrue(plan.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(1) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(2) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(3) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(4) instanceof Activity); } @Test @@ -383,11 +383,11 @@ void testRepeatingActs() { reader.parse(new ByteArrayInputStream(str.getBytes())); Plan plan = population.getPersons().get(Id.create(1, Person.class)).getSelectedPlan(); - Assert.assertEquals(4, plan.getPlanElements().size()); - Assert.assertTrue(plan.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(1) instanceof Leg); - Assert.assertTrue(plan.getPlanElements().get(2) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(3) instanceof Activity); + Assertions.assertEquals(4, plan.getPlanElements().size()); + Assertions.assertTrue(plan.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(1) instanceof Leg); + Assertions.assertTrue(plan.getPlanElements().get(2) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(3) instanceof Activity); } @Test @@ -412,13 +412,13 @@ void testVehicleIdInRoute() { reader.parse(new ByteArrayInputStream(str.getBytes())); Plan plan = population.getPersons().get(Id.create(1, Person.class)).getSelectedPlan(); - Assert.assertEquals(3, plan.getPlanElements().size()); - Assert.assertTrue(plan.getPlanElements().get(0) instanceof Activity); - Assert.assertTrue(plan.getPlanElements().get(1) instanceof Leg); + Assertions.assertEquals(3, plan.getPlanElements().size()); + Assertions.assertTrue(plan.getPlanElements().get(0) instanceof Activity); + Assertions.assertTrue(plan.getPlanElements().get(1) instanceof Leg); Leg leg = (Leg) plan.getPlanElements().get(1) ; NetworkRoute route = (NetworkRoute) leg.getRoute() ; - Assert.assertEquals(Id.create("123", Vehicle.class), route.getVehicleId() ) ; - Assert.assertTrue(plan.getPlanElements().get(2) instanceof Activity); + Assertions.assertEquals(Id.create("123", Vehicle.class), route.getVehicleId() ) ; + Assertions.assertTrue(plan.getPlanElements().get(2) instanceof Activity); } private static class XmlParserTestHelper { diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java index adeec746849..6a2da5d5506 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationReprojectionIOIT.java @@ -27,7 +27,7 @@ import java.util.Iterator; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -52,7 +52,7 @@ import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; - /** + /** * @author thibautd */ public class PopulationReprojectionIOIT { @@ -190,10 +190,10 @@ void testWithControlerAndAttributes() { final List originalActivities = TripStructureUtils.getActivities( originalPerson.getSelectedPlan() , StageActivityHandling.StagesAsNormalActivities ); final List reprojectedActivities = TripStructureUtils.getActivities( internalPerson.getSelectedPlan() , StageActivityHandling.StagesAsNormalActivities ); - Assert.assertEquals( - "unexpected number of activities in reprojected plan", + Assertions.assertEquals( originalActivities.size(), - reprojectedActivities.size() ); + reprojectedActivities.size(), + "unexpected number of activities in reprojected plan" ); final Iterator originalIterator = originalActivities.iterator(); final Iterator reprojectedIterator = reprojectedActivities.iterator(); @@ -202,17 +202,17 @@ void testWithControlerAndAttributes() { final Activity o = originalIterator.next(); final Activity r = reprojectedIterator.next(); - Assert.assertNotEquals( - "No coordinates transform performed!", + Assertions.assertNotEquals( transformation.transform(o.getCoord()), - r); + r, + "No coordinates transform performed!"); } } - Assert.assertEquals( - "wrong CRS information after loading", + Assertions.assertEquals( TARGET_CRS, - ProjectionUtils.getCRS(scenario.getPopulation())); + ProjectionUtils.getCRS(scenario.getPopulation()), + "wrong CRS information after loading"); // do not perform ANY mobsim run config.controller().setLastIteration( -1 ); @@ -231,10 +231,10 @@ void testWithControlerAndAttributes() { final List internalActivities = TripStructureUtils.getActivities( internalPerson.getSelectedPlan() , StageActivityHandling.StagesAsNormalActivities ); final List reprojectedActivities = TripStructureUtils.getActivities( dumpedPerson.getSelectedPlan() , StageActivityHandling.StagesAsNormalActivities ); - Assert.assertEquals( - "unexpected number of activities in reprojected plan", + Assertions.assertEquals( internalActivities.size(), - reprojectedActivities.size() ); + reprojectedActivities.size(), + "unexpected number of activities in reprojected plan" ); final Iterator internalIterator = internalActivities.iterator(); final Iterator reprojectedIterator = reprojectedActivities.iterator(); @@ -243,16 +243,16 @@ void testWithControlerAndAttributes() { final Activity o = internalIterator.next(); final Activity r = reprojectedIterator.next(); - Assert.assertEquals( - "coordinates were reprojected for dump", + Assertions.assertEquals( o.getCoord().getX(), r.getCoord().getX(), - epsilon ); - Assert.assertEquals( - "coordinates were reprojected for dump", + epsilon, + "coordinates were reprojected for dump" ); + Assertions.assertEquals( o.getCoord().getY(), r.getCoord().getY(), - epsilon ); + epsilon, + "coordinates were reprojected for dump" ); } } } @@ -299,10 +299,10 @@ void testWithControlerAndConfigParameters() { final List originalActivities = TripStructureUtils.getActivities( originalPerson.getSelectedPlan() , StageActivityHandling.StagesAsNormalActivities ); final List reprojectedActivities = TripStructureUtils.getActivities( internalPerson.getSelectedPlan() , StageActivityHandling.StagesAsNormalActivities ); - Assert.assertEquals( - "unexpected number of activities in reprojected plan", + Assertions.assertEquals( originalActivities.size(), - reprojectedActivities.size() ); + reprojectedActivities.size(), + "unexpected number of activities in reprojected plan" ); final Iterator originalIterator = originalActivities.iterator(); final Iterator reprojectedIterator = reprojectedActivities.iterator(); @@ -311,10 +311,10 @@ void testWithControlerAndConfigParameters() { final Activity o = originalIterator.next(); final Activity r = reprojectedIterator.next(); - Assert.assertNotEquals( - "No coordinates transform performed!", + Assertions.assertNotEquals( transformation.transform(o.getCoord()), - r); + r, + "No coordinates transform performed!"); } } @@ -335,10 +335,10 @@ void testWithControlerAndConfigParameters() { final List internalActivities = TripStructureUtils.getActivities( internalPerson.getSelectedPlan() , StageActivityHandling.StagesAsNormalActivities ); final List reprojectedActivities = TripStructureUtils.getActivities( dumpedPerson.getSelectedPlan() , StageActivityHandling.StagesAsNormalActivities ); - Assert.assertEquals( - "unexpected number of activities in reprojected plan", + Assertions.assertEquals( internalActivities.size(), - reprojectedActivities.size() ); + reprojectedActivities.size(), + "unexpected number of activities in reprojected plan" ); final Iterator internalIterator = internalActivities.iterator(); final Iterator reprojectedIterator = reprojectedActivities.iterator(); @@ -347,16 +347,16 @@ void testWithControlerAndConfigParameters() { final Activity o = internalIterator.next(); final Activity r = reprojectedIterator.next(); - Assert.assertEquals( - "coordinates were reprojected for dump", + Assertions.assertEquals( o.getCoord().getX(), r.getCoord().getX(), - epsilon ); - Assert.assertEquals( - "coordinates were reprojected for dump", + epsilon, + "coordinates were reprojected for dump" ); + Assertions.assertEquals( o.getCoord().getY(), r.getCoord().getY(), - epsilon ); + epsilon, + "coordinates were reprojected for dump" ); } } } @@ -382,10 +382,10 @@ public void testConversionAtInput(final String inputFile) { private void assertPopulationCorrectlyTransformed( final Population originalPopulation, final Population reprojectedPopulation) { - Assert.assertEquals( - "unexpected size of reprojected population", + Assertions.assertEquals( originalPopulation.getPersons().size(), - reprojectedPopulation.getPersons().size()); + reprojectedPopulation.getPersons().size(), + "unexpected size of reprojected population"); for (Id personId : originalPopulation.getPersons().keySet()) { final Person originalPerson = originalPopulation.getPersons().get(personId); @@ -401,10 +401,10 @@ private void assertPlanCorrectlyTransformed( final List originalActivities = TripStructureUtils.getActivities( originalPlan , StageActivityHandling.StagesAsNormalActivities ); final List reprojectedActivities = TripStructureUtils.getActivities( reprojectedPlan , StageActivityHandling.StagesAsNormalActivities ); - Assert.assertEquals( - "unexpected number of activities in reprojected plan", + Assertions.assertEquals( originalActivities.size(), - reprojectedActivities.size() ); + reprojectedActivities.size(), + "unexpected number of activities in reprojected plan" ); final Iterator originalIterator = originalActivities.iterator(); final Iterator reprojectedIterator = reprojectedActivities.iterator(); @@ -420,10 +420,10 @@ private void assertPlanCorrectlyTransformed( private void assertIsCorrectlyTransformed( final Coord original , final Coord transformed ) { final Coord target = transformation.transform(original); - Assert.assertEquals( - "wrong reprojected value", + Assertions.assertEquals( target, - transformed); + transformed, + "wrong reprojected value"); } } diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java index b30030727e9..4e7005dc1df 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationV6IOTest.java @@ -21,7 +21,7 @@ package org.matsim.core.population.io; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -54,7 +54,7 @@ import java.util.Map; - /** + /** * @author thibautd */ public class PopulationV6IOTest { @@ -83,16 +83,16 @@ void testCoord3dIO() { final Activity readSpeach = (Activity) readPerson.getSelectedPlan().getPlanElements().get( 0 ); final Activity readTweet = (Activity) readPerson.getSelectedPlan().getPlanElements().get( 1 ); - Assert.assertFalse( "did not expect Z value in "+readSpeach.getCoord() , - readSpeach.getCoord().hasZ() ); + Assertions.assertFalse( readSpeach.getCoord().hasZ(), + "did not expect Z value in "+readSpeach.getCoord() ); - Assert.assertTrue( "did expect T value in "+readTweet.getCoord() , - readTweet.getCoord().hasZ() ); + Assertions.assertTrue( readTweet.getCoord().hasZ(), + "did expect T value in "+readTweet.getCoord() ); - Assert.assertEquals( "unexpected Z value in "+readTweet.getCoord(), - -100, + Assertions.assertEquals( -100, readTweet.getCoord().getZ(), - MatsimTestUtils.EPSILON ); + MatsimTestUtils.EPSILON, + "unexpected Z value in "+readTweet.getCoord() ); } @Test @@ -132,17 +132,17 @@ void testPersonAttributesIO() { final Person readPerson = readScenario.getPopulation().getPersons().get( Id.createPersonId( "Donald Trump" ) ); - Assert.assertEquals( "Unexpected boolean attribute in " + readPerson.getAttributes(), - person.getAttributes().getAttribute( "brain" ) , - readPerson.getAttributes().getAttribute( "brain" ) ); + Assertions.assertEquals( person.getAttributes().getAttribute( "brain" ) , + readPerson.getAttributes().getAttribute( "brain" ), + "Unexpected boolean attribute in " + readPerson.getAttributes() ); - Assert.assertEquals( "Unexpected String attribute in " + readPerson.getAttributes(), - person.getAttributes().getAttribute( "party" ) , - readPerson.getAttributes().getAttribute( "party" ) ); + Assertions.assertEquals( person.getAttributes().getAttribute( "party" ) , + readPerson.getAttributes().getAttribute( "party" ), + "Unexpected String attribute in " + readPerson.getAttributes() ); - Assert.assertEquals( "Unexpected PersonVehicle attribute in " + readPerson.getAttributes(), - VehicleUtils.getVehicleIds(person) , - VehicleUtils.getVehicleIds(readPerson) ); + Assertions.assertEquals( VehicleUtils.getVehicleIds(person) , + VehicleUtils.getVehicleIds(readPerson), + "Unexpected PersonVehicle attribute in " + readPerson.getAttributes() ); } @Test @@ -169,13 +169,13 @@ void testActivityAttributesIO() { final Person readPerson = readScenario.getPopulation().getPersons().get( Id.createPersonId( "Donald Trump" ) ); final Activity readAct = (Activity) readPerson.getSelectedPlan().getPlanElements().get( 0 ); - Assert.assertEquals( "Unexpected boolean attribute in " + readAct.getAttributes(), - act.getAttributes().getAttribute( "makes sense" ) , - readAct.getAttributes().getAttribute( "makes sense" ) ); + Assertions.assertEquals( act.getAttributes().getAttribute( "makes sense" ) , + readAct.getAttributes().getAttribute( "makes sense" ), + "Unexpected boolean attribute in " + readAct.getAttributes() ); - Assert.assertEquals( "Unexpected Long attribute in " + readAct.getAttributes(), - act.getAttributes().getAttribute( "length" ) , - readAct.getAttributes().getAttribute( "length" ) ); + Assertions.assertEquals( act.getAttributes().getAttribute( "length" ) , + readAct.getAttributes().getAttribute( "length" ), + "Unexpected Long attribute in " + readAct.getAttributes() ); } @Test @@ -204,12 +204,12 @@ void testLegAttributesIO() { final Person readPerson = readScenario.getPopulation().getPersons().get( Id.createPersonId( "Donald Trump" ) ); final Leg readLeg = (Leg) readPerson.getSelectedPlan().getPlanElements().get( 1 ); - Assert.assertEquals("Expected a single leg attribute.", 1, readLeg.getAttributes().size()); - Assert.assertEquals( "Unexpected Double attribute in " + readLeg.getAttributes(), - leg.getAttributes().getAttribute( "mpg" ) , - readLeg.getAttributes().getAttribute( "mpg" ) ); + Assertions.assertEquals(1, readLeg.getAttributes().size(), "Expected a single leg attribute."); + Assertions.assertEquals( leg.getAttributes().getAttribute( "mpg" ) , + readLeg.getAttributes().getAttribute( "mpg" ), + "Unexpected Double attribute in " + readLeg.getAttributes() ); - Assert.assertEquals("RoutingMode not set in Leg.", TransportMode.car, readLeg.getRoutingMode()); + Assertions.assertEquals(TransportMode.car, readLeg.getRoutingMode(), "RoutingMode not set in Leg."); } @Test @@ -238,12 +238,12 @@ void testLegAttributesLegacyIO() { final Person readPerson = readScenario.getPopulation().getPersons().get( Id.createPersonId( "Donald Trump" ) ); final Leg readLeg = (Leg) readPerson.getSelectedPlan().getPlanElements().get( 1 ); - Assert.assertEquals("Expected a single leg attribute.", 1, readLeg.getAttributes().size()); - Assert.assertEquals( "Unexpected Double attribute in " + readLeg.getAttributes(), - leg.getAttributes().getAttribute( "mpg" ) , - readLeg.getAttributes().getAttribute( "mpg" ) ); + Assertions.assertEquals(1, readLeg.getAttributes().size(), "Expected a single leg attribute."); + Assertions.assertEquals( leg.getAttributes().getAttribute( "mpg" ) , + readLeg.getAttributes().getAttribute( "mpg" ), + "Unexpected Double attribute in " + readLeg.getAttributes() ); - Assert.assertEquals("RoutingMode not set in Leg.", TransportMode.car, readLeg.getRoutingMode()); + Assertions.assertEquals(TransportMode.car, readLeg.getRoutingMode(), "RoutingMode not set in Leg."); } @Test @@ -271,7 +271,7 @@ void testPlanAttributesIO() { final Person readPerson = readScenario.getPopulation().getPersons().get( Id.createPersonId( "Donald Trump" ) ); final Plan readPlan = readPerson.getSelectedPlan() ; - Assert.assertEquals( plan.getAttributes().getAttribute( "beauty" ) , + Assertions.assertEquals( plan.getAttributes().getAttribute( "beauty" ) , readPlan.getAttributes().getAttribute( "beauty" ) ); } @@ -288,13 +288,13 @@ void testPopulationAttributesIO() { final Scenario readScenario = ScenarioUtils.createScenario( ConfigUtils.createConfig() ); new PopulationReader( readScenario ).readFile( file ); - Assert.assertEquals( "Unexpected numeric attribute in " + readScenario.getPopulation().getAttributes(), - population.getAttributes().getAttribute( "number" ) , - readScenario.getPopulation().getAttributes().getAttribute( "number" ) ); + Assertions.assertEquals( population.getAttributes().getAttribute( "number" ) , + readScenario.getPopulation().getAttributes().getAttribute( "number" ), + "Unexpected numeric attribute in " + readScenario.getPopulation().getAttributes() ); - Assert.assertEquals( "Unexpected String attribute in " + readScenario.getPopulation().getAttributes(), - population.getAttributes().getAttribute( "type" ) , - readScenario.getPopulation().getAttributes().getAttribute( "type" ) ); + Assertions.assertEquals( population.getAttributes().getAttribute( "type" ) , + readScenario.getPopulation().getAttributes().getAttribute( "type" ), + "Unexpected String attribute in " + readScenario.getPopulation().getAttributes() ); } // see MATSIM-927, https://matsim.atlassian.net/browse/MATSIM-927 @@ -329,7 +329,7 @@ void testRouteIO() { ByteArrayInputStream in = new ByteArrayInputStream(out.toByteArray()); new PopulationReader(scenario).parse(in); - Assert.assertEquals(route.getRouteDescription(), ((Leg) scenario.getPopulation().getPersons().get(person1.getId()).getSelectedPlan().getPlanElements().get(1)).getRoute().getRouteDescription()); + Assertions.assertEquals(route.getRouteDescription(), ((Leg) scenario.getPopulation().getPersons().get(person1.getId()).getSelectedPlan().getPlanElements().get(1)).getRoute().getRouteDescription()); } // inspired from MATSIM-927, https://matsim.atlassian.net/browse/MATSIM-927 @@ -373,10 +373,10 @@ void testSpecialCharactersIO() { Person p1 = scenario.getPopulation().getPersons().get(person1.getId()); // this already checks the id Plan pl1 = p1.getSelectedPlan(); - Assert.assertEquals(act1.getType(), ((Activity) pl1.getPlanElements().get(0)).getType()); - Assert.assertEquals(act1.getLinkId(), ((Activity) pl1.getPlanElements().get(0)).getLinkId()); + Assertions.assertEquals(act1.getType(), ((Activity) pl1.getPlanElements().get(0)).getType()); + Assertions.assertEquals(act1.getLinkId(), ((Activity) pl1.getPlanElements().get(0)).getLinkId()); - Assert.assertEquals(route.getRouteDescription(), ((Leg) scenario.getPopulation().getPersons().get(person1.getId()).getSelectedPlan().getPlanElements().get(1)).getRoute().getRouteDescription()); + Assertions.assertEquals(route.getRouteDescription(), ((Leg) scenario.getPopulation().getPersons().get(person1.getId()).getSelectedPlan().getPlanElements().get(1)).getRoute().getRouteDescription()); } @Test @@ -419,17 +419,17 @@ void testSingleActivityLocationInfoIO() { Person p1 = scenario.getPopulation().getPersons().get(person1.getId()); Plan pp1 = p1.getPlans().get(0); - Assert.assertEquals(((Activity) pp1.getPlanElements().get(0)).getFacilityId(), facilityId); - Assert.assertNull(((Activity) pp1.getPlanElements().get(0)).getCoord()); - Assert.assertNull(((Activity) pp1.getPlanElements().get(0)).getLinkId()); + Assertions.assertEquals(((Activity) pp1.getPlanElements().get(0)).getFacilityId(), facilityId); + Assertions.assertNull(((Activity) pp1.getPlanElements().get(0)).getCoord()); + Assertions.assertNull(((Activity) pp1.getPlanElements().get(0)).getLinkId()); - Assert.assertNull(((Activity) pp1.getPlanElements().get(2)).getFacilityId()); - Assert.assertEquals(((Activity) pp1.getPlanElements().get(2)).getCoord(), coord); - Assert.assertNull(((Activity) pp1.getPlanElements().get(2)).getLinkId()); + Assertions.assertNull(((Activity) pp1.getPlanElements().get(2)).getFacilityId()); + Assertions.assertEquals(((Activity) pp1.getPlanElements().get(2)).getCoord(), coord); + Assertions.assertNull(((Activity) pp1.getPlanElements().get(2)).getLinkId()); - Assert.assertNull(((Activity) pp1.getPlanElements().get(4)).getFacilityId()); - Assert.assertNull(((Activity) pp1.getPlanElements().get(4)).getCoord()); - Assert.assertEquals(((Activity) pp1.getPlanElements().get(4)).getLinkId(), linkId); + Assertions.assertNull(((Activity) pp1.getPlanElements().get(4)).getFacilityId()); + Assertions.assertNull(((Activity) pp1.getPlanElements().get(4)).getCoord()); + Assertions.assertEquals(((Activity) pp1.getPlanElements().get(4)).getLinkId(), linkId); } @Test @@ -457,8 +457,8 @@ void testPopulationCoordinateTransformationIO() { reader.readFile(outputDirectory + "output.xml"); Person inputPerson = scenario.getPopulation().getPersons().values().iterator().next(); Activity act = (Activity) inputPerson.getPlans().get(0).getPlanElements().get(0); - Assert.assertEquals(10.911495969392414, act.getCoord().getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals(2.3202288392002424, act.getCoord().getY(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(10.911495969392414, act.getCoord().getX(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2.3202288392002424, act.getCoord().getY(), MatsimTestUtils.EPSILON); } diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java index 1de5e13e690..ba414a38881 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV4Test.java @@ -20,7 +20,7 @@ package org.matsim.core.population.io; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java index a28f6de0734..fef85f401fb 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java +++ b/matsim/src/test/java/org/matsim/core/population/io/PopulationWriterHandlerImplV5Test.java @@ -23,7 +23,7 @@ import java.util.List; import java.util.Stack; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -104,14 +104,14 @@ private NetworkRoute doTestWriteNetworkRoute(final String startLinkId, final Str Person person2 = pop2.getPersons().get(Id.create(1, Person.class)); Leg leg2 = (Leg) person2.getPlans().get(0).getPlanElements().get(1); Route route2 = leg2.getRoute(); - Assert.assertEquals(expectedRouteSerialization, popReader.interceptedRouteContent.trim()); - Assert.assertTrue("read route is of class " + route2.getClass().getCanonicalName(), route2 instanceof NetworkRoute); + Assertions.assertEquals(expectedRouteSerialization, popReader.interceptedRouteContent.trim()); + Assertions.assertTrue(route2 instanceof NetworkRoute, "read route is of class " + route2.getClass().getCanonicalName()); NetworkRoute nr = (NetworkRoute) route2; - Assert.assertEquals("wrong start link", startLinkId, nr.getStartLinkId().toString()); - Assert.assertEquals("wrong end link", endLinkId, nr.getEndLinkId().toString()); - Assert.assertEquals("wrong number of links in route", routeLinkIds.size(), nr.getLinkIds().size()); + Assertions.assertEquals(startLinkId, nr.getStartLinkId().toString(), "wrong start link"); + Assertions.assertEquals(endLinkId, nr.getEndLinkId().toString(), "wrong end link"); + Assertions.assertEquals(routeLinkIds.size(), nr.getLinkIds().size(), "wrong number of links in route"); for (int i = 0; i < routeLinkIds.size(); i++) { - Assert.assertEquals("wrong link in route at position " + i, routeLinkIds.get(i), nr.getLinkIds().get(i)); + Assertions.assertEquals(routeLinkIds.get(i), nr.getLinkIds().get(i), "wrong link in route at position " + i); } return nr; } @@ -152,10 +152,10 @@ void testWriteGenericRouteRoute() { Leg leg2 = (Leg) person2.getPlans().get(0).getPlanElements().get(1); Route route2 = leg2.getRoute(); // Assert.assertTrue("read route is of class " + route2.getClass().getCanonicalName(), route2 instanceof GenericRouteImpl); - Assert.assertEquals("wrong start link", startLinkId, route2.getStartLinkId().toString()); - Assert.assertEquals("wrong end link", endLinkId, route2.getEndLinkId().toString()); - Assert.assertEquals("wrong travel time", travTime, route2.getTravelTime().seconds(), 1e-9); - Assert.assertEquals("wrong distance", dist, route2.getDistance(), 1e-9); + Assertions.assertEquals(startLinkId, route2.getStartLinkId().toString(), "wrong start link"); + Assertions.assertEquals(endLinkId, route2.getEndLinkId().toString(), "wrong end link"); + Assertions.assertEquals(travTime, route2.getTravelTime().seconds(), 1e-9, "wrong travel time"); + Assertions.assertEquals(dist, route2.getDistance(), 1e-9, "wrong distance"); } private static final class RouteInterceptingPopulationReader extends MatsimXmlParser implements MatsimReader { diff --git a/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java b/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java index add49f76e92..0e1220ac877 100644 --- a/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/core/population/io/StreamingPopulationAttributeConversionTest.java @@ -25,7 +25,7 @@ import java.util.function.BiConsumer; import java.util.function.Consumer; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -85,10 +85,10 @@ public void testWriteAndRereadStreaming( final Person readPerson = readScenario.getPopulation().getPersons().get(personId0); final Object readAttribute = readPerson.getAttributes().getAttribute("job"); - Assert.assertEquals( - "unexpected read attribute", + Assertions.assertEquals( attribute, - readAttribute); + readAttribute, + "unexpected read attribute"); } private static class CustomClass { diff --git a/matsim/src/test/java/org/matsim/core/population/routes/AbstractNetworkRouteTest.java b/matsim/src/test/java/org/matsim/core/population/routes/AbstractNetworkRouteTest.java index b3410153f72..d2c3542b04a 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/AbstractNetworkRouteTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/AbstractNetworkRouteTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -59,12 +59,12 @@ void testSetLinkIds() { route.setLinkIds(link11, links, link15); List> linkIds = route.getLinkIds(); - Assert.assertEquals("number of links in route.", 5, linkIds.size()); - Assert.assertEquals(Id.create("-22", Link.class), linkIds.get(0)); - Assert.assertEquals(Id.create("2", Link.class), linkIds.get(1)); - Assert.assertEquals(Id.create("3", Link.class), linkIds.get(2)); - Assert.assertEquals(Id.create("24", Link.class), linkIds.get(3)); - Assert.assertEquals(Id.create("14", Link.class), linkIds.get(4)); + Assertions.assertEquals(5, linkIds.size(), "number of links in route."); + Assertions.assertEquals(Id.create("-22", Link.class), linkIds.get(0)); + Assertions.assertEquals(Id.create("2", Link.class), linkIds.get(1)); + Assertions.assertEquals(Id.create("3", Link.class), linkIds.get(2)); + Assertions.assertEquals(Id.create("24", Link.class), linkIds.get(3)); + Assertions.assertEquals(Id.create("14", Link.class), linkIds.get(4)); } @Test @@ -83,7 +83,7 @@ void testSetLinks_linksNull() { Id link2 = Id.create("2", Link.class); route.setLinkIds(link1, null, link2); List> linkIds2 = route.getLinkIds(); - Assert.assertEquals("number of links in route.", 0, linkIds2.size()); + Assertions.assertEquals(0, linkIds2.size(), "number of links in route."); } } @@ -102,7 +102,7 @@ void testSetLinks_AllNull() { { route.setLinkIds(null, null, null); List> linkIds = route.getLinkIds(); - Assert.assertEquals("number of nodes in route.", 0, linkIds.size()); + Assertions.assertEquals(0, linkIds.size(), "number of nodes in route."); } } @@ -115,7 +115,7 @@ void testGetDistance() { route.setLinkIds(link1, NetworkUtils.getLinkIds("22 12 -23 3"), link4); route.setDistance(1234.5); - Assert.assertEquals("wrong difference.", 1234.5, route.getDistance(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1234.5, route.getDistance(), MatsimTestUtils.EPSILON, "wrong difference."); } @Test @@ -127,11 +127,11 @@ void testGetLinkIds() { route.setLinkIds(link1, NetworkUtils.getLinkIds("22 12 -23 3"), link4); List> ids = route.getLinkIds(); - Assert.assertEquals("number of links in route.", 4, ids.size()); - Assert.assertEquals(Id.create("22", Link.class), ids.get(0)); - Assert.assertEquals(Id.create("12", Link.class), ids.get(1)); - Assert.assertEquals(Id.create("-23", Link.class), ids.get(2)); - Assert.assertEquals(Id.create("3", Link.class), ids.get(3)); + Assertions.assertEquals(4, ids.size(), "number of links in route."); + Assertions.assertEquals(Id.create("22", Link.class), ids.get(0)); + Assertions.assertEquals(Id.create("12", Link.class), ids.get(1)); + Assertions.assertEquals(Id.create("-23", Link.class), ids.get(2)); + Assertions.assertEquals(Id.create("3", Link.class), ids.get(3)); } @Test @@ -148,11 +148,11 @@ void testGetSubRoute() { NetworkRoute subRoute = route.getSubRoute(id12, id24); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 2, linkIds.size()); - Assert.assertEquals(id23m, linkIds.get(0)); - Assert.assertEquals(id3, linkIds.get(1)); - Assert.assertEquals("wrong start link.", id12, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id24, subRoute.getEndLinkId()); + Assertions.assertEquals(2, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(id23m, linkIds.get(0)); + Assertions.assertEquals(id3, linkIds.get(1)); + Assertions.assertEquals(id12, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id24, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -170,13 +170,13 @@ void testGetSubRoute_fromStart() { NetworkRoute subRoute = route.getSubRoute(id0, id3); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 4, linkIds.size()); - Assert.assertEquals(id1, linkIds.get(0)); - Assert.assertEquals(id22, linkIds.get(1)); - Assert.assertEquals(id12, linkIds.get(2)); - Assert.assertEquals(id23m, linkIds.get(3)); - Assert.assertEquals("wrong start link.", id0, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id3, subRoute.getEndLinkId()); + Assertions.assertEquals(4, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(id1, linkIds.get(0)); + Assertions.assertEquals(id22, linkIds.get(1)); + Assertions.assertEquals(id12, linkIds.get(2)); + Assertions.assertEquals(id23m, linkIds.get(3)); + Assertions.assertEquals(id0, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id3, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -192,11 +192,11 @@ void testGetSubRoute_toEnd() { NetworkRoute subRoute = route.getSubRoute(id23m, id15); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 3, linkIds.size()); - Assert.assertEquals(id3, linkIds.get(0)); - Assert.assertEquals(id24, linkIds.get(1)); - Assert.assertEquals("wrong start link.", id23m, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id15, subRoute.getEndLinkId()); + Assertions.assertEquals(3, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(id3, linkIds.get(0)); + Assertions.assertEquals(id24, linkIds.get(1)); + Assertions.assertEquals(id23m, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id15, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -209,9 +209,9 @@ void testGetSubRoute_startOnly() { NetworkRoute subRoute = route.getSubRoute(id0, id0); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 0, linkIds.size()); - Assert.assertEquals("wrong start link.", id0, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id0, subRoute.getEndLinkId()); + Assertions.assertEquals(0, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(id0, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id0, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -224,9 +224,9 @@ void testGetSubRoute_endOnly() { NetworkRoute subRoute = route.getSubRoute(id15, id15); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 0, linkIds.size()); - Assert.assertEquals("wrong start link.", id15, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id15, subRoute.getEndLinkId()); + Assertions.assertEquals(0, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(id15, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id15, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -240,7 +240,7 @@ void testGetSubRoute_wrongStart() { try { route.getSubRoute(id0, id15); - Assert.fail("expected IllegalArgumentException, but it did not happen."); + Assertions.fail("expected IllegalArgumentException, but it did not happen."); } catch (IllegalArgumentException expected) { log.info("catched expected exception: " + expected.getMessage()); } @@ -257,7 +257,7 @@ void testGetSubRoute_wrongEnd() { try { route.getSubRoute(id1, id15); - Assert.fail("expected IllegalArgumentException, but it did not happen."); + Assertions.fail("expected IllegalArgumentException, but it did not happen."); } catch (IllegalArgumentException expected) { log.info("catched expected exception: " + expected.getMessage()); } @@ -274,9 +274,9 @@ void testGetSubRoute_sameLinks() { NetworkRoute subRoute = route.getSubRoute(id12, id12); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 0, linkIds.size()); - Assert.assertEquals("wrong start link.", id12, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id12, subRoute.getEndLinkId()); + Assertions.assertEquals(0, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(id12, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id12, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -288,9 +288,9 @@ void testGetSubRoute_sameLinks_emptyRoute1() { NetworkRoute subRoute = route.getSubRoute(id1, id1); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 0, linkIds.size()); - Assert.assertEquals("wrong start link.", id1, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id1, subRoute.getEndLinkId()); + Assertions.assertEquals(0, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(id1, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id1, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -303,15 +303,15 @@ void testGetSubRoute_sameLinks_emptyRoute2() { NetworkRoute subRoute = route.getSubRoute(id1, id1); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 0, linkIds.size()); - Assert.assertEquals("wrong start link.", id1, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id1, subRoute.getEndLinkId()); + Assertions.assertEquals(0, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(id1, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id1, subRoute.getEndLinkId(), "wrong end link."); NetworkRoute subRoute2 = route.getSubRoute(id2, id2); List> linkIds2 = subRoute2.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 0, linkIds2.size()); - Assert.assertEquals("wrong start link.", id2, subRoute2.getStartLinkId()); - Assert.assertEquals("wrong end link.", id2, subRoute2.getEndLinkId()); + Assertions.assertEquals(0, linkIds2.size(), "number of links in subRoute."); + Assertions.assertEquals(id2, subRoute2.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id2, subRoute2.getEndLinkId(), "wrong end link."); } @Test @@ -324,14 +324,14 @@ void testGetSubRoute_fullRoute() { NetworkRoute subRoute = route.getSubRoute(id0, id4); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 5, linkIds.size()); - Assert.assertEquals("wrong link.", Id.create("1", Link.class), subRoute.getLinkIds().get(0)); - Assert.assertEquals("wrong link.", Id.create("22", Link.class), subRoute.getLinkIds().get(1)); - Assert.assertEquals("wrong link.", Id.create("12", Link.class), subRoute.getLinkIds().get(2)); - Assert.assertEquals("wrong link.", Id.create("-23", Link.class), subRoute.getLinkIds().get(3)); - Assert.assertEquals("wrong link.", Id.create("3", Link.class), subRoute.getLinkIds().get(4)); - Assert.assertEquals("wrong start link.", id0, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id4, subRoute.getEndLinkId()); + Assertions.assertEquals(5, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(Id.create("1", Link.class), subRoute.getLinkIds().get(0), "wrong link."); + Assertions.assertEquals(Id.create("22", Link.class), subRoute.getLinkIds().get(1), "wrong link."); + Assertions.assertEquals(Id.create("12", Link.class), subRoute.getLinkIds().get(2), "wrong link."); + Assertions.assertEquals(Id.create("-23", Link.class), subRoute.getLinkIds().get(3), "wrong link."); + Assertions.assertEquals(Id.create("3", Link.class), subRoute.getLinkIds().get(4), "wrong link."); + Assertions.assertEquals(id0, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id4, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -347,14 +347,14 @@ void testGetSubRoute_circleInRoute() { Id id14 = Id.create("14", Link.class); NetworkRoute subRoute = route.getSubRoute(id12, id14); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 5, linkIds.size()); - Assert.assertEquals("wrong link.", Id.create("13", Link.class), subRoute.getLinkIds().get(0)); - Assert.assertEquals("wrong link.", Id.create("-24", Link.class), subRoute.getLinkIds().get(1)); - Assert.assertEquals("wrong link.", Id.create("-3", Link.class), subRoute.getLinkIds().get(2)); - Assert.assertEquals("wrong link.", Id.create("23", Link.class), subRoute.getLinkIds().get(3)); - Assert.assertEquals("wrong link.", Id.create("13", Link.class), subRoute.getLinkIds().get(4)); - Assert.assertEquals("wrong start link.", id12, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id14, subRoute.getEndLinkId()); + Assertions.assertEquals(5, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(Id.create("13", Link.class), subRoute.getLinkIds().get(0), "wrong link."); + Assertions.assertEquals(Id.create("-24", Link.class), subRoute.getLinkIds().get(1), "wrong link."); + Assertions.assertEquals(Id.create("-3", Link.class), subRoute.getLinkIds().get(2), "wrong link."); + Assertions.assertEquals(Id.create("23", Link.class), subRoute.getLinkIds().get(3), "wrong link."); + Assertions.assertEquals(Id.create("13", Link.class), subRoute.getLinkIds().get(4), "wrong link."); + Assertions.assertEquals(id12, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id14, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -370,11 +370,11 @@ void testGetSubRoute_startInCircle() { Id id23 = Id.create("23", Link.class); NetworkRoute subRoute = route.getSubRoute(id13, id23); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 2, linkIds.size()); - Assert.assertEquals("wrong link.", Id.create("-24", Link.class), subRoute.getLinkIds().get(0)); - Assert.assertEquals("wrong link.", Id.create("-3", Link.class), subRoute.getLinkIds().get(1)); - Assert.assertEquals("wrong start link.", id13, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id23, subRoute.getEndLinkId()); + Assertions.assertEquals(2, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(Id.create("-24", Link.class), subRoute.getLinkIds().get(0), "wrong link."); + Assertions.assertEquals(Id.create("-3", Link.class), subRoute.getLinkIds().get(1), "wrong link."); + Assertions.assertEquals(id13, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id23, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -389,11 +389,11 @@ void testGetSubRoute_startInCircle_CircleInEnd() { Id id_24 = Id.create("-24", Link.class); NetworkRoute subRoute = route.getSubRoute(id_24, id13); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 2, linkIds.size()); - Assert.assertEquals("wrong link.", Id.create("-3", Link.class), subRoute.getLinkIds().get(0)); - Assert.assertEquals("wrong link.", Id.create("23", Link.class), subRoute.getLinkIds().get(1)); - Assert.assertEquals("wrong start link.", id_24, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id13, subRoute.getEndLinkId()); + Assertions.assertEquals(2, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(Id.create("-3", Link.class), subRoute.getLinkIds().get(0), "wrong link."); + Assertions.assertEquals(Id.create("23", Link.class), subRoute.getLinkIds().get(1), "wrong link."); + Assertions.assertEquals(id_24, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id13, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -407,10 +407,10 @@ void testGetSubRoute_CircleAtStart() { NetworkRoute subRoute = route.getSubRoute(id13, id15); List> linkIds = subRoute.getLinkIds(); - Assert.assertEquals("number of links in subRoute.", 1, linkIds.size()); - Assert.assertEquals("wrong link.", Id.create("14", Link.class), subRoute.getLinkIds().get(0)); - Assert.assertEquals("wrong start link.", id13, subRoute.getStartLinkId()); - Assert.assertEquals("wrong end link.", id15, subRoute.getEndLinkId()); + Assertions.assertEquals(1, linkIds.size(), "number of links in subRoute."); + Assertions.assertEquals(Id.create("14", Link.class), subRoute.getLinkIds().get(0), "wrong link."); + Assertions.assertEquals(id13, subRoute.getStartLinkId(), "wrong start link."); + Assertions.assertEquals(id15, subRoute.getEndLinkId(), "wrong end link."); } @Test @@ -419,7 +419,7 @@ void testStartAndEndOnSameLinks_setLinks() { Id link = Id.create("3", Link.class); NetworkRoute route = getNetworkRouteInstance(link, link, network); route.setLinkIds(link, new ArrayList>(0), link); - Assert.assertEquals(0, route.getLinkIds().size()); + Assertions.assertEquals(0, route.getLinkIds().size()); } @Test @@ -429,7 +429,7 @@ void testStartAndEndOnSubsequentLinks_setLinks() { final Id link14 = Id.create("14", Link.class); NetworkRoute route = getNetworkRouteInstance(link13, link14, network); route.setLinkIds(link13, new ArrayList>(0), link14); - Assert.assertEquals(0, route.getLinkIds().size()); + Assertions.assertEquals(0, route.getLinkIds().size()); } @Test @@ -438,12 +438,12 @@ void testVehicleId() { Id link0 = Id.create("0", Link.class); Id link15 = Id.create("15", Link.class); NetworkRoute route = getNetworkRouteInstance(link0, link15, network); - Assert.assertNull(route.getVehicleId()); + Assertions.assertNull(route.getVehicleId()); Id id = Id.create("8134", Vehicle.class); route.setVehicleId(id); - Assert.assertEquals(id, route.getVehicleId()); + Assertions.assertEquals(id, route.getVehicleId()); route.setVehicleId(null); - Assert.assertNull(route.getVehicleId()); + Assertions.assertNull(route.getVehicleId()); } protected Network createTestNetwork() { diff --git a/matsim/src/test/java/org/matsim/core/population/routes/LinkNetworkRouteTest.java b/matsim/src/test/java/org/matsim/core/population/routes/LinkNetworkRouteTest.java index 82fcb5fb6d7..f06574e1ca5 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/LinkNetworkRouteTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/LinkNetworkRouteTest.java @@ -22,7 +22,7 @@ import java.util.ArrayList; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -56,15 +56,15 @@ void testClone() { srcRoute.add(link3.getId()); srcRoute.add(link4.getId()); route1.setLinkIds(startLink.getId(), srcRoute, endLink.getId()); - Assert.assertEquals(2, route1.getLinkIds().size()); + Assertions.assertEquals(2, route1.getLinkIds().size()); NetworkRoute route2 = (NetworkRoute) route1.clone(); srcRoute.add(link5.getId()); route1.setLinkIds(startLink.getId(), srcRoute, endLink.getId()); - Assert.assertEquals(3, route1.getLinkIds().size()); - Assert.assertEquals(2, route2.getLinkIds().size()); + Assertions.assertEquals(3, route1.getLinkIds().size()); + Assertions.assertEquals(2, route2.getLinkIds().size()); } } diff --git a/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java b/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java index 4288ce19e19..4477b446823 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/NetworkFactoryTest.java @@ -20,7 +20,7 @@ package org.matsim.core.population.routes; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -114,10 +114,10 @@ void testSetRouteFactory() { // test default Route carRoute = factory.getRouteFactories().createRoute(NetworkRoute.class, null, null); - Assert.assertTrue(carRoute instanceof NetworkRoute); + Assertions.assertTrue(carRoute instanceof NetworkRoute); Route route = factory.getRouteFactories().createRoute(Route.class, null, null); - Assert.assertTrue(route instanceof GenericRouteImpl); + Assertions.assertTrue(route instanceof GenericRouteImpl); // overwrite car-mode factory.getRouteFactories().setRouteFactory(CarRouteMock.class, new CarRouteMockFactory()); @@ -126,18 +126,18 @@ void testSetRouteFactory() { // test car-mode carRoute = factory.getRouteFactories().createRoute(CarRouteMock.class, null, null); - Assert.assertTrue(carRoute instanceof CarRouteMock); + Assertions.assertTrue(carRoute instanceof CarRouteMock); // add pt-mode Route ptRoute = factory.getRouteFactories().createRoute(PtRouteMock.class, null, null); - Assert.assertTrue(ptRoute instanceof PtRouteMock); + Assertions.assertTrue(ptRoute instanceof PtRouteMock); // remove pt-mode factory.getRouteFactories().setRouteFactory(PtRouteMock.class, null); // test pt again route = factory.getRouteFactories().createRoute(PtRouteMock.class, null, null); - Assert.assertTrue(route instanceof GenericRouteImpl); + Assertions.assertTrue(route instanceof GenericRouteImpl); } diff --git a/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryImplTest.java b/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryImplTest.java index 943fb3c9adc..a058cde481a 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryImplTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryImplTest.java @@ -18,6 +18,7 @@ * *********************************************************************** */ package org.matsim.core.population.routes; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -31,8 +32,6 @@ import org.matsim.core.population.routes.mediumcompressed.MediumCompressedNetworkRoute; import org.matsim.core.scenario.ScenarioUtils; -import org.junit.Assert; - /** * @author mrieser / senozon */ @@ -47,7 +46,7 @@ void testConstructor_DefaultNetworkRouteType() { Id linkId = Id.create(1, Link.class); final Id startLinkId = linkId; final Id endLinkId = linkId; - Assert.assertEquals(GenericRouteImpl.class, pf.getRouteFactories().createRoute(Route.class, startLinkId, endLinkId).getClass()); + Assertions.assertEquals(GenericRouteImpl.class, pf.getRouteFactories().createRoute(Route.class, startLinkId, endLinkId).getClass()); } @Test @@ -60,7 +59,7 @@ void testConstructor_LinkNetworkRouteType() { Id linkId = Id.create(1, Link.class); final Id startLinkId = linkId; final Id endLinkId = linkId; - Assert.assertEquals(LinkNetworkRouteImpl.class, pf.getRouteFactories().createRoute(NetworkRoute.class, startLinkId, endLinkId).getClass()); + Assertions.assertEquals(LinkNetworkRouteImpl.class, pf.getRouteFactories().createRoute(NetworkRoute.class, startLinkId, endLinkId).getClass()); } @Test @@ -73,7 +72,7 @@ void testConstructor_HeavyCompressedNetworkRouteType() { Id linkId = Id.create(1, Link.class); final Id startLinkId = linkId; final Id endLinkId = linkId; - Assert.assertEquals(HeavyCompressedNetworkRoute.class, pf.getRouteFactories().createRoute(NetworkRoute.class, startLinkId, endLinkId).getClass()); + Assertions.assertEquals(HeavyCompressedNetworkRoute.class, pf.getRouteFactories().createRoute(NetworkRoute.class, startLinkId, endLinkId).getClass()); } @Test @@ -86,7 +85,7 @@ void testConstructor_MediumCompressedNetworkRouteType() { Id linkId = Id.create(1, Link.class); final Id startLinkId = linkId; final Id endLinkId = linkId; - Assert.assertEquals(MediumCompressedNetworkRoute.class, pf.getRouteFactories().createRoute(NetworkRoute.class, startLinkId, endLinkId).getClass()); + Assertions.assertEquals(MediumCompressedNetworkRoute.class, pf.getRouteFactories().createRoute(NetworkRoute.class, startLinkId, endLinkId).getClass()); } } diff --git a/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java b/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java index 25b4b0ba526..dfab4c52794 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/RouteFactoryIntegrationTest.java @@ -20,7 +20,7 @@ package org.matsim.core.population.routes; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.TransportMode; @@ -77,7 +77,7 @@ void testRouteFactoryIntegration() { if (pe instanceof Leg) { Leg leg = (Leg) pe; Route route = leg.getRoute(); - Assert.assertTrue(route instanceof NetworkRoute || route instanceof GenericRouteImpl ); // that must be different from the class used below + Assertions.assertTrue(route instanceof NetworkRoute || route instanceof GenericRouteImpl ); // that must be different from the class used below // yy I added the "|| route instanceof GenericRouteImpl" to compensate for the added walk legs; a more precise // test would be better. kai, feb'16 } @@ -105,8 +105,8 @@ void testRouteFactoryIntegration() { if (pe instanceof Leg) { Leg leg = (Leg) pe; Route route = leg.getRoute(); - Assert.assertTrue("person: " + person.getId() + "; plan: " + planCounter, - route instanceof HeavyCompressedNetworkRoute || route instanceof GenericRouteImpl ); + Assertions.assertTrue(route instanceof HeavyCompressedNetworkRoute || route instanceof GenericRouteImpl, + "person: " + person.getId() + "; plan: " + planCounter ); // yy I added the "|| route instanceof GenericRouteImpl" to compensate for the added walk legs; a more precise // test would be better. kai, feb'16 } diff --git a/matsim/src/test/java/org/matsim/core/population/routes/heavycompressed/HeavyCompressedNetworkRouteTest.java b/matsim/src/test/java/org/matsim/core/population/routes/heavycompressed/HeavyCompressedNetworkRouteTest.java index ed788d2cb1a..676caca941e 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/heavycompressed/HeavyCompressedNetworkRouteTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/heavycompressed/HeavyCompressedNetworkRouteTest.java @@ -20,7 +20,7 @@ package org.matsim.core.population.routes.heavycompressed; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -69,9 +69,9 @@ void testGetLinks_setLinks() { route.setLinkIds(link1.getId(), linkIds, link4.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -96,9 +96,9 @@ void testGetLinks_onlySubsequentLinks() { route.setLinkIds(link0.getId(), linkIds, link4.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -124,8 +124,8 @@ void testGetLinkIds_incompleteInitialization() { NetworkRoute route = new HeavyCompressedNetworkRoute(link0.getId(), link4.getId(), HeavyCompressedNetworkRouteFactory.createCompressionData(network, subsequentLinks)); // NO route.setLinks() here! - Assert.assertEquals("expected 0 links.", 0, route.getLinkIds().size()); - Assert.assertEquals("expected 0 link ids.", 0, route.getLinkIds().size()); + Assertions.assertEquals(0, route.getLinkIds().size(), "expected 0 links."); + Assertions.assertEquals(0, route.getLinkIds().size(), "expected 0 link ids."); } @Test @@ -169,15 +169,15 @@ void testClone() { ArrayList> srcRoute = new ArrayList<>(5); Collections.addAll(srcRoute, link3.getId(), link4.getId()); route1.setLinkIds(startLink.getId(), srcRoute, link5.getId()); - Assert.assertEquals(2, route1.getLinkIds().size()); + Assertions.assertEquals(2, route1.getLinkIds().size()); HeavyCompressedNetworkRoute route2 = route1.clone(); srcRoute.add(link5.getId()); route2.setLinkIds(startLink.getId(), srcRoute, endLink.getId()); - Assert.assertEquals(2, route1.getLinkIds().size()); - Assert.assertEquals(3, route2.getLinkIds().size()); + Assertions.assertEquals(2, route1.getLinkIds().size()); + Assertions.assertEquals(3, route2.getLinkIds().size()); } @Test @@ -195,9 +195,9 @@ void testGetLinks_setLinks_alternative() { route.setLinkIds(link1.getId(), linkIds, link4.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -221,9 +221,9 @@ void testGetLinks_setLinks_endLoopLink() { route.setLinkIds(link1.getId(), linkIds, linkLoop5.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -249,9 +249,9 @@ void testGetLinks_setLinks_containsLargeLoop() { route.setLinkIds(link1.getId(), linkIds, link4.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -287,9 +287,9 @@ void testGetLinks_setLinks_containsLargeLoop_alternative() { route.setLinkIds(link1.getId(), linkIds, link23.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -316,9 +316,9 @@ void testGetLinks_setLinks_isLargeLoop() { route.setLinkIds(link2.getId(), linkIds, link2.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } diff --git a/matsim/src/test/java/org/matsim/core/population/routes/mediumcompressed/MediumCompressedNetworkRouteTest.java b/matsim/src/test/java/org/matsim/core/population/routes/mediumcompressed/MediumCompressedNetworkRouteTest.java index 483f7955606..afe9c68c62b 100644 --- a/matsim/src/test/java/org/matsim/core/population/routes/mediumcompressed/MediumCompressedNetworkRouteTest.java +++ b/matsim/src/test/java/org/matsim/core/population/routes/mediumcompressed/MediumCompressedNetworkRouteTest.java @@ -20,7 +20,7 @@ package org.matsim.core.population.routes.mediumcompressed; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -68,9 +68,9 @@ void testGetLinks_setLinks() { route.setLinkIds(link1.getId(), linkIds, link4.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -89,9 +89,9 @@ void testGetLinks_onlySubsequentLinks() { route.setLinkIds(link0.getId(), linkIds, link4.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -108,8 +108,8 @@ void testGetLinkIds_incompleteInitialization() { NetworkRoute route = new MediumCompressedNetworkRoute(link0.getId(), link4.getId()); // NO route.setLinks() here! - Assert.assertEquals("expected 0 links.", 0, route.getLinkIds().size()); - Assert.assertEquals("expected 0 link ids.", 0, route.getLinkIds().size()); + Assertions.assertEquals(0, route.getLinkIds().size(), "expected 0 links."); + Assertions.assertEquals(0, route.getLinkIds().size(), "expected 0 link ids."); } @Test @@ -147,15 +147,15 @@ void testClone() { ArrayList> srcRoute = new ArrayList<>(5); Collections.addAll(srcRoute, link3.getId(), link4.getId()); route1.setLinkIds(startLink.getId(), srcRoute, link5.getId()); - Assert.assertEquals(2, route1.getLinkIds().size()); + Assertions.assertEquals(2, route1.getLinkIds().size()); MediumCompressedNetworkRoute route2 = route1.clone(); srcRoute.add(link5.getId()); route2.setLinkIds(startLink.getId(), srcRoute, endLink.getId()); - Assert.assertEquals(2, route1.getLinkIds().size()); - Assert.assertEquals(3, route2.getLinkIds().size()); + Assertions.assertEquals(2, route1.getLinkIds().size()); + Assertions.assertEquals(3, route2.getLinkIds().size()); } @Test @@ -173,9 +173,9 @@ void testGetLinks_setLinks_alternative() { route.setLinkIds(link1.getId(), linkIds, link4.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -199,9 +199,9 @@ void testGetLinks_setLinks_endLoopLink() { route.setLinkIds(link1.getId(), linkIds, linkLoop5.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -227,9 +227,9 @@ void testGetLinks_setLinks_containsLargeLoop() { route.setLinkIds(link1.getId(), linkIds, link4.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -265,9 +265,9 @@ void testGetLinks_setLinks_containsLargeLoop_alternative() { route.setLinkIds(link1.getId(), linkIds, link23.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } @@ -294,9 +294,9 @@ void testGetLinks_setLinks_isLargeLoop() { route.setLinkIds(link2.getId(), linkIds, link2.getId()); List> linksId2 = route.getLinkIds(); - Assert.assertEquals("wrong number of links.", linkIds.size(), linksId2.size()); + Assertions.assertEquals(linkIds.size(), linksId2.size(), "wrong number of links."); for (int i = 0, n = linkIds.size(); i < n; i++) { - Assert.assertEquals("different link at position " + i, linkIds.get(i), linksId2.get(i)); + Assertions.assertEquals(linkIds.get(i), linksId2.get(i), "different link at position " + i); } } diff --git a/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java b/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java index 00f3b6ba499..61f35fa4440 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/PlanStrategyTest.java @@ -20,7 +20,7 @@ package org.matsim.core.replanning; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerSubpopulationsTest.java b/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerSubpopulationsTest.java index df7709658c9..ce0f3336b16 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerSubpopulationsTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerSubpopulationsTest.java @@ -22,7 +22,7 @@ import java.util.Random; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.HasPlansAndId; @@ -80,10 +80,10 @@ public void run(HasPlansAndId person) { counter.incCounter(); Person person1 = population.getPersons().get( person.getId() ) ; Gbl.assertNotNull( person1 ); - Assert.assertNull( - "unexpected subpopulation", + Assertions.assertNull( + PopulationUtils.getSubpopulation( person1 ), // PopulationUtils.getPersonAttribute( person1, SUBPOP_ATT_NAME) ); - PopulationUtils.getSubpopulation( person1 ) ); + "unexpected subpopulation" ); } @@ -101,11 +101,12 @@ public void run(HasPlansAndId person) { counter.incCounter(); Person person1 = population.getPersons().get( person.getId() ) ; Gbl.assertNotNull( person1 ); - Assert.assertEquals( - "unexpected subpopulation", + Assertions.assertEquals( POP_NAME_1, // PopulationUtils.getPersonAttribute( person1, SUBPOP_ATT_NAME) ); - PopulationUtils.getSubpopulation( person1 ) ); + PopulationUtils.getSubpopulation( person1 ), +// PopulationUtils.getPersonAttribute( person1, SUBPOP_ATT_NAME) ); + "unexpected subpopulation" ); } @Override @@ -122,11 +123,12 @@ public void run(HasPlansAndId person) { counter.incCounter(); Person person1 = population.getPersons().get( person.getId() ) ; Gbl.assertNotNull( person1 ); - Assert.assertEquals( - "unexpected subpopulation", + Assertions.assertEquals( POP_NAME_2, // PopulationUtils.getPersonAttribute( person1, SUBPOP_ATT_NAME) ); - PopulationUtils.getSubpopulation( person1 ) ); + PopulationUtils.getSubpopulation( person1 ), +// PopulationUtils.getPersonAttribute( person1, SUBPOP_ATT_NAME) ); + "unexpected subpopulation" ); } @Override diff --git a/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerTest.java b/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerTest.java index 90748e9f33b..24c87c752de 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/StrategyManagerTest.java @@ -20,7 +20,7 @@ package org.matsim.core.replanning; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.HasPlansAndId; @@ -39,8 +39,7 @@ import java.util.List; -import static org.junit.Assert.*; -import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.*; public class StrategyManagerTest { @@ -236,7 +235,7 @@ void testOptimisticBehavior() { for (int i = 0; i < 4; i++) { manager.run(population, i, null); Plan plan = person.getSelectedPlan(); - assertNull("plan has not undefined score in iteration " + i, plan.getScore()); + assertNull(plan.getScore(), "plan has not undefined score in iteration " + i); plan.setScore(Double.valueOf(i)); } @@ -272,22 +271,22 @@ void testSetPlanSelectorForRemoval() { manager.setMaxPlansPerAgent(plans.length - 2); manager.run(pop, -1,null); - assertEquals("wrong number of plans.", 5, p.getPlans().size()); + assertEquals(5, p.getPlans().size(), "wrong number of plans."); // default of StrategyManager is to remove worst plans: - assertFalse("plan should have been removed.", p.getPlans().contains(plans[0])); - assertFalse("plan should have been removed.", p.getPlans().contains(plans[1])); - assertTrue("plan should not have been removed.", p.getPlans().contains(plans[2])); + assertFalse(p.getPlans().contains(plans[0]), "plan should have been removed."); + assertFalse(p.getPlans().contains(plans[1]), "plan should have been removed."); + assertTrue(p.getPlans().contains(plans[2]), "plan should not have been removed."); // change plan selector for removal and run again manager.setPlanSelectorForRemoval(new BestPlanSelector()); manager.setMaxPlansPerAgent(plans.length - 4); manager.run(pop, -1,null); - assertEquals("wrong number of plans.", 3, p.getPlans().size()); + assertEquals(3, p.getPlans().size(), "wrong number of plans."); // default of StrategyManager is to remove worst plans: - assertFalse("plan should have been removed.", p.getPlans().contains(plans[plans.length - 1])); - assertFalse("plan should have been removed.", p.getPlans().contains(plans[plans.length - 2])); - assertTrue("plan should not have been removed.", p.getPlans().contains(plans[plans.length - 3])); + assertFalse(p.getPlans().contains(plans[plans.length - 1]), "plan should have been removed."); + assertFalse(p.getPlans().contains(plans[plans.length - 2]), "plan should have been removed."); + assertTrue(p.getPlans().contains(plans[plans.length - 3]), "plan should not have been removed."); } @Test @@ -303,11 +302,11 @@ void testGetStrategies() { manager.addStrategy( str3, null, 0.5 ); List> strategies = manager.getStrategies( null ); - Assert.assertEquals(3, strategies.size()); + Assertions.assertEquals(3, strategies.size()); - Assert.assertEquals(str1, strategies.get(0)); - Assert.assertEquals(str2, strategies.get(1)); - Assert.assertEquals(str3, strategies.get(2)); + Assertions.assertEquals(str1, strategies.get(0)); + Assertions.assertEquals(str2, strategies.get(1)); + Assertions.assertEquals(str3, strategies.get(2)); } @Test @@ -323,11 +322,11 @@ void testGetWeights() { manager.addStrategy( str3, null, 0.5 ); List weights = manager.getWeights( null ); - Assert.assertEquals(3, weights.size()); + Assertions.assertEquals(3, weights.size()); - Assert.assertEquals(1.0, weights.get(0), 1e-8); - Assert.assertEquals(2.0, weights.get(1), 1e-8); - Assert.assertEquals(0.5, weights.get(2), 1e-8); + Assertions.assertEquals(1.0, weights.get(0), 1e-8); + Assertions.assertEquals(2.0, weights.get(1), 1e-8); + Assertions.assertEquals(0.5, weights.get(2), 1e-8); } @Test @@ -350,29 +349,29 @@ void testGetWeights_ChangeRequests() { manager.run(pop, 1, null); List weights = manager.getWeights( null ); - Assert.assertEquals(3, weights.size()); + Assertions.assertEquals(3, weights.size()); - Assert.assertEquals(1.0, weights.get(0), 1e-8); - Assert.assertEquals(2.0, weights.get(1), 1e-8); - Assert.assertEquals(0.5, weights.get(2), 1e-8); + Assertions.assertEquals(1.0, weights.get(0), 1e-8); + Assertions.assertEquals(2.0, weights.get(1), 1e-8); + Assertions.assertEquals(0.5, weights.get(2), 1e-8); manager.run(pop, 5, null); weights = manager.getWeights( null ); - Assert.assertEquals(3, weights.size()); + Assertions.assertEquals(3, weights.size()); - Assert.assertEquals(1.0, weights.get(0), 1e-8); - Assert.assertEquals(3.0, weights.get(1), 1e-8); - Assert.assertEquals(0.5, weights.get(2), 1e-8); + Assertions.assertEquals(1.0, weights.get(0), 1e-8); + Assertions.assertEquals(3.0, weights.get(1), 1e-8); + Assertions.assertEquals(0.5, weights.get(2), 1e-8); manager.run(pop, 10, null); weights = manager.getWeights( null ); - Assert.assertEquals(3, weights.size()); + Assertions.assertEquals(3, weights.size()); - Assert.assertEquals(1.0, weights.get(0), 1e-8); - Assert.assertEquals(3.0, weights.get(1), 1e-8); - Assert.assertEquals(1.0, weights.get(2), 1e-8); + Assertions.assertEquals(1.0, weights.get(0), 1e-8); + Assertions.assertEquals(3.0, weights.get(1), 1e-8); + Assertions.assertEquals(1.0, weights.get(2), 1e-8); } /** diff --git a/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java b/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java index 4d2a55cfbb1..fc56e540746 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java @@ -3,8 +3,8 @@ import java.io.BufferedReader; import java.io.IOException; import java.util.List; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -200,12 +200,12 @@ void testLinearAnneal() throws IOException { Controler controler = new Controler(this.scenario); controler.run(); - Assert.assertEquals(expectedLinearAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); + Assertions.assertEquals(expectedLinearAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); StrategyManager sm = controler.getInjector().getInstance(StrategyManager.class); List weights = sm.getWeights(null); - Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); + Assertions.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } @Test @@ -217,12 +217,12 @@ void testMsaAnneal() throws IOException { Controler controler = new Controler(this.scenario); controler.run(); - Assert.assertEquals(expectedMsaAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); + Assertions.assertEquals(expectedMsaAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); StrategyManager sm = controler.getInjector().getInstance(StrategyManager.class); List weights = sm.getWeights(null); - Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); + Assertions.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } @Test @@ -234,12 +234,12 @@ void testGeometricAnneal() throws IOException { Controler controler = new Controler(this.scenario); controler.run(); - Assert.assertEquals(expectedGeometricAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); + Assertions.assertEquals(expectedGeometricAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); StrategyManager sm = controler.getInjector().getInstance(StrategyManager.class); List weights = sm.getWeights(null); - Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); + Assertions.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } @Test @@ -251,12 +251,12 @@ void testExponentialAnneal() throws IOException { Controler controler = new Controler(this.scenario); controler.run(); - Assert.assertEquals(expectedExponentialAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); + Assertions.assertEquals(expectedExponentialAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); StrategyManager sm = controler.getInjector().getInstance(StrategyManager.class); List weights = sm.getWeights(null); - Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); + Assertions.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } @Test @@ -269,12 +269,12 @@ void testSigmoidAnneal() throws IOException { Controler controler = new Controler(this.scenario); controler.run(); - Assert.assertEquals(expectedSigmoidAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); + Assertions.assertEquals(expectedSigmoidAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); StrategyManager sm = controler.getInjector().getInstance(StrategyManager.class); List weights = sm.getWeights(null); - Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); + Assertions.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } @Test @@ -287,8 +287,8 @@ void testParameterAnneal() throws IOException { Controler controler = new Controler(this.scenario); controler.run(); - Assert.assertEquals(expectedParameterAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); - Assert.assertEquals(0.0, controler.getConfig().scoring().getBrainExpBeta(), 1e-4); + Assertions.assertEquals(expectedParameterAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); + Assertions.assertEquals(0.0, controler.getConfig().scoring().getBrainExpBeta(), 1e-4); } @Test @@ -307,13 +307,13 @@ void testTwoParameterAnneal() throws IOException { Controler controler = new Controler(this.scenario); controler.run(); - Assert.assertEquals(expectedTwoParameterAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); - Assert.assertEquals(0.0, controler.getConfig().scoring().getBrainExpBeta(), 1e-4); + Assertions.assertEquals(expectedTwoParameterAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); + Assertions.assertEquals(0.0, controler.getConfig().scoring().getBrainExpBeta(), 1e-4); StrategyManager sm = controler.getInjector().getInstance(StrategyManager.class); List weights = sm.getWeights(null); - Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); + Assertions.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } @Test @@ -326,12 +326,12 @@ void testInnovationSwitchoffAnneal() throws IOException { Controler controler = new Controler(this.scenario); controler.run(); - Assert.assertEquals(expectedInnovationSwitchoffAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); + Assertions.assertEquals(expectedInnovationSwitchoffAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); StrategyManager sm = controler.getInjector().getInstance(StrategyManager.class); List weights = sm.getWeights(null); - Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); + Assertions.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } @Test @@ -344,12 +344,12 @@ void testFreezeEarlyAnneal() throws IOException { Controler controler = new Controler(this.scenario); controler.run(); - Assert.assertEquals(expectedFreezeEarlyAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); + Assertions.assertEquals(expectedFreezeEarlyAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); StrategyManager sm = controler.getInjector().getInstance(StrategyManager.class); List weights = sm.getWeights(null); - Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); + Assertions.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } @Test @@ -369,12 +369,12 @@ void testSubpopulationAnneal() throws IOException { Controler controler = new Controler(this.scenario); controler.run(); - Assert.assertEquals(expectedLinearAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); + Assertions.assertEquals(expectedLinearAnneal, readResult(controler.getControlerIO().getOutputFilename(FILENAME_ANNEAL))); StrategyManager sm = controler.getInjector().getInstance(StrategyManager.class); List weights = sm.getWeights(targetSubpop); - Assert.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); + Assertions.assertEquals(1.0, weights.stream().mapToDouble(Double::doubleValue).sum(), 1e-4); } } diff --git a/matsim/src/test/java/org/matsim/core/replanning/choosers/ForceInnovationStrategyChooserTest.java b/matsim/src/test/java/org/matsim/core/replanning/choosers/ForceInnovationStrategyChooserTest.java index b6683edb58c..f1722a11e41 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/choosers/ForceInnovationStrategyChooserTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/choosers/ForceInnovationStrategyChooserTest.java @@ -3,7 +3,7 @@ import java.util.ArrayList; import java.util.List; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; diff --git a/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java b/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java index 1015bd7582c..81b9522bb1b 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/conflicts/ReplanningWithConflictsTest.java @@ -1,6 +1,6 @@ package org.matsim.core.replanning.conflicts; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/replanning/modules/AbstractMultithreadedModuleTest.java b/matsim/src/test/java/org/matsim/core/replanning/modules/AbstractMultithreadedModuleTest.java index 042b090e267..583a1ad2df3 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/modules/AbstractMultithreadedModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/modules/AbstractMultithreadedModuleTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.population.Plan; import org.matsim.core.config.Config; @@ -42,7 +42,7 @@ void testGetNumOfThreads() { config.addCoreModules(); config.global().setNumberOfThreads(3); DummyAbstractMultithreadedModule testee = new DummyAbstractMultithreadedModule(config.global()); - Assert.assertEquals(3, testee.getNumOfThreads()); + Assertions.assertEquals(3, testee.getNumOfThreads()); } @Test @@ -54,7 +54,7 @@ void testCrashingThread() { testee.handlePlan(null); testee.handlePlan(null); testee.finishReplanning(); - Assert.fail("expected exception, got none."); + Assertions.fail("expected exception, got none."); } catch (Exception e) { log.info("Catched expected exception.", e); } diff --git a/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeLegModeTest.java b/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeLegModeTest.java index b3fb4b3a27c..53621cacc8d 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeLegModeTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeLegModeTest.java @@ -20,7 +20,7 @@ package org.matsim.core.replanning.modules; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -122,7 +122,7 @@ void testWithConfig_withoutIgnoreCarAvailability() { Integer count = counter.get(leg.getMode()); counter.put(leg.getMode(), Integer.valueOf(count.intValue() + 1)); } - Assert.assertEquals(0, counter.get("car").intValue()); + Assertions.assertEquals(0, counter.get("car").intValue()); } private void runTest(final ChangeLegMode module, final String[] possibleModes) { @@ -141,13 +141,13 @@ private void runTest(final ChangeLegMode module, final String[] possibleModes) { for (int i = 0; i < 50; i++) { module.handlePlan(plan); Integer count = counter.get(leg.getMode()); - Assert.assertNotNull("unexpected mode: " + leg.getMode(), count); + Assertions.assertNotNull(count, "unexpected mode: " + leg.getMode()); counter.put(leg.getMode(), Integer.valueOf(count.intValue() + 1)); } for (Map.Entry entry : counter.entrySet()) { int count = entry.getValue().intValue(); - Assert.assertTrue("mode " + entry.getKey() + " was never chosen.", count > 0); + Assertions.assertTrue(count > 0, "mode " + entry.getKey() + " was never chosen."); } } } diff --git a/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeSingleLegModeTest.java b/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeSingleLegModeTest.java index fd66a829450..2e590fc9299 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeSingleLegModeTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/modules/ChangeSingleLegModeTest.java @@ -23,7 +23,7 @@ import java.util.HashMap; import java.util.Map; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -98,7 +98,7 @@ void testWithConfig_withoutIgnoreCarAvailability() { Integer count = counter.get(leg.getMode()); counter.put(leg.getMode(), Integer.valueOf(count.intValue() + 1)); } - Assert.assertEquals(0, counter.get("car").intValue()); + Assertions.assertEquals(0, counter.get("car").intValue()); } private void runTest(final ChangeSingleLegMode module, final String[] possibleModes, final int nOfTries) { @@ -117,13 +117,13 @@ private void runTest(final ChangeSingleLegMode module, final String[] possibleMo for (int i = 0; i < nOfTries; i++) { module.handlePlan(plan); Integer count = counter.get(leg.getMode()); - Assert.assertNotNull("unexpected mode: " + leg.getMode(), count); + Assertions.assertNotNull(count, "unexpected mode: " + leg.getMode()); counter.put(leg.getMode(), Integer.valueOf(count.intValue() + 1)); } for (Map.Entry entry : counter.entrySet()) { int count = entry.getValue().intValue(); - Assert.assertTrue("mode " + entry.getKey() + " was never chosen.", count > 0); + Assertions.assertTrue(count > 0, "mode " + entry.getKey() + " was never chosen."); } } } diff --git a/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java b/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java index d739f20c19c..61f0dff7923 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java @@ -22,8 +22,8 @@ package org.matsim.core.replanning.modules; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -82,7 +82,7 @@ public boolean invoke() { } }, "test", outputDirectoryHierarchy, scenario); replanPopulation(scenario.getPopulation(), testee); - Assert.assertTrue(PopulationUtils.equalPopulation(scenario.getPopulation(), originalScenario.getPopulation())); + Assertions.assertTrue(PopulationUtils.equalPopulation(scenario.getPopulation(), originalScenario.getPopulation())); } @Test @@ -99,7 +99,7 @@ public boolean invoke() { } }, "test", outputDirectoryHierarchy, scenario); replanPopulation(scenario.getPopulation(), testee); - Assert.assertFalse(PopulationUtils.equalPopulation(scenario.getPopulation(), originalScenario.getPopulation())); + Assertions.assertFalse(PopulationUtils.equalPopulation(scenario.getPopulation(), originalScenario.getPopulation())); } private Population loadPopulation(String filename) { diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java index 8b0774ada00..0412fa36c31 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/AbstractPlanSelectorTest.java @@ -20,8 +20,8 @@ package org.matsim.core.replanning.selectors; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertNull; +import static org.junit.jupiter.api.Assertions.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertNull; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/BestPlanSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/BestPlanSelectorTest.java index 53a61e636db..dd86806d2e1 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/BestPlanSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/BestPlanSelectorTest.java @@ -20,8 +20,8 @@ package org.matsim.core.replanning.selectors; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNull; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java index fa08c8705d5..62ffb7eaaeb 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java @@ -20,7 +20,7 @@ package org.matsim.core.replanning.selectors; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/KeepSelectedTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/KeepSelectedTest.java index 97f74593bc3..6c8dbb5fc91 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/KeepSelectedTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/KeepSelectedTest.java @@ -20,7 +20,7 @@ package org.matsim.core.replanning.selectors; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java index 6a50781d5c5..905a8f32cdb 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java @@ -20,8 +20,8 @@ package org.matsim.core.replanning.selectors; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; import java.util.ArrayList; diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/RandomPlanSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/RandomPlanSelectorTest.java index 2d1bd9c14b5..9b56aafd4c1 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/RandomPlanSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/RandomPlanSelectorTest.java @@ -20,7 +20,7 @@ package org.matsim.core.replanning.selectors; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/WorstPlanForRemovalSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/WorstPlanForRemovalSelectorTest.java index 631173aa68d..c7e0a826528 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/WorstPlanForRemovalSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/WorstPlanForRemovalSelectorTest.java @@ -20,7 +20,7 @@ package org.matsim.core.replanning.selectors; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -60,20 +60,20 @@ void testRemoveWorstPlans_nullType() { person.addPlan(plan4); person.addPlan(plan5); - assertEquals("test we have all plans we want", 5, person.getPlans().size()); + assertEquals(5, person.getPlans().size(), "test we have all plans we want"); person.getPlans().remove(selector.selectPlan(person)); - assertEquals("test that a plan was removed", 4, person.getPlans().size()); - assertFalse("test that plan with undefined score was removed.", person.getPlans().contains(plan3)); + assertEquals(4, person.getPlans().size(), "test that a plan was removed"); + assertFalse(person.getPlans().contains(plan3), "test that plan with undefined score was removed."); person.getPlans().remove(selector.selectPlan(person)); - assertEquals("test that a plan was removed", 3, person.getPlans().size()); - assertFalse("test that the plan with minimal score was removed", person.getPlans().contains(plan4)); + assertEquals(3, person.getPlans().size(), "test that a plan was removed"); + assertFalse(person.getPlans().contains(plan4), "test that the plan with minimal score was removed"); person.getPlans().remove(selector.selectPlan(person)); person.getPlans().remove(selector.selectPlan(person)); - assertEquals("test that two plans were removed", 1, person.getPlans().size()); - assertTrue("test that the plan left has highest score", person.getPlans().contains(plan2)); + assertEquals(1, person.getPlans().size(), "test that two plans were removed"); + assertTrue(person.getPlans().contains(plan2), "test that the plan left has highest score"); } /** @@ -119,24 +119,24 @@ void testRemoveWorstPlans_withTypes() { person.addPlan(plan5); person.addPlan(plan6); - assertEquals("test we have all plans we want", 6, person.getPlans().size()); + assertEquals(6, person.getPlans().size(), "test we have all plans we want"); person.getPlans().remove(selector.selectPlan(person)); person.getPlans().remove(selector.selectPlan(person)); - assertEquals("test that two plans were removed", 4, person.getPlans().size()); - assertFalse("test that plan with undefined score was removed.", person.getPlans().contains(plan3)); - assertFalse("test that plan with worst score was removed.", person.getPlans().contains(plan4)); + assertEquals(4, person.getPlans().size(), "test that two plans were removed"); + assertFalse(person.getPlans().contains(plan3), "test that plan with undefined score was removed."); + assertFalse(person.getPlans().contains(plan4), "test that plan with worst score was removed."); person.getPlans().remove(selector.selectPlan(person)); person.getPlans().remove(selector.selectPlan(person)); - assertEquals("test that two plans were removed", 2, person.getPlans().size()); - assertFalse("test that the plan with worst score was removed", person.getPlans().contains(plan1)); - assertTrue("test that the now only plan of type a was not removed", person.getPlans().contains(plan5)); - assertFalse("test that the plan with the 2nd-worst score was removed", person.getPlans().contains(plan6)); + assertEquals(2, person.getPlans().size(), "test that two plans were removed"); + assertFalse(person.getPlans().contains(plan1), "test that the plan with worst score was removed"); + assertTrue(person.getPlans().contains(plan5), "test that the now only plan of type a was not removed"); + assertFalse(person.getPlans().contains(plan6), "test that the plan with the 2nd-worst score was removed"); person.getPlans().remove(selector.selectPlan(person)); - assertEquals("test that one plan was removed", 1, person.getPlans().size()); - assertTrue("test that the plan with highest score of type b was not removed", person.getPlans().contains(plan2)); + assertEquals(1, person.getPlans().size(), "test that one plan was removed"); + assertTrue(person.getPlans().contains(plan2), "test that the plan with highest score of type b was not removed"); } } diff --git a/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java b/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java index 1e32151930b..898ccfd8b2e 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java +++ b/matsim/src/test/java/org/matsim/core/replanning/strategies/DeterministicMultithreadedReplanningIT.java @@ -21,8 +21,7 @@ package org.matsim.core.replanning.strategies; import com.google.inject.Singleton; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -98,13 +97,13 @@ void testTimeAllocationMutator() { long cksum1 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run1/ITERS/it."+ i +"/"+ i +".events.xml.gz"); long cksum2 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run2/ITERS/it."+ i +"/"+ i +".events.xml.gz"); - Assert.assertEquals("The checksums of events must be the same in iteration " + i + ", even when multiple threads are used.", cksum1, cksum2); + Assertions.assertEquals(cksum1, cksum2, "The checksums of events must be the same in iteration " + i + ", even when multiple threads are used."); } for (int i = 0; i < 2; i++) { long pcksum1 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run1/ITERS/it."+ i +"/"+ i +".plans.xml.gz"); long pcksum2 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run2/ITERS/it."+ i +"/"+ i +".plans.xml.gz"); - Assert.assertEquals("The checksums of plans must be the same in iteration " + i + ", even when multiple threads are used.", pcksum1, pcksum2); + Assertions.assertEquals(pcksum1, pcksum2, "The checksums of plans must be the same in iteration " + i + ", even when multiple threads are used."); } } @@ -151,13 +150,13 @@ void testReRouteTimeAllocationMutator() { long cksum1 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run1/ITERS/it."+ i +"/"+ i +".events.xml.gz"); long cksum2 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run2/ITERS/it."+ i +"/"+ i +".events.xml.gz"); - Assert.assertEquals("The checksums of events must be the same in iteration " + i + ", even when multiple threads are used.", cksum1, cksum2); + Assertions.assertEquals(cksum1, cksum2, "The checksums of events must be the same in iteration " + i + ", even when multiple threads are used."); } for (int i = 0; i < 2; i++) { long pcksum1 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run1/ITERS/it."+ i +"/"+ i +".plans.xml.gz"); long pcksum2 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run2/ITERS/it."+ i +"/"+ i +".plans.xml.gz"); - Assert.assertEquals("The checksums of plans must be the same in iteration " + i + ", even when multiple threads are used.", pcksum1, pcksum2); + Assertions.assertEquals(pcksum1, pcksum2, "The checksums of plans must be the same in iteration " + i + ", even when multiple threads are used."); } } @@ -205,13 +204,13 @@ void testReRouteOneAgent() { long cksum1 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run1/ITERS/it."+ i +"/"+ i +".events.xml.gz"); long cksum2 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run2/ITERS/it."+ i +"/"+ i +".events.xml.gz"); - Assert.assertEquals("The checksums of events must be the same in iteration " + i + ", even when multiple threads are used.", cksum1, cksum2); + Assertions.assertEquals(cksum1, cksum2, "The checksums of events must be the same in iteration " + i + ", even when multiple threads are used."); } for (int i = 0; i < 2; i++) { long pcksum1 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run1/ITERS/it."+ i +"/"+ i +".plans.xml.gz"); long pcksum2 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run2/ITERS/it."+ i +"/"+ i +".plans.xml.gz"); - Assert.assertEquals("The checksums of plans must be the same in iteration " + i + ", even when multiple threads are used.", pcksum1, pcksum2); + Assertions.assertEquals(pcksum1, pcksum2, "The checksums of plans must be the same in iteration " + i + ", even when multiple threads are used."); } } @@ -257,13 +256,13 @@ void testReRoute() { long cksum1 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run1/ITERS/it."+ i +"/"+ i +".events.xml.gz"); long cksum2 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run2/ITERS/it."+ i +"/"+ i +".events.xml.gz"); - Assert.assertEquals("The checksums of events must be the same in iteration " + i + ", even when multiple threads are used.", cksum1, cksum2); + Assertions.assertEquals(cksum1, cksum2, "The checksums of events must be the same in iteration " + i + ", even when multiple threads are used."); } for (int i = 0; i < 2; i++) { long pcksum1 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run1/ITERS/it."+ i +"/"+ i +".plans.xml.gz"); long pcksum2 = CRCChecksum.getCRCFromFile(testUtils.getOutputDirectory() + "/run2/ITERS/it."+ i +"/"+ i +".plans.xml.gz"); - Assert.assertEquals("The checksums of plans must be the same in iteration " + i + ", even when multiple threads are used.", pcksum1, pcksum2); + Assertions.assertEquals(pcksum1, pcksum2, "The checksums of plans must be the same in iteration " + i + ", even when multiple threads are used."); } } diff --git a/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java b/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java index 16d45333e37..f62b40c44e2 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/strategies/InnovationSwitchOffTest.java @@ -23,7 +23,7 @@ package org.matsim.core.replanning.strategies; import com.google.inject.*; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -139,18 +139,18 @@ public void notifyBeforeMobsim(BeforeMobsimEvent event) { for ( int ii = 0 ; ii < sm.getStrategies( null ).size(); ii++) { log.warn("strategy " + sm.getStrategies( null ).get(ii ) + " has weight " + sm.getWeights( null ).get(ii ) ); if (event.getIteration() == 11 && sm.getStrategies( null ).get(ii ).toString().contains(ReRoute.class.getSimpleName() )) { - Assert.assertEquals(0.1, sm.getWeights( null ).get(ii ), 0.000001 ); + Assertions.assertEquals(0.1, sm.getWeights( null ).get(ii ), 0.000001 ); } if (event.getIteration() == 12 && sm.getStrategies( null ).get(ii ).toString().contains(ReRoute.class.getSimpleName() )) { - Assert.assertEquals(0., sm.getWeights( null ).get(ii ), 0.000001 ); + Assertions.assertEquals(0., sm.getWeights( null ).get(ii ), 0.000001 ); } if (event.getIteration() == 13 && sm.getStrategies( null ).get(ii ).toString().contains( TimeAllocationMutatorModule.class.getSimpleName() )) { - Assert.assertEquals(0.1, sm.getWeights( null ).get(ii ), 0.000001 ); + Assertions.assertEquals(0.1, sm.getWeights( null ).get(ii ), 0.000001 ); } if (event.getIteration() == 14 && sm.getStrategies( null ).get(ii ).toString().contains( TimeAllocationMutatorModule.class.getSimpleName() )) { - Assert.assertEquals(0.0, sm.getWeights( null ).get(ii ), 0.000001 ); + Assertions.assertEquals(0.0, sm.getWeights( null ).get(ii ), 0.000001 ); } } System.err.flush(); diff --git a/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java b/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java index e82ed18aab7..2c8396b447e 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/strategies/TimeAllocationMutatorModuleTest.java @@ -20,9 +20,9 @@ package org.matsim.core.replanning.strategies; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertTrue; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -126,16 +126,16 @@ private void runSimplifiedMutationRangeTest(final PlanAlgorithm tripPlanMutateTi if (diff > maxDiff1) maxDiff1 = diff; if (diff < minDiff1) minDiff1 = diff; act1End = act1.getEndTime().seconds(); - assertTrue("activity end time cannot be smaller than 0, is " + act1End, act1End >= 0.0); + assertTrue(act1End >= 0.0, "activity end time cannot be smaller than 0, is " + act1End); // test end time of act2 diff = act2Dur - act2.getMaximumDuration().seconds(); if (diff > maxDiff2) maxDiff2 = diff; if (diff < minDiff2) minDiff2 = diff; act2Dur = act2.getMaximumDuration().seconds(); - assertTrue("activity duration cannot be smaller than 0, is " + act2Dur, act2Dur >= 0.0); + assertTrue(act2Dur >= 0.0, "activity duration cannot be smaller than 0, is " + act2Dur); } - assertTrue("mutation range differences wrong (act1).", minDiff1 <= maxDiff1); - assertTrue("mutation range differences wrong (act2).", minDiff2 <= maxDiff2); + assertTrue(minDiff1 <= maxDiff1, "mutation range differences wrong (act1)."); + assertTrue(minDiff2 <= maxDiff2, "mutation range differences wrong (act2)."); /* The following asserts are dependent on random numbers. * But I would still expect that we get up to at least 95% of the limit... */ @@ -146,7 +146,7 @@ private void runSimplifiedMutationRangeTest(final PlanAlgorithm tripPlanMutateTi } private static void assertValueInRange(final String message, final double actual, final double lowerLimit, final double upperLimit) { - assertTrue(message + " actual: " + actual + ", range: " + lowerLimit + "..." + upperLimit, (lowerLimit <= actual) && (actual <= upperLimit)); + assertTrue((lowerLimit <= actual) && (actual <= upperLimit), message + " actual: " + actual + ", range: " + lowerLimit + "..." + upperLimit); } @@ -182,10 +182,10 @@ void testRun() { affectingDuration, new Random(2011),24*3600,false,1); mutator.run(plan); - Assert.assertEquals(0.0, ptAct1.getMaximumDuration().seconds(), 1e-8); - Assert.assertEquals(0.0, ptAct2.getMaximumDuration().seconds(), 1e-8); - Assert.assertEquals(0.0, ptAct3.getMaximumDuration().seconds(), 1e-8); - Assert.assertEquals(0.0, ptAct4.getMaximumDuration().seconds(), 1e-8); + Assertions.assertEquals(0.0, ptAct1.getMaximumDuration().seconds(), 1e-8); + Assertions.assertEquals(0.0, ptAct2.getMaximumDuration().seconds(), 1e-8); + Assertions.assertEquals(0.0, ptAct3.getMaximumDuration().seconds(), 1e-8); + Assertions.assertEquals(0.0, ptAct4.getMaximumDuration().seconds(), 1e-8); } @Test @@ -227,19 +227,19 @@ void testRunLatestEndTime() { mutator.run(plan); - Assert.assertEquals(0.0, ptAct1.getMaximumDuration().seconds(), 1e-8); - Assert.assertEquals(0.0, ptAct2.getMaximumDuration().seconds(), 1e-8); - Assert.assertEquals(0.0, ptAct3.getMaximumDuration().seconds(), 1e-8); - Assert.assertEquals(0.0, ptAct4.getMaximumDuration().seconds(), 1e-8); + Assertions.assertEquals(0.0, ptAct1.getMaximumDuration().seconds(), 1e-8); + Assertions.assertEquals(0.0, ptAct2.getMaximumDuration().seconds(), 1e-8); + Assertions.assertEquals(0.0, ptAct3.getMaximumDuration().seconds(), 1e-8); + Assertions.assertEquals(0.0, ptAct4.getMaximumDuration().seconds(), 1e-8); // check whether activity times are equal or less than latestEndTime for (PlanElement pe : plan.getPlanElements()) { if (pe instanceof Activity activity) { if (activity.getStartTime().isDefined()) { - Assert.assertTrue(activity.getStartTime().seconds() <= latestEndTime); + Assertions.assertTrue(activity.getStartTime().seconds() <= latestEndTime); } if (activity.getEndTime().isDefined()) { - Assert.assertTrue(activity.getEndTime().seconds() <= latestEndTime); + Assertions.assertTrue(activity.getEndTime().seconds() <= latestEndTime); } } } @@ -271,8 +271,8 @@ void testLegTimesAreSetCorrectly() { double firstActEndTime = act.getEndTime().seconds(); double secondActDuration = act2.getMaximumDuration().seconds(); - Assert.assertEquals(firstActEndTime,leg1.getDepartureTime().seconds(), MatsimTestUtils.EPSILON); - Assert.assertEquals(firstActEndTime+secondActDuration+leg1.getTravelTime().seconds(),leg2.getDepartureTime().seconds(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(firstActEndTime,leg1.getDepartureTime().seconds(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(firstActEndTime+secondActDuration+leg1.getTravelTime().seconds(),leg2.getDepartureTime().seconds(), MatsimTestUtils.EPSILON); diff --git a/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java b/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java index 67ccf869eeb..1aa98e5bc16 100644 --- a/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/router/AbstractLeastCostPathCalculatorTest.java @@ -20,13 +20,13 @@ package org.matsim.core.router; -import static org.junit.Assert.assertEquals; - import java.io.IOException; import javax.xml.parsers.ParserConfigurationException; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -66,8 +66,8 @@ void testCalcLeastCostPath_Normal() throws SAXException, ParserConfigurationExce LeastCostPathCalculator routerAlgo = getLeastCostPathCalculator(network); Path path = routerAlgo.calcLeastCostPath(node12, node15, 8.0*3600, null, null); - assertEquals("number of nodes wrong.", 4, path.nodes.size()); - assertEquals("number of links wrong.", 3, path.links.size()); + assertEquals(4, path.nodes.size(), "number of nodes wrong."); + assertEquals(3, path.links.size(), "number of links wrong."); assertEquals(network.getNodes().get(Id.create("12", Node.class)), path.nodes.get(0)); assertEquals(network.getNodes().get(Id.create("13", Node.class)), path.nodes.get(1)); assertEquals(network.getNodes().get(Id.create("14", Node.class)), path.nodes.get(2)); @@ -87,8 +87,8 @@ void testCalcLeastCostPath_SameFromTo() throws SAXException, ParserConfiguration LeastCostPathCalculator routerAlgo = getLeastCostPathCalculator(network); Path path = routerAlgo.calcLeastCostPath(node12, node12, 8.0*3600, null, null); - assertEquals("number of nodes wrong.", 1, path.nodes.size()); - assertEquals("number of links wrong.", 0, path.links.size()); + assertEquals(1, path.nodes.size(), "number of nodes wrong."); + assertEquals(0, path.links.size(), "number of links wrong."); assertEquals(network.getNodes().get(Id.create("12", Node.class)), path.nodes.get(0)); } diff --git a/matsim/src/test/java/org/matsim/core/router/InvertertedNetworkRoutingTest.java b/matsim/src/test/java/org/matsim/core/router/InvertertedNetworkRoutingTest.java index 22f15d7f73e..1378f0b5195 100644 --- a/matsim/src/test/java/org/matsim/core/router/InvertertedNetworkRoutingTest.java +++ b/matsim/src/test/java/org/matsim/core/router/InvertertedNetworkRoutingTest.java @@ -18,6 +18,7 @@ * * * *********************************************************************** */ package org.matsim.core.router; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.*; import org.matsim.api.core.v01.network.*; @@ -32,7 +33,6 @@ import org.matsim.core.scenario.ScenarioUtils; import org.matsim.facilities.Facility; import org.matsim.vehicles.Vehicle; -import org.junit.Assert; /** @@ -64,36 +64,36 @@ void testInvertedNetworkLegRouter() { tt.setTurningMoveCosts(0.0, 100.0, 50.0); NetworkRoute route = calcRoute(router, fromFacility, toFacility, person); - Assert.assertNotNull(route); - Assert.assertEquals(Id.create("12", Link.class), route.getStartLinkId()); - Assert.assertEquals(Id.create("78", Link.class), route.getEndLinkId()); - Assert.assertEquals(3, route.getLinkIds().size()); - Assert.assertEquals(Id.create("23", Link.class), route.getLinkIds().get(0)); - Assert.assertEquals(Id.create("34", Link.class), route.getLinkIds().get(1)); - Assert.assertEquals(Id.create("47", Link.class), route.getLinkIds().get(2)); + Assertions.assertNotNull(route); + Assertions.assertEquals(Id.create("12", Link.class), route.getStartLinkId()); + Assertions.assertEquals(Id.create("78", Link.class), route.getEndLinkId()); + Assertions.assertEquals(3, route.getLinkIds().size()); + Assertions.assertEquals(Id.create("23", Link.class), route.getLinkIds().get(0)); + Assertions.assertEquals(Id.create("34", Link.class), route.getLinkIds().get(1)); + Assertions.assertEquals(Id.create("47", Link.class), route.getLinkIds().get(2)); //test 2 tt.setTurningMoveCosts(100.0, 0.0, 50.0); route = calcRoute(router, fromFacility, toFacility, person); - Assert.assertNotNull(route); - Assert.assertEquals(Id.create("12", Link.class), route.getStartLinkId()); - Assert.assertEquals(Id.create("78", Link.class), route.getEndLinkId()); - Assert.assertEquals(3, route.getLinkIds().size()); - Assert.assertEquals(Id.create("23", Link.class), route.getLinkIds().get(0)); - Assert.assertEquals(Id.create("35", Link.class), route.getLinkIds().get(1)); - Assert.assertEquals(Id.create("57", Link.class), route.getLinkIds().get(2)); + Assertions.assertNotNull(route); + Assertions.assertEquals(Id.create("12", Link.class), route.getStartLinkId()); + Assertions.assertEquals(Id.create("78", Link.class), route.getEndLinkId()); + Assertions.assertEquals(3, route.getLinkIds().size()); + Assertions.assertEquals(Id.create("23", Link.class), route.getLinkIds().get(0)); + Assertions.assertEquals(Id.create("35", Link.class), route.getLinkIds().get(1)); + Assertions.assertEquals(Id.create("57", Link.class), route.getLinkIds().get(2)); //test 3 tt.setTurningMoveCosts(50.0, 100.0, 0.0); route = calcRoute(router, fromFacility, toFacility, person); - Assert.assertNotNull(route); - Assert.assertEquals(Id.create("12", Link.class), route.getStartLinkId()); - Assert.assertEquals(Id.create("78", Link.class), route.getEndLinkId()); - Assert.assertEquals(3, route.getLinkIds().size()); - Assert.assertEquals(Id.create("23", Link.class), route.getLinkIds().get(0)); - Assert.assertEquals(Id.create("36", Link.class), route.getLinkIds().get(1)); - Assert.assertEquals(Id.create("67", Link.class), route.getLinkIds().get(2)); + Assertions.assertNotNull(route); + Assertions.assertEquals(Id.create("12", Link.class), route.getStartLinkId()); + Assertions.assertEquals(Id.create("78", Link.class), route.getEndLinkId()); + Assertions.assertEquals(3, route.getLinkIds().size()); + Assertions.assertEquals(Id.create("23", Link.class), route.getLinkIds().get(0)); + Assertions.assertEquals(Id.create("36", Link.class), route.getLinkIds().get(1)); + Assertions.assertEquals(Id.create("67", Link.class), route.getLinkIds().get(2)); diff --git a/matsim/src/test/java/org/matsim/core/router/MultimodalLinkChooserTest.java b/matsim/src/test/java/org/matsim/core/router/MultimodalLinkChooserTest.java index c7dfc9741e8..78a0dba6426 100644 --- a/matsim/src/test/java/org/matsim/core/router/MultimodalLinkChooserTest.java +++ b/matsim/src/test/java/org/matsim/core/router/MultimodalLinkChooserTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.core.router; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -77,16 +77,16 @@ void testDecideOnLink() { Link linkFromFacLinkId = linkChooser.decideOnLink(facilityLinkIdNotNull, network); - Assert.assertEquals(networkLink, linkFromFacLinkId); + Assertions.assertEquals(networkLink, linkFromFacLinkId); Link linkFromFacCoord = linkChooser.decideOnLink(facilityLinkIdNull, network); - Assert.assertEquals(networkLink, linkFromFacCoord); + Assertions.assertEquals(networkLink, linkFromFacCoord); //not sure whether the following makes sense as we basically are some functionality of NetworkUtils (which is used in the linkChooser) //testing this with the decideOnLink method would mean causing a RuntimeException -sm 0622 Link linkNotInNetwork = NetworkUtils.getNearestLink(netWithoutLinks, facilityLinkIdNull.getCoord()); - Assert.assertNull(linkNotInNetwork); + Assertions.assertNull(linkNotInNetwork); } } diff --git a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java index 5329d4c68ee..be39a4c44ba 100644 --- a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java @@ -33,8 +33,7 @@ import java.util.*; import java.util.stream.Collectors; -import static org.junit.Assert.*; -import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.*; public class NetworkRoutingInclAccessEgressModuleTest { diff --git a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingModuleTest.java b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingModuleTest.java index 57ee84872c5..f866a531b92 100644 --- a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingModuleTest.java @@ -21,7 +21,7 @@ import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -70,10 +70,10 @@ void testRouteLeg() { Facility fromFacility = FacilitiesUtils.toFacility( fromAct, f.s.getActivityFacilities() ); Facility toFacility = FacilitiesUtils.toFacility( toAct, f.s.getActivityFacilities() ); List result = routingModule.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFacility, toFacility, 7.0*3600, person)) ; - Assert.assertEquals(1, result.size() ); + Assertions.assertEquals(1, result.size() ); Leg leg = (Leg)result.get(0) ; - Assert.assertEquals(100.0, leg.getTravelTime().seconds(), 1e-8); - Assert.assertTrue(leg.getRoute() instanceof NetworkRoute); + Assertions.assertEquals(100.0, leg.getTravelTime().seconds(), 1e-8); + Assertions.assertTrue(leg.getRoute() instanceof NetworkRoute); } @Test @@ -103,14 +103,14 @@ void testRouteLegWithDistance() { List results = router.calcRoute( DefaultRoutingRequest.withoutAttributes( FacilitiesUtils.toFacility(fromAct, f.s.getActivityFacilities() ), FacilitiesUtils.toFacility(toAct, f.s.getActivityFacilities() ), 8.*3600, person ) ) ; - Assert.assertEquals( 1, results.size() ); + Assertions.assertEquals( 1, results.size() ); Leg leg = (Leg) results.get(0) ; - Assert.assertEquals(100.0, leg.getTravelTime().seconds(), 1e-8); - Assert.assertTrue(leg.getRoute() instanceof NetworkRoute); + Assertions.assertEquals(100.0, leg.getTravelTime().seconds(), 1e-8); + Assertions.assertTrue(leg.getRoute() instanceof NetworkRoute); NetworkRoute route = (NetworkRoute) leg.getRoute() ; - Assert.assertEquals(0.3333333333, route.getTravelCost(), 1e-8 ) ; + Assertions.assertEquals(0.3333333333, route.getTravelCost(), 1e-8 ) ; } // and now with a monetary distance rate different from zero: @@ -133,14 +133,14 @@ void testRouteLegWithDistance() { List result = router.calcRoute( DefaultRoutingRequest.withoutAttributes( FacilitiesUtils.toFacility(fromAct, f.s.getActivityFacilities() ), FacilitiesUtils.toFacility(toAct, f.s.getActivityFacilities() ), 7.*3600, person ) ) ; - Assert.assertEquals( 1, result.size() ) ; + Assertions.assertEquals( 1, result.size() ) ; Leg leg = (Leg) result.get(0) ; - Assert.assertEquals(100.0, leg.getTravelTime().seconds(), 1e-8); - Assert.assertTrue(leg.getRoute() instanceof NetworkRoute); + Assertions.assertEquals(100.0, leg.getTravelTime().seconds(), 1e-8); + Assertions.assertTrue(leg.getRoute() instanceof NetworkRoute); NetworkRoute route = (NetworkRoute) leg.getRoute() ; - Assert.assertEquals(1000.3333333333, route.getTravelCost(), 1e-8 ) ; + Assertions.assertEquals(1000.3333333333, route.getTravelCost(), 1e-8 ) ; } } diff --git a/matsim/src/test/java/org/matsim/core/router/PersonalizableDisutilityIntegrationTest.java b/matsim/src/test/java/org/matsim/core/router/PersonalizableDisutilityIntegrationTest.java index 703cf44b966..9a8a70a187a 100644 --- a/matsim/src/test/java/org/matsim/core/router/PersonalizableDisutilityIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/core/router/PersonalizableDisutilityIntegrationTest.java @@ -19,7 +19,7 @@ package org.matsim.core.router; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -57,7 +57,7 @@ void testPersonAvailableForDisutility_Dijkstra() { 07*3600, f.person, f.vehicle); // hopefully there was no Exception until here... - Assert.assertEquals(22, f.costFunction.cnt); // make sure the costFunction was actually used + Assertions.assertEquals(22, f.costFunction.cnt); // make sure the costFunction was actually used } @Test @@ -72,7 +72,7 @@ void testPersonAvailableForDisutility_AStarEuclidean() { 07*3600, f.person, f.vehicle); // hopefully there was no Exception until here... - Assert.assertEquals(22, f.costFunction.cnt); // make sure the costFunction was actually used + Assertions.assertEquals(22, f.costFunction.cnt); // make sure the costFunction was actually used } @Test @@ -86,7 +86,7 @@ void testPersonAvailableForDisutility_SpeedyALT() { 07*3600, f.person, f.vehicle); // hopefully there was no Exception until here... - Assert.assertEquals(22, f.costFunction.cnt); // make sure the costFunction was actually used + Assertions.assertEquals(22, f.costFunction.cnt); // make sure the costFunction was actually used } private static class Fixture { @@ -128,8 +128,8 @@ private static class PersonEnforcingTravelDisutility implements TravelDisutility @Override public double getLinkTravelDisutility(Link link, double time, Person person, Vehicle vehicle) { - Assert.assertEquals("different person than expected!", this.person, person); - Assert.assertEquals("different vehicle than expected!", this.veh, vehicle); + Assertions.assertEquals(this.person, person, "different person than expected!"); + Assertions.assertEquals(this.veh, vehicle, "different vehicle than expected!"); this.cnt++; return 1.0; } diff --git a/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java b/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java index be691aa8394..74f366f4864 100644 --- a/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/PseudoTransitRoutingModuleTest.java @@ -21,7 +21,7 @@ import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -80,10 +80,10 @@ void testRouteLeg() { double tt = new FreespeedFactorRoutingModule( "mode", f.s.getPopulation().getFactory(), f.s.getNetwork(), routeAlgo, params).routeLeg(person, leg, fromAct, toAct, 7.0*3600); - Assert.assertEquals(400.0, tt, 1e-8); - Assert.assertEquals(400.0, leg.getTravelTime().seconds(), 1e-8); + Assertions.assertEquals(400.0, tt, 1e-8); + Assertions.assertEquals(400.0, leg.getTravelTime().seconds(), 1e-8); // Assert.assertTrue(leg.getRoute() instanceof GenericRouteImpl); - Assert.assertEquals(3000.0, leg.getRoute().getDistance(), 1e-8); + Assertions.assertEquals(3000.0, leg.getRoute().getDistance(), 1e-8); }{ TeleportedModeParams params = new TeleportedModeParams("mode") ; params.setTeleportedModeFreespeedFactor(3.); @@ -91,9 +91,9 @@ void testRouteLeg() { double tt = new FreespeedFactorRoutingModule( "mode", f.s.getPopulation().getFactory(), f.s.getNetwork(), routeAlgo, params).routeLeg(person, leg, fromAct, toAct, 7.0*3600); - Assert.assertEquals(600.0, tt, 1e-8); - Assert.assertEquals(600.0, leg.getTravelTime().seconds(), 1e-8); - Assert.assertEquals(6000.0, leg.getRoute().getDistance(), 1e-8); + Assertions.assertEquals(600.0, tt, 1e-8); + Assertions.assertEquals(600.0, leg.getTravelTime().seconds(), 1e-8); + Assertions.assertEquals(6000.0, leg.getRoute().getDistance(), 1e-8); }{ // the following test is newer than the ones above. I wanted to test the freespeed limit. But could not do it in the same way // above since it is not in FreespeedTravelTimeAndDisutility. Could have modified that disutility. But preferred to test in context. @@ -124,9 +124,9 @@ void testRouteLeg() { Gbl.assertIf( result.size()==1); Leg newLeg = (Leg) result.get(0) ; - Assert.assertEquals(800.0, newLeg.getTravelTime().seconds(), 1e-8); + Assertions.assertEquals(800.0, newLeg.getTravelTime().seconds(), 1e-8); // Assert.assertTrue(leg.getRoute() instanceof GenericRouteImpl); - Assert.assertEquals(3000.0, newLeg.getRoute().getDistance(), 1e-8); + Assertions.assertEquals(3000.0, newLeg.getRoute().getDistance(), 1e-8); } } diff --git a/matsim/src/test/java/org/matsim/core/router/RoutingIT.java b/matsim/src/test/java/org/matsim/core/router/RoutingIT.java index 41da4c9aa46..35ac550ee68 100644 --- a/matsim/src/test/java/org/matsim/core/router/RoutingIT.java +++ b/matsim/src/test/java/org/matsim/core/router/RoutingIT.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -166,7 +166,7 @@ private void doTest(final RouterProvider provider) { new PopulationWriter(referenceScenario.getPopulation(), scenario.getNetwork()).write(this.utils.getOutputDirectory() + "/reference_population.xml.gz"); new PopulationWriter(scenario.getPopulation(), scenario.getNetwork()).write(this.utils.getOutputDirectory() + "/output_population.xml.gz"); } - Assert.assertTrue("different plans files.", isEqual); + Assertions.assertTrue(isEqual, "different plans files."); } private static void calcRoute( diff --git a/matsim/src/test/java/org/matsim/core/router/TeleportationRoutingModuleTest.java b/matsim/src/test/java/org/matsim/core/router/TeleportationRoutingModuleTest.java index 2245d7effe3..44fb6186ed6 100644 --- a/matsim/src/test/java/org/matsim/core/router/TeleportationRoutingModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TeleportationRoutingModuleTest.java @@ -19,7 +19,7 @@ package org.matsim.core.router; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -59,9 +59,9 @@ void testRouteLeg() { "mode", scenario, 10.0, 1.0); double tt = router.routeLeg(person, leg, fromAct, toAct, 7.0 * 3600); - Assert.assertEquals(100.0, tt, 10e-7); - Assert.assertEquals(100.0, leg.getTravelTime().seconds(), 10e-7); - Assert.assertEquals(100.0, leg.getRoute().getTravelTime().seconds(), 10e-7); + Assertions.assertEquals(100.0, tt, 10e-7); + Assertions.assertEquals(100.0, leg.getTravelTime().seconds(), 10e-7); + Assertions.assertEquals(100.0, leg.getRoute().getTravelTime().seconds(), 10e-7); router = new TeleportationRoutingModule( @@ -70,9 +70,9 @@ void testRouteLeg() { 20.0, 1.0); tt = router.routeLeg(person, leg, fromAct, toAct, 7.0 * 3600); - Assert.assertEquals(50.0, tt, 10e-7); - Assert.assertEquals(50.0, leg.getTravelTime().seconds(), 10e-7); - Assert.assertEquals(50.0, leg.getRoute().getTravelTime().seconds(), 10e-7); + Assertions.assertEquals(50.0, tt, 10e-7); + Assertions.assertEquals(50.0, leg.getTravelTime().seconds(), 10e-7); + Assertions.assertEquals(50.0, leg.getRoute().getTravelTime().seconds(), 10e-7); // Activity otherToAct = PopulationUtils.createActivityFromCoord("h", new Coord(1000, 1000)); Facility otherToAct = scenario.getActivityFacilities().getFactory().createActivityFacility( Id.create( "h", ActivityFacility.class ), @@ -85,8 +85,8 @@ void testRouteLeg() { 10.0, manhattanBeelineDistanceFactor); tt = router.routeLeg(person, leg, fromAct, otherToAct, 7.0 * 3600); - Assert.assertEquals(200.0, tt, 10e-7); - Assert.assertEquals(200.0, leg.getTravelTime().seconds(), 10e-7); - Assert.assertEquals(200.0, leg.getRoute().getTravelTime().seconds(), 10e-7); + Assertions.assertEquals(200.0, tt, 10e-7); + Assertions.assertEquals(200.0, leg.getTravelTime().seconds(), 10e-7); + Assertions.assertEquals(200.0, leg.getRoute().getTravelTime().seconds(), 10e-7); } } diff --git a/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java b/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java index fb433b944c3..0b924a0c516 100644 --- a/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java +++ b/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java @@ -22,8 +22,8 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -62,15 +62,15 @@ void testWrapper() { for (Activity activity : activities) { Facility wrapper = FacilitiesUtils.toFacility( activity, null ); - Assert.assertEquals( - "wrapped activity returns incorrect coordinate!", + Assertions.assertEquals( activity.getCoord(), - wrapper.getCoord()); + wrapper.getCoord(), + "wrapped activity returns incorrect coordinate!"); - Assert.assertEquals( - "wrapped activity returns incorrect link id!", + Assertions.assertEquals( activity.getLinkId(), - wrapper.getLinkId()); + wrapper.getLinkId(), + "wrapped activity returns incorrect link id!"); } } } diff --git a/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java b/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java index a49ac52dfd4..d2a23b546a1 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java @@ -18,8 +18,7 @@ * * * *********************************************************************** */ package org.matsim.core.router; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -137,15 +136,15 @@ public void install() { // actual test NetworkRoute r = (NetworkRoute) l.getRoute(); - Assert.assertEquals( - "unexpected route length "+r.getLinkIds(), + Assertions.assertEquals( 1, - r.getLinkIds().size() ); + r.getLinkIds().size(), + "unexpected route length "+r.getLinkIds() ); - Assert.assertEquals( - "unexpected link", + Assertions.assertEquals( l2c.getId(), - r.getLinkIds().get( 0 )); + r.getLinkIds().get( 0 ), + "unexpected link"); } /** @@ -213,15 +212,15 @@ public void install() { // actual test NetworkRoute r = (NetworkRoute) l.getRoute(); - Assert.assertEquals( - "unexpected route length "+r.getLinkIds(), + Assertions.assertEquals( 1, - r.getLinkIds().size() ); + r.getLinkIds().size(), + "unexpected route length "+r.getLinkIds() ); - Assert.assertEquals( - "unexpected link", + Assertions.assertEquals( l2short.getId(), - r.getLinkIds().get( 0 )); + r.getLinkIds().get( 0 ), + "unexpected link"); } private static class LinkFacility implements Facility { diff --git a/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java b/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java index 7fd09524d24..dcc8626033a 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripRouterModuleTest.java @@ -22,7 +22,7 @@ package org.matsim.core.router; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -52,7 +52,7 @@ void testRouterCreation() { scenario.getNetwork(), ControlerDefaults.createDefaultTravelDisutilityFactory(scenario).createTravelDisutility(new FreeSpeedTravelTime()), new FreeSpeedTravelTime()); - Assert.assertNotNull(pathCalculator); + Assertions.assertNotNull(pathCalculator); } } diff --git a/matsim/src/test/java/org/matsim/core/router/TripRouterTest.java b/matsim/src/test/java/org/matsim/core/router/TripRouterTest.java index d3150f2c945..b97cdf0b8a6 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripRouterTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripRouterTest.java @@ -19,8 +19,8 @@ * *********************************************************************** */ package org.matsim.core.router; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.ArrayList; import java.util.List; @@ -64,9 +64,9 @@ void testTripInsertion() { TripRouter.insertTrip( plan , o , trip , d ); assertEquals( - "insertion did not produce the expected plan length!", 13, - plan.getPlanElements().size()); + plan.getPlanElements().size(), + "insertion did not produce the expected plan length!"); int oldIndex = Integer.MIN_VALUE; for (PlanElement pe : plan.getPlanElements()) { @@ -80,8 +80,8 @@ void testTripInsertion() { } assertTrue( - "wrong inserted sequence: "+plan.getPlanElements(), - newIndex > oldIndex); + newIndex > oldIndex, + "wrong inserted sequence: "+plan.getPlanElements()); oldIndex = newIndex; } } @@ -110,9 +110,9 @@ void testTripInsertionIfActivitiesImplementEquals() { TripRouter.insertTrip( plan , o , trip , d ); assertEquals( - "insertion did not produce the expected plan length!", 13, - plan.getPlanElements().size()); + plan.getPlanElements().size(), + "insertion did not produce the expected plan length!"); int oldIndex = Integer.MIN_VALUE; for (PlanElement pe : plan.getPlanElements()) { @@ -126,8 +126,8 @@ void testTripInsertionIfActivitiesImplementEquals() { } assertTrue( - "wrong inserted sequence: "+plan.getPlanElements(), - newIndex > oldIndex); + newIndex > oldIndex, + "wrong inserted sequence: "+plan.getPlanElements()); oldIndex = newIndex; } } @@ -159,9 +159,9 @@ void testReturnedOldTrip() throws Exception { trip.add( PopulationUtils.createLeg("4") ); assertEquals( - "wrong old trip", expected, - TripRouter.insertTrip( plan , o , trip , d ) ); + TripRouter.insertTrip( plan , o , trip , d ), + "wrong old trip" ); } private static class EqualsActivity implements Activity { diff --git a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java index 9ca21632379..106ea1e7790 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java @@ -19,8 +19,8 @@ * *********************************************************************** */ package org.matsim.core.router; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.ArrayList; import java.util.Arrays; @@ -794,18 +794,16 @@ private static void performTest(final Fixture fixture) { TripStructureUtils.getSubtours( fixture.plan ); assertEquals( - "[anchorAtFacilities="+fixture.useFacilitiesAsAnchorPoint+"] "+ - "unexpected number of subtours in "+subtours, fixture.expectedSubtours.size(), - subtours.size() ); + subtours.size(), + "[anchorAtFacilities="+fixture.useFacilitiesAsAnchorPoint+"] "+ + "unexpected number of subtours in "+subtours ); assertEquals( - "[anchorAtFacilities="+fixture.useFacilitiesAsAnchorPoint+"] "+ - "uncompatible subtours", - // do not bother about iteration order, - // but ensure you get some information on failure new HashSet( fixture.expectedSubtours ), - new HashSet( subtours ) ); + new HashSet( subtours ), + "[anchorAtFacilities="+fixture.useFacilitiesAsAnchorPoint+"] "+ + "uncompatible subtours" ); } @Test @@ -820,9 +818,9 @@ void testInconsistentPlan() throws Exception { } assertTrue( + hadException, "[anchorAtFacilities="+fixture.useFacilitiesAsAnchorPoint+"] "+ - "no exception was thrown!", - hadException); + "no exception was thrown!"); } @Test @@ -838,10 +836,10 @@ void testGetTripsWithoutSubSubtours() throws Exception { } assertEquals( - "[anchorAtFacilities="+f.useFacilitiesAsAnchorPoint+"] "+ - "unexpected total number of trips in subtours without subsubtours", countTrips, - nTrips); + nTrips, + "[anchorAtFacilities="+f.useFacilitiesAsAnchorPoint+"] "+ + "unexpected total number of trips in subtours without subsubtours"); } } @@ -853,17 +851,17 @@ void testFatherhood() throws Exception { for (Subtour s : subtours) { for ( Subtour child : s.getChildren() ) { assertEquals( - "[anchorAtFacilities="+f.useFacilitiesAsAnchorPoint+"] "+ - "wrong father!", child.getParent(), - s); + s, + "[anchorAtFacilities="+f.useFacilitiesAsAnchorPoint+"] "+ + "wrong father!"); } if ( s.getParent() != null ) { assertTrue( + s.getParent().getChildren().contains( s ), "[anchorAtFacilities="+f.useFacilitiesAsAnchorPoint+"] "+ - "father does not have subtour has a child", - s.getParent().getChildren().contains( s )); + "father does not have subtour has a child"); } } } diff --git a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java index c27172a82ca..2f28185b50f 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java @@ -26,8 +26,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.After; -import org.junit.Assert; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -42,8 +42,7 @@ import org.matsim.core.router.TripStructureUtils.Trip; import org.matsim.core.scenario.ScenarioUtils; -import static org.junit.Assert.*; -import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.*; /** * @author thibautd @@ -388,14 +387,14 @@ void testActivities() throws Exception { StageActivityHandling.ExcludeStageActivities); assertEquals( - "unexpected number of activities in "+acts+" for fixture "+fixture.name, fixture.expectedNActs, - acts.size() ); + acts.size(), + "unexpected number of activities in "+acts+" for fixture "+fixture.name ); for (Activity act : acts) { assertFalse( - "found a dummy act in "+acts+" for fixture "+fixture.name, - StageActivityTypeIdentifier.isStageActivity( act.getType() )); + StageActivityTypeIdentifier.isStageActivity( act.getType() ), + "found a dummy act in "+acts+" for fixture "+fixture.name); } } } @@ -407,16 +406,16 @@ void testTrips() throws Exception { TripStructureUtils.getTrips(fixture.plan); assertEquals( - "unexpected number of trips in "+trips+" for fixture "+fixture.name, fixture.expectedNTrips, - trips.size() ); + trips.size(), + "unexpected number of trips in "+trips+" for fixture "+fixture.name ); for (Trip trip : trips) { for (PlanElement pe : trip.getTripElements()) { if (pe instanceof Leg) continue; assertTrue( - "found a non-dummy act in "+trip.getTripElements()+" for fixture "+fixture.name, - StageActivityTypeIdentifier.isStageActivity( ((Activity) pe).getType() )); + StageActivityTypeIdentifier.isStageActivity( ((Activity) pe).getType() ), + "found a non-dummy act in "+trip.getTripElements()+" for fixture "+fixture.name); } final int indexOfStart = @@ -431,9 +430,9 @@ void testTrips() throws Exception { indexOfEnd ); assertEquals( - "trip in Trip is not the same as in plan for fixture "+fixture.name, inPlan, - trip.getTripElements()); + trip.getTripElements(), + "trip in Trip is not the same as in plan for fixture "+fixture.name); } } } @@ -450,9 +449,9 @@ void testLegs() throws Exception { } assertEquals( - "getLegsOnly() does not returns the right number of legs", fixture.expectedNLegs, - countLegs); + countLegs, + "getLegsOnly() does not returns the right number of legs"); } } @@ -535,8 +534,8 @@ void testFindTripAtPlanElement() { log.info( tripElement ); } log.info( "" ); - Assert.assertEquals( 9, trip.getTripElements().size() ); - Assert.assertEquals( 5, trip.getLegsOnly().size() ); + Assertions.assertEquals( 9, trip.getTripElements().size() ); + Assertions.assertEquals( 5, trip.getLegsOnly().size() ); } { Trip trip = TripStructureUtils.findTripAtPlanElement( leg, f0.plan, TripStructureUtils::isStageActivityType ) ; @@ -546,8 +545,8 @@ void testFindTripAtPlanElement() { log.info( tripElement ); } log.info( "" ); - Assert.assertEquals( 9, trip.getTripElements().size() ); - Assert.assertEquals( 5, trip.getLegsOnly().size() ); + Assertions.assertEquals( 9, trip.getTripElements().size() ); + Assertions.assertEquals( 5, trip.getLegsOnly().size() ); } { Trip trip = TripStructureUtils.findTripAtPlanElement( leg, f0.plan, TripStructureUtils.createStageActivityType(leg.getMode())::equals ) ; @@ -557,8 +556,8 @@ void testFindTripAtPlanElement() { log.info( tripElement ); } log.info( "" ); - Assert.assertEquals( 5, trip.getTripElements().size() ); - Assert.assertEquals( 3, trip.getLegsOnly().size() ); + Assertions.assertEquals( 5, trip.getTripElements().size() ); + Assertions.assertEquals( 3, trip.getLegsOnly().size() ); } } diff --git a/matsim/src/test/java/org/matsim/core/router/costcalculators/RandomizingTimeDistanceTravelDisutilityTest.java b/matsim/src/test/java/org/matsim/core/router/costcalculators/RandomizingTimeDistanceTravelDisutilityTest.java index b5526dd425a..b564dd46e49 100644 --- a/matsim/src/test/java/org/matsim/core/router/costcalculators/RandomizingTimeDistanceTravelDisutilityTest.java +++ b/matsim/src/test/java/org/matsim/core/router/costcalculators/RandomizingTimeDistanceTravelDisutilityTest.java @@ -23,7 +23,7 @@ import java.util.List; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -66,7 +66,7 @@ void testRoutesForDifferentSigmas() { routes.add(route.getLinkIds().toString()); } System.out.println("Route (sigma = 0.0): " + routes.toString()); - Assert.assertEquals("There should only be a single route in the sigma = 0 case.", 1, routes.size()); + Assertions.assertEquals(1, routes.size(), "There should only be a single route in the sigma = 0 case."); } { @@ -76,7 +76,7 @@ void testRoutesForDifferentSigmas() { routes.add(route.getLinkIds().toString()); } System.out.println("Route (sigma = 3.0): " + routes.toString()); - Assert.assertEquals("There should be two routes in the sigma = 3 case.", 2, routes.size()); + Assertions.assertEquals(2, routes.size(), "There should be two routes in the sigma = 3 case."); } } @@ -112,7 +112,7 @@ public NetworkRoute computeRoute(double sigma) { Facility fromFacility = FacilitiesUtils.toFacility( fromAct, f.s.getActivityFacilities() ); Facility toFacility = FacilitiesUtils.toFacility( toAct, f.s.getActivityFacilities() ); List result = routingModule.calcRoute(DefaultRoutingRequest.withoutAttributes(fromFacility, toFacility, 7.0*3600, person)) ; - Assert.assertEquals(1, result.size() ); + Assertions.assertEquals(1, result.size() ); Leg leg = (Leg) result.get(0) ; return (NetworkRoute) leg.getRoute(); } diff --git a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java index 128a511292e..abf9b242c7a 100644 --- a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java +++ b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java @@ -22,7 +22,7 @@ package org.matsim.core.router.old; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -81,9 +81,9 @@ public void install() { testee.run(plan); if ( config.routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - Assert.assertEquals("Vehicle Id transferred to new Plan", vehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(0).getRoute()).getVehicleId()); + Assertions.assertEquals(vehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(0).getRoute()).getVehicleId(), "Vehicle Id transferred to new Plan"); } else { - Assert.assertEquals("Vehicle Id transferred to new Plan", vehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(1).getRoute()).getVehicleId()); + Assertions.assertEquals(vehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(1).getRoute()).getVehicleId(), "Vehicle Id transferred to new Plan"); // yy I changed get(0) to get(1) since in the input file there is no intervening walk leg, but in the output there is. kai, feb'16 } } @@ -139,9 +139,9 @@ public void install() { PlanRouter testee = new PlanRouter(tripRouter, TimeInterpretation.create(config)); testee.run(plan); if ( config.routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - Assert.assertEquals("Vehicle Id from TripRouter used", newVehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(0).getRoute()).getVehicleId()); + Assertions.assertEquals(newVehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(0).getRoute()).getVehicleId(), "Vehicle Id from TripRouter used"); } else { - Assert.assertEquals("Vehicle Id from TripRouter used", newVehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(1).getRoute()).getVehicleId()); + Assertions.assertEquals(newVehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(1).getRoute()).getVehicleId(), "Vehicle Id from TripRouter used"); // yy I changed get(0) to get(1) since in the input file there is no intervening walk leg, but in the output there is. kai, feb'16 } diff --git a/matsim/src/test/java/org/matsim/core/router/priorityqueue/BinaryMinHeapTest.java b/matsim/src/test/java/org/matsim/core/router/priorityqueue/BinaryMinHeapTest.java index 3cc3590ef0c..b3c2ca23129 100644 --- a/matsim/src/test/java/org/matsim/core/router/priorityqueue/BinaryMinHeapTest.java +++ b/matsim/src/test/java/org/matsim/core/router/priorityqueue/BinaryMinHeapTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** @@ -52,16 +52,16 @@ private void testAdd(MinHeap pq) { DummyHeapEntry entry1 = new DummyHeapEntry(3); DummyHeapEntry entry2 = new DummyHeapEntry(6); - Assert.assertEquals(0, pq.size()); + Assertions.assertEquals(0, pq.size()); pq.add(entry0, 1.0); - Assert.assertEquals(1, pq.size()); + Assertions.assertEquals(1, pq.size()); pq.add(entry1, 2.0); - Assert.assertEquals(2, pq.size()); + Assertions.assertEquals(2, pq.size()); pq.add(entry2, 2.0); // different element with same priority - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); pq.add(entry2, 3.0); // same element with different priority - Assert.assertEquals(3, pq.size()); // should not be added! - Assert.assertEquals(3, iteratorElementCount(pq.iterator())); + Assertions.assertEquals(3, pq.size()); // should not be added! + Assertions.assertEquals(3, iteratorElementCount(pq.iterator())); } @Test @@ -75,13 +75,13 @@ void testAdd_Null() { private void testAdd_Null(MinHeap pq) { try { pq.add(null, 1.0); - Assert.fail("missing NullPointerException."); + Assertions.fail("missing NullPointerException."); } catch (NullPointerException e) { log.info("catched expected exception. ", e); } - Assert.assertEquals(0, pq.size()); - Assert.assertEquals(0, iteratorElementCount(pq.iterator())); + Assertions.assertEquals(0, pq.size()); + Assertions.assertEquals(0, iteratorElementCount(pq.iterator())); } @Test @@ -103,21 +103,21 @@ private void testPoll(MinHeap pq) { pq.add(entry0, 5.0); pq.add(entry1, 3.0); pq.add(entry2, 6.0); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); assertEqualsHE(entry1, pq.poll()); - Assert.assertEquals(2, pq.size()); + Assertions.assertEquals(2, pq.size()); pq.add(entry3, 1.0); pq.add(entry4, 4.0); pq.add(entry5, 9.0); - Assert.assertEquals(5, pq.size()); + Assertions.assertEquals(5, pq.size()); assertEqualsHE(entry3, pq.poll()); assertEqualsHE(entry4, pq.poll()); assertEqualsHE(entry0, pq.poll()); assertEqualsHE(entry2, pq.poll()); assertEqualsHE(entry5, pq.poll()); - Assert.assertEquals(0, pq.size()); - Assert.assertNull(pq.poll()); + Assertions.assertEquals(0, pq.size()); + Assertions.assertNull(pq.poll()); } @Test @@ -140,21 +140,21 @@ private void testPoll2(MinHeap pq) { pq.add(entry0, 5.0); pq.add(entry1, 3.0); pq.add(entry2, 6.0); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); assertEqualsHE(entry1, pq.poll()); - Assert.assertEquals(2, pq.size()); + Assertions.assertEquals(2, pq.size()); pq.add(entry3, 1.0); pq.add(entry4, 4.0); pq.add(entry5, 9.0); - Assert.assertEquals(5, pq.size()); + Assertions.assertEquals(5, pq.size()); assertEqualsHE(entry3, pq.poll()); assertEqualsHE(entry4, pq.poll()); assertEqualsHE(entry0, pq.poll()); assertEqualsHE(entry2, pq.poll()); assertEqualsHE(entry5, pq.poll()); - Assert.assertEquals(0, pq.size()); - Assert.assertNull(pq.poll()); + Assertions.assertEquals(0, pq.size()); + Assertions.assertNull(pq.poll()); } @Test @@ -174,11 +174,11 @@ private void testIterator(MinHeap pq) { pq.add(entry1, 3.0); pq.add(entry2, 6.0); Collection coll = getIteratorCollection(pq.iterator()); - Assert.assertEquals(3, coll.size()); - Assert.assertTrue(coll.contains(entry0)); - Assert.assertTrue(coll.contains(entry1)); - Assert.assertTrue(coll.contains(entry2)); - Assert.assertFalse(coll.contains(entry3)); + Assertions.assertEquals(3, coll.size()); + Assertions.assertTrue(coll.contains(entry0)); + Assertions.assertTrue(coll.contains(entry1)); + Assertions.assertTrue(coll.contains(entry2)); + Assertions.assertFalse(coll.contains(entry3)); } @Test @@ -198,21 +198,21 @@ private void testIterator_ConcurrentModification_add(MinHeap pq) { pq.add(entry1, 3.0); pq.add(entry2, 6.0); Iterator iter = pq.iterator(); - Assert.assertTrue(iter.hasNext()); - Assert.assertNotNull(iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertNotNull(iter.next()); pq.add(entry3, 4.0); - Assert.assertTrue(iter.hasNext()); + Assertions.assertTrue(iter.hasNext()); try { iter.next(); - Assert.fail("missing ConcurrentModificationException"); + Assertions.fail("missing ConcurrentModificationException"); } catch (ConcurrentModificationException e) { log.info("catched expected exception.", e); } iter = pq.iterator(); // but a new iterator must work again - Assert.assertTrue(iter.hasNext()); - Assert.assertNotNull(iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertNotNull(iter.next()); } @Test @@ -231,21 +231,21 @@ private void testIterator_ConcurrentModification_poll(MinHeap pq) { pq.add(entry1, 3.0); pq.add(entry2, 6.0); Iterator iter = pq.iterator(); - Assert.assertTrue(iter.hasNext()); - Assert.assertNotNull(iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertNotNull(iter.next()); pq.poll(); - Assert.assertTrue(iter.hasNext()); + Assertions.assertTrue(iter.hasNext()); try { iter.next(); - Assert.fail("missing ConcurrentModificationException"); + Assertions.fail("missing ConcurrentModificationException"); } catch (ConcurrentModificationException e) { log.info("catched expected exception.", e); } iter = pq.iterator(); // but a new iterator must work again - Assert.assertTrue(iter.hasNext()); - Assert.assertNotNull(iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertNotNull(iter.next()); } @Test @@ -264,24 +264,24 @@ private void testIterator_ConcurrentModification_remove(MinHeap pq) { pq.add(entry1, 3.0); pq.add(entry2, 6.0); Iterator iter = pq.iterator(); - Assert.assertTrue(iter.hasNext()); - Assert.assertNotNull(iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertNotNull(iter.next()); - Assert.assertTrue(pq.remove(entry0)); - Assert.assertTrue(iter.hasNext()); + Assertions.assertTrue(pq.remove(entry0)); + Assertions.assertTrue(iter.hasNext()); try { iter.next(); - Assert.fail("missing ConcurrentModificationException"); + Assertions.fail("missing ConcurrentModificationException"); } catch (ConcurrentModificationException e) { log.info("catched expected exception.", e); } iter = pq.iterator(); // but a new iterator must work again - Assert.assertTrue(iter.hasNext()); - Assert.assertNotNull(iter.next()); - Assert.assertFalse(pq.remove(entry0)); // cannot be removed, so it's no change - Assert.assertTrue(iter.hasNext()); - Assert.assertNotNull(iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertNotNull(iter.next()); + Assertions.assertFalse(pq.remove(entry0)); // cannot be removed, so it's no change + Assertions.assertTrue(iter.hasNext()); + Assertions.assertNotNull(iter.next()); } @Test @@ -300,11 +300,11 @@ private void testIterator_RemoveUnsupported(MinHeap pq) { pq.add(entry1, 3.0); pq.add(entry2, 6.0); Iterator iter = pq.iterator(); - Assert.assertTrue(iter.hasNext()); - Assert.assertNotNull(iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertNotNull(iter.next()); try { iter.remove(); - Assert.fail("missing UnsupportedOperationException"); + Assertions.fail("missing UnsupportedOperationException"); } catch (UnsupportedOperationException e) { log.info("catched expected exception.", e); @@ -329,39 +329,39 @@ private void testRemove(MinHeap pq) { pq.add(entry2, 6.0); Collection coll = getIteratorCollection(pq.iterator()); - Assert.assertEquals(3, coll.size()); - Assert.assertTrue(coll.contains(entry0)); - Assert.assertTrue(coll.contains(entry1)); - Assert.assertTrue(coll.contains(entry2)); - Assert.assertFalse(coll.contains(entry3)); + Assertions.assertEquals(3, coll.size()); + Assertions.assertTrue(coll.contains(entry0)); + Assertions.assertTrue(coll.contains(entry1)); + Assertions.assertTrue(coll.contains(entry2)); + Assertions.assertFalse(coll.contains(entry3)); // remove some element - Assert.assertTrue(pq.remove(entry0)); - Assert.assertEquals(2, pq.size()); + Assertions.assertTrue(pq.remove(entry0)); + Assertions.assertEquals(2, pq.size()); coll = getIteratorCollection(pq.iterator()); - Assert.assertEquals(2, coll.size()); - Assert.assertFalse(coll.contains(entry0)); - Assert.assertTrue(coll.contains(entry1)); - Assert.assertTrue(coll.contains(entry2)); + Assertions.assertEquals(2, coll.size()); + Assertions.assertFalse(coll.contains(entry0)); + Assertions.assertTrue(coll.contains(entry1)); + Assertions.assertTrue(coll.contains(entry2)); // remove the same element again - Assert.assertFalse(pq.remove(entry0)); - Assert.assertEquals(2, pq.size()); + Assertions.assertFalse(pq.remove(entry0)); + Assertions.assertEquals(2, pq.size()); coll = getIteratorCollection(pq.iterator()); - Assert.assertEquals(2, coll.size()); + Assertions.assertEquals(2, coll.size()); // remove null - Assert.assertFalse(pq.remove(null)); - Assert.assertEquals(2, pq.size()); + Assertions.assertFalse(pq.remove(null)); + Assertions.assertEquals(2, pq.size()); coll = getIteratorCollection(pq.iterator()); - Assert.assertEquals(2, coll.size()); - Assert.assertTrue(coll.contains(entry1)); - Assert.assertTrue(coll.contains(entry2)); + Assertions.assertEquals(2, coll.size()); + Assertions.assertTrue(coll.contains(entry1)); + Assertions.assertTrue(coll.contains(entry2)); // now poll the pq and ensure, no removed element is returned assertEqualsHE(entry1, pq.poll()); assertEqualsHE(entry2, pq.poll()); - Assert.assertNull(pq.poll()); + Assertions.assertNull(pq.poll()); } @Test @@ -380,17 +380,17 @@ private void testRemoveAndAdd_LowerPriority(MinHeap pq) { pq.add(entry1, 3.0); pq.add(entry2, 6.0); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); // test removing an element and adding it with lower priority (=higher value) pq.remove(entry0); - Assert.assertEquals(2, pq.size()); + Assertions.assertEquals(2, pq.size()); pq.add(entry0, 7.0); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); assertEqualsHE(entry1, pq.poll()); assertEqualsHE(entry2, pq.poll()); assertEqualsHE(entry0, pq.poll()); - Assert.assertNull(pq.poll()); + Assertions.assertNull(pq.poll()); } // increase priority -> decrease key since it is a min-heap @@ -422,15 +422,15 @@ private void testIncreasePriority(MinHeap pq) { pq.add(entry1, 3.0); pq.add(entry2, 6.0); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); // test decreasing an element by increasing priority (=lower value) pq.decreaseKey(entry0, 2); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); assertEqualsHE(entry0, pq.poll()); assertEqualsHE(entry1, pq.poll()); assertEqualsHE(entry2, pq.poll()); - Assert.assertNull(pq.poll()); + Assertions.assertNull(pq.poll()); /* * Add two elements with the same priority, then add one with a @@ -439,13 +439,13 @@ private void testIncreasePriority(MinHeap pq) { pq.add(entry0, 5.0); pq.add(entry1, 5.0); pq.add(entry2, 6.0); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); pq.decreaseKey(entry2, 4.0); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); assertEqualsHE(entry2, pq.poll()); assertEqualsHE(entry1, pq.poll()); assertEqualsHE(entry0, pq.poll()); - Assert.assertNull(pq.poll()); + Assertions.assertNull(pq.poll()); } @Test @@ -464,17 +464,17 @@ private void testRemoveAndAdd_HigherPriority(MinHeap pq) { pq.add(entry1, 3.0); pq.add(entry2, 6.0); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); // test removing an element and adding it with higher priority (=lower value) pq.remove(entry0); - Assert.assertEquals(2, pq.size()); + Assertions.assertEquals(2, pq.size()); pq.add(entry0, 2.5); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); assertEqualsHE(entry0, pq.poll()); assertEqualsHE(entry1, pq.poll()); assertEqualsHE(entry2, pq.poll()); - Assert.assertNull(pq.poll()); + Assertions.assertNull(pq.poll()); } @Test @@ -507,16 +507,16 @@ private void testEqualCosts(MinHeap pq) { pq.add(entry3, 5.0); pq.add(entry1, 5.0); pq.add(entry0, 5.0); - Assert.assertEquals(4, pq.size()); + Assertions.assertEquals(4, pq.size()); assertEqualsHE(entry0, pq.poll()); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); assertEqualsHE(entry1, pq.poll()); - Assert.assertEquals(2, pq.size()); + Assertions.assertEquals(2, pq.size()); assertEqualsHE(entry2, pq.poll()); - Assert.assertEquals(1, pq.size()); + Assertions.assertEquals(1, pq.size()); assertEqualsHE(entry3, pq.poll()); - Assert.assertEquals(0, pq.size()); - Assert.assertNull(pq.poll()); + Assertions.assertEquals(0, pq.size()); + Assertions.assertNull(pq.poll()); } @Test @@ -577,7 +577,7 @@ private void testEqualCosts2(MinHeap pq) { assertEqualsHE(entry7, pq.poll()); assertEqualsHE(entry8, pq.poll()); assertEqualsHE(entry9, pq.poll()); - Assert.assertNull(pq.poll()); + Assertions.assertNull(pq.poll()); } @Test @@ -614,7 +614,7 @@ private void testExceedCapacity(MinHeap pq) { // this entry should exceed the heaps capacity try { pq.add(entry10, 5.0); - Assert.fail("missing NullPointerException."); + Assertions.fail("missing NullPointerException."); } catch (RuntimeException e) { log.info("catched expected exception. ", e); @@ -642,7 +642,7 @@ private void testOddOrder(MinHeap pq) { assertEqualsHE(entry1, pq.poll()); assertEqualsHE(entry2, pq.poll()); assertEqualsHE(entry3, pq.poll()); - Assert.assertNull(pq.poll()); + Assertions.assertNull(pq.poll()); } private MinHeap createMinHeap(boolean classicalRemove) { @@ -673,8 +673,8 @@ private Collection getIteratorCollection(final Iterator iterator) { } private void assertEqualsHE(HasIndex e1, HasIndex e2) { - Assert.assertEquals(e1.getArrayIndex(), e2.getArrayIndex()); - Assert.assertEquals(e1, e2); + Assertions.assertEquals(e1.getArrayIndex(), e2.getArrayIndex()); + Assertions.assertEquals(e1, e2); } private static class DummyHeapEntry implements HasIndex { diff --git a/matsim/src/test/java/org/matsim/core/router/speedy/DAryMinHeapTest.java b/matsim/src/test/java/org/matsim/core/router/speedy/DAryMinHeapTest.java index f2737b2ed76..01f30c231ac 100644 --- a/matsim/src/test/java/org/matsim/core/router/speedy/DAryMinHeapTest.java +++ b/matsim/src/test/java/org/matsim/core/router/speedy/DAryMinHeapTest.java @@ -1,6 +1,6 @@ package org.matsim.core.router.speedy; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import java.util.Random; @@ -28,27 +28,27 @@ void testPoll() { pq.insert(1, cost[1]); pq.insert(0, cost[0]); - Assert.assertEquals(3, pq.size()); + Assertions.assertEquals(3, pq.size()); - Assert.assertEquals(1, pq.poll()); - Assert.assertEquals(2, pq.poll()); - Assert.assertEquals(0, pq.poll()); + Assertions.assertEquals(1, pq.poll()); + Assertions.assertEquals(2, pq.poll()); + Assertions.assertEquals(0, pq.poll()); - Assert.assertTrue(pq.isEmpty()); + Assertions.assertTrue(pq.isEmpty()); for (int i = 0; i < 8; i++) { pq.insert(i, cost[i]); } - Assert.assertEquals(5, pq.poll()); - Assert.assertEquals(1, pq.poll()); - Assert.assertEquals(6, pq.poll()); - Assert.assertEquals(2, pq.poll()); - Assert.assertEquals(0, pq.poll()); - Assert.assertEquals(7, pq.poll()); - Assert.assertEquals(3, pq.poll()); - Assert.assertEquals(4, pq.poll()); - Assert.assertTrue(pq.isEmpty()); + Assertions.assertEquals(5, pq.poll()); + Assertions.assertEquals(1, pq.poll()); + Assertions.assertEquals(6, pq.poll()); + Assertions.assertEquals(2, pq.poll()); + Assertions.assertEquals(0, pq.poll()); + Assertions.assertEquals(7, pq.poll()); + Assertions.assertEquals(3, pq.poll()); + Assertions.assertEquals(4, pq.poll()); + Assertions.assertTrue(pq.isEmpty()); } @Test @@ -61,10 +61,10 @@ void testDecreaseKey() { pq.decreaseKey(2, 1.0); - Assert.assertEquals(2, pq.poll()); - Assert.assertEquals(1, pq.poll()); - Assert.assertEquals(0, pq.poll()); - Assert.assertTrue(pq.isEmpty()); + Assertions.assertEquals(2, pq.poll()); + Assertions.assertEquals(1, pq.poll()); + Assertions.assertEquals(0, pq.poll()); + Assertions.assertTrue(pq.isEmpty()); } @Test @@ -87,7 +87,7 @@ void stresstest() { step++; int node = pq.poll(); double nodeCost = cost[node]; - Assert.assertTrue(step + ": " + lastCost + " <= " + nodeCost, lastCost <= nodeCost); + Assertions.assertTrue(lastCost <= nodeCost, step + ": " + lastCost + " <= " + nodeCost); lastCost = nodeCost; } @@ -110,7 +110,7 @@ void stresstest() { step++; int node = pq.poll(); double nodeCost = cost[node]; - Assert.assertTrue(step + ": " + lastCost + " <= " + nodeCost, lastCost <= nodeCost); + Assertions.assertTrue(lastCost <= nodeCost, step + ": " + lastCost + " <= " + nodeCost); lastCost = nodeCost; } diff --git a/matsim/src/test/java/org/matsim/core/router/speedy/SpeedyGraphTest.java b/matsim/src/test/java/org/matsim/core/router/speedy/SpeedyGraphTest.java index 2127d559b03..4085ebd3b25 100644 --- a/matsim/src/test/java/org/matsim/core/router/speedy/SpeedyGraphTest.java +++ b/matsim/src/test/java/org/matsim/core/router/speedy/SpeedyGraphTest.java @@ -1,6 +1,6 @@ package org.matsim.core.router.speedy; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -32,58 +32,58 @@ void testConstruction() { // test out-links node 1 li.reset(f.node1.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link12); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link13); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link14); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test out-links node 2 li.reset(f.node2.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link21); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test out-links node 3 li.reset(f.node3.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link34); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link35); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test out-links node 4 li.reset(f.node4.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link46); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test out-links node 5 li.reset(f.node5.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link56); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test out-links node 6 li.reset(f.node6.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link65); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link62); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test in-links @@ -92,66 +92,66 @@ void testConstruction() { // test in-links node 1 li.reset(f.node1.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link21); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test in-links node 2 li.reset(f.node2.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link12); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link62); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test in-links node 3 li.reset(f.node3.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link13); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test in-links node 4 li.reset(f.node4.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link14); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link34); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test in-links node 5 li.reset(f.node5.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link35); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link65); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); // test in-links node 6 li.reset(f.node6.getId().index()); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link46); - Assert.assertTrue(li.next()); + Assertions.assertTrue(li.next()); assertLink(li, f.link56); - Assert.assertFalse(li.next()); - Assert.assertFalse(li.next()); + Assertions.assertFalse(li.next()); + Assertions.assertFalse(li.next()); } private void assertLink(LinkIterator li, Link link) { - Assert.assertEquals(link.getId().index(), li.getLinkIndex()); - Assert.assertEquals(link.getFromNode().getId().index(), li.getFromNodeIndex()); - Assert.assertEquals(link.getToNode().getId().index(), li.getToNodeIndex()); - Assert.assertEquals(link.getLength(), li.getLength(), 1e-2); - Assert.assertEquals(link.getLength() / link.getFreespeed(), li.getFreespeedTravelTime(), 1e-2); + Assertions.assertEquals(link.getId().index(), li.getLinkIndex()); + Assertions.assertEquals(link.getFromNode().getId().index(), li.getFromNodeIndex()); + Assertions.assertEquals(link.getToNode().getId().index(), li.getToNodeIndex()); + Assertions.assertEquals(link.getLength(), li.getLength(), 1e-2); + Assertions.assertEquals(link.getLength() / link.getFreespeed(), li.getFreespeedTravelTime(), 1e-2); } private static class Fixture { diff --git a/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java b/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java index a11338e58e2..0bc1000c65c 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java +++ b/matsim/src/test/java/org/matsim/core/scenario/ScenarioByConfigInjectionTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -42,7 +42,7 @@ import org.matsim.utils.objectattributes.ObjectAttributes; import org.matsim.utils.objectattributes.ObjectAttributesXmlWriter; - /** + /** * @author thibautd */ public class ScenarioByConfigInjectionTest { @@ -81,10 +81,10 @@ public void install() { Object stupid = person.getAttributes().getAttribute( "stupidAttribute" ); // TODO test for ALL attribute containers... - Assert.assertEquals( - "Unexpected type of read in attribute", + Assertions.assertEquals( StupidClass.class, - stupid.getClass() ); + stupid.getClass(), + "Unexpected type of read in attribute" ); log.info( "get person attribute" ); stupid = scenario.getPopulation() @@ -93,10 +93,10 @@ public void install() { .getAttributes() .getAttribute( "otherAttribute" ); - Assert.assertEquals( - "Unexpected type of read in attribute", + Assertions.assertEquals( StupidClass.class, - stupid.getClass() ); + stupid.getClass(), + "Unexpected type of read in attribute" ); log.info( "get activity attribute" ); stupid = scenario.getPopulation() @@ -108,10 +108,10 @@ public void install() { .getAttributes() .getAttribute( "actAttribute" ); - Assert.assertEquals( - "Unexpected type of read in attribute", + Assertions.assertEquals( StupidClass.class, - stupid.getClass() ); + stupid.getClass(), + "Unexpected type of read in attribute" ); log.info( "get leg attribute" ); stupid = scenario.getPopulation() @@ -123,20 +123,20 @@ public void install() { .getAttributes() .getAttribute( "legAttribute" ); - Assert.assertEquals( - "Unexpected type of read in attribute", + Assertions.assertEquals( StupidClass.class, - stupid.getClass() ); + stupid.getClass(), + "Unexpected type of read in attribute" ); log.info( "get network attribute" ); stupid = scenario.getNetwork() .getAttributes() .getAttribute( "networkAttribute" ); - Assert.assertEquals( - "Unexpected type of read in attribute", + Assertions.assertEquals( StupidClass.class, - stupid.getClass() ); + stupid.getClass(), + "Unexpected type of read in attribute" ); log.info( "get Link attribute" ); stupid = scenario.getNetwork() @@ -145,10 +145,10 @@ public void install() { .getAttributes() .getAttribute( "linkAttribute" ); - Assert.assertEquals( - "Unexpected type of read in attribute", + Assertions.assertEquals( StupidClass.class, - stupid.getClass() ); + stupid.getClass(), + "Unexpected type of read in attribute" ); log.info( "get Node attribute" ); stupid = scenario.getNetwork() @@ -157,10 +157,10 @@ public void install() { .getAttributes() .getAttribute( "nodeAttribute" ); - Assert.assertEquals( - "Unexpected type of read in attribute", + Assertions.assertEquals( StupidClass.class, - stupid.getClass() ); + stupid.getClass(), + "Unexpected type of read in attribute" ); } private Config createTestScenario() { diff --git a/matsim/src/test/java/org/matsim/core/scenario/ScenarioImplTest.java b/matsim/src/test/java/org/matsim/core/scenario/ScenarioImplTest.java index 20585a8dd28..741fbf70dca 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/ScenarioImplTest.java +++ b/matsim/src/test/java/org/matsim/core/scenario/ScenarioImplTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.core.scenario; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.config.ConfigUtils; import org.matsim.households.Households; @@ -41,20 +41,20 @@ void testAddAndGetScenarioElement() { s.addScenarioElement( name1 , element1 ); s.addScenarioElement( name2 , element2 ); - Assert.assertSame( - "unexpected scenario element", + Assertions.assertSame( element1, - s.getScenarioElement( name1 ) ); + s.getScenarioElement( name1 ), + "unexpected scenario element" ); // just check that it is got, not removed - Assert.assertSame( - "unexpected scenario element", + Assertions.assertSame( element1, - s.getScenarioElement( name1 ) ); + s.getScenarioElement( name1 ), + "unexpected scenario element" ); - Assert.assertSame( - "unexpected scenario element", + Assertions.assertSame( element2, - s.getScenarioElement( name2 ) ); + s.getScenarioElement( name2 ), + "unexpected scenario element" ); } @@ -72,9 +72,9 @@ void testCannotAddAnElementToAnExistingName() { return; } catch (Exception e) { - Assert.fail( "wrong exception thrown when trying to add an element for an existing name "+e.getClass().getName() ); + Assertions.fail( "wrong exception thrown when trying to add an element for an existing name "+e.getClass().getName() ); } - Assert.fail( "no exception thrown when trying to add an element for an existing name" ); + Assertions.fail( "no exception thrown when trying to add an element for an existing name" ); } @Test @@ -85,13 +85,13 @@ void testRemoveElement() { final String name = "clark_kent"; s.addScenarioElement( name , element ); - Assert.assertSame( - "unexpected removed element", + Assertions.assertSame( element, - s.removeScenarioElement( name ) ); - Assert.assertNull( - "element was not removed", - s.getScenarioElement( name ) ); + s.removeScenarioElement( name ), + "unexpected removed element" ); + Assertions.assertNull( + s.getScenarioElement( name ), + "element was not removed" ); } diff --git a/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java b/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java index 1cdae1fd44a..a26eaacb88f 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java +++ b/matsim/src/test/java/org/matsim/core/scenario/ScenarioLoaderImplTest.java @@ -20,7 +20,7 @@ package org.matsim.core.scenario; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -55,18 +55,18 @@ void testLoadScenario_loadTransitData() { ScenarioBuilder builder = new ScenarioBuilder(ConfigUtils.loadConfig(IOUtils.extendUrl(this.util.classInputResourcePath(), "transitConfig.xml"))); // facilities is there by default???? Scenario scenario = builder.build() ; - Assert.assertEquals(0, scenario.getTransitSchedule().getTransitLines().size()); - Assert.assertEquals(0, scenario.getTransitSchedule().getFacilities().size()); + Assertions.assertEquals(0, scenario.getTransitSchedule().getTransitLines().size()); + Assertions.assertEquals(0, scenario.getTransitSchedule().getFacilities().size()); ScenarioUtils.loadScenario(scenario); - Assert.assertEquals(1, scenario.getTransitSchedule().getTransitLines().size()); - Assert.assertEquals(2, scenario.getTransitSchedule().getFacilities().size()); + Assertions.assertEquals(1, scenario.getTransitSchedule().getTransitLines().size()); + Assertions.assertEquals(2, scenario.getTransitSchedule().getFacilities().size()); } // load directly: { Scenario scenario = ScenarioUtils.loadScenario(ConfigUtils.loadConfig(IOUtils.extendUrl(this.util.classInputResourcePath(), "transitConfig.xml"))); - Assert.assertEquals(1, scenario.getTransitSchedule().getTransitLines().size()); - Assert.assertEquals(2, scenario.getTransitSchedule().getFacilities().size()); + Assertions.assertEquals(1, scenario.getTransitSchedule().getTransitLines().size()); + Assertions.assertEquals(2, scenario.getTransitSchedule().getFacilities().size()); } } @@ -79,7 +79,7 @@ void testLoadScenario_loadPersonAttributes_nowDeprecated() { Population population = scenario.getPopulation(); Person person = population.getPersons().get( Id.createPersonId( "1" ) ) ; Gbl.assertNotNull( person ); - Assert.assertEquals("world", person.getAttributes().getAttribute( "hello" ) ); + Assertions.assertEquals("world", person.getAttributes().getAttribute( "hello" ) ); } @Test @@ -94,7 +94,7 @@ void testLoadScenario_loadPersonAttributes() { // expected exception caughtException = true ; } - Assert.assertTrue( caughtException ); + Assertions.assertTrue( caughtException ); } @@ -104,12 +104,12 @@ void testLoadScenario_loadFacilitiesAttributes() { config.facilities().setInsistingOnUsingDeprecatedFacilitiesAttributeFile(true); config.facilities().addParam("inputFacilityAttributesFile", "facilityAttributes.xml"); Scenario scenario = ScenarioUtils.loadScenario(config); - Assert.assertEquals( - "unexpected attribute value", + Assertions.assertEquals( "world", FacilitiesUtils.getFacilityAttribute( scenario.getActivityFacilities().getFacilities().get(Id.create(1, ActivityFacility.class)), - "hello")); + "hello"), + "unexpected attribute value"); } @Test @@ -118,12 +118,12 @@ void testLoadScenario_loadHouseholdAttributes() { config.households().addParam("inputHouseholdAttributesFile", "householdAttributes.xml"); config.households().setInsistingOnUsingDeprecatedHouseholdsAttributeFile(true); Scenario scenario = ScenarioUtils.loadScenario(config); - Assert.assertEquals( - "unexpected attribute value", + Assertions.assertEquals( "world", HouseholdUtils.getHouseholdAttribute( scenario.getHouseholds().getHouseholds().get(Id.create(1, Household.class)), - "hello")); + "hello"), + "unexpected attribute value"); } } diff --git a/matsim/src/test/java/org/matsim/core/scenario/ScenarioUtilsTest.java b/matsim/src/test/java/org/matsim/core/scenario/ScenarioUtilsTest.java index 2e6b2aa7e22..ad3a64fa662 100644 --- a/matsim/src/test/java/org/matsim/core/scenario/ScenarioUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/scenario/ScenarioUtilsTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Scenario; @@ -36,11 +36,11 @@ public class ScenarioUtilsTest { void testCreateScenario_nullConfig() { try { Scenario s = ScenarioUtils.createScenario(null); - Assert.fail("expected NPE, but got none." + s.toString()); + Assertions.fail("expected NPE, but got none." + s.toString()); } catch (NullPointerException e) { log.info("Catched expected NPE.", e); - Assert.assertTrue("Message in NPE should not be empty.", e.getMessage().length() > 0); + Assertions.assertTrue(e.getMessage().length() > 0, "Message in NPE should not be empty."); } } } diff --git a/matsim/src/test/java/org/matsim/core/scoring/EventsToActivitiesTest.java b/matsim/src/test/java/org/matsim/core/scoring/EventsToActivitiesTest.java index 9af33789d81..463657b2410 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/EventsToActivitiesTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/EventsToActivitiesTest.java @@ -19,7 +19,7 @@ package org.matsim.core.scoring; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -42,11 +42,11 @@ void testCreatesActivty() { "work", new Coord( 123., 4.56 ) ) ); testee.handleEvent(new ActivityEndEvent(30.0, Id.create("1", Person.class), Id.create("l1", Link.class), Id.create("l1", ActivityFacility.class), "work", new Coord( 123., 4.56 ))); - Assert.assertNotNull(ah.handledActivity); - Assert.assertEquals(10.0, ah.handledActivity.getActivity().getStartTime().seconds(), 1e-8); - Assert.assertEquals(30.0, ah.handledActivity.getActivity().getEndTime().seconds(), 1e-8); - Assert.assertEquals( 123., ah.handledActivity.getActivity().getCoord().getX(), 0. ); - Assert.assertEquals( 4.56, ah.handledActivity.getActivity().getCoord().getY(), 0. ); + Assertions.assertNotNull(ah.handledActivity); + Assertions.assertEquals(10.0, ah.handledActivity.getActivity().getStartTime().seconds(), 1e-8); + Assertions.assertEquals(30.0, ah.handledActivity.getActivity().getEndTime().seconds(), 1e-8); + Assertions.assertEquals( 123., ah.handledActivity.getActivity().getCoord().getX(), 0. ); + Assertions.assertEquals( 4.56, ah.handledActivity.getActivity().getCoord().getY(), 0. ); } @Test @@ -57,18 +57,18 @@ void testCreateNightActivity() { testee.reset(0); testee.handleEvent(new ActivityEndEvent(10.0, Id.create("1", Person.class), Id.create("l1", Link.class), Id.create("l1", ActivityFacility.class), "home", new Coord( 123., 4.56 ))); - Assert.assertNotNull(ah.handledActivity); - Assert.assertTrue(ah.handledActivity.getActivity().getStartTime().isUndefined()); - Assert.assertEquals(10.0, ah.handledActivity.getActivity().getEndTime().seconds(), 1e-8); + Assertions.assertNotNull(ah.handledActivity); + Assertions.assertTrue(ah.handledActivity.getActivity().getStartTime().isUndefined()); + Assertions.assertEquals(10.0, ah.handledActivity.getActivity().getEndTime().seconds(), 1e-8); ah.reset(); testee.handleEvent(new ActivityStartEvent(90.0, Id.create("1", Person.class), Id.create("l1", Link.class), Id.create("l1", ActivityFacility.class), "home", new Coord( 123., 4.56 ) ) ); testee.finish(); - Assert.assertNotNull(ah.handledActivity); - Assert.assertTrue(ah.handledActivity.getActivity().getEndTime().isUndefined()); - Assert.assertEquals(90.0, ah.handledActivity.getActivity().getStartTime().seconds(), 1e-8); - Assert.assertEquals( 123., ah.handledActivity.getActivity().getCoord().getX(), 0. ); - Assert.assertEquals( 4.56, ah.handledActivity.getActivity().getCoord().getY(), 0. ); + Assertions.assertNotNull(ah.handledActivity); + Assertions.assertTrue(ah.handledActivity.getActivity().getEndTime().isUndefined()); + Assertions.assertEquals(90.0, ah.handledActivity.getActivity().getStartTime().seconds(), 1e-8); + Assertions.assertEquals( 123., ah.handledActivity.getActivity().getCoord().getX(), 0. ); + Assertions.assertEquals( 4.56, ah.handledActivity.getActivity().getCoord().getY(), 0. ); } @Test @@ -79,12 +79,12 @@ void testDontCreateNightActivityIfNoneIsBeingPerformedWhenSimulationEnds() { testee.reset(0); testee.handleEvent(new ActivityEndEvent(10.0, Id.create("1", Person.class), Id.create("l1", Link.class), Id.create("f1", ActivityFacility.class), "home", new Coord( 123., 4.56 ))); - Assert.assertNotNull(ah.handledActivity); - Assert.assertTrue(ah.handledActivity.getActivity().getStartTime().isUndefined()) ; - Assert.assertEquals(10.0, ah.handledActivity.getActivity().getEndTime().seconds(), 1e-8); + Assertions.assertNotNull(ah.handledActivity); + Assertions.assertTrue(ah.handledActivity.getActivity().getStartTime().isUndefined()) ; + Assertions.assertEquals(10.0, ah.handledActivity.getActivity().getEndTime().seconds(), 1e-8); ah.reset(); testee.finish(); - Assert.assertNull(ah.handledActivity); + Assertions.assertNull(ah.handledActivity); } private static class MockActivityHandler implements ActivityHandler { diff --git a/matsim/src/test/java/org/matsim/core/scoring/EventsToLegsTest.java b/matsim/src/test/java/org/matsim/core/scoring/EventsToLegsTest.java index e4867f43cad..aa5f159bca9 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/EventsToLegsTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/EventsToLegsTest.java @@ -21,7 +21,7 @@ import java.util.Collections; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -88,8 +88,7 @@ void testCreatesLegWithRoute() { eventsToLegs.handleEvent(new VehicleLeavesTrafficEvent(30.0, agentId, Id.createLinkId("l3"), vehId, "car", 1.0)); eventsToLegs.handleEvent(new PersonArrivalEvent(30.0, agentId, Id.createLinkId("l3"), "car")); assertLeg(lh, 10., 20., 550.0, "car"); - Assert.assertEquals(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME + " missing or incorrect!", - 10.0, lh.handledLeg.getLeg().getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME)); + Assertions.assertEquals(10.0, lh.handledLeg.getLeg().getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME), EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME + " missing or incorrect!"); } @Test @@ -130,8 +129,7 @@ void testCreatesLegWithRoute_jointTrip() { eventsToLegs.handleEvent(new PersonArrivalEvent(30.0, agentId1, Id.createLinkId("l3"), "car")); assertLeg(lh, 10., 20., 550.0, "car"); - Assert.assertEquals(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME + " missing or incorrect!", - 10.0, lh.handledLeg.getLeg().getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME)); + Assertions.assertEquals(10.0, lh.handledLeg.getLeg().getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME), EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME + " missing or incorrect!"); } @Test @@ -148,8 +146,7 @@ void testCreatesLegWithRoute_withoutEnteringTraffic() { //driver leaves out vehicle after 10 seconds, no driving at all eventsToLegs.handleEvent(new PersonArrivalEvent(20.0, agentId1, Id.createLinkId("l1"), "car")); assertLeg(lh, 10., 10., 0.0, "car"); - Assert.assertEquals(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME + " missing or incorrect!", - 10.0, lh.handledLeg.getLeg().getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME)); + Assertions.assertEquals(10.0, lh.handledLeg.getLeg().getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME), EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME + " missing or incorrect!"); } @Test @@ -170,8 +167,7 @@ void testCreatesLegWithRoute_withLeavingTrafficOnTheSameLink() { new VehicleLeavesTrafficEvent(25.0, agentId1, Id.createLinkId("l1"), vehId, "car", 1.0)); eventsToLegs.handleEvent(new PersonArrivalEvent(20.0, agentId1, Id.createLinkId("l1"), "car")); assertLeg(lh, 10., 10., 500.0, "car"); - Assert.assertEquals(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME + " missing or incorrect!", - 10.0, lh.handledLeg.getLeg().getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME)); + Assertions.assertEquals(10.0, lh.handledLeg.getLeg().getAttributes().getAttribute(EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME), EventsToLegs.ENTER_VEHICLE_TIME_ATTRIBUTE_NAME + " missing or incorrect!"); } @Test @@ -228,12 +224,12 @@ void testCreatesTransitPassengerRoute() { eventsToLegs.handleEvent(new PersonEntersVehicleEvent(100.0, passengerId, transitVehiceId)); eventsToLegs.handleEvent(new PersonArrivalEvent(1000.0, passengerId, accessLinkId, "pt")); - Assert.assertEquals(10.0, lh.handledLeg.getLeg().getDepartureTime().seconds(), 1e-3); - Assert.assertEquals(1000.0 - 10.0, lh.handledLeg.getLeg().getTravelTime().seconds(), 1e-3); - Assert.assertTrue(lh.handledLeg.getLeg().getRoute() instanceof TransitPassengerRoute); + Assertions.assertEquals(10.0, lh.handledLeg.getLeg().getDepartureTime().seconds(), 1e-3); + Assertions.assertEquals(1000.0 - 10.0, lh.handledLeg.getLeg().getTravelTime().seconds(), 1e-3); + Assertions.assertTrue(lh.handledLeg.getLeg().getRoute() instanceof TransitPassengerRoute); TransitPassengerRoute route = (TransitPassengerRoute) lh.handledLeg.getLeg().getRoute(); - Assert.assertEquals(100.0, route.getBoardingTime().seconds(), 1e-3); + Assertions.assertEquals(100.0, route.getBoardingTime().seconds(), 1e-3); } private static Scenario createTriangularNetwork() { @@ -266,12 +262,12 @@ private static Scenario createTriangularNetwork() { private void assertLeg(RememberingLegHandler lh, double departureTime, double travelTime, double distance, String mode) { - Assert.assertNotNull(lh.handledLeg); - Assert.assertEquals(departureTime, lh.handledLeg.getLeg().getDepartureTime().seconds(), 1e-9); - Assert.assertEquals(travelTime, lh.handledLeg.getLeg().getTravelTime().seconds(), 1e-9); - Assert.assertEquals(travelTime, lh.handledLeg.getLeg().getRoute().getTravelTime().seconds(), 1e-9); - Assert.assertEquals(distance, lh.handledLeg.getLeg().getRoute().getDistance(), 1e-9); - Assert.assertEquals(mode, lh.handledLeg.getLeg().getMode()); + Assertions.assertNotNull(lh.handledLeg); + Assertions.assertEquals(departureTime, lh.handledLeg.getLeg().getDepartureTime().seconds(), 1e-9); + Assertions.assertEquals(travelTime, lh.handledLeg.getLeg().getTravelTime().seconds(), 1e-9); + Assertions.assertEquals(travelTime, lh.handledLeg.getLeg().getRoute().getTravelTime().seconds(), 1e-9); + Assertions.assertEquals(distance, lh.handledLeg.getLeg().getRoute().getDistance(), 1e-9); + Assertions.assertEquals(mode, lh.handledLeg.getLeg().getMode()); } private static class RememberingLegHandler implements LegHandler { diff --git a/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java b/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java index ea8da87ea56..4d0bbb8f127 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/EventsToScoreTest.java @@ -20,7 +20,7 @@ package org.matsim.core.scoring; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -65,7 +65,7 @@ void testAddMoney() { events.processEvent(new PersonMoneyEvent(3600.0, person.getId(), 3.4, "tollRefund", "motorwayOperator")); events.finishProcessing(); e2s.finish(); - Assert.assertEquals(3.4, e2s.getAgentScore(person.getId()), 0); + Assertions.assertEquals(3.4, e2s.getAgentScore(person.getId()), 0); } @Test @@ -105,53 +105,53 @@ void testMsaAveraging() { switch(mockIteration){ case 99: - Assert.assertEquals(1.0, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(1.0, person.getSelectedPlan().getScore(), 0); break ; case 100: // first MSA iteration; plain score should be ok: - Assert.assertEquals(2.0, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(2.0, person.getSelectedPlan().getScore(), 0); break ; case 101: // second MSA iteration // (2+3)/2 = 2.5 - Assert.assertEquals(2.5, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(2.5, person.getSelectedPlan().getScore(), 0); break ; case 102: // 3rd MSA iteration // (2+3+4)/3 = 3 - Assert.assertEquals(3.0, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(3.0, person.getSelectedPlan().getScore(), 0); break ; case 103: // (2+3+4+5)/4 = 3.5 - Assert.assertEquals(3.5, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(3.5, person.getSelectedPlan().getScore(), 0); break ; case 104: // 3rd MSA iteration - Assert.assertEquals(4.0, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(4.0, person.getSelectedPlan().getScore(), 0); break ; case 105: // 3rd MSA iteration - Assert.assertEquals(4.5, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(4.5, person.getSelectedPlan().getScore(), 0); break ; case 106: // 3rd MSA iteration - Assert.assertEquals(5.0, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(5.0, person.getSelectedPlan().getScore(), 0); break ; case 107: // 3rd MSA iteration - Assert.assertEquals(5.5, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(5.5, person.getSelectedPlan().getScore(), 0); break ; case 108: // 3rd MSA iteration - Assert.assertEquals(6.0, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(6.0, person.getSelectedPlan().getScore(), 0); break ; case 109: // 3rd MSA iteration - Assert.assertEquals(6.5, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(6.5, person.getSelectedPlan().getScore(), 0); break ; case 110: // 3rd MSA iteration - Assert.assertEquals(7.0, person.getSelectedPlan().getScore(), 0); + Assertions.assertEquals(7.0, person.getSelectedPlan().getScore(), 0); break ; } diff --git a/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java b/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java index 2f180299805..52cdbb2ca36 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java +++ b/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java @@ -44,7 +44,7 @@ import org.matsim.core.scenario.ScenarioUtils; import org.matsim.core.scoring.functions.CharyparNagelScoringFunctionFactory; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertThrows; public class ScoringFunctionsForPopulationStressIT { diff --git a/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationTest.java b/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationTest.java index 9eec6681fb6..cecacd2f17d 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationTest.java @@ -21,7 +21,7 @@ package org.matsim.core.scoring; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -44,7 +44,7 @@ import org.matsim.core.router.TripStructureUtils; import org.matsim.core.scenario.ScenarioUtils; - /** + /** * @author mrieser / Simunto GmbH */ public class ScoringFunctionsForPopulationTest { @@ -68,39 +68,39 @@ void testTripScoring() { ScoringFunctionsForPopulation sf = new ScoringFunctionsForPopulation(controlerListenerManager, eventsManager, eventsToActivities, eventsToLegs, population, scoringFunctionFactory, scenario.getConfig()); controlerListenerManager.fireControlerIterationStartsEvent(0, false); ScoringFunction s = sf.getScoringFunctionForAgent(personId); - Assert.assertEquals(RecordingScoringFunction.class, s.getClass()); + Assertions.assertEquals(RecordingScoringFunction.class, s.getClass()); RecordingScoringFunction rs = (RecordingScoringFunction) s; sf.handleActivity(new PersonExperiencedActivity(personId, pf.createActivityFromCoord("home", new Coord(100, 100)))); - Assert.assertEquals(0, rs.tripCounter); + Assertions.assertEquals(0, rs.tripCounter); sf.handleLeg(new PersonExperiencedLeg(personId, pf.createLeg("walk"))); - Assert.assertEquals(0, rs.tripCounter); + Assertions.assertEquals(0, rs.tripCounter); sf.handleEvent(new ActivityStartEvent(8*3600, personId, null, null, "work", new Coord(1000, 100))); - Assert.assertEquals(1, rs.tripCounter); + Assertions.assertEquals(1, rs.tripCounter); sf.handleActivity(new PersonExperiencedActivity(personId, pf.createActivityFromCoord("work", new Coord(1000, 100)))); - Assert.assertEquals(1, rs.tripCounter); - Assert.assertEquals(1, rs.lastTrip.getTripElements().size()); - Assert.assertEquals("walk", ((Leg) rs.lastTrip.getTripElements().get(0)).getMode()); + Assertions.assertEquals(1, rs.tripCounter); + Assertions.assertEquals(1, rs.lastTrip.getTripElements().size()); + Assertions.assertEquals("walk", ((Leg) rs.lastTrip.getTripElements().get(0)).getMode()); sf.handleLeg(new PersonExperiencedLeg(personId, pf.createLeg("transit_walk"))); sf.handleEvent(new ActivityStartEvent(17*3600 - 10, personId, null, null, "pt interaction", new Coord(1000, 200))); - Assert.assertEquals(1, rs.tripCounter); + Assertions.assertEquals(1, rs.tripCounter); sf.handleActivity(new PersonExperiencedActivity(personId, PopulationUtils.createStageActivityFromCoordLinkIdAndModePrefix(new Coord(1000, 200), null, TransportMode.pt))); - Assert.assertEquals(1, rs.tripCounter); + Assertions.assertEquals(1, rs.tripCounter); sf.handleLeg(new PersonExperiencedLeg(personId, pf.createLeg("pt"))); sf.handleEvent(new ActivityStartEvent(17*3600, personId, null, null, "pt interaction", new Coord(1000, 200))); - Assert.assertEquals(1, rs.tripCounter); + Assertions.assertEquals(1, rs.tripCounter); sf.handleActivity(new PersonExperiencedActivity(personId, PopulationUtils.createStageActivityFromCoordLinkIdAndModePrefix(new Coord(1000, 200), null, TransportMode.pt))); - Assert.assertEquals(1, rs.tripCounter); + Assertions.assertEquals(1, rs.tripCounter); sf.handleLeg(new PersonExperiencedLeg(personId, pf.createLeg("transit_walk"))); sf.handleEvent(new ActivityStartEvent(17*3600 + 10, personId, null, null, "leisure", new Coord(1000, 200))); - Assert.assertEquals(2, rs.tripCounter); + Assertions.assertEquals(2, rs.tripCounter); sf.handleActivity(new PersonExperiencedActivity(personId, pf.createActivityFromCoord("leisure", new Coord(1000, 200)))); - Assert.assertEquals(2, rs.tripCounter); - Assert.assertEquals(5, rs.lastTrip.getTripElements().size()); - Assert.assertEquals("transit_walk", ((Leg) rs.lastTrip.getTripElements().get(0)).getMode()); - Assert.assertEquals("pt", ((Leg) rs.lastTrip.getTripElements().get(2)).getMode()); - Assert.assertEquals("transit_walk", ((Leg) rs.lastTrip.getTripElements().get(4)).getMode()); + Assertions.assertEquals(2, rs.tripCounter); + Assertions.assertEquals(5, rs.lastTrip.getTripElements().size()); + Assertions.assertEquals("transit_walk", ((Leg) rs.lastTrip.getTripElements().get(0)).getMode()); + Assertions.assertEquals("pt", ((Leg) rs.lastTrip.getTripElements().get(2)).getMode()); + Assertions.assertEquals("transit_walk", ((Leg) rs.lastTrip.getTripElements().get(4)).getMode()); } @Test @@ -129,10 +129,10 @@ void testPersonScoreEventScoring() { eventsManager.processEvent(new PersonScoreEvent(9*3600, Id.create("xyz", Person.class), 2.345, "testing")); eventsManager.finishProcessing(); - Assert.assertTrue(s instanceof RecordingScoringFunction); + Assertions.assertTrue(s instanceof RecordingScoringFunction); RecordingScoringFunction rsf = (RecordingScoringFunction) s; - Assert.assertEquals(2, rsf.separateScoreCounter); - Assert.assertEquals(1.234+2.345, rsf.separateScoreSum, 1e-7); + Assertions.assertEquals(2, rsf.separateScoreCounter); + Assertions.assertEquals(1.234+2.345, rsf.separateScoreSum, 1e-7); } private static class RecordingScoringFunction implements ScoringFunction { diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringDailyConstantsTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringDailyConstantsTest.java index 20f3e790285..a80a186aa0e 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringDailyConstantsTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringDailyConstantsTest.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.core.scoring.functions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -173,19 +173,19 @@ void test1() throws Exception { scoring2.finish(); } - Assert.assertEquals( - "wrong score; daily constants are not accounted for in the scoring.", + Assertions.assertEquals( -12345.678, scoring1.getScore(), - MatsimTestUtils.EPSILON ); + MatsimTestUtils.EPSILON, + "wrong score; daily constants are not accounted for in the scoring." ); double defaultScore = (legTravelTime1 + legTravelTime2) * new ScoringConfigGroup().getModes().get(TransportMode.car).getMarginalUtilityOfTraveling() / 3600. + legTravelTime3 * new ScoringConfigGroup().getModes().get(TransportMode.bike).getMarginalUtilityOfTraveling() / 3600.; - Assert.assertEquals( - "wrong score; daily constants are not accounted for in the scoring.", + Assertions.assertEquals( -12345.678 + defaultScore, scoring2.getScore(), - MatsimTestUtils.EPSILON ); + MatsimTestUtils.EPSILON, + "wrong score; daily constants are not accounted for in the scoring." ); } private CharyparNagelLegScoring createDefaultPlusConstants(Network network) { diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringPtChangeTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringPtChangeTest.java index 7993c58251f..cf0c0d3131b 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringPtChangeTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelLegScoringPtChangeTest.java @@ -21,7 +21,7 @@ import java.util.Random; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -105,11 +105,11 @@ void testPtParamsDoNotInfluenceCarScore() throws Exception { scoring2.finish(); // here, we should get the same score. - Assert.assertEquals( - "score for car leg differs when changing pt parameters! Probably a problem in line change handling.", + Assertions.assertEquals( scoring1.getScore(), scoring2.getScore(), - MatsimTestUtils.EPSILON ); + MatsimTestUtils.EPSILON, + "score for car leg differs when changing pt parameters! Probably a problem in line change handling." ); } private static CharyparNagelLegScoring createScoring( diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java index be33cc41056..18f059766b9 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java @@ -20,7 +20,7 @@ package org.matsim.core.scoring.functions; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.After; import org.junit.Before; diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java index c6d2b91d154..b63e771c6f9 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java @@ -20,8 +20,8 @@ package org.matsim.core.scoring.functions; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.Arrays; diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelWithSubpopulationsTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelWithSubpopulationsTest.java index 0ea4ba8bcd4..153a2796e35 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelWithSubpopulationsTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelWithSubpopulationsTest.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.core.scoring.functions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -71,9 +71,9 @@ void testLegsScoredDifferently() { function2.handleLeg(leg); function2.finish(); - Assert.assertFalse( - "same score for legs of agents in different subpopulations", - Math.abs( function1.getScore() - function2.getScore() ) < 1E-9 ); + Assertions.assertFalse( + Math.abs( function1.getScore() - function2.getScore() ) < 1E-9, + "same score for legs of agents in different subpopulations" ); } @Test @@ -102,9 +102,9 @@ void testActivitiesScoredDifferently() { function2.handleActivity( act ); function2.finish(); - Assert.assertFalse( - "same score for legs of agents in different subpopulations", - Math.abs( function1.getScore() - function2.getScore() ) < 1E-9 ); + Assertions.assertFalse( + Math.abs( function1.getScore() - function2.getScore() ) < 1E-9, + "same score for legs of agents in different subpopulations" ); } private Scenario createTestScenario() { diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java index 8fa5e790ab5..ad9ef3dcc1a 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/LinkToLinkTravelTimeCalculatorTest.java @@ -20,7 +20,7 @@ package org.matsim.core.trafficmonitoring; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java index 552d6399169..87495bae909 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorTest.java @@ -20,8 +20,8 @@ package org.matsim.core.trafficmonitoring; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.fail; import java.io.BufferedReader; import java.io.BufferedWriter; @@ -32,7 +32,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -359,8 +359,8 @@ void testReadFromFile_LargeScenarioCase() throws SAXException, ParserConfigurati Link link10 = network.getLinks().get(Id.create("10", Link.class)); - assertEquals("wrong link travel time at 06:00.", 110.0, ttCalc.getLinkTravelTimes().getLinkTravelTime(link10, 6.0 * 3600, null, null), MatsimTestUtils.EPSILON); - assertEquals("wrong link travel time at 06:15.", 359.9712023038157, ttCalc.getLinkTravelTimes().getLinkTravelTime(link10, 6.25 * 3600, null, null), 1e-3); // traveltimecalculator has a resolution of 0.001 seconds + assertEquals(110.0, ttCalc.getLinkTravelTimes().getLinkTravelTime(link10, 6.0 * 3600, null, null), MatsimTestUtils.EPSILON, "wrong link travel time at 06:00."); + assertEquals(359.9712023038157, ttCalc.getLinkTravelTimes().getLinkTravelTime(link10, 6.25 * 3600, null, null), 1e-3, "wrong link travel time at 06:15."); // traveltimecalculator has a resolution of 0.001 seconds } /** @@ -389,7 +389,7 @@ void testGetLinkTravelTime_ignorePtVehiclesAtStop() { ttc.handleEvent(new VehicleArrivesAtFacilityEvent(240, ptVehId, Id.create("stop", TransitStopFacility.class), 0)); ttc.handleEvent(new LinkLeaveEvent(350, ptVehId, link1.getId())); - Assert.assertEquals("The time of transit vehicles at stop should not be counted", 100.0, ttc.getLinkTravelTimes().getLinkTravelTime(link1, 200, null, null), 1e-8); + Assertions.assertEquals(100.0, ttc.getLinkTravelTimes().getLinkTravelTime(link1, 200, null, null), 1e-8, "The time of transit vehicles at stop should not be counted"); } /** @@ -417,7 +417,7 @@ void testGetLinkTravelTime_usePtVehiclesWithoutStop() { ttc.handleEvent(new LinkLeaveEvent(200, ivVehId, link1.getId())); ttc.handleEvent(new LinkLeaveEvent(300, ptVehId, link1.getId())); - Assert.assertEquals("The time of transit vehicles at stop should not be counted", 125.0, ttc.getLinkTravelTimes().getLinkTravelTime(link1, 200, null, null), 1e-8); + Assertions.assertEquals(125.0, ttc.getLinkTravelTimes().getLinkTravelTime(link1, 200, null, null), 1e-8, "The time of transit vehicles at stop should not be counted"); } @@ -454,7 +454,7 @@ void testGetLinkTravelTime_NoAnalyzedModes() { ttc.handleEvent(new LinkEnterEvent(200, vehId, link2.getId())); ttc.handleEvent(new LinkLeaveEvent(300, vehId, link2.getId())); - Assert.assertEquals("No transport mode has been registered to be analyzed, therefore no vehicle/agent should be counted", 1000.0, ttc.getLinkTravelTimes().getLinkTravelTime(link2, 300, null, null), 1e-8); + Assertions.assertEquals(1000.0, ttc.getLinkTravelTimes().getLinkTravelTime(link2, 300, null, null), 1e-8, "No transport mode has been registered to be analyzed, therefore no vehicle/agent should be counted"); // 1000.0s is the freespeed travel time (euclidean link length: 1000m, default freespeed: 1m/s) } @@ -497,7 +497,7 @@ void testGetLinkTravelTime_CarAnalyzedModes() { ttc.handleEvent(new LinkLeaveEvent(200, vehId1, link2.getId())); ttc.handleEvent(new LinkLeaveEvent(410, vehId2, link2.getId())); - Assert.assertEquals("Only transport mode has been registered to be analyzed, therefore no walk agent should be counted", 100.0, ttc.getLinkTravelTimes().getLinkTravelTime(link2, 200, null, null), 1e-8); + Assertions.assertEquals(100.0, ttc.getLinkTravelTimes().getLinkTravelTime(link2, 200, null, null), 1e-8, "Only transport mode has been registered to be analyzed, therefore no walk agent should be counted"); } /** @@ -539,7 +539,7 @@ void testGetLinkTravelTime_NoFilterModes() { ttc.handleEvent(new LinkLeaveEvent(200, vehId1, link2.getId())); ttc.handleEvent(new LinkLeaveEvent(410, vehId2, link2.getId())); - Assert.assertEquals("Filtering analyzed transport modes is disabled, therefore count all modes", 200.0, ttc.getLinkTravelTimes().getLinkTravelTime(link2, 200, null, null), 1e-8); + Assertions.assertEquals(200.0, ttc.getLinkTravelTimes().getLinkTravelTime(link2, 200, null, null), 1e-8, "Filtering analyzed transport modes is disabled, therefore count all modes"); } /** @@ -580,7 +580,7 @@ void testGetLinkTravelTime_FilterDefaultModes() { ttc.handleEvent(new LinkLeaveEvent(200, vehId1, link2.getId())); ttc.handleEvent(new LinkLeaveEvent(410, vehId2, link2.getId())); - Assert.assertEquals("Filtering analyzed transport modes is enabled, but no modes set. Therefore, use default (=car)", 100.0, - ttc.getLinkTravelTimes().getLinkTravelTime(link2, 200, null, null), 1e-8); + Assertions.assertEquals(100.0, + ttc.getLinkTravelTimes().getLinkTravelTime(link2, 200, null, null), 1e-8, "Filtering analyzed transport modes is enabled, but no modes set. Therefore, use default (=car)"); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java index 4d9f848e412..1b5156efb97 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/BarChartTest.java @@ -20,8 +20,8 @@ package org.matsim.core.utils.charts; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.awt.image.BufferedImage; import java.io.File; diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java index d51e8a862ad..b69ed06a93c 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/LineChartTest.java @@ -20,8 +20,8 @@ package org.matsim.core.utils.charts; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.awt.image.BufferedImage; import java.io.File; diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java index 2820560dec5..4b8274257fa 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/XYLineChartTest.java @@ -20,8 +20,8 @@ package org.matsim.core.utils.charts; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.awt.image.BufferedImage; import java.io.File; diff --git a/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java b/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java index 146203c96d9..2f3dd4db905 100644 --- a/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/charts/XYScatterChartTest.java @@ -20,8 +20,8 @@ package org.matsim.core.utils.charts; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.awt.image.BufferedImage; import java.io.File; diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/ArrayMapTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/ArrayMapTest.java index c50c2131c3e..becaf977020 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/ArrayMapTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/ArrayMapTest.java @@ -1,6 +1,6 @@ package org.matsim.core.utils.collections; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import java.util.ArrayList; @@ -22,36 +22,36 @@ public class ArrayMapTest { void testPutGetRemoveSize() { ArrayMap map = new ArrayMap<>(); - Assert.assertEquals(0, map.size()); - Assert.assertTrue(map.isEmpty()); + Assertions.assertEquals(0, map.size()); + Assertions.assertTrue(map.isEmpty()); - Assert.assertNull(map.put("1", "one")); + Assertions.assertNull(map.put("1", "one")); - Assert.assertEquals(1, map.size()); - Assert.assertFalse(map.isEmpty()); + Assertions.assertEquals(1, map.size()); + Assertions.assertFalse(map.isEmpty()); - Assert.assertNull(map.put("2", "two")); + Assertions.assertNull(map.put("2", "two")); - Assert.assertEquals(2, map.size()); - Assert.assertFalse(map.isEmpty()); + Assertions.assertEquals(2, map.size()); + Assertions.assertFalse(map.isEmpty()); - Assert.assertEquals("one", map.put("1", "also-one")); - Assert.assertEquals(2, map.size()); + Assertions.assertEquals("one", map.put("1", "also-one")); + Assertions.assertEquals(2, map.size()); - Assert.assertNull(map.put("3", "three")); - Assert.assertEquals(3, map.size()); + Assertions.assertNull(map.put("3", "three")); + Assertions.assertEquals(3, map.size()); - Assert.assertNull(map.put("4", null)); - Assert.assertEquals(4, map.size()); + Assertions.assertNull(map.put("4", null)); + Assertions.assertEquals(4, map.size()); - Assert.assertEquals("also-one", map.get("1")); - Assert.assertEquals("two", map.get("2")); - Assert.assertEquals("three", map.get("3")); - Assert.assertNull(map.get("4")); + Assertions.assertEquals("also-one", map.get("1")); + Assertions.assertEquals("two", map.get("2")); + Assertions.assertEquals("three", map.get("3")); + Assertions.assertNull(map.get("4")); - Assert.assertEquals("two", map.remove("2")); - Assert.assertEquals(3, map.size()); - Assert.assertNull(map.get("2")); + Assertions.assertEquals("two", map.remove("2")); + Assertions.assertEquals(3, map.size()); + Assertions.assertNull(map.get("2")); } @Test @@ -66,19 +66,19 @@ void testValuesIterable() { int i = 0; for (String data : map.values()) { if (i == 0) { - Assert.assertEquals("one", data); + Assertions.assertEquals("one", data); } else if (i == 1) { - Assert.assertEquals("two", data); + Assertions.assertEquals("two", data); } else if (i == 2) { - Assert.assertEquals("four", data); + Assertions.assertEquals("four", data); } else if (i == 3) { - Assert.assertEquals("five", data); + Assertions.assertEquals("five", data); } else { throw new RuntimeException("unexpected element: " + data); } i++; } - Assert.assertEquals(4, i); + Assertions.assertEquals(4, i); } @Test @@ -94,17 +94,17 @@ void testForEach() { map.forEach((k, v) -> data.add(new Tuple<>(k, v))); - Assert.assertEquals("1", data.get(0).getFirst()); - Assert.assertEquals("one", data.get(0).getSecond()); + Assertions.assertEquals("1", data.get(0).getFirst()); + Assertions.assertEquals("one", data.get(0).getSecond()); - Assert.assertEquals("2", data.get(1).getFirst()); - Assert.assertEquals("two", data.get(1).getSecond()); + Assertions.assertEquals("2", data.get(1).getFirst()); + Assertions.assertEquals("two", data.get(1).getSecond()); - Assert.assertEquals("4", data.get(2).getFirst()); - Assert.assertEquals("four", data.get(2).getSecond()); + Assertions.assertEquals("4", data.get(2).getFirst()); + Assertions.assertEquals("four", data.get(2).getSecond()); - Assert.assertEquals("5", data.get(3).getFirst()); - Assert.assertEquals("five", data.get(3).getSecond()); + Assertions.assertEquals("5", data.get(3).getFirst()); + Assertions.assertEquals("five", data.get(3).getSecond()); } @Test @@ -116,19 +116,19 @@ void testContainsKey() { map.put("4", "four"); map.put("5", "five"); - Assert.assertTrue(map.containsKey("1")); - Assert.assertTrue(map.containsKey("2")); - Assert.assertFalse(map.containsKey("3")); - Assert.assertTrue(map.containsKey("4")); - Assert.assertTrue(map.containsKey("5")); - Assert.assertFalse(map.containsKey("6")); - - Assert.assertTrue(map.containsKey("1")); - Assert.assertTrue(map.containsKey("2")); - Assert.assertFalse(map.containsKey("3")); - Assert.assertTrue(map.containsKey("4")); - Assert.assertTrue(map.containsKey("5")); - Assert.assertFalse(map.containsKey("6")); + Assertions.assertTrue(map.containsKey("1")); + Assertions.assertTrue(map.containsKey("2")); + Assertions.assertFalse(map.containsKey("3")); + Assertions.assertTrue(map.containsKey("4")); + Assertions.assertTrue(map.containsKey("5")); + Assertions.assertFalse(map.containsKey("6")); + + Assertions.assertTrue(map.containsKey("1")); + Assertions.assertTrue(map.containsKey("2")); + Assertions.assertFalse(map.containsKey("3")); + Assertions.assertTrue(map.containsKey("4")); + Assertions.assertTrue(map.containsKey("5")); + Assertions.assertFalse(map.containsKey("6")); } @Test @@ -140,12 +140,12 @@ void testContainsValue() { map.put("4", "four"); map.put("5", "five"); - Assert.assertTrue(map.containsValue("one")); - Assert.assertTrue(map.containsValue("two")); - Assert.assertFalse(map.containsValue("three")); - Assert.assertTrue(map.containsValue("four")); - Assert.assertTrue(map.containsValue("five")); - Assert.assertFalse(map.containsValue("six")); + Assertions.assertTrue(map.containsValue("one")); + Assertions.assertTrue(map.containsValue("two")); + Assertions.assertFalse(map.containsValue("three")); + Assertions.assertTrue(map.containsValue("four")); + Assertions.assertTrue(map.containsValue("five")); + Assertions.assertFalse(map.containsValue("six")); } @Test @@ -160,13 +160,13 @@ void testPutAll_ArrayMap() { map.putAll(map2); - Assert.assertEquals(4, map.size()); + Assertions.assertEquals(4, map.size()); - Assert.assertEquals("one", map.get("1")); - Assert.assertEquals("two", map.get("2")); - Assert.assertNull(map.get("3")); - Assert.assertEquals("four", map.get("4")); - Assert.assertEquals("five", map.get("5")); + Assertions.assertEquals("one", map.get("1")); + Assertions.assertEquals("two", map.get("2")); + Assertions.assertNull(map.get("3")); + Assertions.assertEquals("four", map.get("4")); + Assertions.assertEquals("five", map.get("5")); } @Test @@ -181,13 +181,13 @@ void testPutAll_GenericMap() { map.putAll(map2); - Assert.assertEquals(4, map.size()); + Assertions.assertEquals(4, map.size()); - Assert.assertEquals("one", map.get("1")); - Assert.assertEquals("two", map.get("2")); - Assert.assertNull(map.get("3")); - Assert.assertEquals("four", map.get("4")); - Assert.assertEquals("five", map.get("5")); + Assertions.assertEquals("one", map.get("1")); + Assertions.assertEquals("two", map.get("2")); + Assertions.assertNull(map.get("3")); + Assertions.assertEquals("four", map.get("4")); + Assertions.assertEquals("five", map.get("5")); } @Test @@ -199,17 +199,17 @@ void testClear() { map.put("4", "four"); map.put("5", "five"); - Assert.assertEquals(4, map.size()); + Assertions.assertEquals(4, map.size()); map.clear(); - Assert.assertEquals(0, map.size()); + Assertions.assertEquals(0, map.size()); - Assert.assertNull(map.get("1")); - Assert.assertNull(map.get("2")); - Assert.assertNull(map.get("3")); + Assertions.assertNull(map.get("1")); + Assertions.assertNull(map.get("2")); + Assertions.assertNull(map.get("3")); - Assert.assertFalse(map.containsKey("1")); + Assertions.assertFalse(map.containsKey("1")); } @Test @@ -222,28 +222,28 @@ void testValues() { map.put("5", "five"); Collection coll = map.values(); - Assert.assertEquals(4, coll.size()); + Assertions.assertEquals(4, coll.size()); map.put("6", "six"); - Assert.assertEquals(5, coll.size()); + Assertions.assertEquals(5, coll.size()); - Assert.assertTrue(coll.remove("one")); - Assert.assertFalse(coll.remove("null")); + Assertions.assertTrue(coll.remove("one")); + Assertions.assertFalse(coll.remove("null")); - Assert.assertFalse(map.containsValue("one")); - Assert.assertTrue(map.containsValue("two")); + Assertions.assertFalse(map.containsValue("one")); + Assertions.assertTrue(map.containsValue("two")); - Assert.assertTrue(coll.contains("two")); - Assert.assertFalse(coll.contains("one")); + Assertions.assertTrue(coll.contains("two")); + Assertions.assertFalse(coll.contains("one")); Set values = new HashSet<>(); coll.forEach(v -> values.add(v)); - Assert.assertEquals(4, values.size()); - Assert.assertTrue(values.contains("two")); - Assert.assertTrue(values.contains("four")); - Assert.assertTrue(values.contains("five")); - Assert.assertTrue(values.contains("six")); + Assertions.assertEquals(4, values.size()); + Assertions.assertTrue(values.contains("two")); + Assertions.assertTrue(values.contains("four")); + Assertions.assertTrue(values.contains("five")); + Assertions.assertTrue(values.contains("six")); } @Test @@ -263,28 +263,28 @@ void testKeySet() { map.put(key5, "five"); Set set = map.keySet(); - Assert.assertEquals(4, set.size()); + Assertions.assertEquals(4, set.size()); map.put(key6, "six"); - Assert.assertEquals(5, set.size()); + Assertions.assertEquals(5, set.size()); - Assert.assertTrue(set.remove(key1)); - Assert.assertFalse(set.remove(key3)); + Assertions.assertTrue(set.remove(key1)); + Assertions.assertFalse(set.remove(key3)); - Assert.assertFalse(map.containsKey(key1)); - Assert.assertTrue(map.containsKey(key2)); + Assertions.assertFalse(map.containsKey(key1)); + Assertions.assertTrue(map.containsKey(key2)); - Assert.assertTrue(set.contains(key2)); - Assert.assertFalse(set.contains(key1)); + Assertions.assertTrue(set.contains(key2)); + Assertions.assertFalse(set.contains(key1)); Set keys = new HashSet<>(); set.forEach(k -> keys.add(k)); - Assert.assertEquals(4, keys.size()); - Assert.assertTrue(keys.contains(key2)); - Assert.assertTrue(keys.contains(key4)); - Assert.assertTrue(keys.contains(key5)); - Assert.assertTrue(keys.contains(key6)); + Assertions.assertEquals(4, keys.size()); + Assertions.assertTrue(keys.contains(key2)); + Assertions.assertTrue(keys.contains(key4)); + Assertions.assertTrue(keys.contains(key5)); + Assertions.assertTrue(keys.contains(key6)); } @Test @@ -303,10 +303,10 @@ void testEntrySet() { map.put(key5, "five"); Set> set = map.entrySet(); - Assert.assertEquals(4, set.size()); + Assertions.assertEquals(4, set.size()); map.put(key6, "six"); - Assert.assertEquals(5, set.size()); + Assertions.assertEquals(5, set.size()); Map> entries = new HashMap<>(); @@ -314,31 +314,31 @@ void testEntrySet() { entries.put(e.getKey(), e); } - Assert.assertEquals(key1, entries.get(key1).getKey()); - Assert.assertEquals("one", entries.get(key1).getValue()); - Assert.assertEquals("two", entries.get(key2).getValue()); - Assert.assertEquals("four", entries.get(key4).getValue()); - Assert.assertEquals("five", entries.get(key5).getValue()); + Assertions.assertEquals(key1, entries.get(key1).getKey()); + Assertions.assertEquals("one", entries.get(key1).getValue()); + Assertions.assertEquals("two", entries.get(key2).getValue()); + Assertions.assertEquals("four", entries.get(key4).getValue()); + Assertions.assertEquals("five", entries.get(key5).getValue()); - Assert.assertTrue(set.remove(entries.get(key1))); + Assertions.assertTrue(set.remove(entries.get(key1))); //noinspection SuspiciousMethodCalls - Assert.assertFalse(set.remove(new Object())); + Assertions.assertFalse(set.remove(new Object())); - Assert.assertFalse(map.containsKey(key1)); - Assert.assertTrue(map.containsKey(key2)); + Assertions.assertFalse(map.containsKey(key1)); + Assertions.assertTrue(map.containsKey(key2)); - Assert.assertTrue(set.contains(entries.get(key2))); - Assert.assertFalse(set.contains(entries.get(key1))); + Assertions.assertTrue(set.contains(entries.get(key2))); + Assertions.assertFalse(set.contains(entries.get(key1))); // test forEach Set> es = new HashSet<>(); set.forEach(k -> es.add(k)); - Assert.assertEquals(4, es.size()); - Assert.assertTrue(es.contains(entries.get(key2))); - Assert.assertTrue(es.contains(entries.get(key4))); - Assert.assertTrue(es.contains(entries.get(key5))); - Assert.assertTrue(es.contains(entries.get(key6))); + Assertions.assertEquals(4, es.size()); + Assertions.assertTrue(es.contains(entries.get(key2))); + Assertions.assertTrue(es.contains(entries.get(key4))); + Assertions.assertTrue(es.contains(entries.get(key5))); + Assertions.assertTrue(es.contains(entries.get(key6))); } @Test @@ -356,28 +356,28 @@ void testValuesIterator_iterate() { map.put(key5, "five"); Iterator iter = map.values().iterator(); - Assert.assertNotNull(iter); + Assertions.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("one", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("one", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("two", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("two", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("four", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("four", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("five", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("five", iter.next()); - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); try { iter.next(); - Assert.fail("Expected exception, got none."); + Assertions.fail("Expected exception, got none."); } catch (NoSuchElementException ignore) { } - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); } @Test @@ -395,24 +395,24 @@ void testValuesIterator_remove() { map.put(key5, "five"); Iterator iter = map.values().iterator(); - Assert.assertNotNull(iter); + Assertions.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("one", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("one", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("two", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("two", iter.next()); iter.remove(); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("four", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("four", iter.next()); - Assert.assertEquals(3, map.size()); - Assert.assertTrue(map.containsValue("one")); - Assert.assertFalse(map.containsValue("two")); - Assert.assertTrue(map.containsValue("four")); - Assert.assertTrue(map.containsValue("five")); + Assertions.assertEquals(3, map.size()); + Assertions.assertTrue(map.containsValue("one")); + Assertions.assertFalse(map.containsValue("two")); + Assertions.assertTrue(map.containsValue("four")); + Assertions.assertTrue(map.containsValue("five")); } @Test @@ -430,28 +430,28 @@ void testKeySetIterator_iterate() { map.put(key5, "five"); Iterator iter = map.keySet().iterator(); - Assert.assertNotNull(iter); + Assertions.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("1", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("1", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("2", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("2", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("4", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("4", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("5", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("5", iter.next()); - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); try { iter.next(); - Assert.fail("Expected exception, got none."); + Assertions.fail("Expected exception, got none."); } catch (NoSuchElementException ignore) { } - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); } @Test @@ -469,24 +469,24 @@ void testKeySetIterator_remove() { map.put(key5, "five"); Iterator iter = map.keySet().iterator(); - Assert.assertNotNull(iter); + Assertions.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("1", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("1", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("2", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("2", iter.next()); iter.remove(); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("4", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("4", iter.next()); - Assert.assertEquals(3, map.size()); - Assert.assertTrue(map.containsKey("1")); - Assert.assertFalse(map.containsKey("2")); - Assert.assertTrue(map.containsKey("4")); - Assert.assertTrue(map.containsKey("5")); + Assertions.assertEquals(3, map.size()); + Assertions.assertTrue(map.containsKey("1")); + Assertions.assertFalse(map.containsKey("2")); + Assertions.assertTrue(map.containsKey("4")); + Assertions.assertTrue(map.containsKey("5")); } @Test @@ -504,10 +504,10 @@ void testKeySetToArray() { map.put(key5, "five"); Object[] array = map.keySet().toArray(); - Assert.assertEquals(key1, array[0]); - Assert.assertEquals(key2, array[1]); - Assert.assertEquals(key4, array[2]); - Assert.assertEquals(key5, array[3]); + Assertions.assertEquals(key1, array[0]); + Assertions.assertEquals(key2, array[1]); + Assertions.assertEquals(key4, array[2]); + Assertions.assertEquals(key5, array[3]); } @@ -521,26 +521,26 @@ void testCopyConstructor() { ArrayMap map = new ArrayMap<>(map0); - Assert.assertEquals(4, map.size()); - Assert.assertFalse(map.isEmpty()); - - Assert.assertTrue(map.containsKey("2")); - Assert.assertTrue(map.containsKey("1")); - Assert.assertTrue(map.containsKey("3")); - Assert.assertTrue(map.containsKey("4")); - Assert.assertFalse(map.containsKey("5")); - - Assert.assertTrue(map.containsValue("one")); - Assert.assertTrue(map.containsValue("two")); - Assert.assertTrue(map.containsValue("three")); - Assert.assertTrue(map.containsValue("four")); - Assert.assertFalse(map.containsValue("five")); - - Assert.assertEquals("one", map.get("1")); - Assert.assertEquals("two", map.get("2")); - Assert.assertEquals("three", map.get("3")); - Assert.assertEquals("four", map.get("4")); - Assert.assertNull(map.get("5")); + Assertions.assertEquals(4, map.size()); + Assertions.assertFalse(map.isEmpty()); + + Assertions.assertTrue(map.containsKey("2")); + Assertions.assertTrue(map.containsKey("1")); + Assertions.assertTrue(map.containsKey("3")); + Assertions.assertTrue(map.containsKey("4")); + Assertions.assertFalse(map.containsKey("5")); + + Assertions.assertTrue(map.containsValue("one")); + Assertions.assertTrue(map.containsValue("two")); + Assertions.assertTrue(map.containsValue("three")); + Assertions.assertTrue(map.containsValue("four")); + Assertions.assertFalse(map.containsValue("five")); + + Assertions.assertEquals("one", map.get("1")); + Assertions.assertEquals("two", map.get("2")); + Assertions.assertEquals("three", map.get("3")); + Assertions.assertEquals("four", map.get("4")); + Assertions.assertNull(map.get("5")); } } \ No newline at end of file diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/CollectionUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/CollectionUtilsTest.java index 40ad88c902d..67f3a4924bd 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/CollectionUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/CollectionUtilsTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -44,13 +44,13 @@ void testSetToString() { set.add("Bbb"); set.add("Ddd"); set.add("Ccc"); - Assert.assertEquals("Aaa,Bbb,Ddd,Ccc", CollectionUtils.setToString(set)); + Assertions.assertEquals("Aaa,Bbb,Ddd,Ccc", CollectionUtils.setToString(set)); } @Test void testArrayToString() { String[] array = new String[] {"Aaa", "Bbb", "Ddd", "Ccc"}; - Assert.assertEquals("Aaa,Bbb,Ddd,Ccc", CollectionUtils.arrayToString(array)); + Assertions.assertEquals("Aaa,Bbb,Ddd,Ccc", CollectionUtils.arrayToString(array)); } @Test @@ -68,20 +68,20 @@ void testStringToSet() { for (String str : testStrings) { log.info("testing String: " + str); Set set = CollectionUtils.stringToSet(str); - Assert.assertEquals(4, set.size()); + Assertions.assertEquals(4, set.size()); Iterator iter = set.iterator(); - Assert.assertEquals("Aaa", iter.next()); - Assert.assertEquals("Bbb", iter.next()); - Assert.assertEquals("Ddd", iter.next()); - Assert.assertEquals("Ccc", iter.next()); - Assert.assertFalse(iter.hasNext()); + Assertions.assertEquals("Aaa", iter.next()); + Assertions.assertEquals("Bbb", iter.next()); + Assertions.assertEquals("Ddd", iter.next()); + Assertions.assertEquals("Ccc", iter.next()); + Assertions.assertFalse(iter.hasNext()); } } @Test void testNullStringToSet() { Set set = CollectionUtils.stringToSet(null); - Assert.assertEquals(0, set.size()); + Assertions.assertEquals(0, set.size()); } @Test @@ -99,18 +99,18 @@ void testStringToArray() { for (String str : testStrings) { log.info("testing String: " + str); String[] array = CollectionUtils.stringToArray(str); - Assert.assertEquals(4, array.length); - Assert.assertEquals("Aaa", array[0]); - Assert.assertEquals("Bbb", array[1]); - Assert.assertEquals("Ddd", array[2]); - Assert.assertEquals("Ccc", array[3]); + Assertions.assertEquals(4, array.length); + Assertions.assertEquals("Aaa", array[0]); + Assertions.assertEquals("Bbb", array[1]); + Assertions.assertEquals("Ddd", array[2]); + Assertions.assertEquals("Ccc", array[3]); } } @Test void testNullStringToArray() { String[] array = CollectionUtils.stringToArray(null); - Assert.assertEquals(0, array.length); + Assertions.assertEquals(0, array.length); } @Test @@ -120,7 +120,7 @@ void testIdSetToString() { set.add(Id.create("Bbb", Link.class)); set.add(Id.create("Ddd", Link.class)); set.add(Id.create("Ccc", Link.class)); - Assert.assertEquals("Aaa,Bbb,Ddd,Ccc", CollectionUtils.idSetToString(set)); + Assertions.assertEquals("Aaa,Bbb,Ddd,Ccc", CollectionUtils.idSetToString(set)); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/IdentifiableArrayMapTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/IdentifiableArrayMapTest.java index d7ab9d6f2a6..f15c84aa5e3 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/IdentifiableArrayMapTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/IdentifiableArrayMapTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Identifiable; @@ -42,8 +42,8 @@ public class IdentifiableArrayMapTest { @Test void testConstructor() { Map, TO> map = new IdentifiableArrayMap<>(); - Assert.assertEquals(0, map.size()); - Assert.assertTrue(map.isEmpty()); + Assertions.assertEquals(0, map.size()); + Assertions.assertTrue(map.isEmpty()); } @Test @@ -57,20 +57,20 @@ void testPutGet() { TO to2 = new TO(id2); TO to3 = new TO(id3); - Assert.assertNull(map.put(id1, to1)); - Assert.assertEquals(1, map.size()); - Assert.assertFalse(map.isEmpty()); - Assert.assertEquals(to1, map.get(id1)); + Assertions.assertNull(map.put(id1, to1)); + Assertions.assertEquals(1, map.size()); + Assertions.assertFalse(map.isEmpty()); + Assertions.assertEquals(to1, map.get(id1)); - Assert.assertNull(map.put(id2, to2)); - Assert.assertEquals(2, map.size()); - Assert.assertEquals(to2, map.get(id2)); + Assertions.assertNull(map.put(id2, to2)); + Assertions.assertEquals(2, map.size()); + Assertions.assertEquals(to2, map.get(id2)); - Assert.assertNull(map.put(id3, to3)); - Assert.assertEquals(3, map.size()); - Assert.assertEquals(to3, map.get(id3)); - Assert.assertEquals(to2, map.get(id2)); - Assert.assertEquals(to1, map.get(id1)); + Assertions.assertNull(map.put(id3, to3)); + Assertions.assertEquals(3, map.size()); + Assertions.assertEquals(to3, map.get(id3)); + Assertions.assertEquals(to2, map.get(id2)); + Assertions.assertEquals(to1, map.get(id1)); } @Test @@ -84,19 +84,19 @@ void testPutGet_identifiablePut() { TO to2 = new TO(id2); TO to3 = new TO(id3); - Assert.assertNull(map.put(to1)); - Assert.assertEquals(1, map.size()); - Assert.assertEquals(to1, map.get(id1)); + Assertions.assertNull(map.put(to1)); + Assertions.assertEquals(1, map.size()); + Assertions.assertEquals(to1, map.get(id1)); - Assert.assertNull(map.put(to2)); - Assert.assertEquals(2, map.size()); - Assert.assertEquals(to2, map.get(id2)); + Assertions.assertNull(map.put(to2)); + Assertions.assertEquals(2, map.size()); + Assertions.assertEquals(to2, map.get(id2)); - Assert.assertNull(map.put(to3)); - Assert.assertEquals(3, map.size()); - Assert.assertEquals(to3, map.get(id3)); - Assert.assertEquals(to2, map.get(id2)); - Assert.assertEquals(to1, map.get(id1)); + Assertions.assertNull(map.put(to3)); + Assertions.assertEquals(3, map.size()); + Assertions.assertEquals(to3, map.get(id3)); + Assertions.assertEquals(to2, map.get(id2)); + Assertions.assertEquals(to1, map.get(id1)); } @Test @@ -111,25 +111,25 @@ void testPut_multiple() { TO to3 = new TO(id3); map.put(id1, to1); - Assert.assertEquals(1, map.size()); + Assertions.assertEquals(1, map.size()); map.put(id1, to1); - Assert.assertEquals(1, map.size()); + Assertions.assertEquals(1, map.size()); map.put(id2, to2); - Assert.assertEquals(2, map.size()); + Assertions.assertEquals(2, map.size()); map.put(id2, to2); - Assert.assertEquals(2, map.size()); + Assertions.assertEquals(2, map.size()); map.put(id3, to3); - Assert.assertEquals(3, map.size()); + Assertions.assertEquals(3, map.size()); map.put(id2, to2); - Assert.assertEquals(3, map.size()); + Assertions.assertEquals(3, map.size()); map.put(id1, to1); - Assert.assertEquals(3, map.size()); + Assertions.assertEquals(3, map.size()); } @Test @@ -141,9 +141,9 @@ void testGet_equalKeys() { TO to2 = new TO(id2a); map.put(id2a, to2); - Assert.assertEquals(1, map.size()); - Assert.assertEquals(to2, map.get(id2a)); - Assert.assertEquals(to2, map.get(id2b)); + Assertions.assertEquals(1, map.size()); + Assertions.assertEquals(to2, map.get(id2a)); + Assertions.assertEquals(to2, map.get(id2b)); } @Test @@ -160,18 +160,18 @@ void testPut_Overwrite() { TO to3 = new TO(id3); map.put(id1, to1); - Assert.assertEquals(1, map.size()); + Assertions.assertEquals(1, map.size()); - Assert.assertNull(map.put(id2a, to2a)); - Assert.assertEquals(2, map.size()); + Assertions.assertNull(map.put(id2a, to2a)); + Assertions.assertEquals(2, map.size()); map.put(id3, to3); - Assert.assertEquals(3, map.size()); + Assertions.assertEquals(3, map.size()); - Assert.assertEquals(to2a, map.get(id2a)); - Assert.assertEquals(to2a, map.put(id2b, to2b)); - Assert.assertEquals(to2b, map.get(id2b)); - Assert.assertEquals(to2b, map.get(id2a)); + Assertions.assertEquals(to2a, map.get(id2a)); + Assertions.assertEquals(to2a, map.put(id2b, to2b)); + Assertions.assertEquals(to2b, map.get(id2b)); + Assertions.assertEquals(to2b, map.get(id2a)); } @Test @@ -186,28 +186,28 @@ void testContainsKey() { TO to2 = new TO(id2); TO to3 = new TO(id3); - Assert.assertFalse(map.containsKey(id1)); - Assert.assertFalse(map.containsKey(id2)); - Assert.assertFalse(map.containsKey(id2b)); - Assert.assertFalse(map.containsKey(id3)); + Assertions.assertFalse(map.containsKey(id1)); + Assertions.assertFalse(map.containsKey(id2)); + Assertions.assertFalse(map.containsKey(id2b)); + Assertions.assertFalse(map.containsKey(id3)); map.put(id1, to1); - Assert.assertTrue(map.containsKey(id1)); - Assert.assertFalse(map.containsKey(id2)); - Assert.assertFalse(map.containsKey(id2b)); - Assert.assertFalse(map.containsKey(id3)); + Assertions.assertTrue(map.containsKey(id1)); + Assertions.assertFalse(map.containsKey(id2)); + Assertions.assertFalse(map.containsKey(id2b)); + Assertions.assertFalse(map.containsKey(id3)); map.put(id2, to2); - Assert.assertTrue(map.containsKey(id1)); - Assert.assertTrue(map.containsKey(id2)); - Assert.assertTrue(map.containsKey(id2b)); - Assert.assertFalse(map.containsKey(id3)); + Assertions.assertTrue(map.containsKey(id1)); + Assertions.assertTrue(map.containsKey(id2)); + Assertions.assertTrue(map.containsKey(id2b)); + Assertions.assertFalse(map.containsKey(id3)); map.put(id3, to3); - Assert.assertTrue(map.containsKey(id1)); - Assert.assertTrue(map.containsKey(id2)); - Assert.assertTrue(map.containsKey(id2b)); - Assert.assertTrue(map.containsKey(id3)); + Assertions.assertTrue(map.containsKey(id1)); + Assertions.assertTrue(map.containsKey(id2)); + Assertions.assertTrue(map.containsKey(id2b)); + Assertions.assertTrue(map.containsKey(id3)); } @Test @@ -221,24 +221,24 @@ void testContainsValue() { TO to2 = new TO(id2); TO to3 = new TO(id3); - Assert.assertFalse(map.containsValue(to1)); - Assert.assertFalse(map.containsValue(to2)); - Assert.assertFalse(map.containsValue(to3)); + Assertions.assertFalse(map.containsValue(to1)); + Assertions.assertFalse(map.containsValue(to2)); + Assertions.assertFalse(map.containsValue(to3)); map.put(id1, to1); - Assert.assertTrue(map.containsValue(to1)); - Assert.assertFalse(map.containsValue(to2)); - Assert.assertFalse(map.containsValue(to3)); + Assertions.assertTrue(map.containsValue(to1)); + Assertions.assertFalse(map.containsValue(to2)); + Assertions.assertFalse(map.containsValue(to3)); map.put(id2, to2); - Assert.assertTrue(map.containsValue(to1)); - Assert.assertTrue(map.containsValue(to2)); - Assert.assertFalse(map.containsValue(to3)); + Assertions.assertTrue(map.containsValue(to1)); + Assertions.assertTrue(map.containsValue(to2)); + Assertions.assertFalse(map.containsValue(to3)); map.put(id3, to3); - Assert.assertTrue(map.containsValue(to1)); - Assert.assertTrue(map.containsValue(to2)); - Assert.assertTrue(map.containsValue(to3)); + Assertions.assertTrue(map.containsValue(to1)); + Assertions.assertTrue(map.containsValue(to2)); + Assertions.assertTrue(map.containsValue(to3)); } @Test @@ -256,12 +256,12 @@ void testRemove_middle() { map.put(id2, to2); map.put(id3, to3); - Assert.assertTrue(map.containsValue(to2)); - Assert.assertEquals(to2, map.remove(id2)); + Assertions.assertTrue(map.containsValue(to2)); + Assertions.assertEquals(to2, map.remove(id2)); - Assert.assertTrue(map.containsValue(to1)); - Assert.assertFalse(map.containsValue(to2)); - Assert.assertTrue(map.containsValue(to3)); + Assertions.assertTrue(map.containsValue(to1)); + Assertions.assertFalse(map.containsValue(to2)); + Assertions.assertTrue(map.containsValue(to3)); } @Test @@ -279,12 +279,12 @@ void testRemove_start() { map.put(id2, to2); map.put(id3, to3); - Assert.assertTrue(map.containsValue(to2)); - Assert.assertEquals(to1, map.remove(id1)); + Assertions.assertTrue(map.containsValue(to2)); + Assertions.assertEquals(to1, map.remove(id1)); - Assert.assertFalse(map.containsValue(to1)); - Assert.assertTrue(map.containsValue(to2)); - Assert.assertTrue(map.containsValue(to3)); + Assertions.assertFalse(map.containsValue(to1)); + Assertions.assertTrue(map.containsValue(to2)); + Assertions.assertTrue(map.containsValue(to3)); } @Test @@ -302,12 +302,12 @@ void testRemove_end() { map.put(id2, to2); map.put(id3, to3); - Assert.assertTrue(map.containsValue(to2)); - Assert.assertEquals(to3, map.remove(id3)); + Assertions.assertTrue(map.containsValue(to2)); + Assertions.assertEquals(to3, map.remove(id3)); - Assert.assertTrue(map.containsValue(to1)); - Assert.assertTrue(map.containsValue(to2)); - Assert.assertFalse(map.containsValue(to3)); + Assertions.assertTrue(map.containsValue(to1)); + Assertions.assertTrue(map.containsValue(to2)); + Assertions.assertFalse(map.containsValue(to3)); } @Test @@ -325,14 +325,14 @@ void testClear() { map.put(id2, to2); map.put(id3, to3); - Assert.assertEquals(3, map.size()); + Assertions.assertEquals(3, map.size()); map.clear(); - Assert.assertEquals(0, map.size()); - Assert.assertTrue(map.isEmpty()); - Assert.assertFalse(map.containsValue(to2)); - Assert.assertNull(map.get(id2)); + Assertions.assertEquals(0, map.size()); + Assertions.assertTrue(map.isEmpty()); + Assertions.assertFalse(map.containsValue(to2)); + Assertions.assertNull(map.get(id2)); } @Test @@ -352,10 +352,10 @@ void testValues() { Collection values = map.values(); - Assert.assertEquals(3, values.size()); - Assert.assertTrue(values.contains(to1)); - Assert.assertTrue(values.contains(to2)); - Assert.assertTrue(values.contains(to3)); + Assertions.assertEquals(3, values.size()); + Assertions.assertTrue(values.contains(to1)); + Assertions.assertTrue(values.contains(to2)); + Assertions.assertTrue(values.contains(to3)); } @Test @@ -375,10 +375,10 @@ void testKeySet() { Set> keys = map.keySet(); - Assert.assertEquals(3, keys.size()); - Assert.assertTrue(keys.contains(id1)); - Assert.assertTrue(keys.contains(id2)); - Assert.assertTrue(keys.contains(id3)); + Assertions.assertEquals(3, keys.size()); + Assertions.assertTrue(keys.contains(id1)); + Assertions.assertTrue(keys.contains(id2)); + Assertions.assertTrue(keys.contains(id3)); } @Test @@ -398,7 +398,7 @@ void testEntrySet() { Set, TO>> entries = map.entrySet(); - Assert.assertEquals(3, entries.size()); + Assertions.assertEquals(3, entries.size()); } @Test @@ -417,18 +417,18 @@ void testValuesIterator() { map.put(id3, to3); Iterator iter = map.values().iterator(); - Assert.assertNotNull(iter); - - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(to1, iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(to2, iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(to3, iter.next()); - Assert.assertFalse(iter.hasNext()); + Assertions.assertNotNull(iter); + + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(to1, iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(to2, iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(to3, iter.next()); + Assertions.assertFalse(iter.hasNext()); try { iter.next(); - Assert.fail("expected NoSuchElementException."); + Assertions.fail("expected NoSuchElementException."); } catch (NoSuchElementException e) { log.info("catched expected exception."); } @@ -450,22 +450,22 @@ void testValuesToArray() { map.put(id3, to3); Object[] array1 = map.values().toArray(); - Assert.assertEquals(3, array1.length); - Assert.assertEquals(to1, array1[0]); - Assert.assertEquals(to2, array1[1]); - Assert.assertEquals(to3, array1[2]); + Assertions.assertEquals(3, array1.length); + Assertions.assertEquals(to1, array1[0]); + Assertions.assertEquals(to2, array1[1]); + Assertions.assertEquals(to3, array1[2]); TO[] array2 = map.values().toArray(new TO[0]); - Assert.assertEquals(3, array2.length); - Assert.assertEquals(to1, array2[0]); - Assert.assertEquals(to2, array2[1]); - Assert.assertEquals(to3, array2[2]); + Assertions.assertEquals(3, array2.length); + Assertions.assertEquals(to1, array2[0]); + Assertions.assertEquals(to2, array2[1]); + Assertions.assertEquals(to3, array2[2]); TO[] array3 = map.values().toArray(new TO[3]); - Assert.assertEquals(3, array3.length); - Assert.assertEquals(to1, array3[0]); - Assert.assertEquals(to2, array3[1]); - Assert.assertEquals(to3, array3[2]); + Assertions.assertEquals(3, array3.length); + Assertions.assertEquals(to1, array3[0]); + Assertions.assertEquals(to2, array3[1]); + Assertions.assertEquals(to3, array3[2]); } @Test @@ -479,7 +479,7 @@ void testValuesIterator_SingleDiretor() { TO toX = map.values().iterator().next(); - Assert.assertEquals(to1, toX); + Assertions.assertEquals(to1, toX); } private static class TO implements Identifiable { diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/IntArrayMapTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/IntArrayMapTest.java index a23afe67ad0..ea8a040a699 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/IntArrayMapTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/IntArrayMapTest.java @@ -1,6 +1,6 @@ package org.matsim.core.utils.collections; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import java.util.ArrayList; @@ -22,36 +22,36 @@ public class IntArrayMapTest { void testPutGetRemoveSize() { IntArrayMap map = new IntArrayMap<>(); - Assert.assertEquals(0, map.size()); - Assert.assertTrue(map.isEmpty()); + Assertions.assertEquals(0, map.size()); + Assertions.assertTrue(map.isEmpty()); - Assert.assertNull(map.put(1, "one")); + Assertions.assertNull(map.put(1, "one")); - Assert.assertEquals(1, map.size()); - Assert.assertFalse(map.isEmpty()); + Assertions.assertEquals(1, map.size()); + Assertions.assertFalse(map.isEmpty()); - Assert.assertNull(map.put(2, "two")); + Assertions.assertNull(map.put(2, "two")); - Assert.assertEquals(2, map.size()); - Assert.assertFalse(map.isEmpty()); + Assertions.assertEquals(2, map.size()); + Assertions.assertFalse(map.isEmpty()); - Assert.assertEquals("one", map.put(1, "also-one")); - Assert.assertEquals(2, map.size()); + Assertions.assertEquals("one", map.put(1, "also-one")); + Assertions.assertEquals(2, map.size()); - Assert.assertNull(map.put(3, "three")); - Assert.assertEquals(3, map.size()); + Assertions.assertNull(map.put(3, "three")); + Assertions.assertEquals(3, map.size()); - Assert.assertNull(map.put(4, null)); - Assert.assertEquals(4, map.size()); + Assertions.assertNull(map.put(4, null)); + Assertions.assertEquals(4, map.size()); - Assert.assertEquals("also-one", map.get(1)); - Assert.assertEquals("two", map.get(2)); - Assert.assertEquals("three", map.get(3)); - Assert.assertNull(map.get(4)); + Assertions.assertEquals("also-one", map.get(1)); + Assertions.assertEquals("two", map.get(2)); + Assertions.assertEquals("three", map.get(3)); + Assertions.assertNull(map.get(4)); - Assert.assertEquals("two", map.remove(2)); - Assert.assertEquals(3, map.size()); - Assert.assertNull(map.get(2)); + Assertions.assertEquals("two", map.remove(2)); + Assertions.assertEquals(3, map.size()); + Assertions.assertNull(map.get(2)); } @Test @@ -66,19 +66,19 @@ void testValuesIterable() { int i = 0; for (String data : map.values()) { if (i == 0) { - Assert.assertEquals("one", data); + Assertions.assertEquals("one", data); } else if (i == 1) { - Assert.assertEquals("two", data); + Assertions.assertEquals("two", data); } else if (i == 2) { - Assert.assertEquals("four", data); + Assertions.assertEquals("four", data); } else if (i == 3) { - Assert.assertEquals("five", data); + Assertions.assertEquals("five", data); } else { throw new RuntimeException("unexpected element: " + data); } i++; } - Assert.assertEquals(4, i); + Assertions.assertEquals(4, i); } @Test @@ -94,17 +94,17 @@ void testForEach() { map.forEach((k, v) -> data.add(new Tuple<>(k, v))); - Assert.assertEquals(1, data.get(0).getFirst().intValue()); - Assert.assertEquals("one", data.get(0).getSecond()); + Assertions.assertEquals(1, data.get(0).getFirst().intValue()); + Assertions.assertEquals("one", data.get(0).getSecond()); - Assert.assertEquals(2, data.get(1).getFirst().intValue()); - Assert.assertEquals("two", data.get(1).getSecond()); + Assertions.assertEquals(2, data.get(1).getFirst().intValue()); + Assertions.assertEquals("two", data.get(1).getSecond()); - Assert.assertEquals(4, data.get(2).getFirst().intValue()); - Assert.assertEquals("four", data.get(2).getSecond()); + Assertions.assertEquals(4, data.get(2).getFirst().intValue()); + Assertions.assertEquals("four", data.get(2).getSecond()); - Assert.assertEquals(5, data.get(3).getFirst().intValue()); - Assert.assertEquals("five", data.get(3).getSecond()); + Assertions.assertEquals(5, data.get(3).getFirst().intValue()); + Assertions.assertEquals("five", data.get(3).getSecond()); } @Test @@ -116,19 +116,19 @@ void testContainsKey() { map.put(4, "four"); map.put(5, "five"); - Assert.assertTrue(map.containsKey(1)); - Assert.assertTrue(map.containsKey(2)); - Assert.assertFalse(map.containsKey(3)); - Assert.assertTrue(map.containsKey(4)); - Assert.assertTrue(map.containsKey(5)); - Assert.assertFalse(map.containsKey(6)); - - Assert.assertTrue(map.containsKey(1)); - Assert.assertTrue(map.containsKey(2)); - Assert.assertFalse(map.containsKey(3)); - Assert.assertTrue(map.containsKey(4)); - Assert.assertTrue(map.containsKey(5)); - Assert.assertFalse(map.containsKey(6)); + Assertions.assertTrue(map.containsKey(1)); + Assertions.assertTrue(map.containsKey(2)); + Assertions.assertFalse(map.containsKey(3)); + Assertions.assertTrue(map.containsKey(4)); + Assertions.assertTrue(map.containsKey(5)); + Assertions.assertFalse(map.containsKey(6)); + + Assertions.assertTrue(map.containsKey(1)); + Assertions.assertTrue(map.containsKey(2)); + Assertions.assertFalse(map.containsKey(3)); + Assertions.assertTrue(map.containsKey(4)); + Assertions.assertTrue(map.containsKey(5)); + Assertions.assertFalse(map.containsKey(6)); } @Test @@ -140,12 +140,12 @@ void testContainsValue() { map.put(4, "four"); map.put(5, "five"); - Assert.assertTrue(map.containsValue("one")); - Assert.assertTrue(map.containsValue("two")); - Assert.assertFalse(map.containsValue("three")); - Assert.assertTrue(map.containsValue("four")); - Assert.assertTrue(map.containsValue("five")); - Assert.assertFalse(map.containsValue("six")); + Assertions.assertTrue(map.containsValue("one")); + Assertions.assertTrue(map.containsValue("two")); + Assertions.assertFalse(map.containsValue("three")); + Assertions.assertTrue(map.containsValue("four")); + Assertions.assertTrue(map.containsValue("five")); + Assertions.assertFalse(map.containsValue("six")); } @Test @@ -160,13 +160,13 @@ void testPutAll_ArrayMap() { map.putAll(map2); - Assert.assertEquals(4, map.size()); + Assertions.assertEquals(4, map.size()); - Assert.assertEquals("one", map.get(1)); - Assert.assertEquals("two", map.get(2)); - Assert.assertNull(map.get(3)); - Assert.assertEquals("four", map.get(4)); - Assert.assertEquals("five", map.get(5)); + Assertions.assertEquals("one", map.get(1)); + Assertions.assertEquals("two", map.get(2)); + Assertions.assertNull(map.get(3)); + Assertions.assertEquals("four", map.get(4)); + Assertions.assertEquals("five", map.get(5)); } @Test @@ -181,13 +181,13 @@ void testPutAll_GenericMap() { map.putAll(map2); - Assert.assertEquals(4, map.size()); + Assertions.assertEquals(4, map.size()); - Assert.assertEquals("one", map.get(1)); - Assert.assertEquals("two", map.get(2)); - Assert.assertNull(map.get(3)); - Assert.assertEquals("four", map.get(4)); - Assert.assertEquals("five", map.get(5)); + Assertions.assertEquals("one", map.get(1)); + Assertions.assertEquals("two", map.get(2)); + Assertions.assertNull(map.get(3)); + Assertions.assertEquals("four", map.get(4)); + Assertions.assertEquals("five", map.get(5)); } @Test @@ -199,17 +199,17 @@ void testClear() { map.put(4, "four"); map.put(5, "five"); - Assert.assertEquals(4, map.size()); + Assertions.assertEquals(4, map.size()); map.clear(); - Assert.assertEquals(0, map.size()); + Assertions.assertEquals(0, map.size()); - Assert.assertNull(map.get(1)); - Assert.assertNull(map.get(2)); - Assert.assertNull(map.get(3)); + Assertions.assertNull(map.get(1)); + Assertions.assertNull(map.get(2)); + Assertions.assertNull(map.get(3)); - Assert.assertFalse(map.containsKey(1)); + Assertions.assertFalse(map.containsKey(1)); } @Test @@ -222,28 +222,28 @@ void testValues() { map.put(5, "five"); Collection coll = map.values(); - Assert.assertEquals(4, coll.size()); + Assertions.assertEquals(4, coll.size()); map.put(6, "six"); - Assert.assertEquals(5, coll.size()); + Assertions.assertEquals(5, coll.size()); - Assert.assertTrue(coll.remove("one")); - Assert.assertFalse(coll.remove("null")); + Assertions.assertTrue(coll.remove("one")); + Assertions.assertFalse(coll.remove("null")); - Assert.assertFalse(map.containsValue("one")); - Assert.assertTrue(map.containsValue("two")); + Assertions.assertFalse(map.containsValue("one")); + Assertions.assertTrue(map.containsValue("two")); - Assert.assertTrue(coll.contains("two")); - Assert.assertFalse(coll.contains("one")); + Assertions.assertTrue(coll.contains("two")); + Assertions.assertFalse(coll.contains("one")); Set values = new HashSet<>(); coll.forEach(v -> values.add(v)); - Assert.assertEquals(4, values.size()); - Assert.assertTrue(values.contains("two")); - Assert.assertTrue(values.contains("four")); - Assert.assertTrue(values.contains("five")); - Assert.assertTrue(values.contains("six")); + Assertions.assertEquals(4, values.size()); + Assertions.assertTrue(values.contains("two")); + Assertions.assertTrue(values.contains("four")); + Assertions.assertTrue(values.contains("five")); + Assertions.assertTrue(values.contains("six")); } @Test @@ -263,28 +263,28 @@ void testKeySet() { map.put(key5, "five"); Set set = map.keySet(); - Assert.assertEquals(4, set.size()); + Assertions.assertEquals(4, set.size()); map.put(key6, "six"); - Assert.assertEquals(5, set.size()); + Assertions.assertEquals(5, set.size()); - Assert.assertTrue(set.remove(key1)); - Assert.assertFalse(set.remove(key3)); + Assertions.assertTrue(set.remove(key1)); + Assertions.assertFalse(set.remove(key3)); - Assert.assertFalse(map.containsKey(key1)); - Assert.assertTrue(map.containsKey(key2)); + Assertions.assertFalse(map.containsKey(key1)); + Assertions.assertTrue(map.containsKey(key2)); - Assert.assertTrue(set.contains(key2)); - Assert.assertFalse(set.contains(key1)); + Assertions.assertTrue(set.contains(key2)); + Assertions.assertFalse(set.contains(key1)); Set keys = new HashSet<>(); set.forEach(k -> keys.add(k)); - Assert.assertEquals(4, keys.size()); - Assert.assertTrue(keys.contains(key2)); - Assert.assertTrue(keys.contains(key4)); - Assert.assertTrue(keys.contains(key5)); - Assert.assertTrue(keys.contains(key6)); + Assertions.assertEquals(4, keys.size()); + Assertions.assertTrue(keys.contains(key2)); + Assertions.assertTrue(keys.contains(key4)); + Assertions.assertTrue(keys.contains(key5)); + Assertions.assertTrue(keys.contains(key6)); } @Test @@ -303,10 +303,10 @@ void testEntrySet() { map.put(key5, "five"); Set> set = map.entrySet(); - Assert.assertEquals(4, set.size()); + Assertions.assertEquals(4, set.size()); map.put(key6, "six"); - Assert.assertEquals(5, set.size()); + Assertions.assertEquals(5, set.size()); Map> entries = new HashMap<>(); @@ -314,31 +314,31 @@ void testEntrySet() { entries.put(e.getKey(), e); } - Assert.assertEquals(key1, entries.get(key1).getKey().intValue()); - Assert.assertEquals("one", entries.get(key1).getValue()); - Assert.assertEquals("two", entries.get(key2).getValue()); - Assert.assertEquals("four", entries.get(key4).getValue()); - Assert.assertEquals("five", entries.get(key5).getValue()); + Assertions.assertEquals(key1, entries.get(key1).getKey().intValue()); + Assertions.assertEquals("one", entries.get(key1).getValue()); + Assertions.assertEquals("two", entries.get(key2).getValue()); + Assertions.assertEquals("four", entries.get(key4).getValue()); + Assertions.assertEquals("five", entries.get(key5).getValue()); - Assert.assertTrue(set.remove(entries.get(key1))); + Assertions.assertTrue(set.remove(entries.get(key1))); //noinspection SuspiciousMethodCalls - Assert.assertFalse(set.remove(new Object())); + Assertions.assertFalse(set.remove(new Object())); - Assert.assertFalse(map.containsKey(key1)); - Assert.assertTrue(map.containsKey(key2)); + Assertions.assertFalse(map.containsKey(key1)); + Assertions.assertTrue(map.containsKey(key2)); - Assert.assertTrue(set.contains(entries.get(key2))); - Assert.assertFalse(set.contains(entries.get(key1))); + Assertions.assertTrue(set.contains(entries.get(key2))); + Assertions.assertFalse(set.contains(entries.get(key1))); // test forEach Set> es = new HashSet<>(); set.forEach(k -> es.add(k)); - Assert.assertEquals(4, es.size()); - Assert.assertTrue(es.contains(entries.get(key2))); - Assert.assertTrue(es.contains(entries.get(key4))); - Assert.assertTrue(es.contains(entries.get(key5))); - Assert.assertTrue(es.contains(entries.get(key6))); + Assertions.assertEquals(4, es.size()); + Assertions.assertTrue(es.contains(entries.get(key2))); + Assertions.assertTrue(es.contains(entries.get(key4))); + Assertions.assertTrue(es.contains(entries.get(key5))); + Assertions.assertTrue(es.contains(entries.get(key6))); } @Test @@ -356,28 +356,28 @@ void testValuesIterator_iterate() { map.put(key5, "five"); Iterator iter = map.values().iterator(); - Assert.assertNotNull(iter); + Assertions.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("one", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("one", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("two", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("two", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("four", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("four", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("five", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("five", iter.next()); - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); try { iter.next(); - Assert.fail("Expected exception, got none."); + Assertions.fail("Expected exception, got none."); } catch (NoSuchElementException ignore) { } - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); } @Test @@ -395,25 +395,25 @@ void testValuesIterator_remove() { map.put(key5, "five"); Iterator iter = map.values().iterator(); - Assert.assertNotNull(iter); + Assertions.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("one", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("one", iter.next()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("two", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("two", iter.next()); iter.remove(); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals("five", iter.next()); - Assert.assertEquals("four", iter.next()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals("five", iter.next()); + Assertions.assertEquals("four", iter.next()); - Assert.assertEquals(3, map.size()); - Assert.assertTrue(map.containsValue("one")); - Assert.assertFalse(map.containsValue("two")); - Assert.assertTrue(map.containsValue("four")); - Assert.assertTrue(map.containsValue("five")); + Assertions.assertEquals(3, map.size()); + Assertions.assertTrue(map.containsValue("one")); + Assertions.assertFalse(map.containsValue("two")); + Assertions.assertTrue(map.containsValue("four")); + Assertions.assertTrue(map.containsValue("five")); } @Test @@ -431,28 +431,28 @@ void testKeySetIterator_iterate() { map.put(key5, "five"); Iterator iter = map.keySet().iterator(); - Assert.assertNotNull(iter); + Assertions.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(1, iter.next().intValue()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(1, iter.next().intValue()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(2, iter.next().intValue()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(2, iter.next().intValue()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(4, iter.next().intValue()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(4, iter.next().intValue()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(5, iter.next().intValue()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(5, iter.next().intValue()); - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); try { iter.next(); - Assert.fail("Expected exception, got none."); + Assertions.fail("Expected exception, got none."); } catch (NoSuchElementException ignore) { } - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); } @Test @@ -470,25 +470,25 @@ void testKeySetIterator_remove() { map.put(key5, "five"); Iterator iter = map.keySet().iterator(); - Assert.assertNotNull(iter); + Assertions.assertNotNull(iter); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(1, iter.next().intValue()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(1, iter.next().intValue()); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(2, iter.next().intValue()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(2, iter.next().intValue()); iter.remove(); - Assert.assertTrue(iter.hasNext()); - Assert.assertEquals(5, iter.next().intValue()); - Assert.assertEquals(4, iter.next().intValue()); + Assertions.assertTrue(iter.hasNext()); + Assertions.assertEquals(5, iter.next().intValue()); + Assertions.assertEquals(4, iter.next().intValue()); - Assert.assertEquals(3, map.size()); - Assert.assertTrue(map.containsKey(1)); - Assert.assertFalse(map.containsKey(2)); - Assert.assertTrue(map.containsKey(4)); - Assert.assertTrue(map.containsKey(5)); + Assertions.assertEquals(3, map.size()); + Assertions.assertTrue(map.containsKey(1)); + Assertions.assertFalse(map.containsKey(2)); + Assertions.assertTrue(map.containsKey(4)); + Assertions.assertTrue(map.containsKey(5)); } @Test @@ -506,10 +506,10 @@ void testKeySetToArray() { map.put(key5, "five"); Object[] array = map.keySet().toArray(); - Assert.assertEquals(key1, array[0]); - Assert.assertEquals(key2, array[1]); - Assert.assertEquals(key4, array[2]); - Assert.assertEquals(key5, array[3]); + Assertions.assertEquals(key1, array[0]); + Assertions.assertEquals(key2, array[1]); + Assertions.assertEquals(key4, array[2]); + Assertions.assertEquals(key5, array[3]); } } \ No newline at end of file diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/PseudoRemovePriorityQueueTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/PseudoRemovePriorityQueueTest.java index d1f726ab458..cf10dd84105 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/PseudoRemovePriorityQueueTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/PseudoRemovePriorityQueueTest.java @@ -20,7 +20,7 @@ package org.matsim.core.utils.collections; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.Collection; import java.util.ConcurrentModificationException; diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/QuadTreeTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/QuadTreeTest.java index 56a7867b1f9..61f66e6a0ce 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/QuadTreeTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/QuadTreeTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.collections.QuadTree.Rect; @@ -40,11 +40,7 @@ import java.util.List; import java.util.Random; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertTrue; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.*; /** * Test for {@link QuadTree}. @@ -111,7 +107,7 @@ void testPutOutsideBounds() { QuadTree qt = new QuadTree<>(-50.0, -50.0, 50.0, 50.0); try { qt.put( -100 , 0 , "-100 0" ); - Assert.fail( "no exception when adding an element on the left" ); + Assertions.fail( "no exception when adding an element on the left" ); } catch (IllegalArgumentException e) { log.info( "catched expected exception" , e ); @@ -119,7 +115,7 @@ void testPutOutsideBounds() { try { qt.put( 100 , 0 , "100 0" ); - Assert.fail( "no exception when adding an element on the right" ); + Assertions.fail( "no exception when adding an element on the right" ); } catch (IllegalArgumentException e) { log.info( "catched expected exception" , e ); @@ -127,7 +123,7 @@ void testPutOutsideBounds() { try { qt.put( 0 , 100 , "0 100" ); - Assert.fail( "no exception when adding an element above" ); + Assertions.fail( "no exception when adding an element above" ); } catch (IllegalArgumentException e) { log.info( "catched expected exception" , e ); @@ -135,7 +131,7 @@ void testPutOutsideBounds() { try { qt.put( 0 , -100 , "0 -100" ); - Assert.fail( "no exception when adding an element below" ); + Assertions.fail( "no exception when adding an element below" ); } catch (IllegalArgumentException e) { log.info( "catched expected exception" , e ); @@ -189,19 +185,19 @@ void testGet() { // test "distance" get with critical distances values = qt.getDisk(90.0, 0.0, 9.0); - assertEquals("test with distance 9.0", 0, values.size()); + assertEquals(0, values.size(), "test with distance 9.0"); values = qt.getDisk(90.0, 0.0, 9.999); - assertEquals("test with distance 9.999", 0, values.size()); + assertEquals(0, values.size(), "test with distance 9.999"); values = qt.getDisk(90.0, 0.0, 10.0); - assertEquals("test with distance 10.0", 1, values.size()); + assertEquals(1, values.size(), "test with distance 10.0"); values = qt.getDisk(90.0, 0.0, 10.001); - assertEquals("test with distance 10.001", 1, values.size()); + assertEquals(1, values.size(), "test with distance 10.001"); values = qt.getDisk(90.0, 0.0, 11.0); - assertEquals("test with distance 11.0", 1, values.size()); + assertEquals(1, values.size(), "test with distance 11.0"); // test "area" values.clear(); @@ -363,14 +359,14 @@ void testGetElliptical() { distance ); //log.info( "testing foci "+f1+" and "+f2+", distance="+distance+", expected="+expected ); - Assert.assertEquals( - "unexpected number of elements returned for foci "+f1+" and "+f2+", distance="+distance, + Assertions.assertEquals( expected.size(), - actual.size() ); + actual.size(), + "unexpected number of elements returned for foci "+f1+" and "+f2+", distance="+distance ); - Assert.assertTrue( - "unexpected elements returned for foci "+f1+" and "+f2+", distance="+distance, - expected.containsAll( actual ) ); + Assertions.assertTrue( + expected.containsAll( actual ), + "unexpected elements returned for foci "+f1+" and "+f2+", distance="+distance ); } } } @@ -388,9 +384,9 @@ void testGetRect() { Collection values = new ArrayList<>(); qt.getRectangle(new Rect(400, 300, 700, 900), values); - Assert.assertEquals(2, values.size()); - Assert.assertTrue(values.contains("node2")); - Assert.assertTrue(values.contains("node3")); + Assertions.assertEquals(2, values.size()); + Assertions.assertTrue(values.contains("node2")); + Assertions.assertTrue(values.contains("node3")); } @Test @@ -403,15 +399,15 @@ void testGetRect_flatNetwork() { Collection values = new ArrayList<>(); qt.getRectangle(new Rect(90, -10, 600, +10), values); - Assert.assertEquals(2, values.size()); - Assert.assertTrue(values.contains("node2")); - Assert.assertTrue(values.contains("node3")); + Assertions.assertEquals(2, values.size()); + Assertions.assertTrue(values.contains("node2")); + Assertions.assertTrue(values.contains("node3")); Collection values2 = new ArrayList<>(); qt.getRectangle(new Rect(90, 0, 600, 0), values2); - Assert.assertEquals(2, values2.size()); - Assert.assertTrue(values2.contains("node2")); - Assert.assertTrue(values2.contains("node3")); + Assertions.assertEquals(2, values2.size()); + Assertions.assertTrue(values2.contains("node2")); + Assertions.assertTrue(values2.contains("node3")); } /** @@ -704,11 +700,11 @@ void testGetValues() { } List items = new ArrayList<>(qt.values()); - Assert.assertEquals(1000, items.size()); + Assertions.assertEquals(1000, items.size()); items.sort(String::compareTo); expected.sort(String::compareTo); for (int i = 0; i < 1000; i++) { - Assert.assertEquals(expected.get(i), items.get(i)); + Assertions.assertEquals(expected.get(i), items.get(i)); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/collections/TupleTest.java b/matsim/src/test/java/org/matsim/core/utils/collections/TupleTest.java index bb7a2d62046..059938c9b50 100644 --- a/matsim/src/test/java/org/matsim/core/utils/collections/TupleTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/collections/TupleTest.java @@ -20,7 +20,7 @@ package org.matsim.core.utils.collections; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/CoordImplTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/CoordImplTest.java index ee6b99929f1..7beaf878b34 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/CoordImplTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/CoordImplTest.java @@ -21,7 +21,7 @@ import java.util.Arrays; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -62,6 +62,6 @@ void testHashCode() { lastValue = hc; } - Assert.assertEquals("There has been a hashCode collision, which is undesired!", hashCodes.length, cnt); + Assertions.assertEquals(hashCodes.length, cnt, "There has been a hashCode collision, which is undesired!"); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java index 01bb58b1090..958f38182ec 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java @@ -20,10 +20,10 @@ package org.matsim.core.utils.geometry; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.testcases.MatsimTestUtils; @@ -153,20 +153,20 @@ void testRotateToRight() { Coord coord1 = new Coord(3., 2.); Coord result = CoordUtils.rotateToRight( coord1 ) ; - Assert.assertEquals( 2., result.getX(), MatsimTestUtils.EPSILON ) ; - Assert.assertEquals( -3., result.getY(), MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals( 2., result.getX(), MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals( -3., result.getY(), MatsimTestUtils.EPSILON ) ; result = CoordUtils.rotateToRight( result ) ; - Assert.assertEquals( -3., result.getX(), MatsimTestUtils.EPSILON ) ; - Assert.assertEquals( -2., result.getY(), MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals( -3., result.getX(), MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals( -2., result.getY(), MatsimTestUtils.EPSILON ) ; result = CoordUtils.rotateToRight( result ) ; - Assert.assertEquals( -2., result.getX(), MatsimTestUtils.EPSILON ) ; - Assert.assertEquals( 3., result.getY(), MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals( -2., result.getX(), MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals( 3., result.getY(), MatsimTestUtils.EPSILON ) ; result = CoordUtils.rotateToRight( result ) ; - Assert.assertEquals( coord1.getX(), result.getX(), MatsimTestUtils.EPSILON ) ; - Assert.assertEquals( coord1.getY(), result.getY(), MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals( coord1.getX(), result.getX(), MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals( coord1.getY(), result.getY(), MatsimTestUtils.EPSILON ) ; } @Test diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java index 10527d9d759..ace12f31bf6 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/GeometryUtilsTest.java @@ -20,7 +20,7 @@ package org.matsim.core.utils.geometry; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.locationtech.jts.geom.Coordinate; @@ -63,9 +63,9 @@ final void testIntersectingLinks() { List> expectedLinkIds = List.of(Id.createLinkId(1)); - Assert.assertEquals(expectedLinkIds.size(), results.size()) ; + Assertions.assertEquals(expectedLinkIds.size(), results.size()) ; for ( int ii=0 ; ii> expectedIds = List.of(Id.createLinkId(2), Id.createLinkId(3), Id.createLinkId(4), Id.createLinkId(5), Id.createLinkId(6)); - Assert.assertEquals(expectedIds.size(), results.size()); + Assertions.assertEquals(expectedIds.size(), results.size()); for (Id id : expectedIds) { - Assert.assertTrue("expected link " + id, intersectingLinkIds.contains(id)); + Assertions.assertTrue(intersectingLinkIds.contains(id), "expected link " + id); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java index bef47a55d81..67cdccc70a1 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/geotools/MGCTest.java @@ -21,6 +21,7 @@ package org.matsim.core.utils.geometry.geotools; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.locationtech.jts.geom.Coordinate; @@ -28,7 +29,7 @@ import org.matsim.api.core.v01.Coord; import org.matsim.testcases.MatsimTestUtils; - /** + /** * * @author laemmel * @@ -49,8 +50,8 @@ void testCoord2CoordinateAndViceVersa(){ Coord coord3 = MGC.coordinate2Coord(coord2); double x1 = coord3.getX(); double y1 = coord3.getY(); - org.junit.Assert.assertEquals(x,x1,delta); - org.junit.Assert.assertEquals(y,y1,delta); + Assertions.assertEquals(x,x1,delta); + Assertions.assertEquals(y,y1,delta); } @Test @@ -63,8 +64,8 @@ void testCoord2PointAndViceVersa(){ Coord coord2 = MGC.point2Coord(p); double x1 = coord2.getX(); double y1 = coord2.getY(); - org.junit.Assert.assertEquals(x,x1,delta); - org.junit.Assert.assertEquals(y,y1,delta); + Assertions.assertEquals(x,x1,delta); + Assertions.assertEquals(y,y1,delta); } @@ -75,59 +76,59 @@ void testGetUTMEPSGCodeForWGS84Coordinate() { double lat = 53.562021; double lon = 9.961533; String epsg = MGC.getUTMEPSGCodeForWGS84Coordinate(lon, lat); - org.junit.Assert.assertEquals("EPSG:32632", epsg); + Assertions.assertEquals("EPSG:32632", epsg); } { //Cupertino - should be UTM 10 North --> EPSG:32610 double lat = 37.333488; double lon = -122.029710; String epsg = MGC.getUTMEPSGCodeForWGS84Coordinate(lon, lat); - org.junit.Assert.assertEquals("EPSG:32610", epsg); + Assertions.assertEquals("EPSG:32610", epsg); } { //Anchorage - should be UTM 6 North --> EPSG:32606 double lat = 61.2176; double lon = -149.8997; String epsg = MGC.getUTMEPSGCodeForWGS84Coordinate(lon, lat); - org.junit.Assert.assertEquals("EPSG:32606", epsg); + Assertions.assertEquals("EPSG:32606", epsg); } { //Lourdes (France) - should be UTM 30 North --> EPSG:32630 double lat = 43.1; double lon = -0.05; String epsg = MGC.getUTMEPSGCodeForWGS84Coordinate(lon, lat); - org.junit.Assert.assertEquals("EPSG:32630", epsg); + Assertions.assertEquals("EPSG:32630", epsg); } { //east of Lourdes (France) - should be UTM 31 North --> EPSG:32631 double lat = 43.1; double lon = 0.05; String epsg = MGC.getUTMEPSGCodeForWGS84Coordinate(lon, lat); - org.junit.Assert.assertEquals("EPSG:32631", epsg); + Assertions.assertEquals("EPSG:32631", epsg); } { //Padang - should be UTM 47 South --> EPSG:32747 double lat = -0.959484; double lon = 100.354052; String epsg = MGC.getUTMEPSGCodeForWGS84Coordinate(lon, lat); - org.junit.Assert.assertEquals("EPSG:32747", epsg); + Assertions.assertEquals("EPSG:32747", epsg); } } @Test void testGetCRS(){ // CH1903_LV03 Id - org.junit.Assert.assertNotNull(MGC.getCRS("EPSG:21781")); + Assertions.assertNotNull(MGC.getCRS("EPSG:21781")); try { MGC.getCRS(""); - org.junit.Assert.fail("IllegalArgumentException expected"); + Assertions.fail("IllegalArgumentException expected"); } catch (IllegalArgumentException expected) { } // unknown EPSG Id try { MGC.getCRS("EPSG:MATSim"); - org.junit.Assert.fail("IllegalArgumentException expected"); + Assertions.fail("IllegalArgumentException expected"); } catch (IllegalArgumentException expected) { } } diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustoWGS84Test.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustoWGS84Test.java index 3c88bf71af1..6b0dbf8e097 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustoWGS84Test.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustoWGS84Test.java @@ -21,7 +21,7 @@ package org.matsim.core.utils.geometry.transformations; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -42,7 +42,7 @@ void testTransform() { CH1903LV03PlustoWGS84 converter = new CH1903LV03PlustoWGS84(); Coord n = converter.transform(new Coord((double) 2700000, (double) 1100000)); - Assert.assertEquals(xx, n.getX(), epsilon); - Assert.assertEquals(yy, n.getY(), epsilon); + Assertions.assertEquals(xx, n.getX(), epsilon); + Assertions.assertEquals(yy, n.getY(), epsilon); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustofromCH1903LV03Test.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustofromCH1903LV03Test.java index 3f7420d1340..6fcc291e693 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustofromCH1903LV03Test.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03PlustofromCH1903LV03Test.java @@ -21,7 +21,7 @@ package org.matsim.core.utils.geometry.transformations; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -34,15 +34,15 @@ public class CH1903LV03PlustofromCH1903LV03Test { void testCH1903LV03PlustoCH1903LV03() { CH1903LV03PlustoCH1903LV03 converter = new CH1903LV03PlustoCH1903LV03(); Coord n = converter.transform(new Coord((double) 2700000, (double) 1100000)); - Assert.assertEquals(700000, n.getX(), 0.0); - Assert.assertEquals(100000, n.getY(), 0.0); + Assertions.assertEquals(700000, n.getX(), 0.0); + Assertions.assertEquals(100000, n.getY(), 0.0); } @Test void testCH1903LV03toCH1903LV03Plus() { CH1903LV03toCH1903LV03Plus converter = new CH1903LV03toCH1903LV03Plus(); Coord n = converter.transform(new Coord((double) 700000, (double) 100000)); - Assert.assertEquals(2700000, n.getX(), 0.0); - Assert.assertEquals(1100000, n.getY(), 0.0); + Assertions.assertEquals(2700000, n.getX(), 0.0); + Assertions.assertEquals(1100000, n.getY(), 0.0); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03toWGS84Test.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03toWGS84Test.java index a8e43c4d8ed..3a767dd39c7 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03toWGS84Test.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/CH1903LV03toWGS84Test.java @@ -19,7 +19,7 @@ package org.matsim.core.utils.geometry.transformations; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -40,7 +40,7 @@ void testTransform() { CH1903LV03toWGS84 converter = new CH1903LV03toWGS84(); Coord n = converter.transform(new Coord((double) 700000, (double) 100000)); - Assert.assertEquals(xx, n.getX(), epsilon); - Assert.assertEquals(yy, n.getY(), epsilon); + Assertions.assertEquals(xx, n.getX(), epsilon); + Assertions.assertEquals(yy, n.getY(), epsilon); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java index aac31a1b9be..b10f60aeca0 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/GeotoolsTransformationTest.java @@ -20,6 +20,7 @@ package org.matsim.core.utils.geometry.transformations; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -56,8 +57,8 @@ void testTransform(){ double yWGS84 = coordWGS84.getY(); - org.junit.Assert.assertEquals(targetX, xWGS84, delta); - org.junit.Assert.assertEquals(targetY, yWGS84, delta); + Assertions.assertEquals(targetX, xWGS84, delta); + Assertions.assertEquals(targetY, yWGS84, delta); } diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/TransformationFactoryTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/TransformationFactoryTest.java index f55454c7314..4be45f50e96 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/TransformationFactoryTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/TransformationFactoryTest.java @@ -20,7 +20,7 @@ package org.matsim.core.utils.geometry.transformations; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03PlusTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03PlusTest.java index 93fecc49e19..9b36045dd2d 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03PlusTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03PlusTest.java @@ -21,7 +21,7 @@ package org.matsim.core.utils.geometry.transformations; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -42,8 +42,8 @@ void testTransform() { WGS84toCH1903LV03Plus converter = new WGS84toCH1903LV03Plus(); Coord n = converter.transform(new Coord(xx, yy)); - Assert.assertEquals(2700000.0, n.getX(), epsilon); - Assert.assertEquals(1100000.0, n.getY(), epsilon); + Assertions.assertEquals(2700000.0, n.getX(), epsilon); + Assertions.assertEquals(1100000.0, n.getY(), epsilon); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03Test.java b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03Test.java index 717fa4da70c..a16578d4f83 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03Test.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/transformations/WGS84toCH1903LV03Test.java @@ -19,7 +19,7 @@ package org.matsim.core.utils.geometry.transformations; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -36,8 +36,8 @@ void testTransform() { WGS84toCH1903LV03 converter = new WGS84toCH1903LV03(); Coord n = converter.transform(new Coord(xx, yy)); - Assert.assertEquals(699999.76, n.getX(), epsilon); - Assert.assertEquals(99999.97, n.getY(), epsilon); + Assertions.assertEquals(699999.76, n.getX(), epsilon); + Assertions.assertEquals(99999.97, n.getY(), epsilon); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java index 650293090b4..1a07451aa7b 100644 --- a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileReaderTest.java @@ -24,7 +24,7 @@ import java.io.IOException; import org.geotools.data.FeatureSource; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -44,6 +44,6 @@ public class ShapeFileReaderTest { void testPlusInFilename() throws IOException { String filename = "src/test/resources/" + utils.getInputDirectory() + "test+test.shp"; FeatureSource fs = ShapeFileReader.readDataFile(filename); - Assert.assertEquals(3, fs.getFeatures().size()); + Assertions.assertEquals(3, fs.getFeatures().size()); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java index a953c2bfd62..70c19d22d88 100644 --- a/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/gis/ShapeFileWriterTest.java @@ -32,7 +32,7 @@ import org.geotools.feature.simple.SimpleFeatureBuilder; import org.geotools.feature.simple.SimpleFeatureTypeBuilder; import org.geotools.referencing.crs.DefaultGeographicCRS; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.locationtech.jts.geom.Coordinate; @@ -70,7 +70,7 @@ void testShapeFileWriter() throws IOException{ SimpleFeature ft1 = it1.next(); Geometry g1 = (Geometry) ft1.getDefaultGeometry(); - Assert.assertEquals(g.getCoordinates().length, g1.getCoordinates().length); + Assertions.assertEquals(g.getCoordinates().length, g1.getCoordinates().length); } @@ -102,7 +102,7 @@ void testShapeFileWriterWithSelfCreatedContent() throws IOException { SimpleFeature ft1 = it1.next(); Geometry g1 = (Geometry) ft1.getDefaultGeometry(); - Assert.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); + Assertions.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); } @@ -133,7 +133,7 @@ void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Polygon() throw SimpleFeature ft1 = it1.next(); Geometry g1 = (Geometry) ft1.getDefaultGeometry(); - Assert.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); + Assertions.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); } @Test @@ -162,7 +162,7 @@ void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Polyline() thro SimpleFeature ft1 = it1.next(); Geometry g1 = (Geometry) ft1.getDefaultGeometry(); - Assert.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); + Assertions.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); } @Test @@ -190,6 +190,6 @@ void testShapeFileWriterWithSelfCreatedContent_withMatsimFactory_Point() throws SimpleFeature ft1 = it1.next(); Geometry g1 = (Geometry) ft1.getDefaultGeometry(); - Assert.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); + Assertions.assertEquals(g0.getCoordinates().length, g1.getCoordinates().length); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java index 150f1982025..5f7394b5b5a 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/IOUtilsTest.java @@ -21,7 +21,7 @@ import static org.junit.jupiter.api.Assertions.assertThrows; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.controler.OutputDirectoryLogging; @@ -51,8 +51,8 @@ void testInitOutputDirLogging() throws IOException { File l = new File(outDir + OutputDirectoryLogging.LOGFILE); File errorLog = new File(outDir + OutputDirectoryLogging.WARNLOGFILE); - Assert.assertTrue(l.exists()); - Assert.assertTrue(errorLog.exists()); + Assertions.assertTrue(l.exists()); + Assertions.assertTrue(errorLog.exists()); } /** @@ -64,14 +64,14 @@ void testDeleteDir() throws IOException { String testDir = outputDir + "a"; String someFilename = testDir + "/a.txt"; File dir = new File(testDir); - Assert.assertTrue(dir.mkdir()); + Assertions.assertTrue(dir.mkdir()); File someFile = new File(someFilename); - Assert.assertTrue(someFile.createNewFile()); + Assertions.assertTrue(someFile.createNewFile()); IOUtils.deleteDirectoryRecursively(dir.toPath()); - Assert.assertFalse(someFile.exists()); - Assert.assertFalse(dir.exists()); + Assertions.assertFalse(someFile.exists()); + Assertions.assertFalse(dir.exists()); } /** @@ -84,7 +84,7 @@ void testDeleteDir_InexistentDir() { String testDir = outputDir + "a"; File dir = new File(testDir); IOUtils.deleteDirectoryRecursively(dir.toPath()); - Assert.assertFalse(dir.exists()); + Assertions.assertFalse(dir.exists()); }); } @@ -93,8 +93,8 @@ void testGetBufferedReader_encodingMacRoman() throws IOException { URL url = IOUtils.resolveFileOrResource(this.utils.getClassInputDirectory() + "textsample_MacRoman.txt"); BufferedReader reader = IOUtils.getBufferedReader(url, Charset.forName("MacRoman")); String line = reader.readLine(); - Assert.assertNotNull(line); - Assert.assertEquals("äöüÉç", line); + Assertions.assertNotNull(line); + Assertions.assertEquals("äöüÉç", line); } @Test @@ -102,8 +102,8 @@ void testGetBufferedReader_encodingIsoLatin1() throws IOException { URL url = IOUtils.resolveFileOrResource(this.utils.getClassInputDirectory() + "textsample_IsoLatin1.txt"); BufferedReader reader = IOUtils.getBufferedReader(url, Charset.forName("ISO-8859-1")); String line = reader.readLine(); - Assert.assertNotNull(line); - Assert.assertEquals("äöüÉç", line); + Assertions.assertNotNull(line); + Assertions.assertEquals("äöüÉç", line); } @Test @@ -111,8 +111,8 @@ void testGetBufferedReader_encodingUTF8() throws IOException { URL url = IOUtils.resolveFileOrResource(this.utils.getClassInputDirectory() + "textsample_UTF8.txt"); BufferedReader reader = IOUtils.getBufferedReader(url); String line = reader.readLine(); - Assert.assertNotNull(line); - Assert.assertEquals("äöüÉç", line); + Assertions.assertNotNull(line); + Assertions.assertEquals("äöüÉç", line); } @Test @@ -124,7 +124,7 @@ void testGetBufferedWriter_encodingMacRoman() throws IOException { writer.close(); long crc1 = CRCChecksum.getCRCFromFile(this.utils.getClassInputDirectory() + "textsample_MacRoman.txt"); long crc2 = CRCChecksum.getCRCFromFile(filename); - Assert.assertEquals("File was not written with encoding MacRoman.", crc1, crc2); + Assertions.assertEquals(crc1, crc2, "File was not written with encoding MacRoman."); } @Test @@ -136,7 +136,7 @@ void testGetBufferedWriter_encodingIsoLatin1() throws IOException { writer.close(); long crc1 = CRCChecksum.getCRCFromFile(this.utils.getClassInputDirectory() + "textsample_IsoLatin1.txt"); long crc2 = CRCChecksum.getCRCFromFile(filename); - Assert.assertEquals("File was not written with encoding IsoLatin1.", crc1, crc2); + Assertions.assertEquals(crc1, crc2, "File was not written with encoding IsoLatin1."); } @Test @@ -148,7 +148,7 @@ void testGetBufferedWriter_encodingUTF8() throws IOException { writer.close(); long crc1 = CRCChecksum.getCRCFromFile(this.utils.getClassInputDirectory() + "textsample_UTF8.txt"); long crc2 = CRCChecksum.getCRCFromFile(filename); - Assert.assertEquals("File was not written with encoding UTF8.", crc1, crc2); + Assertions.assertEquals(crc1, crc2, "File was not written with encoding UTF8."); } @Test @@ -163,7 +163,7 @@ void testGetBufferedWriter_overwrite() throws IOException { writer2.close(); BufferedReader reader = IOUtils.getBufferedReader(url); String line = reader.readLine(); - Assert.assertEquals("bbb", line); + Assertions.assertEquals("bbb", line); } @Test @@ -178,7 +178,7 @@ void testGetBufferedWriter_append() throws IOException { writer2.close(); BufferedReader reader = IOUtils.getBufferedReader(url); String line = reader.readLine(); - Assert.assertEquals("aaabbb", line); + Assertions.assertEquals("aaabbb", line); } @Test @@ -193,7 +193,7 @@ void testGetBufferedWriter_overwrite_gzipped() throws IOException { writer2.close(); BufferedReader reader = IOUtils.getBufferedReader(url); String line = reader.readLine(); - Assert.assertEquals("bbb", line); + Assertions.assertEquals("bbb", line); } @Test @@ -216,7 +216,7 @@ void testGetBufferedWriter_gzipped() throws IOException { writer.write("12345678901234567890123456789012345678901234567890"); writer.close(); File file = new File(filename); - Assert.assertTrue("compressed file should be less than 50 bytes, but is " + file.length(), file.length() < 50); + Assertions.assertTrue(file.length() < 50, "compressed file should be less than 50 bytes, but is " + file.length()); } @Test @@ -239,10 +239,10 @@ void testGetBufferedWriter_lz4() throws IOException { writer.write("12345678901234567890123456789012345678901234567890"); writer.close(); File file = new File(filename); - Assert.assertEquals("compressed file should be equal 35 bytes, but is " + file.length(), 35, file.length()); + Assertions.assertEquals(35, file.length(), "compressed file should be equal 35 bytes, but is " + file.length()); String content = IOUtils.getBufferedReader(filename).readLine(); - Assert.assertEquals("12345678901234567890123456789012345678901234567890", content); + Assertions.assertEquals("12345678901234567890123456789012345678901234567890", content); } @Test @@ -265,7 +265,7 @@ void testGetBufferedWriter_bz2() throws IOException { writer.write("12345678901234567890123456789012345678901234567890"); writer.close(); File file = new File(filename); - Assert.assertTrue("compressed file should be equal 51 bytes, but is " + file.length(), file.length() == 51); + Assertions.assertTrue(file.length() == 51, "compressed file should be equal 51 bytes, but is " + file.length()); } @Test @@ -280,7 +280,7 @@ void testGetBufferedWriter_append_zst() throws IOException { writer.close(); BufferedReader reader = IOUtils.getBufferedReader(url); String content = reader.readLine(); - Assert.assertEquals("aaabbb", content); + Assertions.assertEquals("aaabbb", content); } @Test @@ -291,7 +291,7 @@ void testGetBufferedWriter_zst() throws IOException { writer.write("12345678901234567890123456789012345678901234567890"); writer.close(); File file = new File(filename); - Assert.assertEquals("compressed file should be equal 28 bytes, but is " + file.length(), 28, file.length()); + Assertions.assertEquals(28, file.length(), "compressed file should be equal 28 bytes, but is " + file.length()); } @Test @@ -302,7 +302,7 @@ void testGetInputStream_UTFwithoutBOM() throws IOException { out.close(); InputStream in = IOUtils.getInputStream(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } @@ -315,7 +315,7 @@ void testGetInputStream_UTFwithBOM() throws IOException { out.close(); InputStream in = IOUtils.getInputStream(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } @@ -328,7 +328,7 @@ void testGetInputStream_UTFwithBOM_Compressed() throws IOException { out.close(); InputStream in = IOUtils.getInputStream(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } @@ -341,7 +341,7 @@ void testGetInputStream_UTFwithBOM_Lz4() throws IOException { out.close(); InputStream in = IOUtils.getInputStream(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } @@ -354,7 +354,7 @@ void testGetInputStream_UTFwithBOM_bz2() throws IOException { out.close(); InputStream in = IOUtils.getInputStream(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } @@ -367,7 +367,7 @@ void testGetInputStream_UTFwithBOM_zst() throws IOException { out.close(); InputStream in = IOUtils.getInputStream(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } @@ -380,17 +380,17 @@ void testGetBufferedReader_UTFwithoutBOM() throws IOException { { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_UTF8); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_WINDOWS_ISO88591); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } } @@ -405,17 +405,17 @@ void testGetBufferedReader_UTFwithBOM() throws IOException { { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_UTF8); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_WINDOWS_ISO88591); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } } @@ -430,22 +430,22 @@ void testGetBufferedReader_UTFwithBOM_Compressed() throws IOException { { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename.substring(0, filename.length() - 3))); // without the .gz extension - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_UTF8); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_WINDOWS_ISO88591); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } } @@ -460,17 +460,17 @@ void testGetBufferedReader_UTFwithBOM_lz4() throws IOException { { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_UTF8); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_WINDOWS_ISO88591); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } } @@ -485,17 +485,17 @@ void testGetBufferedReader_UTFwithBOM_bz2() throws IOException { { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_UTF8); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_WINDOWS_ISO88591); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } } @@ -510,17 +510,17 @@ void testGetBufferedReader_UTFwithBOM_zst() throws IOException { { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename)); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_UTF8); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } { BufferedReader in = IOUtils.getBufferedReader(IOUtils.resolveFileOrResource(filename), IOUtils.CHARSET_WINDOWS_ISO88591); - Assert.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); + Assertions.assertEquals("ABCdef", new String(new byte[] { (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read(), (byte) in.read() })); in.close(); } } @@ -539,8 +539,8 @@ void testGetBufferedWriter_withPlusInFilename() throws IOException { writer.close(); File file = new File(filename); - Assert.assertTrue(file.exists()); - Assert.assertEquals("test+test.txt", file.getCanonicalFile().getName()); + Assertions.assertTrue(file.exists()); + Assertions.assertEquals("test+test.txt", file.getCanonicalFile().getName()); } @Test @@ -562,8 +562,8 @@ void testResolveFileOrResource() throws URISyntaxException, IOException { try (InputStream is = url.openStream()) { byte[] data = new byte[4096]; int size = is.read(data); - Assert.assertEquals(9, size); - Assert.assertEquals("Success!\n", new String(data, 0, size)); + Assertions.assertEquals(9, size); + Assertions.assertEquals("Success!\n", new String(data, 0, size)); } } @@ -572,14 +572,14 @@ void testResolveFileOrResource_withWhitespace() throws URISyntaxException, IOExc File jarFile = new File("test/input/org/matsim/core/utils/io/IOUtils/test directory/testfile.jar"); String fileUrlString = "jar:" + jarFile.toURI().toString() + "!/the_file.txt"; - Assert.assertTrue(fileUrlString.contains("test%20directory")); // just make sure the space is correctly URL-encoded + Assertions.assertTrue(fileUrlString.contains("test%20directory")); // just make sure the space is correctly URL-encoded URL url = IOUtils.resolveFileOrResource(fileUrlString); try (InputStream is = url.openStream()) { byte[] data = new byte[4096]; int size = is.read(data); - Assert.assertEquals(9, size); - Assert.assertEquals("Success!\n", new String(data, 0, size)); + Assertions.assertEquals(9, size); + Assertions.assertEquals("Success!\n", new String(data, 0, size)); } } @@ -592,10 +592,10 @@ void testEncryptedFile() throws IOException { // openssl enc -aes256 -md sha512 -pbkdf2 -iter 10000 -in some.secret -out some.secret.enc BufferedReader decrypted = IOUtils.getBufferedReader(new File("test/input/org/matsim/core/utils/io/IOUtils/some.secret.enc").toURL()); - Assert.assertEquals(input, decrypted.readLine()); + Assertions.assertEquals(input, decrypted.readLine()); BufferedReader gziped = IOUtils.getBufferedReader(new File("test/input/org/matsim/core/utils/io/IOUtils/some.secret.gz.enc").toURL()); - Assert.assertEquals(input, gziped.readLine()); + Assertions.assertEquals(input, gziped.readLine()); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/io/MatsimFileTypeGuesserTest.java b/matsim/src/test/java/org/matsim/core/utils/io/MatsimFileTypeGuesserTest.java index 3ec8ab16e69..96008a0ac09 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/MatsimFileTypeGuesserTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/MatsimFileTypeGuesserTest.java @@ -20,10 +20,7 @@ package org.matsim.core.utils.io; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertNull; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.*; import java.io.IOException; import java.io.UncheckedIOException; diff --git a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java index 7f692064d1d..d4d3f715283 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java @@ -19,7 +19,7 @@ package org.matsim.core.utils.io; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; @@ -56,13 +56,13 @@ void testParsingReservedEntities_AttributeValue() { parser.setValidating(false); parser.parse(new ByteArrayInputStream(str.getBytes())); - Assert.assertEquals("dummy", parser.lastStartTag); - Assert.assertEquals("dummy", parser.lastEndTag); - Assert.assertEquals("content", parser.lastContent); - Assert.assertEquals(1, parser.lastAttributes.getLength()); - Assert.assertEquals("someAttribute", parser.lastAttributes.getLocalName(0)); - Assert.assertEquals("value\"&<>value", parser.lastAttributes.getValue(0)); - Assert.assertEquals("value\"&<>value", parser.lastAttributes.getValue("someAttribute")); + Assertions.assertEquals("dummy", parser.lastStartTag); + Assertions.assertEquals("dummy", parser.lastEndTag); + Assertions.assertEquals("content", parser.lastContent); + Assertions.assertEquals(1, parser.lastAttributes.getLength()); + Assertions.assertEquals("someAttribute", parser.lastAttributes.getLocalName(0)); + Assertions.assertEquals("value\"&<>value", parser.lastAttributes.getValue(0)); + Assertions.assertEquals("value\"&<>value", parser.lastAttributes.getValue("someAttribute")); } @Test @@ -74,13 +74,13 @@ void testParsingReservedEntities_Content() { parser.setValidating(false); parser.parse(new ByteArrayInputStream(str.getBytes())); - Assert.assertEquals("dummy", parser.lastStartTag); - Assert.assertEquals("dummy", parser.lastEndTag); - Assert.assertEquals("content\"&<>content", parser.lastContent); - Assert.assertEquals(1, parser.lastAttributes.getLength()); - Assert.assertEquals("someAttribute", parser.lastAttributes.getLocalName(0)); - Assert.assertEquals("value", parser.lastAttributes.getValue(0)); - Assert.assertEquals("value", parser.lastAttributes.getValue("someAttribute")); + Assertions.assertEquals("dummy", parser.lastStartTag); + Assertions.assertEquals("dummy", parser.lastEndTag); + Assertions.assertEquals("content\"&<>content", parser.lastContent); + Assertions.assertEquals(1, parser.lastAttributes.getLength()); + Assertions.assertEquals("someAttribute", parser.lastAttributes.getLocalName(0)); + Assertions.assertEquals("value", parser.lastAttributes.getValue(0)); + Assertions.assertEquals("value", parser.lastAttributes.getValue("someAttribute")); } /** @@ -100,12 +100,12 @@ void testParsing_WindowsLinebreaks() { parser.setValidating(false); parser.parse(new ByteArrayInputStream(str.getBytes())); - Assert.assertEquals("dummy2", parser.lastStartTag); - Assert.assertEquals("root", parser.lastEndTag); - Assert.assertEquals(1, parser.lastAttributes.getLength()); - Assert.assertEquals("someAttribute2", parser.lastAttributes.getLocalName(0)); - Assert.assertEquals("value2", parser.lastAttributes.getValue(0)); - Assert.assertEquals("value2", parser.lastAttributes.getValue("someAttribute2")); + Assertions.assertEquals("dummy2", parser.lastStartTag); + Assertions.assertEquals("root", parser.lastEndTag); + Assertions.assertEquals(1, parser.lastAttributes.getLength()); + Assertions.assertEquals("someAttribute2", parser.lastAttributes.getLocalName(0)); + Assertions.assertEquals("value2", parser.lastAttributes.getValue(0)); + Assertions.assertEquals("value2", parser.lastAttributes.getValue("someAttribute2")); } private static class TestParser extends MatsimXmlParser { @@ -142,13 +142,13 @@ void testParsingPlusSign() { parser.setValidating(false); parser.parse(new ByteArrayInputStream(str.getBytes())); - Assert.assertEquals("dummy", parser.lastStartTag); - Assert.assertEquals("dummy", parser.lastEndTag); - Assert.assertEquals("content+content", parser.lastContent); - Assert.assertEquals(1, parser.lastAttributes.getLength()); - Assert.assertEquals("someAttribute", parser.lastAttributes.getLocalName(0)); - Assert.assertEquals("value+value", parser.lastAttributes.getValue(0)); - Assert.assertEquals("value+value", parser.lastAttributes.getValue("someAttribute")); + Assertions.assertEquals("dummy", parser.lastStartTag); + Assertions.assertEquals("dummy", parser.lastEndTag); + Assertions.assertEquals("content+content", parser.lastContent); + Assertions.assertEquals(1, parser.lastAttributes.getLength()); + Assertions.assertEquals("someAttribute", parser.lastAttributes.getLocalName(0)); + Assertions.assertEquals("value+value", parser.lastAttributes.getValue(0)); + Assertions.assertEquals("value+value", parser.lastAttributes.getValue("someAttribute")); } @Test @@ -178,8 +178,8 @@ public void endTag(String name, String content, Stack context) { } }.parse(stream); - Assert.assertEquals("b1", log.get(0)); - Assert.assertEquals("b2", log.get(1)); + Assertions.assertEquals("b1", log.get(0)); + Assertions.assertEquals("b2", log.get(1)); } @Test @@ -207,16 +207,16 @@ public void startTag(String name, Attributes atts, Stack context) { public void endTag(String name, String content, Stack context) { } }.parse(stream); - Assert.fail("expected exception."); + Assertions.fail("expected exception."); } catch (UncheckedIOException e) { - Assert.assertTrue(e.getCause() instanceof IOException); // expected - Assert.assertTrue(e.getCause().getCause() instanceof SAXParseException); // expected + Assertions.assertTrue(e.getCause() instanceof IOException); // expected + Assertions.assertTrue(e.getCause().getCause() instanceof SAXParseException); // expected } - Assert.assertEquals(3, log.size()); - Assert.assertEquals("network", log.get(0)); - Assert.assertEquals("nodes", log.get(1)); - Assert.assertEquals("node", log.get(2)); + Assertions.assertEquals(3, log.size()); + Assertions.assertEquals("network", log.get(0)); + Assertions.assertEquals("nodes", log.get(1)); + Assertions.assertEquals("node", log.get(2)); } @Test @@ -246,12 +246,12 @@ public void endTag(String name, String content, Stack context) { } }.parse(stream); - Assert.assertEquals(5, log.size()); - Assert.assertEquals("vehicleDefinitions", log.get(0)); - Assert.assertEquals("vehicleType", log.get(1)); - Assert.assertEquals("capacity", log.get(2)); - Assert.assertEquals("length", log.get(3)); - Assert.assertEquals("width", log.get(4)); + Assertions.assertEquals(5, log.size()); + Assertions.assertEquals("vehicleDefinitions", log.get(0)); + Assertions.assertEquals("vehicleType", log.get(1)); + Assertions.assertEquals("capacity", log.get(2)); + Assertions.assertEquals("length", log.get(3)); + Assertions.assertEquals("width", log.get(4)); } @Test @@ -283,18 +283,18 @@ public void startTag(String name, Attributes atts, Stack context) { public void endTag(String name, String content, Stack context) { } }.parse(stream); - Assert.fail("expected exception."); + Assertions.fail("expected exception."); } catch (UncheckedIOException e) { - Assert.assertTrue(e.getCause() instanceof IOException); // expected - Assert.assertTrue(e.getCause().getCause() instanceof SAXParseException); // expected + Assertions.assertTrue(e.getCause() instanceof IOException); // expected + Assertions.assertTrue(e.getCause().getCause() instanceof SAXParseException); // expected } - Assert.assertEquals(5, log.size()); - Assert.assertEquals("vehicleDefinitions", log.get(0)); - Assert.assertEquals("vehicleType", log.get(1)); - Assert.assertEquals("capacity", log.get(2)); - Assert.assertEquals("length", log.get(3)); - Assert.assertEquals("width", log.get(4)); + Assertions.assertEquals(5, log.size()); + Assertions.assertEquals("vehicleDefinitions", log.get(0)); + Assertions.assertEquals("vehicleType", log.get(1)); + Assertions.assertEquals("capacity", log.get(2)); + Assertions.assertEquals("length", log.get(3)); + Assertions.assertEquals("width", log.get(4)); } @Test @@ -336,12 +336,12 @@ public void endTag(String name, String content, Stack context) { log.add(content); } }.parse(stream); - Assert.fail("Expected exception, got none."); + Assertions.fail("Expected exception, got none."); } catch (UncheckedIOException expected) {} - Assert.assertEquals(2, log.size()); - Assert.assertEquals("b1", log.get(0)); - Assert.assertEquals(" - b2 - ", log.get(1)); + Assertions.assertEquals(2, log.size()); + Assertions.assertEquals("b1", log.get(0)); + Assertions.assertEquals(" - b2 - ", log.get(1)); } @Test @@ -385,11 +385,11 @@ public void endTag(String name, String content, Stack context) { } }.parse(stream); - Assert.assertEquals(4, log.size()); - Assert.assertEquals("attribute-a2", log.get(0)); - Assert.assertEquals("attribute-", log.get(1)); - Assert.assertEquals("object-", log.get(2)); - Assert.assertEquals("objectattributes-", log.get(3)); + Assertions.assertEquals(4, log.size()); + Assertions.assertEquals("attribute-a2", log.get(0)); + Assertions.assertEquals("attribute-", log.get(1)); + Assertions.assertEquals("object-", log.get(2)); + Assertions.assertEquals("objectattributes-", log.get(3)); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlWriterTest.java b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlWriterTest.java index 031e405293e..7a8e90c3d85 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlWriterTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlWriterTest.java @@ -3,7 +3,7 @@ import java.io.ByteArrayOutputStream; import java.util.List; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; diff --git a/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java b/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java index b307e54c47d..1fc057aa857 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/OsmNetworkReaderTest.java @@ -19,7 +19,7 @@ package org.matsim.core.utils.io; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -54,12 +54,12 @@ void testConversion() { new OsmNetworkReader(net,ct).parse(filename); - Assert.assertEquals("number of nodes is wrong.", 399, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 872, net.getLinks().size()); + Assertions.assertEquals(399, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(872, net.getLinks().size(), "number of links is wrong."); new NetworkCleaner().run(net); - Assert.assertEquals("number of nodes is wrong.", 344, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 794, net.getLinks().size()); + Assertions.assertEquals(344, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(794, net.getLinks().size(), "number of links is wrong."); } @Test @@ -75,12 +75,12 @@ void testConversionWithDetails() { reader.setKeepPaths(true); reader.parse(filename); - Assert.assertEquals("number of nodes is wrong.", 1844, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 3535, net.getLinks().size()); + Assertions.assertEquals(1844, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(3535, net.getLinks().size(), "number of links is wrong."); new NetworkCleaner().run(net); - Assert.assertEquals("number of nodes is wrong.", 1561, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 3168, net.getLinks().size()); + Assertions.assertEquals(1561, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(3168, net.getLinks().size(), "number of links is wrong."); } @Test @@ -97,12 +97,12 @@ void testConversionWithDetails_witMemoryOptimized() { reader.setMemoryOptimization(true); reader.parse(filename); - Assert.assertEquals("number of nodes is wrong.", 1844, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 3535, net.getLinks().size()); + Assertions.assertEquals(1844, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(3535, net.getLinks().size(), "number of links is wrong."); new NetworkCleaner().run(net); - Assert.assertEquals("number of nodes is wrong.", 1561, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 3168, net.getLinks().size()); + Assertions.assertEquals(1561, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(3168, net.getLinks().size(), "number of links is wrong."); } @Test @@ -119,11 +119,11 @@ void testConversionWithSettings() { reader.setMemoryOptimization(false); reader.parse(filename); - Assert.assertEquals("number of nodes is wrong.", 67, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 122, net.getLinks().size()); + Assertions.assertEquals(67, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(122, net.getLinks().size(), "number of links is wrong."); new NetworkCleaner().run(net); - Assert.assertEquals("number of nodes is wrong.", 57, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 114, net.getLinks().size()); + Assertions.assertEquals(57, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(114, net.getLinks().size(), "number of links is wrong."); } @Test @@ -140,11 +140,11 @@ void testConversionWithSettings_withMemoryOptimization() { reader.setMemoryOptimization(true); reader.parse(filename); - Assert.assertEquals("number of nodes is wrong.", 67, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 122, net.getLinks().size()); + Assertions.assertEquals(67, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(122, net.getLinks().size(), "number of links is wrong."); new NetworkCleaner().run(net); - Assert.assertEquals("number of nodes is wrong.", 57, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 114, net.getLinks().size()); + Assertions.assertEquals(57, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(114, net.getLinks().size(), "number of links is wrong."); } @Test @@ -161,11 +161,11 @@ void testConversionWithSettingsAndDetails() { reader.setHierarchyLayer(47.4, 8.5, 47.2, 8.6, 5); reader.parse(filename); - Assert.assertEquals("number of nodes is wrong.", 769, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 1016, net.getLinks().size()); + Assertions.assertEquals(769, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(1016, net.getLinks().size(), "number of links is wrong."); new NetworkCleaner().run(net); - Assert.assertEquals("number of nodes is wrong.", 441, net.getNodes().size()); - Assert.assertEquals("number of links is wrong.", 841, net.getLinks().size()); + Assertions.assertEquals(441, net.getNodes().size(), "number of nodes is wrong."); + Assertions.assertEquals(841, net.getLinks().size(), "number of links is wrong."); } @Test @@ -195,8 +195,8 @@ void testConversion_MissingNodeRef() { " \n" + ""; reader.parse(() -> new ByteArrayInputStream(str.getBytes())); - Assert.assertEquals("incomplete ways should not be converted.", 0, net.getNodes().size()); - Assert.assertEquals("incomplete ways should not be converted.", 0, net.getLinks().size()); + Assertions.assertEquals(0, net.getNodes().size(), "incomplete ways should not be converted."); + Assertions.assertEquals(0, net.getLinks().size(), "incomplete ways should not be converted."); } @Test @@ -246,12 +246,12 @@ void testConversion_maxspeeds() { Link link1 = net.getLinks().get(Id.create("1", Link.class)); Link link3 = net.getLinks().get(Id.create("3", Link.class)); Link link5 = net.getLinks().get(Id.create("5", Link.class)); - Assert.assertNotNull("Could not find converted link 1.", link1); - Assert.assertNotNull("Could not find converted link 3", link3); - Assert.assertNotNull("Could not find converted link 5", link5); - Assert.assertEquals(50.0/3.6, link1.getFreespeed(), 1e-8); - Assert.assertEquals(40.0/3.6, link3.getFreespeed(), 1e-8); - Assert.assertEquals(60.0/3.6, link5.getFreespeed(), 1e-8); + Assertions.assertNotNull(link1, "Could not find converted link 1."); + Assertions.assertNotNull(link3, "Could not find converted link 3"); + Assertions.assertNotNull(link5, "Could not find converted link 5"); + Assertions.assertEquals(50.0/3.6, link1.getFreespeed(), 1e-8); + Assertions.assertEquals(40.0/3.6, link3.getFreespeed(), 1e-8); + Assertions.assertEquals(60.0/3.6, link5.getFreespeed(), 1e-8); } /** @@ -301,8 +301,8 @@ void testConversion_emptyWay() { Link link1 = net.getLinks().get(Id.create("1", Link.class)); Link link3 = net.getLinks().get(Id.create("3", Link.class)); - Assert.assertNotNull("Could not find converted link 1.", link1); - Assert.assertNotNull("Could not find converted link 3", link3); - Assert.assertNull(net.getLinks().get(Id.create("5", Link.class))); + Assertions.assertNotNull(link1, "Could not find converted link 1."); + Assertions.assertNotNull(link3, "Could not find converted link 3"); + Assertions.assertNull(net.getLinks().get(Id.create("5", Link.class))); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/io/XmlUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/io/XmlUtilsTest.java index 1923fddcfae..5bf09eafec3 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/XmlUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/XmlUtilsTest.java @@ -19,7 +19,7 @@ package org.matsim.core.utils.io; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** @@ -29,24 +29,24 @@ public class XmlUtilsTest { @Test void testEncodeAttributeValue() { - Assert.assertEquals("hello world!", XmlUtils.encodeAttributeValue("hello world!")); - Assert.assertEquals("you & me", XmlUtils.encodeAttributeValue("you & me")); - Assert.assertEquals("you & me & her", XmlUtils.encodeAttributeValue("you & me & her")); - Assert.assertEquals("tick " tack", XmlUtils.encodeAttributeValue("tick \" tack")); - Assert.assertEquals("tick " tack " tock", XmlUtils.encodeAttributeValue("tick \" tack \" tock")); - Assert.assertEquals("this & that " these & those", XmlUtils.encodeAttributeValue("this & that \" these & those")); - Assert.assertEquals("tick < tack > tock", XmlUtils.encodeAttributeValue("tick < tack > tock")); + Assertions.assertEquals("hello world!", XmlUtils.encodeAttributeValue("hello world!")); + Assertions.assertEquals("you & me", XmlUtils.encodeAttributeValue("you & me")); + Assertions.assertEquals("you & me & her", XmlUtils.encodeAttributeValue("you & me & her")); + Assertions.assertEquals("tick " tack", XmlUtils.encodeAttributeValue("tick \" tack")); + Assertions.assertEquals("tick " tack " tock", XmlUtils.encodeAttributeValue("tick \" tack \" tock")); + Assertions.assertEquals("this & that " these & those", XmlUtils.encodeAttributeValue("this & that \" these & those")); + Assertions.assertEquals("tick < tack > tock", XmlUtils.encodeAttributeValue("tick < tack > tock")); } @Test void testEncodedContent() { - Assert.assertEquals("hello world!", XmlUtils.encodeContent("hello world!")); - Assert.assertEquals("you & me", XmlUtils.encodeContent("you & me")); - Assert.assertEquals("you & me & her", XmlUtils.encodeContent("you & me & her")); - Assert.assertEquals("tick \" tack", XmlUtils.encodeContent("tick \" tack")); - Assert.assertEquals("tick \" tack \" tock", XmlUtils.encodeContent("tick \" tack \" tock")); - Assert.assertEquals("this & that \" these & those", XmlUtils.encodeContent("this & that \" these & those")); - Assert.assertEquals("tick < tack > tock", XmlUtils.encodeContent("tick < tack > tock")); + Assertions.assertEquals("hello world!", XmlUtils.encodeContent("hello world!")); + Assertions.assertEquals("you & me", XmlUtils.encodeContent("you & me")); + Assertions.assertEquals("you & me & her", XmlUtils.encodeContent("you & me & her")); + Assertions.assertEquals("tick \" tack", XmlUtils.encodeContent("tick \" tack")); + Assertions.assertEquals("tick \" tack \" tock", XmlUtils.encodeContent("tick \" tack \" tock")); + Assertions.assertEquals("this & that \" these & those", XmlUtils.encodeContent("this & that \" these & those")); + Assertions.assertEquals("tick < tack > tock", XmlUtils.encodeContent("tick < tack > tock")); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java index 3e4e9948379..550ae2c07d4 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ArgumentParserTest.java @@ -20,8 +20,8 @@ package org.matsim.core.utils.misc; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.fail; import java.util.Iterator; import java.util.NoSuchElementException; diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java index 2325de69101..8438ed9b621 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ByteBufferUtilsTest.java @@ -20,8 +20,8 @@ package org.matsim.core.utils.misc; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertFalse; import java.io.Serializable; import java.nio.ByteBuffer; diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ClassUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ClassUtilsTest.java index de4b6b6bb0c..d53b1e6d49e 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ClassUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ClassUtilsTest.java @@ -21,7 +21,7 @@ import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** @@ -32,110 +32,110 @@ public class ClassUtilsTest { @Test void testInterfaceNoInheritance() { Set> set = ClassUtils.getAllTypes(A.class); - Assert.assertEquals(1, set.size()); - Assert.assertTrue(set.contains(A.class)); + Assertions.assertEquals(1, set.size()); + Assertions.assertTrue(set.contains(A.class)); } @Test void testClassNoInheritance() { Set> set = ClassUtils.getAllTypes(Z.class); - Assert.assertEquals(2, set.size()); - Assert.assertTrue(set.contains(Z.class)); - Assert.assertTrue(set.contains(Object.class)); + Assertions.assertEquals(2, set.size()); + Assertions.assertTrue(set.contains(Z.class)); + Assertions.assertTrue(set.contains(Object.class)); } @Test void testInterfaceSingleInheritance() { Set> set = ClassUtils.getAllTypes(B.class); - Assert.assertEquals(2, set.size()); - Assert.assertTrue(set.contains(A.class)); - Assert.assertTrue(set.contains(B.class)); + Assertions.assertEquals(2, set.size()); + Assertions.assertTrue(set.contains(A.class)); + Assertions.assertTrue(set.contains(B.class)); } @Test void testClassSingleInheritance() { Set> set = ClassUtils.getAllTypes(Y.class); - Assert.assertEquals(3, set.size()); - Assert.assertTrue(set.contains(Z.class)); - Assert.assertTrue(set.contains(Y.class)); - Assert.assertTrue(set.contains(Object.class)); + Assertions.assertEquals(3, set.size()); + Assertions.assertTrue(set.contains(Z.class)); + Assertions.assertTrue(set.contains(Y.class)); + Assertions.assertTrue(set.contains(Object.class)); } @Test void testInterfaceMultipleInheritance_SingleLevel() { Set> set = ClassUtils.getAllTypes(AB.class); - Assert.assertEquals(3, set.size()); - Assert.assertTrue(set.contains(A.class)); - Assert.assertTrue(set.contains(B.class)); - Assert.assertTrue(set.contains(AB.class)); + Assertions.assertEquals(3, set.size()); + Assertions.assertTrue(set.contains(A.class)); + Assertions.assertTrue(set.contains(B.class)); + Assertions.assertTrue(set.contains(AB.class)); } @Test void testInterfaceMultipleInheritance_MultipleLevel() { Set> set = ClassUtils.getAllTypes(C.class); - Assert.assertEquals(3, set.size()); - Assert.assertTrue(set.contains(A.class)); - Assert.assertTrue(set.contains(B.class)); - Assert.assertTrue(set.contains(C.class)); + Assertions.assertEquals(3, set.size()); + Assertions.assertTrue(set.contains(A.class)); + Assertions.assertTrue(set.contains(B.class)); + Assertions.assertTrue(set.contains(C.class)); } @Test void testClassMultipleInheritance_MultipleLevel() { Set> set = ClassUtils.getAllTypes(X.class); - Assert.assertEquals(4, set.size()); - Assert.assertTrue(set.contains(Z.class)); - Assert.assertTrue(set.contains(Y.class)); - Assert.assertTrue(set.contains(X.class)); - Assert.assertTrue(set.contains(Object.class)); + Assertions.assertEquals(4, set.size()); + Assertions.assertTrue(set.contains(Z.class)); + Assertions.assertTrue(set.contains(Y.class)); + Assertions.assertTrue(set.contains(X.class)); + Assertions.assertTrue(set.contains(Object.class)); } @Test void testSingleInterfaceImplementation() { Set> set = ClassUtils.getAllTypes(Aimpl.class); - Assert.assertEquals(3, set.size()); - Assert.assertTrue(set.contains(Aimpl.class)); - Assert.assertTrue(set.contains(A.class)); - Assert.assertTrue(set.contains(Object.class)); + Assertions.assertEquals(3, set.size()); + Assertions.assertTrue(set.contains(Aimpl.class)); + Assertions.assertTrue(set.contains(A.class)); + Assertions.assertTrue(set.contains(Object.class)); } @Test void testSingleInterfaceImplementation_MultipleLevel() { Set> set = ClassUtils.getAllTypes(Bimpl.class); - Assert.assertEquals(4, set.size()); - Assert.assertTrue(set.contains(Bimpl.class)); - Assert.assertTrue(set.contains(B.class)); - Assert.assertTrue(set.contains(A.class)); - Assert.assertTrue(set.contains(Object.class)); + Assertions.assertEquals(4, set.size()); + Assertions.assertTrue(set.contains(Bimpl.class)); + Assertions.assertTrue(set.contains(B.class)); + Assertions.assertTrue(set.contains(A.class)); + Assertions.assertTrue(set.contains(Object.class)); } @Test void testMultipleInterfaceImplementation() { Set> set = ClassUtils.getAllTypes(ABimpl.class); - Assert.assertEquals(4, set.size()); - Assert.assertTrue(set.contains(ABimpl.class)); - Assert.assertTrue(set.contains(B.class)); - Assert.assertTrue(set.contains(A.class)); - Assert.assertTrue(set.contains(Object.class)); + Assertions.assertEquals(4, set.size()); + Assertions.assertTrue(set.contains(ABimpl.class)); + Assertions.assertTrue(set.contains(B.class)); + Assertions.assertTrue(set.contains(A.class)); + Assertions.assertTrue(set.contains(Object.class)); } @Test void testComplexClass() { Set> set = ClassUtils.getAllTypes(Dimpl.class); - Assert.assertEquals(5, set.size()); - Assert.assertTrue(set.contains(Dimpl.class)); - Assert.assertTrue(set.contains(Bimpl.class)); - Assert.assertTrue(set.contains(B.class)); - Assert.assertTrue(set.contains(A.class)); - Assert.assertTrue(set.contains(Object.class)); + Assertions.assertEquals(5, set.size()); + Assertions.assertTrue(set.contains(Dimpl.class)); + Assertions.assertTrue(set.contains(Bimpl.class)); + Assertions.assertTrue(set.contains(B.class)); + Assertions.assertTrue(set.contains(A.class)); + Assertions.assertTrue(set.contains(Object.class)); set = ClassUtils.getAllTypes(BCDimpl.class); - Assert.assertEquals(6, set.size()); - Assert.assertTrue(set.contains(BCDimpl.class)); - Assert.assertTrue(set.contains(Bimpl.class)); - Assert.assertTrue(set.contains(C.class)); - Assert.assertTrue(set.contains(B.class)); - Assert.assertTrue(set.contains(A.class)); - Assert.assertTrue(set.contains(Object.class)); + Assertions.assertEquals(6, set.size()); + Assertions.assertTrue(set.contains(BCDimpl.class)); + Assertions.assertTrue(set.contains(Bimpl.class)); + Assertions.assertTrue(set.contains(C.class)); + Assertions.assertTrue(set.contains(B.class)); + Assertions.assertTrue(set.contains(A.class)); + Assertions.assertTrue(set.contains(Object.class)); } /*package*/ interface A { } diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java index 383eba26f43..73c7bde965d 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java @@ -25,6 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.config.Config; @@ -46,33 +47,33 @@ public class ConfigUtilsTest { @Test void testLoadConfig_filenameOnly() throws IOException { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); - Assert.assertNotNull(config); - Assert.assertEquals("network.xml", config.network().getInputFile()); + Assertions.assertNotNull(config); + Assertions.assertEquals("network.xml", config.network().getInputFile()); } @Test void testLoadConfig_emptyConfig() throws IOException { Config config = new Config(); - Assert.assertNull(config.network()); + Assertions.assertNull(config.network()); ConfigUtils.loadConfig(config, IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); - Assert.assertNotNull(config.network()); - Assert.assertEquals("network.xml", config.network().getInputFile()); + Assertions.assertNotNull(config.network()); + Assertions.assertEquals("network.xml", config.network().getInputFile()); } @Test void testLoadConfig_preparedConfig() throws IOException { Config config = new Config(); config.addCoreModules(); - Assert.assertNotNull(config.network()); - Assert.assertNull(config.network().getInputFile()); + Assertions.assertNotNull(config.network()); + Assertions.assertNull(config.network().getInputFile()); ConfigUtils.loadConfig(config, IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); - Assert.assertEquals("network.xml", config.network().getInputFile()); + Assertions.assertEquals("network.xml", config.network().getInputFile()); } @Test void testModifyPaths_missingSeparator() throws IOException { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); - Assert.assertEquals("network.xml", config.network().getInputFile()); + Assertions.assertEquals("network.xml", config.network().getInputFile()); ConfigUtils.modifyFilePaths(config, "/home/username/matsim"); Assert.assertThat(config.network().getInputFile(), anyOf(is("/home/username/matsim/network.xml"),is("/home/username/matsim\\network.xml"))); @@ -81,7 +82,7 @@ void testModifyPaths_missingSeparator() throws IOException { @Test void testModifyPaths_withSeparator() throws IOException { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); - Assert.assertEquals("network.xml", config.network().getInputFile()); + Assertions.assertEquals("network.xml", config.network().getInputFile()); ConfigUtils.modifyFilePaths(config, "/home/username/matsim/"); Assert.assertThat(config.network().getInputFile(), anyOf(is("/home/username/matsim/network.xml"),is("/home/username/matsim\\network.xml"))); } @@ -91,7 +92,7 @@ void loadConfigWithTypedArgs(){ final URL url = IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "equil" ), "config.xml" ); final String [] typedArgs = {"--config:controler.outputDirectory=abc"} ; Config config = ConfigUtils.loadConfig( url, typedArgs ); - Assert.assertEquals("abc", config.controller().getOutputDirectory()); + Assertions.assertEquals("abc", config.controller().getOutputDirectory()); } @Test @@ -106,6 +107,6 @@ void loadConfigWithTypedArgsWithTypo(){ hasFailed = true ; log.warn("the above exception was expected") ; } - Assert.assertTrue( hasFailed ); + Assertions.assertTrue( hasFailed ); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/NetworkUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/NetworkUtilsTest.java index 8f9caadb543..146468c9db8 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/NetworkUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/NetworkUtilsTest.java @@ -20,14 +20,14 @@ package org.matsim.core.utils.misc; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.fail; import java.util.ArrayList; import java.util.Collection; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -225,7 +225,7 @@ void testIsMultimodal_carOnly() { for (Link l : f.links) { l.setAllowedModes(CollectionUtils.stringToSet("car")); } - Assert.assertFalse(NetworkUtils.isMultimodal(f.network)); + Assertions.assertFalse(NetworkUtils.isMultimodal(f.network)); } @Test @@ -235,7 +235,7 @@ void testIsMultimodal_walkOnly() { for (Link l : f.links) { l.setAllowedModes(CollectionUtils.stringToSet("walk")); } - Assert.assertFalse(NetworkUtils.isMultimodal(f.network)); + Assertions.assertFalse(NetworkUtils.isMultimodal(f.network)); } @Test @@ -245,7 +245,7 @@ void testIsMultimodal_2modesOnSingleLink() { l.setAllowedModes(CollectionUtils.stringToSet("car")); } f.links[3].setAllowedModes(CollectionUtils.stringToSet("car,bike")); - Assert.assertTrue(NetworkUtils.isMultimodal(f.network)); + Assertions.assertTrue(NetworkUtils.isMultimodal(f.network)); } @Test @@ -255,7 +255,7 @@ void testIsMultimodal_2modesOnDifferentLinks() { l.setAllowedModes(CollectionUtils.stringToSet("car")); } f.links[2].setAllowedModes(CollectionUtils.stringToSet("bike")); - Assert.assertTrue(NetworkUtils.isMultimodal(f.network)); + Assertions.assertTrue(NetworkUtils.isMultimodal(f.network)); } @Test @@ -265,7 +265,7 @@ void testIsMultimodal_3modes() { l.setAllowedModes(CollectionUtils.stringToSet("car")); } f.links[2].setAllowedModes(CollectionUtils.stringToSet("bike,walk")); - Assert.assertTrue(NetworkUtils.isMultimodal(f.network)); + Assertions.assertTrue(NetworkUtils.isMultimodal(f.network)); } @Test @@ -274,7 +274,7 @@ void testIsMultimodal_onlyNoModes() { for (Link l : f.links) { l.setAllowedModes(CollectionUtils.stringToSet("")); } - Assert.assertFalse(NetworkUtils.isMultimodal(f.network)); + Assertions.assertFalse(NetworkUtils.isMultimodal(f.network)); } @Test @@ -284,7 +284,7 @@ void testIsMultimodal_sometimesNoModes() { l.setAllowedModes(CollectionUtils.stringToSet("car")); } f.links[2].setAllowedModes(CollectionUtils.stringToSet("")); - Assert.assertTrue(NetworkUtils.isMultimodal(f.network)); + Assertions.assertTrue(NetworkUtils.isMultimodal(f.network)); } @Test @@ -296,11 +296,11 @@ void testGetConnectingLink() { Link link1 = net.getLinks().get(Id.create(1, Link.class)); Link link2 = net.getLinks().get(Id.create(2, Link.class)); - Assert.assertEquals(link1, NetworkUtils.getConnectingLink(node1, node2)); - Assert.assertEquals(link2, NetworkUtils.getConnectingLink(node2, node3)); - Assert.assertNull(NetworkUtils.getConnectingLink(node1, node3)); // skip one node - Assert.assertNull(NetworkUtils.getConnectingLink(node3, node2)); // backwards - Assert.assertNull(NetworkUtils.getConnectingLink(node2, node1)); // backwards + Assertions.assertEquals(link1, NetworkUtils.getConnectingLink(node1, node2)); + Assertions.assertEquals(link2, NetworkUtils.getConnectingLink(node2, node3)); + Assertions.assertNull(NetworkUtils.getConnectingLink(node1, node3)); // skip one node + Assertions.assertNull(NetworkUtils.getConnectingLink(node3, node2)); // backwards + Assertions.assertNull(NetworkUtils.getConnectingLink(node2, node1)); // backwards } private static class PseudoLink extends FakeLink { diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java index 5f30320cbd3..f00cd245d00 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/PopulationUtilsTest.java @@ -20,7 +20,7 @@ import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -58,11 +58,11 @@ void testLegOverlap() { List legs3 = PopulationUtils.getLegs(f.plan3); // Assert.assertEquals( 2., PopulationUtils.calculateSimilarity( legs1, legs2, null, 1., 1. ) , 0.001 ) ; - Assert.assertEquals( 4., PopulationUtils.calculateSimilarity( legs1, legs2, null, 1., 1. ) , 0.001 ) ; + Assertions.assertEquals( 4., PopulationUtils.calculateSimilarity( legs1, legs2, null, 1., 1. ) , 0.001 ) ; // (no route is now counted as "same route" and thus reaps the reward. kai, jul'18) // Assert.assertEquals( 1., PopulationUtils.calculateSimilarity( legs1, legs3, null, 1., 1. ) , 0.001 ) ; - Assert.assertEquals( 2., PopulationUtils.calculateSimilarity( legs1, legs3, null, 1., 1. ) , 0.001 ) ; + Assertions.assertEquals( 2., PopulationUtils.calculateSimilarity( legs1, legs3, null, 1., 1. ) , 0.001 ) ; // (no route is now counted as "same route" and thus reaps the reward. kai, jul'18) } @@ -74,8 +74,8 @@ void testActivityOverlap() { List acts2 = PopulationUtils.getActivities(f.plan2, StageActivityHandling.StagesAsNormalActivities ) ; List acts3 = PopulationUtils.getActivities(f.plan3, StageActivityHandling.StagesAsNormalActivities ) ; - Assert.assertEquals( 6., PopulationUtils.calculateSimilarity( acts1, acts2 , 1., 1., 0. ) , 0.001 ) ; - Assert.assertEquals( 5., PopulationUtils.calculateSimilarity( acts1, acts3 , 1., 1., 0. ) , 0.001 ) ; + Assertions.assertEquals( 6., PopulationUtils.calculateSimilarity( acts1, acts2 , 1., 1., 0. ) , 0.001 ) ; + Assertions.assertEquals( 5., PopulationUtils.calculateSimilarity( acts1, acts3 , 1., 1., 0. ) , 0.001 ) ; } private static class Fixture { @@ -153,7 +153,7 @@ private static class Fixture { void testEmptyPopulation() { Scenario s1 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Scenario s2 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); - Assert.assertTrue(PopulationUtils.equalPopulation(s1.getPopulation(), s2.getPopulation())); + Assertions.assertTrue(PopulationUtils.equalPopulation(s1.getPopulation(), s2.getPopulation())); } @Test @@ -162,8 +162,8 @@ void testEmptyPopulationVsOnePerson() { Scenario s2 = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Person person = s2.getPopulation().getFactory().createPerson(Id.create("1", Person.class)); s2.getPopulation().addPerson(person); - Assert.assertFalse(PopulationUtils.equalPopulation(s1.getPopulation(), s2.getPopulation())); - Assert.assertFalse(PopulationUtils.equalPopulation(s2.getPopulation(), s1.getPopulation())); + Assertions.assertFalse(PopulationUtils.equalPopulation(s1.getPopulation(), s2.getPopulation())); + Assertions.assertFalse(PopulationUtils.equalPopulation(s2.getPopulation(), s1.getPopulation())); } @Test @@ -173,7 +173,7 @@ void testCompareBigPopulationWithItself() { String popFileName = "test/scenarios/berlin/plans_hwh_1pct.xml.gz"; new MatsimNetworkReader(s1.getNetwork()).readFile(netFileName); new PopulationReader(s1).readFile(popFileName); - Assert.assertTrue(PopulationUtils.equalPopulation(s1.getPopulation(), s1.getPopulation())); + Assertions.assertTrue(PopulationUtils.equalPopulation(s1.getPopulation(), s1.getPopulation())); } } diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/RouteUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/RouteUtilsTest.java index 01c37c7d52f..8aa058cdf5d 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/RouteUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/RouteUtilsTest.java @@ -23,7 +23,7 @@ import java.util.Collections; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -78,9 +78,9 @@ void testCalculateCoverage() { route3.setLinkIds(startLink.getId(), linkIds, endLink.getId()); } - Assert.assertEquals( 1. , RouteUtils.calculateCoverage( route, route2, f.network ), 0.0001 ); - Assert.assertEquals( (200.+400.+500.)/(200.+300.+400.+500.) , RouteUtils.calculateCoverage( route, route3, f.network ), 0.0001 ); - Assert.assertEquals( 1. , RouteUtils.calculateCoverage( route3, route, f.network ), 0.0001 ); + Assertions.assertEquals( 1. , RouteUtils.calculateCoverage( route, route2, f.network ), 0.0001 ); + Assertions.assertEquals( (200.+400.+500.)/(200.+300.+400.+500.) , RouteUtils.calculateCoverage( route, route3, f.network ), 0.0001 ); + Assertions.assertEquals( 1. , RouteUtils.calculateCoverage( route3, route, f.network ), 0.0001 ); } @@ -95,12 +95,12 @@ void testGetNodes() { route.setLinkIds(startLink.getId(), linkIds, endLink.getId()); List nodes = RouteUtils.getNodes(route, f.network); - Assert.assertEquals(5, nodes.size()); - Assert.assertEquals(f.nodeIds[1], nodes.get(0).getId()); - Assert.assertEquals(f.nodeIds[2], nodes.get(1).getId()); - Assert.assertEquals(f.nodeIds[3], nodes.get(2).getId()); - Assert.assertEquals(f.nodeIds[4], nodes.get(3).getId()); - Assert.assertEquals(f.nodeIds[5], nodes.get(4).getId()); + Assertions.assertEquals(5, nodes.size()); + Assertions.assertEquals(f.nodeIds[1], nodes.get(0).getId()); + Assertions.assertEquals(f.nodeIds[2], nodes.get(1).getId()); + Assertions.assertEquals(f.nodeIds[3], nodes.get(2).getId()); + Assertions.assertEquals(f.nodeIds[4], nodes.get(3).getId()); + Assertions.assertEquals(f.nodeIds[5], nodes.get(4).getId()); } @Test @@ -113,7 +113,7 @@ void testGetNodes_SameStartEndLink() { route.setLinkIds(startLink.getId(), links, endLink.getId()); List nodes = RouteUtils.getNodes(route, f.network); - Assert.assertEquals(0, nodes.size()); + Assertions.assertEquals(0, nodes.size()); } @Test @@ -126,8 +126,8 @@ void testGetNodes_NoLinksBetween() { route.setLinkIds(startLinkId, linkIds, endLinkId); List nodes = RouteUtils.getNodes(route, f.network); - Assert.assertEquals(1, nodes.size()); - Assert.assertEquals(f.nodeIds[4], nodes.get(0).getId()); + Assertions.assertEquals(1, nodes.size()); + Assertions.assertEquals(f.nodeIds[4], nodes.get(0).getId()); } @Test @@ -144,14 +144,14 @@ void testGetNodes_CircularRoute() { route.setLinkIds(startLink.getId(), linkIds, endLink.getId()); List nodes = RouteUtils.getNodes(route, f.network); - Assert.assertEquals(7, nodes.size()); - Assert.assertEquals(f.nodeIds[4], nodes.get(0).getId()); - Assert.assertEquals(f.nodeIds[5], nodes.get(1).getId()); - Assert.assertEquals(f.nodeIds[6], nodes.get(2).getId()); - Assert.assertEquals(f.nodeIds[0], nodes.get(3).getId()); - Assert.assertEquals(f.nodeIds[1], nodes.get(4).getId()); - Assert.assertEquals(f.nodeIds[2], nodes.get(5).getId()); - Assert.assertEquals(f.nodeIds[3], nodes.get(6).getId()); + Assertions.assertEquals(7, nodes.size()); + Assertions.assertEquals(f.nodeIds[4], nodes.get(0).getId()); + Assertions.assertEquals(f.nodeIds[5], nodes.get(1).getId()); + Assertions.assertEquals(f.nodeIds[6], nodes.get(2).getId()); + Assertions.assertEquals(f.nodeIds[0], nodes.get(3).getId()); + Assertions.assertEquals(f.nodeIds[1], nodes.get(4).getId()); + Assertions.assertEquals(f.nodeIds[2], nodes.get(5).getId()); + Assertions.assertEquals(f.nodeIds[3], nodes.get(6).getId()); } @Test @@ -160,29 +160,29 @@ void testGetLinksFromNodes() { ArrayList nodes = new ArrayList(); List links = RouteUtils.getLinksFromNodes(nodes); - Assert.assertEquals(0, links.size()); + Assertions.assertEquals(0, links.size()); nodes.add(f.network.getNodes().get(f.nodeIds[3])); links = RouteUtils.getLinksFromNodes(nodes); - Assert.assertEquals(0, links.size()); + Assertions.assertEquals(0, links.size()); nodes.add(f.network.getNodes().get(f.nodeIds[4])); links = RouteUtils.getLinksFromNodes(nodes); - Assert.assertEquals(1, links.size()); - Assert.assertEquals(f.linkIds[3], links.get(0).getId()); + Assertions.assertEquals(1, links.size()); + Assertions.assertEquals(f.linkIds[3], links.get(0).getId()); nodes.add(f.network.getNodes().get(f.nodeIds[5])); links = RouteUtils.getLinksFromNodes(nodes); - Assert.assertEquals(2, links.size()); - Assert.assertEquals(f.linkIds[3], links.get(0).getId()); - Assert.assertEquals(f.linkIds[4], links.get(1).getId()); + Assertions.assertEquals(2, links.size()); + Assertions.assertEquals(f.linkIds[3], links.get(0).getId()); + Assertions.assertEquals(f.linkIds[4], links.get(1).getId()); nodes.add(0, f.network.getNodes().get(f.nodeIds[2])); links = RouteUtils.getLinksFromNodes(nodes); - Assert.assertEquals(3, links.size()); - Assert.assertEquals(f.linkIds[2], links.get(0).getId()); - Assert.assertEquals(f.linkIds[3], links.get(1).getId()); - Assert.assertEquals(f.linkIds[4], links.get(2).getId()); + Assertions.assertEquals(3, links.size()); + Assertions.assertEquals(f.linkIds[2], links.get(0).getId()); + Assertions.assertEquals(f.linkIds[3], links.get(1).getId()); + Assertions.assertEquals(f.linkIds[4], links.get(2).getId()); } @Test @@ -194,11 +194,11 @@ void testGetSubRoute() { route.setLinkIds(f.linkIds[0], linkIds, f.linkIds[5]); NetworkRoute subRoute = RouteUtils.getSubRoute(route, f.network.getNodes().get(f.nodeIds[3]), f.network.getNodes().get(f.nodeIds[5]), f.network); - Assert.assertEquals(2, subRoute.getLinkIds().size()); - Assert.assertEquals(f.linkIds[2], subRoute.getStartLinkId()); - Assert.assertEquals(f.linkIds[3], subRoute.getLinkIds().get(0)); - Assert.assertEquals(f.linkIds[4], subRoute.getLinkIds().get(1)); - Assert.assertEquals(f.linkIds[5], subRoute.getEndLinkId()); + Assertions.assertEquals(2, subRoute.getLinkIds().size()); + Assertions.assertEquals(f.linkIds[2], subRoute.getStartLinkId()); + Assertions.assertEquals(f.linkIds[3], subRoute.getLinkIds().get(0)); + Assertions.assertEquals(f.linkIds[4], subRoute.getLinkIds().get(1)); + Assertions.assertEquals(f.linkIds[5], subRoute.getEndLinkId()); } @Test @@ -210,13 +210,13 @@ void testGetSubRoute_fullRoute() { route.setLinkIds(f.linkIds[0], linkIds, f.linkIds[5]); NetworkRoute subRoute = RouteUtils.getSubRoute(route, f.network.getNodes().get(f.nodeIds[1]), f.network.getNodes().get(f.nodeIds[5]), f.network); - Assert.assertEquals(4, subRoute.getLinkIds().size()); - Assert.assertEquals(f.linkIds[0], subRoute.getStartLinkId()); - Assert.assertEquals(f.linkIds[1], subRoute.getLinkIds().get(0)); - Assert.assertEquals(f.linkIds[2], subRoute.getLinkIds().get(1)); - Assert.assertEquals(f.linkIds[3], subRoute.getLinkIds().get(2)); - Assert.assertEquals(f.linkIds[4], subRoute.getLinkIds().get(3)); - Assert.assertEquals(f.linkIds[5], subRoute.getEndLinkId()); + Assertions.assertEquals(4, subRoute.getLinkIds().size()); + Assertions.assertEquals(f.linkIds[0], subRoute.getStartLinkId()); + Assertions.assertEquals(f.linkIds[1], subRoute.getLinkIds().get(0)); + Assertions.assertEquals(f.linkIds[2], subRoute.getLinkIds().get(1)); + Assertions.assertEquals(f.linkIds[3], subRoute.getLinkIds().get(2)); + Assertions.assertEquals(f.linkIds[4], subRoute.getLinkIds().get(3)); + Assertions.assertEquals(f.linkIds[5], subRoute.getEndLinkId()); } @Test @@ -228,9 +228,9 @@ void testGetSubRoute_emptySubRoute() { route.setLinkIds(f.linkIds[0], linkIds, f.linkIds[5]); NetworkRoute subRoute = RouteUtils.getSubRoute(route, f.network.getNodes().get(f.nodeIds[4]), f.network.getNodes().get(f.nodeIds[4]), f.network); - Assert.assertEquals(0, subRoute.getLinkIds().size()); - Assert.assertEquals(f.linkIds[3], subRoute.getStartLinkId()); - Assert.assertEquals(f.linkIds[4], subRoute.getEndLinkId()); + Assertions.assertEquals(0, subRoute.getLinkIds().size()); + Assertions.assertEquals(f.linkIds[3], subRoute.getStartLinkId()); + Assertions.assertEquals(f.linkIds[4], subRoute.getEndLinkId()); } @Test @@ -242,9 +242,9 @@ void testGetSubRoute_sameStartEnd() { route.setLinkIds(f.linkIds[0], linkIds, f.linkIds[5]); NetworkRoute subRoute = RouteUtils.getSubRoute(route, f.network.getNodes().get(f.nodeIds[5]), f.network.getNodes().get(f.nodeIds[4]), f.network); - Assert.assertEquals(0, subRoute.getLinkIds().size()); - Assert.assertEquals(f.linkIds[4], subRoute.getStartLinkId()); - Assert.assertEquals(f.linkIds[4], subRoute.getEndLinkId()); + Assertions.assertEquals(0, subRoute.getLinkIds().size()); + Assertions.assertEquals(f.linkIds[4], subRoute.getStartLinkId()); + Assertions.assertEquals(f.linkIds[4], subRoute.getEndLinkId()); } @Test @@ -260,13 +260,13 @@ void testCalcDistance() { List> linkIds = new ArrayList>(); Collections.addAll(linkIds, f.linkIds[1], f.linkIds[2], f.linkIds[3]); route.setLinkIds(f.linkIds[0], linkIds, f.linkIds[4]); - Assert.assertEquals(900.0, RouteUtils.calcDistanceExcludingStartEndLink(route, f.network), MatsimTestUtils.EPSILON); - Assert.assertEquals(1400.0, RouteUtils.calcDistance(route, 1.0, 1.0, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(900.0, RouteUtils.calcDistanceExcludingStartEndLink(route, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1400.0, RouteUtils.calcDistance(route, 1.0, 1.0, f.network), MatsimTestUtils.EPSILON); // modify the route linkIds.add(f.linkIds[4]); route.setLinkIds(f.linkIds[0], linkIds, f.linkIds[5]); - Assert.assertEquals(1400.0, RouteUtils.calcDistanceExcludingStartEndLink(route, f.network), MatsimTestUtils.EPSILON); - Assert.assertEquals(2000.0, RouteUtils.calcDistance(route, 1.0, 1.0, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1400.0, RouteUtils.calcDistanceExcludingStartEndLink(route, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2000.0, RouteUtils.calcDistance(route, 1.0, 1.0, f.network), MatsimTestUtils.EPSILON); } @Test @@ -281,9 +281,9 @@ void testCalcDistance_sameStartEndRoute() { NetworkRoute route = RouteUtils.createLinkNetworkRouteImpl(f.linkIds[3], f.linkIds[3]); List> linkIds = new ArrayList>(); route.setLinkIds(f.linkIds[3], linkIds, f.linkIds[3]); - Assert.assertEquals(0.0, RouteUtils.calcDistanceExcludingStartEndLink(route, f.network), MatsimTestUtils.EPSILON); - Assert.assertEquals(0.0, RouteUtils.calcDistance(route, 1.0, 1.0, f.network), MatsimTestUtils.EPSILON); - Assert.assertEquals(400.0, RouteUtils.calcDistance(route, 0.0, 1.0, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, RouteUtils.calcDistanceExcludingStartEndLink(route, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, RouteUtils.calcDistance(route, 1.0, 1.0, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(400.0, RouteUtils.calcDistance(route, 0.0, 1.0, f.network), MatsimTestUtils.EPSILON); } @Test @@ -298,8 +298,8 @@ void testCalcDistance_subsequentStartEndRoute() { NetworkRoute route = RouteUtils.createLinkNetworkRouteImpl(f.linkIds[2], f.linkIds[3]); List> linkIds = new ArrayList>(); route.setLinkIds(f.linkIds[2], linkIds, f.linkIds[3]); - Assert.assertEquals(0.0, RouteUtils.calcDistanceExcludingStartEndLink(route, f.network), MatsimTestUtils.EPSILON); - Assert.assertEquals(400.0, RouteUtils.calcDistance(route, 1.0, 1.0, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(0.0, RouteUtils.calcDistanceExcludingStartEndLink(route, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(400.0, RouteUtils.calcDistance(route, 1.0, 1.0, f.network), MatsimTestUtils.EPSILON); } @Test @@ -315,8 +315,8 @@ void testCalcDistance_oneLinkRoute() { List> linkIds = new ArrayList>(); linkIds.add(f.linkIds[3]); route.setLinkIds(f.linkIds[2], linkIds, f.linkIds[4]); - Assert.assertEquals(400.0, RouteUtils.calcDistanceExcludingStartEndLink(route, f.network), MatsimTestUtils.EPSILON); - Assert.assertEquals(900.0, RouteUtils.calcDistance(route, 1.0, 1.0, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(400.0, RouteUtils.calcDistanceExcludingStartEndLink(route, f.network), MatsimTestUtils.EPSILON); + Assertions.assertEquals(900.0, RouteUtils.calcDistance(route, 1.0, 1.0, f.network), MatsimTestUtils.EPSILON); } private static class Fixture { diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java index b4048bb20f6..f7b918995f6 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/StringUtilsTest.java @@ -20,7 +20,7 @@ package org.matsim.core.utils.misc; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -47,9 +47,9 @@ void testExplode() { for (String test : testStrings) { String[] resultExplode = StringUtils.explode(test, ':'); String[] resultSplit = test.split(":"); - assertEquals("Different result lengths with test string \"" + test + "\"", resultSplit.length, resultExplode.length); + assertEquals(resultSplit.length, resultExplode.length, "Different result lengths with test string \"" + test + "\""); for (int i = 0; i < resultExplode.length; i++) { - assertEquals("Different result part " + i + " when testing string: \"" + test + "\"", resultSplit[i], resultExplode[i]); + assertEquals(resultSplit[i], resultExplode[i], "Different result part " + i + " when testing string: \"" + test + "\""); } } } @@ -64,9 +64,9 @@ void testExplodeLimit() { for (String test : testStrings) { String[] resultExplode = StringUtils.explode(test, ':', 3); String[] resultSplit = test.split(":", 3); - assertEquals("Different result lengths with test string \"" + test + "\"", resultSplit.length, resultExplode.length); + assertEquals(resultSplit.length, resultExplode.length, "Different result lengths with test string \"" + test + "\""); for (int i = 0; i < resultExplode.length; i++) { - assertEquals("Different result part " + i + " when testing string: \"" + test + "\"", resultSplit[i], resultExplode[i]); + assertEquals(resultSplit[i], resultExplode[i], "Different result part " + i + " when testing string: \"" + test + "\""); } } } diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/TimeTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/TimeTest.java index 1654c1330ba..9f8d3049d58 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/TimeTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/TimeTest.java @@ -20,8 +20,8 @@ package org.matsim.core.utils.misc; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.fail; import org.junit.jupiter.api.Test; diff --git a/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java b/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java index 51722441ce6..d771d585de9 100644 --- a/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/timing/TimeInterpretationTest.java @@ -20,11 +20,11 @@ package org.matsim.core.utils.timing; -import static org.junit.Assert.assertEquals; - import java.util.List; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; diff --git a/matsim/src/test/java/org/matsim/counts/CountTest.java b/matsim/src/test/java/org/matsim/counts/CountTest.java index 7b5194b49c9..641e9dd4c73 100644 --- a/matsim/src/test/java/org/matsim/counts/CountTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountTest.java @@ -20,11 +20,11 @@ package org.matsim.counts; -import static org.junit.Assert.assertTrue; - import java.util.Iterator; import org.junit.Before; + +import static org.junit.jupiter.api.Assertions.assertTrue; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -47,15 +47,15 @@ public void setUp() throws Exception { void testCreateVolume() { Count count = counts.createAndAddCount(Id.create(0, Link.class), "1"); Volume volume = count.createVolume(1, 100.0); - assertTrue("Creation and initialization of volume failed", volume.getHourOfDayStartingWithOne()==1); - assertTrue("Creation and initialization of volume failed", volume.getValue()==100.0); + assertTrue(volume.getHourOfDayStartingWithOne()==1, "Creation and initialization of volume failed"); + assertTrue(volume.getValue()==100.0, "Creation and initialization of volume failed"); } @Test void testGetVolume() { Count count = counts.createAndAddCount(Id.create(0, Link.class), "1"); count.createVolume(1, 100.0); - assertTrue("Getting volume failed", count.getVolume(1).getValue() == 100.0); + assertTrue(count.getVolume(1).getValue() == 100.0, "Getting volume failed"); } @Test @@ -66,7 +66,7 @@ void testGetVolumes() { Iterator vol_it = count.getVolumes().values().iterator(); while (vol_it.hasNext()) { Volume v = vol_it.next(); - assertTrue("Getting volumes failed", v.getValue() == 100.0); + assertTrue(v.getValue() == 100.0, "Getting volumes failed"); } } diff --git a/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java b/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java index 7e652c0e25a..8c65712e935 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsComparisonAlgorithmTest.java @@ -20,11 +20,11 @@ package org.matsim.counts; -import static org.junit.Assert.assertEquals; - import java.util.List; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.counts.algorithms.CountsComparisonAlgorithm; import org.matsim.testcases.MatsimTestUtils; @@ -47,7 +47,7 @@ void testCompare() { int cnt=0; for (CountSimComparison csc : csc_list) { - assertEquals("Wrong sim value set", 2*cnt, csc.getSimulationValue(), 0.0); + assertEquals(2*cnt, csc.getSimulationValue(), 0.0, "Wrong sim value set"); cnt++; cnt=cnt%24; }//while @@ -63,7 +63,7 @@ void testDistanceFilter() { cca.run(); List csc_list = cca.getComparison(); - assertEquals("Distance filter not working", 0, csc_list.size()); + assertEquals(0, csc_list.size(), "Distance filter not working"); } } diff --git a/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java b/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java index 9327948fec4..db2a0498c3e 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsControlerListenerTest.java @@ -26,7 +26,7 @@ import jakarta.inject.Inject; import jakarta.inject.Singleton; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -68,184 +68,184 @@ void testUseVolumesOfIteration() { CountsControlerListener ccl = new CountsControlerListener(config.global(), scenario.getNetwork(), config.controller(), config.counts(), null, null, null); // test defaults - Assert.assertEquals(10, config.counts().getWriteCountsInterval()); - Assert.assertEquals(5, config.counts().getAverageCountsOverIterations()); + Assertions.assertEquals(10, config.counts().getWriteCountsInterval()); + Assertions.assertEquals(5, config.counts().getAverageCountsOverIterations()); // now the real tests - Assert.assertFalse(ccl.useVolumesOfIteration(0, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(1, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(2, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(3, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(4, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(5, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(6, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(7, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(8, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(9, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(10, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(11, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(12, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(13, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(14, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(15, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(16, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(17, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(18, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(19, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(20, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(21, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(0, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(1, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(2, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(3, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(4, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(5, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(6, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(7, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(8, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(9, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(10, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(11, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(12, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(13, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(14, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(15, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(16, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(17, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(18, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(19, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(20, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(21, 0)); // change some values config.counts().setWriteCountsInterval(8); config.counts().setAverageCountsOverIterations(2); - Assert.assertFalse(ccl.useVolumesOfIteration(0, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(1, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(2, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(3, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(4, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(5, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(6, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(7, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(8, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(9, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(10, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(11, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(12, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(13, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(14, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(15, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(16, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(17, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(18, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(19, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(20, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(21, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(0, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(1, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(2, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(3, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(4, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(5, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(6, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(7, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(8, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(9, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(10, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(11, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(12, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(13, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(14, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(15, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(16, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(17, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(18, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(19, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(20, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(21, 0)); // change some values: averaging = 1 config.counts().setWriteCountsInterval(5); config.counts().setAverageCountsOverIterations(1); - Assert.assertTrue(ccl.useVolumesOfIteration(0, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(1, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(2, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(3, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(4, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(5, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(6, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(7, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(8, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(9, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(10, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(11, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(12, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(13, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(14, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(15, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(16, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(17, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(18, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(19, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(20, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(21, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(0, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(1, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(2, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(3, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(4, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(5, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(6, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(7, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(8, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(9, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(10, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(11, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(12, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(13, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(14, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(15, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(16, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(17, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(18, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(19, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(20, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(21, 0)); // change some values: averaging = 0 config.counts().setWriteCountsInterval(5); config.counts().setAverageCountsOverIterations(0); - Assert.assertTrue(ccl.useVolumesOfIteration(0, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(1, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(2, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(3, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(4, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(5, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(6, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(7, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(8, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(9, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(10, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(11, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(12, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(13, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(14, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(15, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(16, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(17, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(18, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(19, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(20, 0)); - Assert.assertFalse(ccl.useVolumesOfIteration(21, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(0, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(1, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(2, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(3, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(4, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(5, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(6, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(7, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(8, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(9, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(10, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(11, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(12, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(13, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(14, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(15, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(16, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(17, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(18, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(19, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(20, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(21, 0)); // change some values: interval equal averaging config.counts().setWriteCountsInterval(5); config.counts().setAverageCountsOverIterations(5); - Assert.assertFalse(ccl.useVolumesOfIteration(0, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(1, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(2, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(3, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(4, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(5, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(6, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(7, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(8, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(9, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(10, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(11, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(12, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(13, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(14, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(15, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(16, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(17, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(18, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(19, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(20, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(21, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(0, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(1, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(2, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(3, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(4, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(5, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(6, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(7, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(8, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(9, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(10, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(11, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(12, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(13, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(14, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(15, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(16, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(17, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(18, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(19, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(20, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(21, 0)); // change some values: averaging > interval config.counts().setWriteCountsInterval(5); config.counts().setAverageCountsOverIterations(6); - Assert.assertFalse(ccl.useVolumesOfIteration(0, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(1, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(2, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(3, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(4, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(5, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(6, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(7, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(8, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(9, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(10, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(11, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(12, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(13, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(14, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(15, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(16, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(17, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(18, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(19, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(20, 0)); - Assert.assertTrue(ccl.useVolumesOfIteration(21, 0)); + Assertions.assertFalse(ccl.useVolumesOfIteration(0, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(1, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(2, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(3, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(4, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(5, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(6, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(7, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(8, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(9, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(10, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(11, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(12, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(13, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(14, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(15, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(16, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(17, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(18, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(19, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(20, 0)); + Assertions.assertTrue(ccl.useVolumesOfIteration(21, 0)); // change some values: different firstIteration config.counts().setWriteCountsInterval(5); config.counts().setAverageCountsOverIterations(3); - Assert.assertFalse(ccl.useVolumesOfIteration(4, 4)); - Assert.assertFalse(ccl.useVolumesOfIteration(5, 4)); - Assert.assertFalse(ccl.useVolumesOfIteration(6, 4)); - Assert.assertFalse(ccl.useVolumesOfIteration(7, 4)); - Assert.assertTrue(ccl.useVolumesOfIteration(8, 4)); - Assert.assertTrue(ccl.useVolumesOfIteration(9, 4)); - Assert.assertTrue(ccl.useVolumesOfIteration(10, 4)); - Assert.assertFalse(ccl.useVolumesOfIteration(11, 4)); - Assert.assertFalse(ccl.useVolumesOfIteration(12, 4)); - Assert.assertTrue(ccl.useVolumesOfIteration(13, 4)); - Assert.assertTrue(ccl.useVolumesOfIteration(14, 4)); - Assert.assertTrue(ccl.useVolumesOfIteration(15, 4)); - Assert.assertFalse(ccl.useVolumesOfIteration(16, 4)); - Assert.assertFalse(ccl.useVolumesOfIteration(17, 4)); - Assert.assertTrue(ccl.useVolumesOfIteration(18, 4)); - Assert.assertTrue(ccl.useVolumesOfIteration(19, 4)); - Assert.assertTrue(ccl.useVolumesOfIteration(20, 4)); - Assert.assertFalse(ccl.useVolumesOfIteration(21, 4)); + Assertions.assertFalse(ccl.useVolumesOfIteration(4, 4)); + Assertions.assertFalse(ccl.useVolumesOfIteration(5, 4)); + Assertions.assertFalse(ccl.useVolumesOfIteration(6, 4)); + Assertions.assertFalse(ccl.useVolumesOfIteration(7, 4)); + Assertions.assertTrue(ccl.useVolumesOfIteration(8, 4)); + Assertions.assertTrue(ccl.useVolumesOfIteration(9, 4)); + Assertions.assertTrue(ccl.useVolumesOfIteration(10, 4)); + Assertions.assertFalse(ccl.useVolumesOfIteration(11, 4)); + Assertions.assertFalse(ccl.useVolumesOfIteration(12, 4)); + Assertions.assertTrue(ccl.useVolumesOfIteration(13, 4)); + Assertions.assertTrue(ccl.useVolumesOfIteration(14, 4)); + Assertions.assertTrue(ccl.useVolumesOfIteration(15, 4)); + Assertions.assertFalse(ccl.useVolumesOfIteration(16, 4)); + Assertions.assertFalse(ccl.useVolumesOfIteration(17, 4)); + Assertions.assertTrue(ccl.useVolumesOfIteration(18, 4)); + Assertions.assertTrue(ccl.useVolumesOfIteration(19, 4)); + Assertions.assertTrue(ccl.useVolumesOfIteration(20, 4)); + Assertions.assertFalse(ccl.useVolumesOfIteration(21, 4)); } @Test @@ -274,14 +274,14 @@ public void install() { config.controller().setWritePlansInterval(0); controler.run(); - Assert.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.0/0.countscompare.txt").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.1/1.countscompare.txt").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.2/2.countscompare.txt").exists()); - Assert.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompare.txt").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.4/4.countscompare.txt").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.5/5.countscompare.txt").exists()); - Assert.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.6/6.countscompare.txt").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.7/7.countscompare.txt").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.0/0.countscompare.txt").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.1/1.countscompare.txt").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.2/2.countscompare.txt").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompare.txt").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.4/4.countscompare.txt").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.5/5.countscompare.txt").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.6/6.countscompare.txt").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.7/7.countscompare.txt").exists()); } @Test @@ -312,17 +312,17 @@ public void install() { config.controller().setWritePlansInterval(0); controler.run(); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.0/0.countscompareAWTV.txt").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.1/1.countscompareAWTV.txt").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.2/2.countscompareAWTV.txt").exists()); - Assert.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.4/4.countscompareAWTV.txt").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.5/5.countscompareAWTV.txt").exists()); - Assert.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.6/6.countscompareAWTV.txt").exists()); - Assert.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.7/7.countscompareAWTV.txt").exists()); - - Assert.assertEquals(3.5, getVolume(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt"), 1e-8); - Assert.assertEquals(6.5, getVolume(config.controller().getOutputDirectory() + "ITERS/it.6/6.countscompareAWTV.txt"), 1e-8); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.0/0.countscompareAWTV.txt").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.1/1.countscompareAWTV.txt").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.2/2.countscompareAWTV.txt").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.4/4.countscompareAWTV.txt").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.5/5.countscompareAWTV.txt").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory() + "ITERS/it.6/6.countscompareAWTV.txt").exists()); + Assertions.assertFalse(new File(config.controller().getOutputDirectory() + "ITERS/it.7/7.countscompareAWTV.txt").exists()); + + Assertions.assertEquals(3.5, getVolume(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt"), 1e-8); + Assertions.assertEquals(6.5, getVolume(config.controller().getOutputDirectory() + "ITERS/it.6/6.countscompareAWTV.txt"), 1e-8); } @Test @@ -342,25 +342,25 @@ void testFilterAnalyzedModes() throws IOException { config.controller().setLastIteration(3); createAndRunControler(config); - Assert.assertEquals(150, getVolume(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt"), 1e-8); + Assertions.assertEquals(150, getVolume(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt"), 1e-8); // enable modes filtering and count only car cConfig.setAnalyzedModes(TransportMode.car); cConfig.setFilterModes(true); createAndRunControler(config); - Assert.assertEquals(100, getVolume(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt"), 1e-8); + Assertions.assertEquals(100, getVolume(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt"), 1e-8); // enable modes filtering and count only walk cConfig.setAnalyzedModes(TransportMode.walk); cConfig.setFilterModes(true); createAndRunControler(config); - Assert.assertEquals(50, getVolume(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt"), 1e-8); + Assertions.assertEquals(50, getVolume(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt"), 1e-8); // enable modes filtering and count only bike cConfig.setAnalyzedModes(TransportMode.bike); cConfig.setFilterModes(true); createAndRunControler(config); - Assert.assertEquals(0, getVolume(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt"), 1e-8); + Assertions.assertEquals(0, getVolume(config.controller().getOutputDirectory() + "ITERS/it.3/3.countscompareAWTV.txt"), 1e-8); } diff --git a/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java b/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java index 9b517b8e4e1..bdbb1f2f297 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsErrorGraphTest.java @@ -20,7 +20,7 @@ package org.matsim.counts; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertNotNull; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -39,6 +39,6 @@ void testCreateChart() { fixture.setUp(); BoxPlotErrorGraph eg = new BoxPlotErrorGraph(fixture.ceateCountSimCompList(), 1, "testCreateChart", "testCreateChart"); - assertNotNull("No graph is created", eg.createChart(0)); + assertNotNull(eg.createChart(0), "No graph is created"); } } diff --git a/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java b/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java index 853f4d548e7..27a8bc1a51c 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsHtmlAndGraphsWriterTest.java @@ -20,7 +20,7 @@ package org.matsim.counts; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertTrue; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java b/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java index b8dc6aecacb..9c8e27e0039 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsLoadCurveGraphTest.java @@ -20,7 +20,7 @@ package org.matsim.counts; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertNotNull; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -39,6 +39,6 @@ void testCreateChart() { fixture.setUp(); CountsLoadCurveGraph eg = new CountsLoadCurveGraph(fixture.ceateCountSimCompList(), 1, "testCreateChart"); - assertNotNull("No graph is created", eg.createChart(0)); + assertNotNull(eg.createChart(0), "No graph is created"); } } diff --git a/matsim/src/test/java/org/matsim/counts/CountsParserTest.java b/matsim/src/test/java/org/matsim/counts/CountsParserTest.java index 5dabdc4ac08..f1d180a0fab 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsParserTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsParserTest.java @@ -20,7 +20,7 @@ package org.matsim.counts; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -44,9 +44,9 @@ void testSEElementCounts() throws SAXException { reader.startElement("", "counts", "counts", attributeFactory.createCountsAttributes()); - assertEquals("Counts attribute setting failed", "testName", counts.getName()); - assertEquals("Counts attribute setting failed", "testDesc", counts.getDescription()); - assertEquals("Counts attribute setting failed", 2000, counts.getYear()); + assertEquals("testName", counts.getName(), "Counts attribute setting failed"); + assertEquals("testDesc", counts.getDescription(), "Counts attribute setting failed"); + assertEquals(2000, counts.getYear(), "Counts attribute setting failed"); try { reader.endElement("", "counts", "counts"); } catch (SAXException e) { @@ -65,8 +65,8 @@ void testSEElementCountWithoutCoords() throws SAXException { reader.startElement("", "count", "count", attributeFactory.createCountAttributes()); Count count = counts.getCount(Id.create(1, Link.class)); - assertEquals("Count attribute setting failed", "testNr", count.getCsLabel()); - assertNull("Count attributes x,y should not be set", count.getCoord()); + assertEquals("testNr", count.getCsLabel(), "Count attribute setting failed"); + assertNull(count.getCoord(), "Count attributes x,y should not be set"); reader.endElement("", "count", "count"); reader.endElement("", "counts", "counts"); @@ -83,9 +83,9 @@ void testSEElementCountWithCoords() throws SAXException { reader.startElement("", "count", "count", attributeFactory.createCountAttributesWithCoords()); Count count = counts.getCount(Id.create(1, Link.class)); - assertNotNull("Count attribute x,y setting failed", count.getCoord()); - assertEquals("Count attribute x setting failed", 123.456, count.getCoord().getX(), MatsimTestUtils.EPSILON); - assertEquals("Count attribute y setting failed", 987.654, count.getCoord().getY(), MatsimTestUtils.EPSILON); + assertNotNull(count.getCoord(), "Count attribute x,y setting failed"); + assertEquals(123.456, count.getCoord().getX(), MatsimTestUtils.EPSILON, "Count attribute x setting failed"); + assertEquals(987.654, count.getCoord().getY(), MatsimTestUtils.EPSILON, "Count attribute y setting failed"); reader.endElement("", "count", "count"); reader.endElement("", "counts", "counts"); @@ -102,7 +102,7 @@ void testSEElementVolume() throws SAXException { reader.startElement("", "count", "count", attributeFactory.createCountAttributes()); reader.startElement("", "volume", "volume", attributeFactory.createVolumeAttributes()); - assertEquals("Volume attribute setting failed", 100.0, counts.getCount(Id.create(1, Link.class)).getVolume(1).getValue(), MatsimTestUtils.EPSILON); + assertEquals(100.0, counts.getCount(Id.create(1, Link.class)).getVolume(1).getValue(), MatsimTestUtils.EPSILON, "Volume attribute setting failed"); reader.endElement("", "volume", "volume"); reader.endElement("", "count", "count"); diff --git a/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java b/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java index 6c7e2a9e76b..06fba65ea32 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsParserWriterTest.java @@ -26,7 +26,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -54,21 +54,21 @@ void testParserWriter() { // test if required fields of schema are filled out: // Counts: - Assert.assertNotNull(fixture.counts.getCounts()); - Assert.assertTrue(fixture.counts.getYear()>2000); - Assert.assertNotNull(fixture.counts.getName()); + Assertions.assertNotNull(fixture.counts.getCounts()); + Assertions.assertTrue(fixture.counts.getYear()>2000); + Assertions.assertNotNull(fixture.counts.getName()); // Count & Volume Iterator c_it = fixture.counts.getCounts().values().iterator(); while (c_it.hasNext()) { Count c = c_it.next(); - Assert.assertNotNull(c.getId()); + Assertions.assertNotNull(c.getId()); Iterator vol_it = c.getVolumes().values().iterator(); while (vol_it.hasNext()) { Volume v = vol_it.next(); - Assert.assertTrue(v.getHourOfDayStartingWithOne()>0); - Assert.assertTrue(v.getValue()>=0.0); + Assertions.assertTrue(v.getHourOfDayStartingWithOne()>0); + Assertions.assertTrue(v.getValue()>=0.0); }//while }//while @@ -80,7 +80,7 @@ void testParserWriter() { CountsWriter counts_writer = new CountsWriter(fixture.counts); counts_writer.write(filename); File f = new File(filename); - Assert.assertTrue(f.length() > 0.0); + Assertions.assertTrue(f.length() > 0.0); } /** @@ -95,12 +95,12 @@ void testWriteParse_nameIsNull() throws SAXException, ParserConfigurationExcepti CountsFixture f = new CountsFixture(); f.setUp(); f.counts.setName(null); - Assert.assertNull(f.counts.getName()); + Assertions.assertNull(f.counts.getName()); String filename = this.utils.getOutputDirectory() + "counts.xml"; new CountsWriterV1(f.counts).write(filename); Counts counts2 = new Counts(); new CountsReaderMatsimV1(counts2).readFile(filename); - Assert.assertEquals("", counts2.getName()); + Assertions.assertEquals("", counts2.getName()); } } diff --git a/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java b/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java index d4214f2485f..c54ed8961c0 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java +++ b/matsim/src/test/java/org/matsim/counts/CountsReaderHandlerImplV1Test.java @@ -20,7 +20,7 @@ package org.matsim.counts; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -41,9 +41,9 @@ void testSECounts() { CountsReaderMatsimV1 reader = new CountsReaderMatsimV1(counts); reader.startTag("counts", attributeFactory.createCountsAttributes(), null); - assertEquals("Counts attribute setting failed", "testName", counts.getName()); - assertEquals("Counts attribute setting failed", "testDesc", counts.getDescription()); - assertEquals("Counts attribute setting failed", 2000, counts.getYear()); + assertEquals("testName", counts.getName(), "Counts attribute setting failed"); + assertEquals("testDesc", counts.getDescription(), "Counts attribute setting failed"); + assertEquals(2000, counts.getYear(), "Counts attribute setting failed"); } @Test @@ -55,7 +55,7 @@ void testSECount() { reader.startTag("counts", attributeFactory.createCountsAttributes(), null); reader.startTag("count", attributeFactory.createCountAttributes(), null); - assertEquals("Count attribute setting failed", "testNr", counts.getCount(Id.create(1, Link.class)).getCsLabel()); + assertEquals("testNr", counts.getCount(Id.create(1, Link.class)).getCsLabel(), "Count attribute setting failed"); } @Test @@ -67,6 +67,6 @@ void testSEVolume() { reader.startTag("count", attributeFactory.createCountAttributes(), null); reader.startTag("volume", attributeFactory.createVolumeAttributes(), null); - assertEquals("Volume attribute setting failed", 100.0, counts.getCount(Id.create(1, Link.class)).getVolume(1).getValue(), MatsimTestUtils.EPSILON); + assertEquals(100.0, counts.getCount(Id.create(1, Link.class)).getVolume(1).getValue(), MatsimTestUtils.EPSILON, "Volume attribute setting failed"); } } diff --git a/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java b/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java index 860767a6553..6badf9a2391 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsReprojectionIOTest.java @@ -23,7 +23,7 @@ import com.google.inject.Key; import com.google.inject.TypeLiteral; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -38,7 +38,7 @@ import org.matsim.core.utils.geometry.transformations.TransformationFactory; import org.matsim.testcases.MatsimTestUtils; - /** + /** * @author thibautd */ public class CountsReprojectionIOTest { @@ -108,16 +108,16 @@ void testWithControlerAndConfigParameters() { final Coord originalCoord = originalCounts.getCount( id ).getCoord(); final Coord internalCoord = internalCounts.getCount( id ).getCoord(); - Assert.assertNotEquals( - "No coordinates transform performed!", + Assertions.assertNotEquals( originalCoord.getX(), internalCoord.getX(), - epsilon ); - Assert.assertNotEquals( - "No coordinates transform performed!", + epsilon, + "No coordinates transform performed!" ); + Assertions.assertNotEquals( originalCoord.getY(), internalCoord.getY(), - epsilon ); + epsilon, + "No coordinates transform performed!" ); } @@ -128,41 +128,41 @@ void testWithControlerAndConfigParameters() { final Coord originalCoord = originalCounts.getCount( id ).getCoord(); final Coord dumpedCoord = dumpedCounts.getCount( id ).getCoord(); - Assert.assertEquals( - "coordinates were not reprojected for dump", + Assertions.assertEquals( originalCoord.getX(), dumpedCoord.getX(), - epsilon ); - Assert.assertEquals( - "coordinates were not reprojected for dump", + epsilon, + "coordinates were not reprojected for dump" ); + Assertions.assertEquals( originalCoord.getY(), dumpedCoord.getY(), - epsilon ); + epsilon, + "coordinates were not reprojected for dump" ); } } private void assertCountsAreReprojectedCorrectly( Counts originalCounts, Counts reprojectedCounts) { - Assert.assertEquals( - "unexpected number of counts", + Assertions.assertEquals( originalCounts.getCounts().size(), - reprojectedCounts.getCounts().size() ); + reprojectedCounts.getCounts().size(), + "unexpected number of counts" ); for ( Id id : originalCounts.getCounts().keySet() ) { final Coord original = originalCounts.getCount( id ).getCoord(); final Coord transformed = reprojectedCounts.getCount( id ).getCoord(); - Assert.assertEquals( - "wrong reprojected X value", + Assertions.assertEquals( original.getX() + 1000 , transformed.getX(), - MatsimTestUtils.EPSILON ); - Assert.assertEquals( - "wrong reprojected Y value", + MatsimTestUtils.EPSILON, + "wrong reprojected X value" ); + Assertions.assertEquals( original.getY() + 1000 , transformed.getY(), - MatsimTestUtils.EPSILON ); + MatsimTestUtils.EPSILON, + "wrong reprojected Y value" ); } } diff --git a/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java b/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java index 2df385e8ab3..c9d89bb8a8c 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsSimRealPerHourGraphTest.java @@ -20,7 +20,7 @@ package org.matsim.counts; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertNotNull; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -39,6 +39,6 @@ void testCreateChart() { fixture.setUp(); CountsSimRealPerHourGraph eg = new CountsSimRealPerHourGraph(fixture.ceateCountSimCompList(), 1, "testCreateChart"); - assertNotNull("No graph is created", eg.createChart(0)); + assertNotNull(eg.createChart(0), "No graph is created"); } } diff --git a/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java b/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java index f373db66b6f..4fb0287175d 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsTableWriterTest.java @@ -20,12 +20,12 @@ package org.matsim.counts; -import static org.junit.Assert.assertTrue; - import java.io.File; import java.util.Locale; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertTrue; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.counts.algorithms.CountSimComparisonTableWriter; import org.matsim.counts.algorithms.CountsComparisonAlgorithm; diff --git a/matsim/src/test/java/org/matsim/counts/CountsTest.java b/matsim/src/test/java/org/matsim/counts/CountsTest.java index f8ee0015e52..3ce4092c295 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountsTest.java @@ -20,7 +20,7 @@ package org.matsim.counts; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -38,6 +38,6 @@ public class CountsTest { void testGetCounts() { final Counts counts = new Counts(); counts.createAndAddCount(Id.create(0, Link.class), "1"); - assertEquals("Getting counts failed", 1, counts.getCounts().size()); + assertEquals(1, counts.getCounts().size(), "Getting counts failed"); } } diff --git a/matsim/src/test/java/org/matsim/counts/CountsV2Test.java b/matsim/src/test/java/org/matsim/counts/CountsV2Test.java index 3ee67c26678..85c211033ee 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsV2Test.java +++ b/matsim/src/test/java/org/matsim/counts/CountsV2Test.java @@ -1,7 +1,7 @@ package org.matsim.counts; import org.assertj.core.api.Assertions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -66,10 +66,10 @@ void test_reader_writer() throws IOException { Assertions.assertThatNoException().isThrownBy(() -> reader.readFile(filename)); Map, MeasurementLocation> countMap = counts.getMeasureLocations(); - Assert.assertEquals(21, countMap.size()); + Assertions.assertEquals(21, countMap.size()); boolean onlyDailyValues = countMap.get(Id.create("12", Link.class)).getMeasurableForMode(Measurable.VOLUMES, TransportMode.car).getInterval() == 24 * 60; - Assert.assertFalse(onlyDailyValues); + Assertions.assertFalse(onlyDailyValues); assertThat(dummyCounts.getMeasurableTypes()) .isEqualTo(counts.getMeasurableTypes()); diff --git a/matsim/src/test/java/org/matsim/counts/MatsimCountsIOTest.java b/matsim/src/test/java/org/matsim/counts/MatsimCountsIOTest.java index 6f2da37f269..e1b45a3328a 100644 --- a/matsim/src/test/java/org/matsim/counts/MatsimCountsIOTest.java +++ b/matsim/src/test/java/org/matsim/counts/MatsimCountsIOTest.java @@ -21,14 +21,14 @@ package org.matsim.counts; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.nio.charset.StandardCharsets; - /** + /** * @author mrieser / Simunto GmbH */ public class MatsimCountsIOTest { @@ -77,7 +77,7 @@ void testReading_year0() { MatsimCountsReader reader = new MatsimCountsReader(counts); ByteArrayInputStream stream = new ByteArrayInputStream(xml.getBytes(StandardCharsets.UTF_8)); reader.parse(stream); - Assert.assertEquals(1, counts.getCounts().size()); + Assertions.assertEquals(1, counts.getCounts().size()); } /** @@ -124,7 +124,7 @@ void testReading_year1padded() { MatsimCountsReader reader = new MatsimCountsReader(counts); ByteArrayInputStream stream = new ByteArrayInputStream(xml.getBytes(StandardCharsets.UTF_8)); reader.parse(stream); - Assert.assertEquals(1, counts.getCounts().size()); + Assertions.assertEquals(1, counts.getCounts().size()); } @Test diff --git a/matsim/src/test/java/org/matsim/counts/OutputDelegateTest.java b/matsim/src/test/java/org/matsim/counts/OutputDelegateTest.java index c1c5e39c014..cbc377b6c15 100644 --- a/matsim/src/test/java/org/matsim/counts/OutputDelegateTest.java +++ b/matsim/src/test/java/org/matsim/counts/OutputDelegateTest.java @@ -20,8 +20,8 @@ package org.matsim.counts; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.io.File; import java.util.List; @@ -57,13 +57,13 @@ void testOutputHtml() { new File(utils.getOutputDirectory() + "graphs").mkdir(); OutputDelegate outputDelegate=new OutputDelegate(utils.getOutputDirectory() + "graphs/"); outputDelegate.addSection(new Section("testOutPutAll")); - assertNotNull("No graph was created", sg.createChart(0)); + assertNotNull(sg.createChart(0), "No graph was created"); outputDelegate.addCountsGraph(sg); outputDelegate.outputHtml(); String filename = utils.getOutputDirectory() + "graphs/png/" + sg.getFilename() +".png"; File fPng = new File(filename); - assertTrue("The png output file " + filename + " doesn't exist", fPng.exists()); - assertTrue("The png output file " + filename + " is empty", fPng.length()>0.0); + assertTrue(fPng.exists(), "The png output file " + filename + " doesn't exist"); + assertTrue(fPng.length()>0.0, "The png output file " + filename + " is empty"); } } diff --git a/matsim/src/test/java/org/matsim/examples/EquilTest.java b/matsim/src/test/java/org/matsim/examples/EquilTest.java index caeaba1786c..ded2c6a9777 100644 --- a/matsim/src/test/java/org/matsim/examples/EquilTest.java +++ b/matsim/src/test/java/org/matsim/examples/EquilTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.runner.RunWith; @@ -102,6 +102,6 @@ void testEquil() { writer.closeFile(); final EventsFileComparator.Result result = new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( referenceFileName , eventsFileName ); - Assert.assertEquals("different event files.", EventsFileComparator.Result.FILES_ARE_EQUAL, result ); + Assertions.assertEquals(EventsFileComparator.Result.FILES_ARE_EQUAL, result, "different event files." ); } } diff --git a/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java b/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java index 5c3a02d326b..89237ec5b1a 100644 --- a/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java +++ b/matsim/src/test/java/org/matsim/examples/OnePercentBerlin10sIT.java @@ -20,7 +20,7 @@ package org.matsim.examples; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -92,8 +92,9 @@ void testOnePercent10sQSim() { writer.closeFile(); System.out.println("reffile: " + referenceEventsFileName); - assertEquals( "different event files", EventsFileComparator.Result.FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( referenceEventsFileName, eventsFileName ) ); + assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( referenceEventsFileName, eventsFileName ), + "different event files" ); } @@ -136,8 +137,9 @@ void testOnePercent10sQSimTryEndTimeThenDuration() { writer.closeFile(); - assertEquals( "different event files", EventsFileComparator.Result.FILES_ARE_EQUAL, - new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( referenceEventsFileName, eventsFileName ) ); + assertEquals( EventsFileComparator.Result.FILES_ARE_EQUAL, + new EventsFileComparator().setIgnoringCoordinates( true ).runComparison( referenceEventsFileName, eventsFileName ), + "different event files" ); } diff --git a/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java b/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java index 3b7f7fd87ca..f9eb2d4f608 100644 --- a/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java +++ b/matsim/src/test/java/org/matsim/examples/PtTutorialIT.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -71,14 +71,14 @@ void ensure_tutorial_runs() throws MalformedURLException { } }); controler.run(); - Assert.assertEquals( 1867, enterVehicleEventCounter.getCnt() ); + Assertions.assertEquals( 1867, enterVehicleEventCounter.getCnt() ); } catch (Exception e) { log.error(e.getMessage(), e); - Assert.fail("There shouldn't be any exception, but there was ... :-("); + Assertions.fail("There shouldn't be any exception, but there was ... :-("); } final String it1Plans = "ITERS/it.1/1.plans.xml.gz"; - Assert.assertTrue(new File(config.controller().getOutputDirectory(), it1Plans).exists()); - Assert.assertTrue(new File(config.controller().getOutputDirectory(), "output_config.xml").exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory(), it1Plans).exists()); + Assertions.assertTrue(new File(config.controller().getOutputDirectory(), "output_config.xml").exists()); log.info( Controler.DIVIDER ) ; log.info( Controler.DIVIDER ) ; @@ -106,10 +106,10 @@ void ensure_tutorial_runs() throws MalformedURLException { }); controler.run(); System.err.println( " cnt=" + enterVehicleEventCounter.getCnt() ) ; - Assert.assertEquals( 1867, enterVehicleEventCounter.getCnt() ); + Assertions.assertEquals( 1867, enterVehicleEventCounter.getCnt() ); } catch (Exception e) { log.error(e.getMessage(), e); - Assert.fail("There shouldn't be any exception, but there was ... :-("); + Assertions.fail("There shouldn't be any exception, but there was ... :-("); } } @@ -144,13 +144,11 @@ private static final class StageActivityDurationChecker implements ActivityStart @Override public void handleEvent( ActivityEndEvent endEvent ) { if (StageActivityTypeIdentifier.isStageActivity(endEvent.getActType()) ) { ActivityStartEvent startEvent = personId2ActivityStartEvent.get(endEvent.getPersonId()); - Assert.assertEquals("Stage activity should have same type in current ActivityEndEvent and in last ActivityStartEvent, but did not. PersonId " + + Assertions.assertEquals(startEvent.getActType(), endEvent.getActType(), "Stage activity should have same type in current ActivityEndEvent and in last ActivityStartEvent, but did not. PersonId " + endEvent.getPersonId() + ", ActivityStartEvent type: " + startEvent.getActType() + ", ActivityEndEvent type: " + endEvent.getActType() + - ", start time: " + startEvent.getTime() + ", end time: " + endEvent.getTime(), - startEvent.getActType(), endEvent.getActType()); - Assert.assertEquals("Stage activity should have a duration of 0 seconds, but did not. PersonId " + - endEvent.getPersonId() + ", start time: " + startEvent.getTime() + ", end time: " + endEvent.getTime(), - 0.0, startEvent.getTime() - endEvent.getTime(), MatsimTestUtils.EPSILON); + ", start time: " + startEvent.getTime() + ", end time: " + endEvent.getTime()); + Assertions.assertEquals(0.0, startEvent.getTime() - endEvent.getTime(), MatsimTestUtils.EPSILON, "Stage activity should have a duration of 0 seconds, but did not. PersonId " + + endEvent.getPersonId() + ", start time: " + startEvent.getTime() + ", end time: " + endEvent.getTime()); personId2ActivityStartEvent.remove(endEvent.getPersonId()); } } diff --git a/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java b/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java index a2ef3a5a8ec..c8b41781421 100644 --- a/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java +++ b/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java @@ -21,7 +21,7 @@ import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.runner.RunWith; @@ -206,10 +206,10 @@ void test_PtScoringLineswitch() { System.out.println(" score: " + pp.getSelectedPlan().getScore() ) ; if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ - Assert.assertEquals(-21.280962467387187, pp.getSelectedPlan().getScore(), MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals(-21.280962467387187, pp.getSelectedPlan().getScore(), MatsimTestUtils.EPSILON ) ; } else{ - Assert.assertEquals(27.468448990195423, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals(27.468448990195423, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; } } @@ -362,10 +362,10 @@ void test_PtScoringLineswitchAndPtConstant() { if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ // Assert.assertEquals(89.14608279715044, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; - Assert.assertEquals(-19.280962467387187, pp.getSelectedPlan().getScore(), MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals(-19.280962467387187, pp.getSelectedPlan().getScore(), MatsimTestUtils.EPSILON ) ; } else{ - Assert.assertEquals(29.468448990195423, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals(29.468448990195423, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; } } @@ -449,10 +449,10 @@ void test_PtScoring_Wait() { System.out.println("agent score: " + pp.getSelectedPlan().getScore() ) ; if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ - Assert.assertEquals(89.13108279715044, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals(89.13108279715044, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; } else{ - Assert.assertEquals(137.1310827971504, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals(137.1310827971504, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; } } @@ -531,10 +531,10 @@ void test_PtScoring() { System.out.println(" score: " + pp.getSelectedPlan().getScore() ) ; if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ - Assert.assertEquals(89.87441613048377, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals(89.87441613048377, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; } else{ - Assert.assertEquals(137.87441613048375, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; + Assertions.assertEquals(137.87441613048375, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; } diff --git a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesFactoryImplTest.java b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesFactoryImplTest.java index e5f8838a405..c016764df06 100644 --- a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesFactoryImplTest.java +++ b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesFactoryImplTest.java @@ -19,7 +19,7 @@ package org.matsim.facilities; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -34,9 +34,9 @@ void testCreateActivityFacility() { ActivityFacilitiesFactoryImpl factory = new ActivityFacilitiesFactoryImpl(); ActivityFacility facility = factory.createActivityFacility(Id.create(1980, ActivityFacility.class), new Coord((double) 5, (double) 11)); - Assert.assertEquals("1980", facility.getId().toString()); - Assert.assertEquals(5.0, facility.getCoord().getX(), 1e-9); - Assert.assertEquals(11.0, facility.getCoord().getY(), 1e-9); + Assertions.assertEquals("1980", facility.getId().toString()); + Assertions.assertEquals(5.0, facility.getCoord().getX(), 1e-9); + Assertions.assertEquals(11.0, facility.getCoord().getY(), 1e-9); } @Test @@ -44,8 +44,8 @@ void testCreateActivityOption() { ActivityFacilitiesFactoryImpl factory = new ActivityFacilitiesFactoryImpl(); ActivityOption option = factory.createActivityOption("leisure"); - Assert.assertEquals("leisure", option.getType()); - Assert.assertEquals(Integer.MAX_VALUE, option.getCapacity(), 1e-9); + Assertions.assertEquals("leisure", option.getType()); + Assertions.assertEquals(Integer.MAX_VALUE, option.getCapacity(), 1e-9); } } diff --git a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesImplTest.java b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesImplTest.java index 223c6e20898..284e73cfe79 100644 --- a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesImplTest.java +++ b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesImplTest.java @@ -19,7 +19,7 @@ package org.matsim.facilities; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -35,16 +35,16 @@ void testAddActivityFacility() { ActivityFacilitiesFactory factory = facilities.getFactory(); ActivityFacility facility1 = factory.createActivityFacility(Id.create(1, ActivityFacility.class), new Coord((double) 200, (double) 5000)); - Assert.assertEquals(0, facilities.getFacilities().size()); + Assertions.assertEquals(0, facilities.getFacilities().size()); facilities.addActivityFacility(facility1); - Assert.assertEquals(1, facilities.getFacilities().size()); + Assertions.assertEquals(1, facilities.getFacilities().size()); ActivityFacility facility2 = factory.createActivityFacility(Id.create(2, ActivityFacility.class), new Coord((double) 300, (double) 4000)); facilities.addActivityFacility(facility2); - Assert.assertEquals(2, facilities.getFacilities().size()); + Assertions.assertEquals(2, facilities.getFacilities().size()); } @Test @@ -54,18 +54,18 @@ void testAddActivityFacility_addingTwice() { ActivityFacility facility1 = factory.createActivityFacility(Id.create(1, ActivityFacility.class), new Coord((double) 200, (double) 5000)); ActivityFacility facility2 = factory.createActivityFacility(Id.create(2, ActivityFacility.class), new Coord((double) 300, (double) 4000)); - Assert.assertEquals(0, facilities.getFacilities().size()); + Assertions.assertEquals(0, facilities.getFacilities().size()); facilities.addActivityFacility(facility1); facilities.addActivityFacility(facility2); - Assert.assertEquals(2, facilities.getFacilities().size()); + Assertions.assertEquals(2, facilities.getFacilities().size()); try { facilities.addActivityFacility(facility1); - Assert.fail("Expected exception, got none."); + Assertions.fail("Expected exception, got none."); } catch (IllegalArgumentException expected) {} - Assert.assertEquals(2, facilities.getFacilities().size()); + Assertions.assertEquals(2, facilities.getFacilities().size()); } @Test @@ -75,16 +75,16 @@ void testAddActivityFacility_sameId() { ActivityFacility facility1 = factory.createActivityFacility(Id.create(1, ActivityFacility.class), new Coord((double) 200, (double) 5000)); ActivityFacility facility2 = factory.createActivityFacility(Id.create(1, ActivityFacility.class), new Coord((double) 300, (double) 4000)); - Assert.assertEquals(0, facilities.getFacilities().size()); + Assertions.assertEquals(0, facilities.getFacilities().size()); facilities.addActivityFacility(facility1); try { facilities.addActivityFacility(facility2); - Assert.fail("Expected exception, got none."); + Assertions.fail("Expected exception, got none."); } catch (IllegalArgumentException expected) {} - Assert.assertEquals(1, facilities.getFacilities().size()); - Assert.assertEquals(facility1, facilities.getFacilities().get(Id.create(1, ActivityFacility.class))); + Assertions.assertEquals(1, facilities.getFacilities().size()); + Assertions.assertEquals(facility1, facilities.getFacilities().get(Id.create(1, ActivityFacility.class))); } /** @@ -99,10 +99,10 @@ void testRemove() { ActivityFacility facility2 = factory.createActivityFacility(Id.create(2, ActivityFacility.class), new Coord((double) 300, (double) 4000)); facilities.addActivityFacility(facility1); facilities.addActivityFacility(facility2); - Assert.assertEquals(2, facilities.getFacilities().size()); + Assertions.assertEquals(2, facilities.getFacilities().size()); - Assert.assertEquals(facility1, facilities.getFacilities().remove(Id.create(1, ActivityFacility.class))); - Assert.assertEquals(1, facilities.getFacilities().size()); + Assertions.assertEquals(facility1, facilities.getFacilities().remove(Id.create(1, ActivityFacility.class))); + Assertions.assertEquals(1, facilities.getFacilities().size()); } } diff --git a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java index 08eb702178b..7fa5c7b47f8 100644 --- a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java +++ b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java @@ -19,7 +19,7 @@ package org.matsim.facilities; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.runner.RunWith; @@ -99,32 +99,32 @@ void test(){ break; case fromFile: for (ActivityFacility af : activityFacilities.getFacilities().values()){ - Assert.assertNotNull(af.getLinkId()); + Assertions.assertNotNull(af.getLinkId()); } break; case setInScenario: - Assert.assertEquals("wrong number of facilities", 2, activityFacilities.getFacilities().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, activityFacilities.getFacilities().size(), MatsimTestUtils.EPSILON, "wrong number of facilities"); if (facilitiesWithCoordOnly) { for (ActivityFacility af : activityFacilities.getFacilities().values()){ - Assert.assertNotNull(af.getLinkId()); + Assertions.assertNotNull(af.getLinkId()); } } else { for (ActivityFacility af : activityFacilities.getFacilities().values()){ - Assert.assertNull(af.getCoord()); + Assertions.assertNull(af.getCoord()); } } break; case onePerActivityLinkInPlansFile: - Assert.assertEquals("wrong number of facilities", 4, getFacilities(scenario.getConfig().controller().getOutputDirectory()).getFacilities().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(4, getFacilities(scenario.getConfig().controller().getOutputDirectory()).getFacilities().size(), MatsimTestUtils.EPSILON, "wrong number of facilities"); for (ActivityFacility af : activityFacilities.getFacilities().values()){ - Assert.assertNotNull(af.getLinkId()); + Assertions.assertNotNull(af.getLinkId()); } break; case onePerActivityLocationInPlansFile: - Assert.assertEquals("wrong number of facilities", 2, getFacilities(scenario.getConfig().controller().getOutputDirectory()).getFacilities().size(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, getFacilities(scenario.getConfig().controller().getOutputDirectory()).getFacilities().size(), MatsimTestUtils.EPSILON, "wrong number of facilities"); for (ActivityFacility af : activityFacilities.getFacilities().values()){ - Assert.assertNotNull(af.getCoord()); - Assert.assertNotNull(af.getLinkId()); + Assertions.assertNotNull(af.getCoord()); + Assertions.assertNotNull(af.getLinkId()); } break; } diff --git a/matsim/src/test/java/org/matsim/facilities/ActivityWithOnlyFacilityIdTest.java b/matsim/src/test/java/org/matsim/facilities/ActivityWithOnlyFacilityIdTest.java index 8c768e8be87..ef42e06d8b5 100644 --- a/matsim/src/test/java/org/matsim/facilities/ActivityWithOnlyFacilityIdTest.java +++ b/matsim/src/test/java/org/matsim/facilities/ActivityWithOnlyFacilityIdTest.java @@ -1,12 +1,12 @@ package org.matsim.facilities; -import static org.junit.Assert.assertTrue; - import java.net.URL; import java.util.Set; import java.util.stream.Collectors; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertTrue; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.population.Activity; import org.matsim.core.config.Config; @@ -34,7 +34,7 @@ void testSiouxFallsWithOnlyFacilityIds() { .flatMap(person -> person.getPlans().stream()).flatMap(plan -> plan.getPlanElements().stream()) .filter(Activity.class::isInstance).map(Activity.class::cast).filter(act -> act.getFacilityId() != null) .collect(Collectors.toSet()); - assertTrue("Need at least some activities with facilityIds.", activitiesWithFacilityIds.size() > 0); + assertTrue(activitiesWithFacilityIds.size() > 0, "Need at least some activities with facilityIds."); // Remove all (redundant) coords and linkIds from activities with facilityIds. activitiesWithFacilityIds.forEach(act -> { diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java index 15ecc2fe919..bf397bf1abb 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesAttributeConvertionTest.java @@ -21,7 +21,7 @@ package org.matsim.facilities; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -34,7 +34,7 @@ import java.util.Objects; import java.util.function.Consumer; - public class FacilitiesAttributeConvertionTest { + public class FacilitiesAttributeConvertionTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @@ -80,10 +80,10 @@ public void testWriteAndReread( final ActivityFacilities readFacilities = readScenario.getActivityFacilities(); final Object readAttribute = readFacilities.getAttributes().getAttribute("attribute"); - Assert.assertEquals( - "unexpected read attribute", + Assertions.assertEquals( attribute, - readAttribute); + readAttribute, + "unexpected read attribute"); } private static class CustomClass { diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesFromPopulationTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesFromPopulationTest.java index 9de3293c4ed..5c49682c9db 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesFromPopulationTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesFromPopulationTest.java @@ -22,7 +22,7 @@ import java.util.HashSet; import java.util.Map; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -55,11 +55,11 @@ void testRun_onePerLink_assignLinks() { generator.setAssignLinksToFacilitiesIfMissing( f.scenario.getNetwork() ); generator.run(f.scenario.getPopulation()); - Assert.assertEquals(3, f.scenario.getActivityFacilities().getFacilities().size()); + Assertions.assertEquals(3, f.scenario.getActivityFacilities().getFacilities().size()); - Assert.assertEquals("bc", f.scenario.getActivityFacilities().getFacilities().get(Id.create("bc", ActivityFacility.class)).getLinkId().toString()); - Assert.assertEquals("ca", f.scenario.getActivityFacilities().getFacilities().get(Id.create("ca", ActivityFacility.class)).getLinkId().toString()); - Assert.assertEquals("ab", f.scenario.getActivityFacilities().getFacilities().get(Id.create("ab", ActivityFacility.class)).getLinkId().toString()); + Assertions.assertEquals("bc", f.scenario.getActivityFacilities().getFacilities().get(Id.create("bc", ActivityFacility.class)).getLinkId().toString()); + Assertions.assertEquals("ca", f.scenario.getActivityFacilities().getFacilities().get(Id.create("ca", ActivityFacility.class)).getLinkId().toString()); + Assertions.assertEquals("ab", f.scenario.getActivityFacilities().getFacilities().get(Id.create("ab", ActivityFacility.class)).getLinkId().toString()); assertPlan(f.scenario.getPopulation().getPersons().get(Id.create("1", Person.class)).getSelectedPlan(), "ab", "bc", true); assertPlan(f.scenario.getPopulation().getPersons().get(Id.create("2", Person.class)).getSelectedPlan(), "ab", "bc", true); @@ -91,11 +91,11 @@ void testRun_onePerLink_assignLinks_openingTimes() { generator.assignOpeningTimes( config ); generator.run(f.scenario.getPopulation()); - Assert.assertEquals(3, f.scenario.getActivityFacilities().getFacilities().size()); + Assertions.assertEquals(3, f.scenario.getActivityFacilities().getFacilities().size()); Map, ? extends ActivityFacility> ffs = f.scenario.getActivityFacilities().getFacilities(); - Assert.assertEquals(7*3600, ffs.get(Id.create("ab", ActivityFacility.class)).getActivityOptions().get("work").getOpeningTimes().first().getStartTime(), 1e-7); - Assert.assertEquals(19*3600, ffs.get(Id.create("ab", ActivityFacility.class)).getActivityOptions().get("work").getOpeningTimes().first().getEndTime(), 1e-7); + Assertions.assertEquals(7*3600, ffs.get(Id.create("ab", ActivityFacility.class)).getActivityOptions().get("work").getOpeningTimes().first().getStartTime(), 1e-7); + Assertions.assertEquals(19*3600, ffs.get(Id.create("ab", ActivityFacility.class)).getActivityOptions().get("work").getOpeningTimes().first().getEndTime(), 1e-7); assertPlan(f.scenario.getPopulation().getPersons().get(Id.create("1", Person.class)).getSelectedPlan(), "ab", "bc", true); assertPlan(f.scenario.getPopulation().getPersons().get(Id.create("2", Person.class)).getSelectedPlan(), "ab", "bc", true); @@ -122,22 +122,22 @@ void testRun_multiple_assignLinks() { // System.out.println(af.getId() + "\t" + af.getLinkId() + "\t" + af.getCoord().getX() + "\t" + af.getCoord().getY()); // } - Assert.assertEquals(13, f.scenario.getActivityFacilities().getFacilities().size()); + Assertions.assertEquals(13, f.scenario.getActivityFacilities().getFacilities().size()); Map, ? extends ActivityFacility> ffs = f.scenario.getActivityFacilities().getFacilities(); - Assert.assertEquals("ab", ffs.get(Id.create("0", ActivityFacility.class)).getLinkId().toString()); // home of agent 1 - Assert.assertEquals("bc", ffs.get(Id.create("1", ActivityFacility.class)).getLinkId().toString()); // work of agent 1-3 - Assert.assertEquals("ab", ffs.get(Id.create("2", ActivityFacility.class)).getLinkId().toString()); // home of agent 2 - Assert.assertEquals("ab", ffs.get(Id.create("3", ActivityFacility.class)).getLinkId().toString()); // home of agent 3 - Assert.assertEquals("bc", ffs.get(Id.create("4", ActivityFacility.class)).getLinkId().toString()); // home of agent 4 - Assert.assertEquals("ca", ffs.get(Id.create("5", ActivityFacility.class)).getLinkId().toString()); // work of agent 4-7 - Assert.assertEquals("bc", ffs.get(Id.create("6", ActivityFacility.class)).getLinkId().toString()); // home of agent 5 - Assert.assertEquals("bc", ffs.get(Id.create("7", ActivityFacility.class)).getLinkId().toString()); // home of agent 6 - Assert.assertEquals("bc", ffs.get(Id.create("8", ActivityFacility.class)).getLinkId().toString()); // home of agent 7 - Assert.assertEquals("ca", ffs.get(Id.create("9", ActivityFacility.class)).getLinkId().toString()); // home of agent 8 - Assert.assertEquals("ab", ffs.get(Id.create("10", ActivityFacility.class)).getLinkId().toString()); // work of agent 8-10 - Assert.assertEquals("ca", ffs.get(Id.create("11", ActivityFacility.class)).getLinkId().toString()); // home of agent 9 - Assert.assertEquals("ca", ffs.get(Id.create("12", ActivityFacility.class)).getLinkId().toString()); // home of agent 10 + Assertions.assertEquals("ab", ffs.get(Id.create("0", ActivityFacility.class)).getLinkId().toString()); // home of agent 1 + Assertions.assertEquals("bc", ffs.get(Id.create("1", ActivityFacility.class)).getLinkId().toString()); // work of agent 1-3 + Assertions.assertEquals("ab", ffs.get(Id.create("2", ActivityFacility.class)).getLinkId().toString()); // home of agent 2 + Assertions.assertEquals("ab", ffs.get(Id.create("3", ActivityFacility.class)).getLinkId().toString()); // home of agent 3 + Assertions.assertEquals("bc", ffs.get(Id.create("4", ActivityFacility.class)).getLinkId().toString()); // home of agent 4 + Assertions.assertEquals("ca", ffs.get(Id.create("5", ActivityFacility.class)).getLinkId().toString()); // work of agent 4-7 + Assertions.assertEquals("bc", ffs.get(Id.create("6", ActivityFacility.class)).getLinkId().toString()); // home of agent 5 + Assertions.assertEquals("bc", ffs.get(Id.create("7", ActivityFacility.class)).getLinkId().toString()); // home of agent 6 + Assertions.assertEquals("bc", ffs.get(Id.create("8", ActivityFacility.class)).getLinkId().toString()); // home of agent 7 + Assertions.assertEquals("ca", ffs.get(Id.create("9", ActivityFacility.class)).getLinkId().toString()); // home of agent 8 + Assertions.assertEquals("ab", ffs.get(Id.create("10", ActivityFacility.class)).getLinkId().toString()); // work of agent 8-10 + Assertions.assertEquals("ca", ffs.get(Id.create("11", ActivityFacility.class)).getLinkId().toString()); // home of agent 9 + Assertions.assertEquals("ca", ffs.get(Id.create("12", ActivityFacility.class)).getLinkId().toString()); // home of agent 10 assertPlan(f.scenario.getPopulation().getPersons().get(Id.create("1", Person.class)).getSelectedPlan(), "0", "1", true); assertPlan(f.scenario.getPopulation().getPersons().get(Id.create("2", Person.class)).getSelectedPlan(), "2", "1", true); @@ -156,17 +156,17 @@ private void assertPlan(Plan plan, String homeFacilityId, String workFacilityId, Activity work = (Activity) plan.getPlanElements().get(2); Activity home2 = (Activity) plan.getPlanElements().get(4); - Assert.assertEquals(homeFacilityId, home1.getFacilityId().toString()); - Assert.assertEquals(workFacilityId, work.getFacilityId().toString()); - Assert.assertEquals(homeFacilityId, home2.getFacilityId().toString()); + Assertions.assertEquals(homeFacilityId, home1.getFacilityId().toString()); + Assertions.assertEquals(workFacilityId, work.getFacilityId().toString()); + Assertions.assertEquals(homeFacilityId, home2.getFacilityId().toString()); if (linkCoordMustBeNull) { - Assert.assertNull(home1.getLinkId()); - Assert.assertNull(home1.getCoord()); - Assert.assertNull(work.getLinkId()); - Assert.assertNull(work.getCoord()); - Assert.assertNull(home2.getLinkId()); - Assert.assertNull(home2.getCoord()); + Assertions.assertNull(home1.getLinkId()); + Assertions.assertNull(home1.getCoord()); + Assertions.assertNull(work.getLinkId()); + Assertions.assertNull(work.getCoord()); + Assertions.assertNull(home2.getLinkId()); + Assertions.assertNull(home2.getCoord()); } } diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java index a56aa037fdd..8fe325a4306 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesParserWriterTest.java @@ -20,7 +20,7 @@ package org.matsim.facilities; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -58,7 +58,7 @@ void testParserWriter1() { long checksum_ref = CRCChecksum.getCRCFromFile(config.facilities().getInputFile()); long checksum_run = CRCChecksum.getCRCFromFile(outputFilename); - Assert.assertEquals(checksum_ref, checksum_run); + Assertions.assertEquals(checksum_ref, checksum_run); } @Test @@ -87,19 +87,19 @@ void testWriteReadV2_withActivities() { ActivityFacilities facilities2 = FacilitiesUtils.createActivityFacilities(); new MatsimFacilitiesReader(null, null, facilities2).parse(inStream); - Assert.assertEquals(2, facilities2.getFacilities().size()); + Assertions.assertEquals(2, facilities2.getFacilities().size()); ActivityFacility fac1b = facilities2.getFacilities().get(Id.create("1", ActivityFacility.class)); - Assert.assertEquals(1, fac1b.getActivityOptions().size()); - Assert.assertTrue(fac1b.getActivityOptions().get("home").getOpeningTimes().isEmpty()); - Assert.assertEquals(0, fac1b.getAttributes().size()); + Assertions.assertEquals(1, fac1b.getActivityOptions().size()); + Assertions.assertTrue(fac1b.getActivityOptions().get("home").getOpeningTimes().isEmpty()); + Assertions.assertEquals(0, fac1b.getAttributes().size()); ActivityFacility fac2b = facilities2.getFacilities().get(Id.create("2", ActivityFacility.class)); - Assert.assertEquals(1, fac2b.getActivityOptions().size()); - Assert.assertNotNull(fac2b.getActivityOptions().get("shop").getOpeningTimes()); - Assert.assertEquals(8*3600, fac2b.getActivityOptions().get("shop").getOpeningTimes().first().getStartTime(), 0.0); - Assert.assertEquals(20*3600, fac2b.getActivityOptions().get("shop").getOpeningTimes().first().getEndTime(), 0.0); - Assert.assertEquals(0, fac2b.getAttributes().size()); + Assertions.assertEquals(1, fac2b.getActivityOptions().size()); + Assertions.assertNotNull(fac2b.getActivityOptions().get("shop").getOpeningTimes()); + Assertions.assertEquals(8*3600, fac2b.getActivityOptions().get("shop").getOpeningTimes().first().getStartTime(), 0.0); + Assertions.assertEquals(20*3600, fac2b.getActivityOptions().get("shop").getOpeningTimes().first().getEndTime(), 0.0); + Assertions.assertEquals(0, fac2b.getAttributes().size()); } @Test @@ -126,17 +126,17 @@ void testWriteReadV2_withAttributes() { ActivityFacilities facilities2 = FacilitiesUtils.createActivityFacilities(); new MatsimFacilitiesReader(null, null, facilities2).parse(inStream); - Assert.assertEquals(2, facilities2.getFacilities().size()); + Assertions.assertEquals(2, facilities2.getFacilities().size()); ActivityFacility fac1b = facilities2.getFacilities().get(Id.create("1", ActivityFacility.class)); - Assert.assertEquals(0, fac1b.getActivityOptions().size()); - Assert.assertEquals(1, fac1b.getAttributes().size()); - Assert.assertEquals(100, fac1b.getAttributes().getAttribute("size_m2")); + Assertions.assertEquals(0, fac1b.getActivityOptions().size()); + Assertions.assertEquals(1, fac1b.getAttributes().size()); + Assertions.assertEquals(100, fac1b.getAttributes().getAttribute("size_m2")); ActivityFacility fac2b = facilities2.getFacilities().get(Id.create("2", ActivityFacility.class)); - Assert.assertEquals(0, fac2b.getActivityOptions().size()); - Assert.assertEquals(1, fac2b.getAttributes().size()); - Assert.assertEquals(500, fac2b.getAttributes().getAttribute("size_m2")); + Assertions.assertEquals(0, fac2b.getActivityOptions().size()); + Assertions.assertEquals(1, fac2b.getAttributes().size()); + Assertions.assertEquals(500, fac2b.getAttributes().getAttribute("size_m2")); } @Test @@ -168,21 +168,21 @@ void testWriteReadV2_withActivitiesAndAttributes() { // MATSIM-859 ActivityFacilities facilities2 = FacilitiesUtils.createActivityFacilities(); new MatsimFacilitiesReader(null, null, facilities2).parse(inStream); - Assert.assertEquals(2, facilities2.getFacilities().size()); + Assertions.assertEquals(2, facilities2.getFacilities().size()); ActivityFacility fac1b = facilities2.getFacilities().get(Id.create("1", ActivityFacility.class)); - Assert.assertEquals(1, fac1b.getActivityOptions().size()); - Assert.assertTrue(fac1b.getActivityOptions().get("home").getOpeningTimes().isEmpty()); - Assert.assertEquals(1, fac1b.getAttributes().size()); - Assert.assertEquals(100, fac1b.getAttributes().getAttribute("size_m2")); + Assertions.assertEquals(1, fac1b.getActivityOptions().size()); + Assertions.assertTrue(fac1b.getActivityOptions().get("home").getOpeningTimes().isEmpty()); + Assertions.assertEquals(1, fac1b.getAttributes().size()); + Assertions.assertEquals(100, fac1b.getAttributes().getAttribute("size_m2")); ActivityFacility fac2b = facilities2.getFacilities().get(Id.create("2", ActivityFacility.class)); - Assert.assertEquals(1, fac2b.getActivityOptions().size()); - Assert.assertNotNull(fac2b.getActivityOptions().get("shop").getOpeningTimes()); - Assert.assertEquals(8*3600, fac2b.getActivityOptions().get("shop").getOpeningTimes().first().getStartTime(), 0.0); - Assert.assertEquals(20*3600, fac2b.getActivityOptions().get("shop").getOpeningTimes().first().getEndTime(), 0.0); - Assert.assertEquals(1, fac2b.getAttributes().size()); - Assert.assertEquals(500, fac2b.getAttributes().getAttribute("size_m2")); + Assertions.assertEquals(1, fac2b.getActivityOptions().size()); + Assertions.assertNotNull(fac2b.getActivityOptions().get("shop").getOpeningTimes()); + Assertions.assertEquals(8*3600, fac2b.getActivityOptions().get("shop").getOpeningTimes().first().getStartTime(), 0.0); + Assertions.assertEquals(20*3600, fac2b.getActivityOptions().get("shop").getOpeningTimes().first().getEndTime(), 0.0); + Assertions.assertEquals(1, fac2b.getAttributes().size()); + Assertions.assertEquals(500, fac2b.getAttributes().getAttribute("size_m2")); } } diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java index 23682c3794b..efee8929cda 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesReprojectionIOTest.java @@ -21,7 +21,7 @@ package org.matsim.facilities; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -39,7 +39,7 @@ import org.matsim.examples.ExamplesUtils; import org.matsim.testcases.MatsimTestUtils; - /** + /** * @author thibautd */ public class FacilitiesReprojectionIOTest { @@ -103,16 +103,16 @@ void testWithControlerAndObjectAttributes() { final Coord originalCoord = originalScenario.getActivityFacilities().getFacilities().get( id ).getCoord(); final Coord internalCoord = scenario.getActivityFacilities().getFacilities().get( id ).getCoord(); - Assert.assertEquals( - "Wrong coordinate transform performed!", + Assertions.assertEquals( transformation.transform(originalCoord), - internalCoord); + internalCoord, + "Wrong coordinate transform performed!"); } - Assert.assertEquals( - "wrong CRS information after loading", + Assertions.assertEquals( TARGET_CRS, - ProjectionUtils.getCRS(scenario.getActivityFacilities())); + ProjectionUtils.getCRS(scenario.getActivityFacilities()), + "wrong CRS information after loading"); config.controller().setLastIteration( -1 ); final String outputDirectory = utils.getOutputDirectory()+"/output/"; @@ -127,16 +127,16 @@ void testWithControlerAndObjectAttributes() { final Coord internalCoord = scenario.getActivityFacilities().getFacilities().get( id ).getCoord(); final Coord dumpedCoord = dumpedScenario.getActivityFacilities().getFacilities().get( id ).getCoord(); - Assert.assertEquals( - "coordinates were reprojected for dump", + Assertions.assertEquals( internalCoord.getX(), dumpedCoord.getX(), - epsilon ); - Assert.assertEquals( - "coordinates were reprojected for dump", + epsilon, + "coordinates were reprojected for dump" ); + Assertions.assertEquals( internalCoord.getY(), dumpedCoord.getY(), - epsilon ); + epsilon, + "coordinates were reprojected for dump" ); } } @@ -167,16 +167,16 @@ void testWithControlerAndConfigParameters() { final Coord originalCoord = originalScenario.getActivityFacilities().getFacilities().get( id ).getCoord(); final Coord internalCoord = scenario.getActivityFacilities().getFacilities().get( id ).getCoord(); - Assert.assertNotEquals( - "No coordinates transform performed!", + Assertions.assertNotEquals( originalCoord.getX(), internalCoord.getX(), - epsilon ); - Assert.assertNotEquals( - "No coordinates transform performed!", + epsilon, + "No coordinates transform performed!" ); + Assertions.assertNotEquals( originalCoord.getY(), internalCoord.getY(), - epsilon ); + epsilon, + "No coordinates transform performed!" ); } config.controller().setLastIteration( -1 ); @@ -192,16 +192,16 @@ void testWithControlerAndConfigParameters() { final Coord originalCoord = originalScenario.getActivityFacilities().getFacilities().get( id ).getCoord(); final Coord dumpedCoord = dumpedScenario.getActivityFacilities().getFacilities().get( id ).getCoord(); - Assert.assertNotEquals( - "coordinates not reprojected for dump", + Assertions.assertNotEquals( originalCoord.getX(), dumpedCoord.getX(), - epsilon ); - Assert.assertNotEquals( - "coordinates not reprojected for dump", + epsilon, + "coordinates not reprojected for dump" ); + Assertions.assertNotEquals( originalCoord.getY(), dumpedCoord.getY(), - epsilon ); + epsilon, + "coordinates not reprojected for dump" ); } } @@ -209,10 +209,10 @@ private void assertScenarioReprojectedCorrectly(Scenario originalScenario, Scena final ActivityFacilities originalFacilities = originalScenario.getActivityFacilities(); final ActivityFacilities reprojectedFacilities = reprojectedScenario.getActivityFacilities(); - Assert.assertEquals( - "unexpected size of reprojected facilities", + Assertions.assertEquals( originalFacilities.getFacilities().size(), - reprojectedFacilities.getFacilities().size() ); + reprojectedFacilities.getFacilities().size(), + "unexpected size of reprojected facilities" ); for (Id id : originalFacilities.getFacilities().keySet() ) { final ActivityFacility originalFacility = originalFacilities.getFacilities().get( id ); @@ -226,9 +226,9 @@ private void assertReprojectedCorrectly(ActivityFacility originalFacility, Activ final Coord original = originalFacility.getCoord(); final Coord transformed = reprojectedFacility.getCoord(); - Assert.assertEquals( - "wrong reprojected coordinate", + Assertions.assertEquals( transformation.transform(original), - transformed); + transformed, + "wrong reprojected coordinate"); } } diff --git a/matsim/src/test/java/org/matsim/facilities/FacilitiesWriterTest.java b/matsim/src/test/java/org/matsim/facilities/FacilitiesWriterTest.java index 2cef9ffb5d5..7a33183eaaf 100644 --- a/matsim/src/test/java/org/matsim/facilities/FacilitiesWriterTest.java +++ b/matsim/src/test/java/org/matsim/facilities/FacilitiesWriterTest.java @@ -21,7 +21,7 @@ package org.matsim.facilities; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -33,7 +33,7 @@ import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; - /** + /** * @author mrieser */ public class FacilitiesWriterTest { @@ -68,19 +68,19 @@ void testWriteLinkId() { MatsimFacilitiesReader reader = new MatsimFacilitiesReader(scenario); reader.parse(inputStream); - Assert.assertEquals(3, facilities.getFacilities().size()); + Assertions.assertEquals(3, facilities.getFacilities().size()); ActivityFacility fac1b = facilities.getFacilities().get(Id.create(1, ActivityFacility.class)); - Assert.assertEquals(Id.create("Abc", Link.class), fac1b.getLinkId()); - Assert.assertEquals(1000, fac1b.getAttributes().getAttribute("population")); + Assertions.assertEquals(Id.create("Abc", Link.class), fac1b.getLinkId()); + Assertions.assertEquals(1000, fac1b.getAttributes().getAttribute("population")); ActivityFacility fac2b = facilities.getFacilities().get(Id.create(2, ActivityFacility.class)); - Assert.assertEquals(Id.create("Def", Link.class), fac2b.getLinkId()); - Assert.assertEquals(1200, fac2b.getAttributes().getAttribute("population")); + Assertions.assertEquals(Id.create("Def", Link.class), fac2b.getLinkId()); + Assertions.assertEquals(1200, fac2b.getAttributes().getAttribute("population")); ActivityFacility fac3b = facilities.getFacilities().get(Id.create(3, ActivityFacility.class)); - Assert.assertNull(fac3b.getLinkId()); - Assert.assertEquals("pepsiCo", fac3b.getAttributes().getAttribute("owner")); + Assertions.assertNull(fac3b.getLinkId()); + Assertions.assertEquals("pepsiCo", fac3b.getAttributes().getAttribute("owner")); } @Test @@ -107,18 +107,18 @@ void testWrite3DCoord() { MatsimFacilitiesReader reader = new MatsimFacilitiesReader(scenario); reader.parse(inputStream); - Assert.assertEquals(3, facilities.getFacilities().size()); + Assertions.assertEquals(3, facilities.getFacilities().size()); ActivityFacility fac1b = facilities.getFacilities().get(Id.create(1, ActivityFacility.class)); - Assert.assertTrue(fac1b.getCoord().hasZ()); - Assert.assertEquals(12.3, fac1b.getCoord().getZ(), Double.MIN_NORMAL); + Assertions.assertTrue(fac1b.getCoord().hasZ()); + Assertions.assertEquals(12.3, fac1b.getCoord().getZ(), Double.MIN_NORMAL); ActivityFacility fac2b = facilities.getFacilities().get(Id.create(2, ActivityFacility.class)); - Assert.assertTrue(fac2b.getCoord().hasZ()); - Assert.assertEquals(-4.2, fac2b.getCoord().getZ(), Double.MIN_NORMAL); + Assertions.assertTrue(fac2b.getCoord().hasZ()); + Assertions.assertEquals(-4.2, fac2b.getCoord().getZ(), Double.MIN_NORMAL); ActivityFacility fac3b = facilities.getFacilities().get(Id.create(3, ActivityFacility.class)); - Assert.assertFalse(fac3b.getCoord().hasZ()); + Assertions.assertFalse(fac3b.getCoord().hasZ()); } // the better fix for https://github.com/matsim-org/matsim/pull/505 @@ -150,10 +150,10 @@ void testFacilityDescription() { // check - Assert.assertEquals(1, facilities.getFacilities().size()); + Assertions.assertEquals(1, facilities.getFacilities().size()); ActivityFacility fac1b = facilities.getFacilities().get(Id.create(1, ActivityFacility.class)); String desc2 = ((ActivityFacilityImpl) fac1b).getDesc(); - Assert.assertEquals(desc, desc2); + Assertions.assertEquals(desc, desc2); } // inspired by https://github.com/matsim-org/matsim/pull/505 @@ -183,7 +183,7 @@ void testFacilitiesName() { // check String desc2 = facilities.getName(); - Assert.assertEquals(desc, desc2); + Assertions.assertEquals(desc, desc2); } } diff --git a/matsim/src/test/java/org/matsim/facilities/MatsimFacilitiesReaderTest.java b/matsim/src/test/java/org/matsim/facilities/MatsimFacilitiesReaderTest.java index e1b5329bb19..049a8e8a398 100644 --- a/matsim/src/test/java/org/matsim/facilities/MatsimFacilitiesReaderTest.java +++ b/matsim/src/test/java/org/matsim/facilities/MatsimFacilitiesReaderTest.java @@ -23,7 +23,7 @@ import java.io.ByteArrayInputStream; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -31,7 +31,7 @@ import org.matsim.core.config.ConfigUtils; import org.matsim.core.scenario.ScenarioUtils; - /** + /** * @author mrieser / Senozon AG */ public class MatsimFacilitiesReaderTest { @@ -72,16 +72,16 @@ void testReadLinkId() { reader.parse(new ByteArrayInputStream(str.getBytes())); ActivityFacilities facilities = scenario.getActivityFacilities(); - Assert.assertEquals(3, facilities.getFacilities().size()); + Assertions.assertEquals(3, facilities.getFacilities().size()); ActivityFacility fac1 = facilities.getFacilities().get(Id.create(1, ActivityFacility.class)); - Assert.assertEquals(Id.create("Aa", Link.class), fac1.getLinkId()); + Assertions.assertEquals(Id.create("Aa", Link.class), fac1.getLinkId()); ActivityFacility fac10 = facilities.getFacilities().get(Id.create(10, ActivityFacility.class)); - Assert.assertEquals(Id.create("Bb", Link.class), fac10.getLinkId()); + Assertions.assertEquals(Id.create("Bb", Link.class), fac10.getLinkId()); ActivityFacility fac20 = facilities.getFacilities().get(Id.create(20, ActivityFacility.class)); - Assert.assertNull(fac20.getLinkId()); + Assertions.assertNull(fac20.getLinkId()); } @Test @@ -120,17 +120,17 @@ void testRead3DCoord() { reader.parse(new ByteArrayInputStream(str.getBytes())); ActivityFacilities facilities = scenario.getActivityFacilities(); - Assert.assertEquals(3, facilities.getFacilities().size()); + Assertions.assertEquals(3, facilities.getFacilities().size()); ActivityFacility fac1 = facilities.getFacilities().get(Id.create(1, ActivityFacility.class)); - Assert.assertTrue(fac1.getCoord().hasZ()); - Assert.assertEquals(12.3, fac1.getCoord().getZ(), Double.MIN_NORMAL); + Assertions.assertTrue(fac1.getCoord().hasZ()); + Assertions.assertEquals(12.3, fac1.getCoord().getZ(), Double.MIN_NORMAL); ActivityFacility fac10 = facilities.getFacilities().get(Id.create(10, ActivityFacility.class)); - Assert.assertTrue(fac10.getCoord().hasZ()); - Assert.assertEquals(-4.2, fac10.getCoord().getZ(), Double.MIN_NORMAL); + Assertions.assertTrue(fac10.getCoord().hasZ()); + Assertions.assertEquals(-4.2, fac10.getCoord().getZ(), Double.MIN_NORMAL); ActivityFacility fac20 = facilities.getFacilities().get(Id.create(20, ActivityFacility.class)); - Assert.assertFalse(fac20.getCoord().hasZ()); + Assertions.assertFalse(fac20.getCoord().hasZ()); } } diff --git a/matsim/src/test/java/org/matsim/facilities/StreamingActivityFacilitiesTest.java b/matsim/src/test/java/org/matsim/facilities/StreamingActivityFacilitiesTest.java index 58a92229f5d..d8cfe1bb722 100644 --- a/matsim/src/test/java/org/matsim/facilities/StreamingActivityFacilitiesTest.java +++ b/matsim/src/test/java/org/matsim/facilities/StreamingActivityFacilitiesTest.java @@ -1,6 +1,6 @@ package org.matsim.facilities; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import java.io.ByteArrayInputStream; @@ -45,30 +45,30 @@ void testFacilityIsComplete() { boolean[] foundFacilities = new boolean[3]; StreamingActivityFacilities streamingFacilities = new StreamingActivityFacilities(f -> { if (f.getId().toString().equals("1")) { - Assert.assertEquals(60.0, f.getCoord().getX(), 1e-7); - Assert.assertTrue(f.getActivityOptions().containsKey("home")); - Assert.assertEquals(1000, ((Integer) f.getAttributes().getAttribute("population")).intValue()); + Assertions.assertEquals(60.0, f.getCoord().getX(), 1e-7); + Assertions.assertTrue(f.getActivityOptions().containsKey("home")); + Assertions.assertEquals(1000, ((Integer) f.getAttributes().getAttribute("population")).intValue()); foundFacilities[0] = true; } if (f.getId().toString().equals("10")) { - Assert.assertEquals(110.0, f.getCoord().getX(), 1e-7); - Assert.assertTrue(f.getActivityOptions().containsKey("education")); - Assert.assertTrue(f.getAttributes().isEmpty()); + Assertions.assertEquals(110.0, f.getCoord().getX(), 1e-7); + Assertions.assertTrue(f.getActivityOptions().containsKey("education")); + Assertions.assertTrue(f.getAttributes().isEmpty()); foundFacilities[1] = true; } if (f.getId().toString().equals("20")) { - Assert.assertEquals(120.0, f.getCoord().getX(), 1e-7); - Assert.assertTrue(f.getActivityOptions().containsKey("shop")); - Assert.assertTrue(f.getAttributes().isEmpty()); + Assertions.assertEquals(120.0, f.getCoord().getX(), 1e-7); + Assertions.assertTrue(f.getActivityOptions().containsKey("shop")); + Assertions.assertTrue(f.getAttributes().isEmpty()); foundFacilities[2] = true; } }); MatsimFacilitiesReader reader = new MatsimFacilitiesReader(null, null, streamingFacilities); reader.parse(new ByteArrayInputStream(str.getBytes())); - Assert.assertTrue(foundFacilities[0]); - Assert.assertTrue(foundFacilities[1]); - Assert.assertTrue(foundFacilities[2]); + Assertions.assertTrue(foundFacilities[0]); + Assertions.assertTrue(foundFacilities[1]); + Assertions.assertTrue(foundFacilities[2]); } } diff --git a/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java b/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java index f115010be8a..ecfd778ca93 100644 --- a/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java +++ b/matsim/src/test/java/org/matsim/facilities/algorithms/AbstractFacilityAlgorithmTest.java @@ -20,7 +20,7 @@ package org.matsim.facilities.algorithms; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -45,7 +45,7 @@ void testRunAlgorithms() { // create an algo and let it run over the facilities MockAlgo1 algo1 = new MockAlgo1(); algo1.run(facilities); - assertEquals("TestAlgo should have handled 2 facilities.", 2, algo1.getCounter()); + assertEquals(2, algo1.getCounter(), "TestAlgo should have handled 2 facilities."); } /*package*/ static class MockAlgo1 extends AbstractFacilityAlgorithm { diff --git a/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java b/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java index 3c3b207f51f..6f8dbc7bbf3 100644 --- a/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java +++ b/matsim/src/test/java/org/matsim/households/HouseholdAttributeConversionTest.java @@ -23,7 +23,7 @@ -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -39,7 +39,7 @@ import java.util.Objects; import java.util.function.Consumer; - public class HouseholdAttributeConversionTest { + public class HouseholdAttributeConversionTest { @RegisterExtension public final MatsimTestUtils utils = new MatsimTestUtils(); @@ -77,10 +77,10 @@ public void testWriteAndReread( final Household readHousehold = readHouseholds.getHouseholds().get(id); final Object readAttribute = readHousehold.getAttributes().getAttribute("attribute"); - Assert.assertEquals( - "unexpected read attribute", + Assertions.assertEquals( attribute, - readAttribute); + readAttribute, + "unexpected read attribute"); } private static class CustomClass { diff --git a/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java b/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java index 8aa02ede926..920477bcf7c 100644 --- a/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java +++ b/matsim/src/test/java/org/matsim/households/HouseholdImplTest.java @@ -20,7 +20,7 @@ package org.matsim.households; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -42,10 +42,10 @@ void testAddHousehold_DuplicateId(){ Household hh1 = new HouseholdImpl(Id.create("1", Household.class)); Household hh2 = new HouseholdImpl(Id.create("1", Household.class)); - assertEquals("Shouldn't have a household.", 0, hhs.getHouseholds().size()); + assertEquals(0, hhs.getHouseholds().size(), "Shouldn't have a household."); hhs.addHousehold(hh1); - assertEquals("Didn't add the household.", 1, hhs.getHouseholds().size()); - assertEquals("Should have added the household.", hh1, hhs.getHouseholds().get(hh1.getId())); + assertEquals(1, hhs.getHouseholds().size(), "Didn't add the household."); + assertEquals(hh1, hhs.getHouseholds().get(hh1.getId()), "Should have added the household."); try{ hhs.addHousehold(hh2); fail("Should not have accepted household with similar Id."); @@ -64,12 +64,12 @@ void testAddHousehold_NoStreaming(){ Household hh2 = new HouseholdImpl(Id.create("2", Household.class)); hhs.addHousehold(hh1); - assertEquals("Should have the first household added.", 1, hhs.getHouseholds().size()); - assertTrue("First household not present.", hhs.getHouseholds().containsValue(hh1)); + assertEquals(1, hhs.getHouseholds().size(), "Should have the first household added."); + assertTrue(hhs.getHouseholds().containsValue(hh1), "First household not present."); hhs.addHousehold(hh2); - assertEquals("Should have the first AND second household added.", 2, hhs.getHouseholds().size()); - assertTrue("First household not present.", hhs.getHouseholds().containsValue(hh1)); - assertTrue("Second household not present.", hhs.getHouseholds().containsValue(hh2)); + assertEquals(2, hhs.getHouseholds().size(), "Should have the first AND second household added."); + assertTrue(hhs.getHouseholds().containsValue(hh1), "First household not present."); + assertTrue(hhs.getHouseholds().containsValue(hh2), "Second household not present."); } } diff --git a/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java b/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java index bba8e6a3916..f2bd9411b73 100644 --- a/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java +++ b/matsim/src/test/java/org/matsim/households/HouseholdsIoTest.java @@ -19,7 +19,7 @@ package org.matsim.households; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.File; import java.io.IOException; @@ -108,7 +108,7 @@ private void checkContent(Households households) { assertEquals(50000.0d, hh.getIncome().getIncome(), MatsimTestUtils.EPSILON); Attributes currentAttributes = hh.getAttributes(); - assertNotNull("Custom attributes from household with id 23 should not be empty.", currentAttributes); + assertNotNull(currentAttributes, "Custom attributes from household with id 23 should not be empty."); String customAttributeName = "customAttribute1"; String customContent = (String)currentAttributes.getAttribute(customAttributeName); assertEquals("customValue1", customContent); diff --git a/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java b/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java index 3db4c83d19f..3e3af8a0501 100644 --- a/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java +++ b/matsim/src/test/java/org/matsim/integration/EquilTwoAgentsTest.java @@ -51,7 +51,7 @@ import jakarta.inject.Inject; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import static org.matsim.testcases.MatsimTestUtils.EPSILON; /** diff --git a/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java b/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java index 0ed09266633..9bd875631c0 100644 --- a/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java +++ b/matsim/src/test/java/org/matsim/integration/SimulateAndScoreTest.java @@ -20,11 +20,11 @@ package org.matsim.integration; -import static org.junit.Assert.assertEquals; - import java.util.Arrays; import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -300,7 +300,7 @@ void testTeleportationScore() { scorer.finish(); Double score = plan.getScore(); - assertEquals("Expecting -1.0 from travel time, -1.0 from travel distance.", -2.0, score, MatsimTestUtils.EPSILON); + assertEquals(-2.0, score, MatsimTestUtils.EPSILON, "Expecting -1.0 from travel time, -1.0 from travel distance."); } diff --git a/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java index c99bcf65622..4d2bf07173c 100644 --- a/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/events/PersonMoneyEventIntegrationTest.java @@ -20,8 +20,8 @@ package org.matsim.integration.events; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.io.BufferedWriter; import java.io.IOException; diff --git a/matsim/src/test/java/org/matsim/integration/events/PersonScoreEventTest.java b/matsim/src/test/java/org/matsim/integration/events/PersonScoreEventTest.java index 8e690949e5e..f1a1eb70d9e 100644 --- a/matsim/src/test/java/org/matsim/integration/events/PersonScoreEventTest.java +++ b/matsim/src/test/java/org/matsim/integration/events/PersonScoreEventTest.java @@ -18,8 +18,8 @@ package org.matsim.integration.events; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; diff --git a/matsim/src/test/java/org/matsim/integration/events/TransitDriverStartsEventHandlerIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/events/TransitDriverStartsEventHandlerIntegrationTest.java index 4ed3071fb8e..1055467d26d 100644 --- a/matsim/src/test/java/org/matsim/integration/events/TransitDriverStartsEventHandlerIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/events/TransitDriverStartsEventHandlerIntegrationTest.java @@ -22,7 +22,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.TransitDriverStartsEvent; @@ -48,14 +48,14 @@ void testProcessEventIntegration() { TransitDriverStartsTestEventHandler eh = new TransitDriverStartsTestEventHandler(); em.addHandler(eh); - Assert.assertEquals(0, eh.events.size()); + Assertions.assertEquals(0, eh.events.size()); em.initProcessing(); em.processEvent(e1); em.finishProcessing(); - Assert.assertEquals(1, eh.events.size()); - Assert.assertEquals(e1, eh.events.get(0)); + Assertions.assertEquals(1, eh.events.size()); + Assertions.assertEquals(e1, eh.events.get(0)); } /*package*/ static class TransitDriverStartsTestEventHandler implements TransitDriverStartsEventHandler { diff --git a/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java b/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java index 438b9fa07c4..3780604dcbf 100644 --- a/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java +++ b/matsim/src/test/java/org/matsim/integration/invertednetworks/InvertedNetworkRoutingIT.java @@ -19,7 +19,7 @@ * *********************************************************************** */ package org.matsim.integration.invertednetworks; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.controler.Controler; @@ -48,7 +48,7 @@ public void notifyStartup(StartupEvent event) { } }); c.run(); - Assert.assertTrue("No traffic on link", testHandler.hadTrafficOnLink25); + Assertions.assertTrue(testHandler.hadTrafficOnLink25, "No traffic on link"); } @@ -68,7 +68,7 @@ public void notifyStartup(StartupEvent event) { } }); c.run(); - Assert.assertTrue("No traffic on link", testHandler.hadTrafficOnLink25); + Assertions.assertTrue(testHandler.hadTrafficOnLink25, "No traffic on link"); } @Test @@ -89,6 +89,6 @@ public void notifyStartup(StartupEvent event) { } }); c.run(); - Assert.assertTrue("No traffic on link", testHandler.hadTrafficOnLink25); + Assertions.assertTrue(testHandler.hadTrafficOnLink25, "No traffic on link"); } } diff --git a/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java b/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java index f5c0a37ec99..c068845de9e 100644 --- a/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java +++ b/matsim/src/test/java/org/matsim/integration/invertednetworks/LanesIT.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -82,12 +82,12 @@ public void install() { addMobsimListenerBinding().toInstance(new MobsimInitializedListener() { @Override public void notifyMobsimInitialized(MobsimInitializedEvent e) { - Assert.assertTrue(e.getQueueSimulation() instanceof QSim); + Assertions.assertTrue(e.getQueueSimulation() instanceof QSim); QSim qsim = (QSim) e.getQueueSimulation(); NetsimLink link = qsim.getNetsimNetwork().getNetsimLink(Id.create("23", Link.class)); - Assert.assertTrue(link instanceof QLinkLanesImpl); + Assertions.assertTrue(link instanceof QLinkLanesImpl); QLinkLanesImpl link23 = (QLinkLanesImpl) link; - Assert.assertNotNull(link23.getQueueLanes()); + Assertions.assertNotNull(link23.getQueueLanes()); // for (QLane lane : link23.getQueueLanes()){ // Assert.assertNotNull(lane); // log.error("lane " + lane.getId() + " flow " + lane.getSimulatedFlowCapacity()); @@ -139,9 +139,9 @@ public void notifyShutdown(ShutdownEvent event) { log.info( "link36:" + percent36 ); // The lanes attached to link 23 should distribute the 3600 veh/h capacity as follows: - Assert.assertEquals("lane to link 34 should have approx. 600 veh/h, i.e. 16.6% of the total flow", 16.6, percent34, 1); - Assert.assertEquals("lane to link 35 should have approx. 1200 veh/h, i.e. 33.3% of the total flow", 33.3, percent35, 1); - Assert.assertEquals("lane to link 36 should have approx. 1800 veh/h, i.e. 50.0% of the total flow", 50.0, percent36, 1); + Assertions.assertEquals(16.6, percent34, 1, "lane to link 34 should have approx. 600 veh/h, i.e. 16.6% of the total flow"); + Assertions.assertEquals(33.3, percent35, 1, "lane to link 35 should have approx. 1200 veh/h, i.e. 33.3% of the total flow"); + Assertions.assertEquals(50.0, percent36, 1, "lane to link 36 should have approx. 1800 veh/h, i.e. 50.0% of the total flow"); } } diff --git a/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java b/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java index 8d745a9e89f..033857c8a4c 100644 --- a/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java +++ b/matsim/src/test/java/org/matsim/integration/population/NonAlternatingPlanElementsIT.java @@ -22,7 +22,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -91,7 +91,7 @@ void test_Controler_QSim_Routechoice_acts() { controler.getConfig().controller().setCreateGraphs(false); controler.run(); - Assert.assertTrue(person.getPlans().size() > 1); // ensure there was some replanning + Assertions.assertTrue(person.getPlans().size() > 1); // ensure there was some replanning } @Test @@ -123,7 +123,7 @@ void test_Controler_QSim_Routechoice_legs() { controler.getConfig().controller().setCreateGraphs(false); controler.run(); - Assert.assertTrue(person.getPlans().size() > 1); // ensure there was some replanning + Assertions.assertTrue(person.getPlans().size() > 1); // ensure there was some replanning } // TODO: make more complicated plans when testing subtour mode choice diff --git a/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java index 933fb43fbf6..e3d4651b7e0 100644 --- a/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/replanning/ChangeTripModeIntegrationTest.java @@ -20,8 +20,8 @@ package org.matsim.integration.replanning; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -130,11 +130,11 @@ public void install() { manager.run(population, 0, injector.getInstance(ReplanningContext.class)); // test that everything worked as expected - assertEquals("number of plans in person.", 2, person.getPlans().size()); + assertEquals(2, person.getPlans().size(), "number of plans in person."); Plan newPlan = person.getSelectedPlan(); Leg newLeg = (Leg) newPlan.getPlanElements().get(1); assertEquals(TransportMode.walk, newLeg.getMode()); - assertNotNull("the leg should now have a route.", newLeg.getRoute()); + assertNotNull(newLeg.getRoute(), "the leg should now have a route."); } } diff --git a/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java b/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java index 2375b591263..c432538434a 100644 --- a/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java +++ b/matsim/src/test/java/org/matsim/integration/replanning/ReRoutingIT.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -130,7 +130,7 @@ private void evaluate(String plansFilename) throws MalformedURLException { new PopulationWriter(referenceScenario.getPopulation(), scenario.getNetwork()).write(utils.getOutputDirectory() + "/reference_population.xml.gz"); new PopulationWriter(scenario.getPopulation(), scenario.getNetwork()).write(utils.getOutputDirectory() + "/output_population.xml.gz"); } - Assert.assertTrue("different plans files.", isEqual); + Assertions.assertTrue(isEqual, "different plans files."); } } diff --git a/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java b/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java index 23691588cff..2b602dfd73c 100644 --- a/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java +++ b/matsim/src/test/java/org/matsim/integration/replanning/ResumableRunsIT.java @@ -20,7 +20,7 @@ package org.matsim.integration.replanning; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -89,15 +89,15 @@ void testResumableRuns() throws MalformedURLException { // comparison long cksum1 = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/run1/ITERS/it.10/10.plans.xml.gz"); long cksum2 = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/run2/ITERS/it.10/10.plans.xml.gz"); - Assert.assertEquals("Plans must not be altered just be reading in and writing out again.", cksum1, cksum2); + Assertions.assertEquals(cksum1, cksum2, "Plans must not be altered just be reading in and writing out again."); cksum1 = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/run1/ITERS/it.10/10.events.xml.gz"); cksum2 = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/run2/ITERS/it.10/10.events.xml.gz"); - Assert.assertEquals("The checksums of events must be the same when resuming runs.", cksum1, cksum2); + Assertions.assertEquals(cksum1, cksum2, "The checksums of events must be the same when resuming runs."); cksum1 = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/run1/ITERS/it.11/11.events.xml.gz"); cksum2 = CRCChecksum.getCRCFromFile(utils.getOutputDirectory() + "/run2/ITERS/it.11/11.events.xml.gz"); - Assert.assertEquals("The checksums of events must be the same when resuming runs.", cksum1, cksum2); + Assertions.assertEquals(cksum1, cksum2, "The checksums of events must be the same when resuming runs."); } } diff --git a/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java b/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java index 214a92bc0a0..609737eb135 100644 --- a/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/integration/timevariantnetworks/QSimIntegrationTest.java @@ -20,12 +20,12 @@ package org.matsim.integration.timevariantnetworks; -import static org.junit.Assert.assertEquals; - import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -116,8 +116,8 @@ void testFreespeed() { .run(); // check that we get the expected result - assertEquals("Person 1 should travel for 11 seconds.", 10.0 + 1.0, ttcalc.person1leaveTime - ttcalc.person1enterTime, MatsimTestUtils.EPSILON); - assertEquals("Person 2 should travel for 6 seconds.", 5.0 + 1.0, ttcalc.person2leaveTime - ttcalc.person2enterTime, MatsimTestUtils.EPSILON); + assertEquals(10.0 + 1.0, ttcalc.person1leaveTime - ttcalc.person1enterTime, MatsimTestUtils.EPSILON, "Person 1 should travel for 11 seconds."); + assertEquals(5.0 + 1.0, ttcalc.person2leaveTime - ttcalc.person2enterTime, MatsimTestUtils.EPSILON, "Person 2 should travel for 6 seconds."); } /** @@ -187,8 +187,8 @@ void testCapacity() { * link 3 (because of the spill-back). The last person of the second * wave should have free-flow travel time. */ - assertEquals("Person 1 should travel for 20 seconds.", 20.0, ttcalc.person1leaveTime - ttcalc.person1enterTime, MatsimTestUtils.EPSILON); - assertEquals("Person 2 should travel for 11 seconds.", 10.0 + 1.0, ttcalc.person2leaveTime - ttcalc.person2enterTime, MatsimTestUtils.EPSILON); + assertEquals(20.0, ttcalc.person1leaveTime - ttcalc.person1enterTime, MatsimTestUtils.EPSILON, "Person 1 should travel for 20 seconds."); + assertEquals(10.0 + 1.0, ttcalc.person2leaveTime - ttcalc.person2enterTime, MatsimTestUtils.EPSILON, "Person 2 should travel for 11 seconds."); } @@ -249,9 +249,9 @@ public void reset(int iteration) {} @Override public void handleEvent(LinkEnterEvent event) { if (id2.equals(event.getLinkId())) - Assert.assertEquals(1.0, event.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(1.0, event.getTime(), MatsimTestUtils.EPSILON); if (id3.equals(event.getLinkId())) - Assert.fail("Link 3 should never be reached as capacity of link 2 is set to 0"); + Assertions.fail("Link 3 should never be reached as capacity of link 2 is set to 0"); } }); @@ -261,9 +261,9 @@ public void reset(int iteration) {} @Override public void handleEvent(PersonStuckEvent event) { - Assert.assertEquals(id2, event.getLinkId()); - Assert.assertEquals(simEndTime, event.getTime(), MatsimTestUtils.EPSILON); - Assert.assertEquals(personId, event.getPersonId()); + Assertions.assertEquals(id2, event.getLinkId()); + Assertions.assertEquals(simEndTime, event.getTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(personId, event.getPersonId()); } }); diff --git a/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java b/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java index 55ca134f315..3311be000ac 100644 --- a/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java +++ b/matsim/src/test/java/org/matsim/lanes/data/LanesReaderWriterTest.java @@ -19,8 +19,8 @@ * *********************************************************************** */ package org.matsim.lanes.data; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; import java.util.ArrayList; import java.util.List; diff --git a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java index a76a672ff7a..b0ee67d400c 100644 --- a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java +++ b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java @@ -27,8 +27,7 @@ import java.util.Map; import jakarta.inject.Inject; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.runner.RunWith; @@ -110,40 +109,40 @@ public void notifyShutdown(ShutdownEvent event) { if ( config.routing().getAccessEgressType().equals(AccessEgressType.none) ) { { Double[] array = result.get(ScoreItem.worst).values().toArray(new Double[0]) ; - Assert.assertEquals(64.75686659291274, array[0], DELTA); - Assert.assertEquals(64.78366379257605, array[1], DELTA); + Assertions.assertEquals(64.75686659291274, array[0], DELTA); + Assertions.assertEquals(64.78366379257605, array[1], DELTA); } { Double[] array = result.get(ScoreItem.best).values().toArray(new Double[0]) ; - Assert.assertEquals(64.75686659291274, array[0], DELTA); - Assert.assertEquals(64.84180132563583, array[1], DELTA); + Assertions.assertEquals(64.75686659291274, array[0], DELTA); + Assertions.assertEquals(64.84180132563583, array[1], DELTA); }{ Double[] array = result.get(ScoreItem.average).values().toArray(new Double[0]) ; - Assert.assertEquals(64.75686659291274, array[0], DELTA); - Assert.assertEquals(64.81273255910591, array[1], DELTA); + Assertions.assertEquals(64.75686659291274, array[0], DELTA); + Assertions.assertEquals(64.81273255910591, array[1], DELTA); }{ Double[] array = result.get(ScoreItem.executed).values().toArray(new Double[0]) ; - Assert.assertEquals(64.75686659291274, array[0], DELTA); - Assert.assertEquals(64.84180132563583, array[1], DELTA); + Assertions.assertEquals(64.75686659291274, array[0], DELTA); + Assertions.assertEquals(64.84180132563583, array[1], DELTA); } } else { // yyyy these change with the access/egress car router, but I cannot say if the magnitude of change is plausible. kai, feb'16 // if(config.qsim().isUsingFastCapacityUpdate()) { { Double[] array = result.get(ScoreItem.worst).values().toArray(new Double[0]) ; - Assert.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[0], array[0], DELTA); - Assert.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[1], array[1], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[0], array[0], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[1], array[1], DELTA); }{ Double[] array = result.get(ScoreItem.best).values().toArray(new Double[0]) ; - Assert.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[0], array[0], DELTA); - Assert.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[1], array[1], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[0], array[0], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[1], array[1], DELTA); }{ Double[] array = result.get(ScoreItem.average).values().toArray(new Double[0]) ; - Assert.assertEquals(new double[]{53.18953957492432, 45.9741777194131}[0], array[0], DELTA); - Assert.assertEquals(new double[]{53.18953957492432, 45.9741777194131}[1], array[1], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 45.9741777194131}[0], array[0], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 45.9741777194131}[1], array[1], DELTA); }{ Double[] array = result.get(ScoreItem.executed).values().toArray(new Double[0]) ; - Assert.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[0], array[0], DELTA); - Assert.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[1], array[1], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[0], array[0], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[1], array[1], DELTA); } // } else { // { diff --git a/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java b/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java index a2aa6eaf190..a7dfc337995 100644 --- a/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java +++ b/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java @@ -19,8 +19,8 @@ package org.matsim.other; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -58,10 +58,10 @@ final void testHttpFromSvn() { Network network = scenario.getNetwork(); // 3 pt nodes and 4 x 4 car nodes - Assert.assertEquals(3 + 4 * 4, network.getNodes().size()); + Assertions.assertEquals(3 + 4 * 4, network.getNodes().size()); // 6 pt links and 3 links * 2 directions * 4 times in parallel * 2 (horizontally and vertically) - Assert.assertEquals(6 + 3 * 2 * 4 * 2, network.getLinks().size()); + Assertions.assertEquals(6 + 3 * 2 * 4 * 2, network.getLinks().size()); } @Test @@ -78,10 +78,10 @@ final void testHttpsFromSvn() { Network network = scenario.getNetwork(); // 3 pt nodes and 4 x 4 car nodes - Assert.assertEquals(3 + 4 * 4, network.getNodes().size()); + Assertions.assertEquals(3 + 4 * 4, network.getNodes().size()); // 6 pt links and 3 links * 2 directions * 4 times in parallel * 2 (horizontally and vertically) - Assert.assertEquals(6 + 3 * 2 * 4 * 2, network.getLinks().size()); + Assertions.assertEquals(6 + 3 * 2 * 4 * 2, network.getLinks().size()); } } diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java index bcf1d9d33ee..4f65ed8e50d 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java @@ -24,7 +24,7 @@ import java.util.Collection; import java.util.List; import java.util.Random; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -482,17 +482,17 @@ void testMutatedTrips() { final List newTrips = TripStructureUtils.getTrips( plan ); - Assert.assertEquals( - "number of trips changed with mode mutation!?", + Assertions.assertEquals( initNTrips, - newTrips.size()); + newTrips.size(), + "number of trips changed with mode mutation!?"); final Collection newSubtours = TripStructureUtils.getSubtours( plan ); - Assert.assertEquals( - "number of subtours changed with mode mutation!?", + Assertions.assertEquals( initSubtours.size(), - newSubtours.size()); + newSubtours.size(), + "number of subtours changed with mode mutation!?"); final List mutated = new ArrayList(); for ( Subtour newSubtour : newSubtours ) { @@ -501,9 +501,9 @@ void testMutatedTrips() { } } - Assert.assertFalse( - "no mutated subtours", - mutated.isEmpty() ); + Assertions.assertFalse( + mutated.isEmpty(), + "no mutated subtours" ); int nMutatedWithoutMutatedFather = 0; for ( Subtour s : mutated ) { @@ -512,17 +512,17 @@ void testMutatedTrips() { } for ( Trip t : s.getTrips() ) { - Assert.assertEquals( - "unexpected mutated trip length", + Assertions.assertEquals( 1, - t.getTripElements().size()); + t.getTripElements().size(), + "unexpected mutated trip length"); } } - Assert.assertEquals( - "unexpected number of roots in mutated subtours", + Assertions.assertEquals( 1, - nMutatedWithoutMutatedFather); + nMutatedWithoutMutatedFather, + "unexpected number of roots in mutated subtours"); } } } diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java index 95030f763d7..cac43bb101c 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java @@ -24,7 +24,7 @@ import java.util.Collection; import java.util.List; import java.util.Random; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -133,17 +133,17 @@ void testMutatedTrips() { final List newTrips = TripStructureUtils.getTrips( plan ); - Assert.assertEquals( - "number of trips changed with mode mutation!?", + Assertions.assertEquals( initNTrips, - newTrips.size()); + newTrips.size(), + "number of trips changed with mode mutation!?"); final Collection newSubtours = TripStructureUtils.getSubtours( plan ); - Assert.assertEquals( - "number of subtours changed with mode mutation!?", + Assertions.assertEquals( initSubtours.size(), - newSubtours.size()); + newSubtours.size(), + "number of subtours changed with mode mutation!?"); final List mutated = new ArrayList(); for ( Subtour newSubtour : newSubtours ) { @@ -152,9 +152,9 @@ void testMutatedTrips() { } } - Assert.assertFalse( - "no mutated subtours", - mutated.isEmpty() ); + Assertions.assertFalse( + mutated.isEmpty(), + "no mutated subtours" ); int nMutatedWithoutMutatedFather = 0; for ( Subtour s : mutated ) { @@ -163,17 +163,17 @@ void testMutatedTrips() { } for ( Trip t : s.getTrips() ) { - Assert.assertEquals( - "unexpected mutated trip length", + Assertions.assertEquals( 1, - t.getTripElements().size()); + t.getTripElements().size(), + "unexpected mutated trip length"); } } - Assert.assertEquals( - "unexpected number of roots in mutated subtours", + Assertions.assertEquals( 1, - nMutatedWithoutMutatedFather); + nMutatedWithoutMutatedFather, + "unexpected number of roots in mutated subtours"); for ( Subtour subtour : newSubtours ) { @@ -223,16 +223,16 @@ private void checkSubtour(Subtour subtour) { } if (atLeastOneSubtourWithDifferentChainBasedModes) { - Assert.fail("Two different modes during one subtour where one of the two different modes is a chain-based mode."); + Assertions.fail("Two different modes during one subtour where one of the two different modes is a chain-based mode."); } if (this.probaForRandomSingleTripMode > 0.) { if (atLeastOneSubtourWithDifferentNonChainBasedModes == false) { - Assert.fail("There is not a single subtour with different non-chain-based modes even though the probability for random single trip mode is " + this.probaForRandomSingleTripMode); + Assertions.fail("There is not a single subtour with different non-chain-based modes even though the probability for random single trip mode is " + this.probaForRandomSingleTripMode); } } else { if (atLeastOneSubtourWithDifferentNonChainBasedModes == true) { - Assert.fail("There is at least one subtour with different non-chain-based modes even though the probability for random single trip mode is " + this.probaForRandomSingleTripMode); + Assertions.fail("There is at least one subtour with different non-chain-based modes even though the probability for random single trip mode is " + this.probaForRandomSingleTripMode); } } } diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java index 091cb019655..e6dc7997e19 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java @@ -21,7 +21,7 @@ package org.matsim.population.algorithms; import static org.assertj.core.api.Assertions.assertThat; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; import java.util.Arrays; @@ -197,9 +197,9 @@ void testSingleTripSubtourHandling() { testee.run(plan); assertEquals( - "unexpected plan size", 3, - plan.getPlanElements().size()); + plan.getPlanElements().size(), + "unexpected plan size"); final Leg newLeg = (Leg) plan.getPlanElements().get( 1 ); @@ -214,11 +214,11 @@ void testSingleTripSubtourHandling() { } } assertTrue( + hasCar && hasPt && hasWalk, "expected subtours with car, pt and walk, got"+ (hasCar ? " car" : " NO car")+","+ (hasPt ? " pt" : " NO pt")+","+ - (hasWalk ? " walk" : " NO walk"), - hasCar && hasPt && hasWalk); + (hasWalk ? " walk" : " NO walk")); } { // test with special single trip subtour settings testee.setSingleTripSubtourModes(new String[] {"pt", "walk"}); @@ -230,9 +230,9 @@ void testSingleTripSubtourHandling() { testee.run(plan); assertEquals( - "unexpected plan size", 3, - plan.getPlanElements().size()); + plan.getPlanElements().size(), + "unexpected plan size"); final Leg newLeg = (Leg) plan.getPlanElements().get( 1 ); @@ -247,11 +247,11 @@ void testSingleTripSubtourHandling() { } } assertTrue( + !hasCar && hasPt && hasWalk, "expected subtours with NO car, pt and walk, got"+ (hasCar ? " car" : " NO car")+","+ (hasPt ? " pt" : " NO pt")+","+ - (hasWalk ? " walk" : " NO walk"), - !hasCar && hasPt && hasWalk); + (hasWalk ? " walk" : " NO walk")); } } @@ -401,17 +401,17 @@ private void testCarDoesntTeleport(Network network, String originalMode, String Id nextLocation = nextActivity.getLinkId(); if (nextLeg.getMode().equals(TransportMode.car)) { assertEquals( - "wrong car location at leg "+legCount+" in "+plan.getPlanElements(), currentLocation, - carLocation); + carLocation, + "wrong car location at leg "+legCount+" in "+plan.getPlanElements()); carLocation = nextLocation; } currentLocation = nextLocation; } assertEquals( - "wrong car location at the end of "+plan.getPlanElements(), firstLocation, - carLocation); + carLocation, + "wrong car location at the end of "+plan.getPlanElements()); } } @@ -435,17 +435,17 @@ private void testCarDoesntTeleport(ActivityFacilities facilities, String origina Id nextLocation = nextActivity.getLinkId(); if (nextLeg.getMode().equals(TransportMode.car)) { assertEquals( - "wrong car location at leg "+legCount+" in "+plan.getPlanElements(), currentLocation, - carLocation); + carLocation, + "wrong car location at leg "+legCount+" in "+plan.getPlanElements()); carLocation = nextLocation; } currentLocation = nextLocation; } assertEquals( - "wrong car location at the end of "+plan.getPlanElements(), firstLocation, - carLocation); + carLocation, + "wrong car location at the end of "+plan.getPlanElements()); } } @@ -460,9 +460,9 @@ private static void assertSubTourMutated( TripStructureUtils.getSubtours( plan ); assertEquals( - "number of subtour changed", originalSubtours.size(), - mutatedSubtours.size()); + mutatedSubtours.size(), + "number of subtour changed"); final List mutateds = new ArrayList(); for (Subtour mutated : mutatedSubtours) { @@ -472,14 +472,14 @@ private static void assertSubTourMutated( for (Trip trip : mutated.getTripsWithoutSubSubtours()) { if ( expectedMode.equals( trip.getLegsOnly().get( 0 ).getMode() ) ) { assertTrue( - "inconsistent mode chain", - isFirst || containsMutatedMode ); + isFirst || containsMutatedMode, + "inconsistent mode chain" ); containsMutatedMode = true; } else { assertFalse( - "inconsistent mode chain", - containsMutatedMode ); + containsMutatedMode, + "inconsistent mode chain" ); } isFirst = false; } @@ -488,8 +488,8 @@ private static void assertSubTourMutated( } assertFalse( - "no mutated subtour", - mutateds.isEmpty() ); + mutateds.isEmpty(), + "no mutated subtour" ); int nMutatedWithoutMutatedFather = 0; for ( Subtour s : mutateds ) { @@ -499,9 +499,9 @@ private static void assertSubTourMutated( } assertEquals( - "unexpected number of roots in mutated subtours", 1, - nMutatedWithoutMutatedFather); + nMutatedWithoutMutatedFather, + "unexpected number of roots in mutated subtours"); } private static Plan createPlan(ActivityFacilities facilities, String facString, String mode) { diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java index 3e9b98977f7..5813718f3fb 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeTest.java @@ -20,7 +20,7 @@ package org.matsim.population.algorithms; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.Random; @@ -60,7 +60,7 @@ void testRandomChoice() { String previousMode = leg.getMode(); for (int i = 0; i < 10; i++) { algo.run(plan); - assertNotSame("leg mode must have changed.", previousMode, leg.getMode()); + assertNotSame(previousMode, leg.getMode(), "leg mode must have changed."); previousMode = leg.getMode(); if (TransportMode.car.equals(previousMode)) { foundCarMode = true; @@ -72,9 +72,9 @@ void testRandomChoice() { fail("unexpected mode: " + previousMode); } } - assertTrue("expected to find car-mode", foundCarMode); - assertTrue("expected to find pt-mode", foundPtMode); - assertTrue("expected to find walk-mode", foundWalkMode); + assertTrue(foundCarMode, "expected to find car-mode"); + assertTrue(foundPtMode, "expected to find pt-mode"); + assertTrue(foundWalkMode, "expected to find walk-mode"); } @Test @@ -90,7 +90,7 @@ void testRandomChoiceWithinListedModesOnly() { String previousMode = leg.getMode(); for (int i = 0; i < 10; i++) { algo.run(plan); - assertNotSame("leg mode must have changed.", previousMode, leg.getMode()); + assertNotSame(previousMode, leg.getMode(), "leg mode must have changed."); previousMode = leg.getMode(); if (TransportMode.car.equals(previousMode)) { foundCarMode = true; @@ -102,9 +102,9 @@ void testRandomChoiceWithinListedModesOnly() { fail("unexpected mode: " + previousMode); } } - assertTrue("expected to find car-mode", foundCarMode); - assertTrue("expected to find pt-mode", foundPtMode); - assertTrue("expected to find walk-mode", foundWalkMode); + assertTrue(foundCarMode, "expected to find car-mode"); + assertTrue(foundPtMode, "expected to find pt-mode"); + assertTrue(foundWalkMode, "expected to find walk-mode"); } @Test @@ -116,7 +116,7 @@ void testRandomChoiceWithinListedModesOnlyWorks() { PopulationUtils.createAndAddActivityFromCoord(plan, "work", new Coord((double) 0, (double) 0)); String previousMode = leg.getMode(); algo.run(plan); - assertSame("leg mode must have changed.", previousMode, leg.getMode()); + assertSame(previousMode, leg.getMode(), "leg mode must have changed."); } @@ -152,9 +152,9 @@ void testMultipleLegs() { PopulationUtils.createAndAddLeg( plan, TransportMode.car ); PopulationUtils.createAndAddActivityFromCoord(plan, "home", new Coord((double) 0, (double) 0)); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode()); - assertEquals("unexpected leg mode in leg 2.", TransportMode.pt, ((Leg) plan.getPlanElements().get(3)).getMode()); - assertEquals("unexpected leg mode in leg 3.", TransportMode.pt, ((Leg) plan.getPlanElements().get(5)).getMode()); + assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); + assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(3)).getMode(), "unexpected leg mode in leg 2."); + assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(5)).getMode(), "unexpected leg mode in leg 3."); } @Test @@ -168,11 +168,11 @@ void testIgnoreCarAvailability_Never() { PopulationUtils.createAndAddLeg( plan, TransportMode.pt ); PopulationUtils.createAndAddActivityFromCoord(plan, "work", new Coord((double) 0, (double) 0)); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); } @Test @@ -186,7 +186,7 @@ void testIgnoreCarAvailability_Never_noChoice() { PopulationUtils.createAndAddLeg( plan, TransportMode.pt ); PopulationUtils.createAndAddActivityFromCoord(plan, "work", new Coord((double) 0, (double) 0)); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); } @Test @@ -200,13 +200,13 @@ void testIgnoreCarAvailability_Always() { PopulationUtils.createAndAddLeg( plan, TransportMode.pt ); PopulationUtils.createAndAddActivityFromCoord(plan, "work", new Coord((double) 0, (double) 0)); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.car, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.car, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.car, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.car, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); } } diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java index c8e4b31cefa..4acfb093c05 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java @@ -20,13 +20,10 @@ package org.matsim.population.algorithms; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.fail; import java.util.Random; -import org.junit.Assert; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -68,9 +65,9 @@ void testRandomChoice() { fail("unexpected mode: " + mode); } } - assertTrue("expected to find car-mode", foundCarMode); - assertTrue("expected to find pt-mode", foundPtMode); - assertTrue("expected to find walk-mode", foundWalkMode); + assertTrue(foundCarMode, "expected to find car-mode"); + assertTrue(foundPtMode, "expected to find pt-mode"); + assertTrue(foundWalkMode, "expected to find walk-mode"); } @@ -97,9 +94,9 @@ void testRandomChoiceWithListedModesOnly() { fail("unexpected mode: " + mode); } } - assertTrue("expected to find car-mode", foundCarMode); - assertTrue("expected to find pt-mode", foundPtMode); - assertTrue("expected to find walk-mode", foundWalkMode); + assertTrue(foundCarMode, "expected to find car-mode"); + assertTrue(foundPtMode, "expected to find pt-mode"); + assertTrue(foundWalkMode, "expected to find walk-mode"); } @Test @@ -111,7 +108,7 @@ void testRandomChoiceWithListedModesOnlyAndDifferentFromMode() { PopulationUtils.createAndAddActivityFromCoord(plan, "work", new Coord((double) 0, (double) 0)); algo.run(plan); String mode = leg.getMode(); - Assert.assertSame(TransportMode.car, mode); + Assertions.assertSame(TransportMode.car, mode); } @Test @@ -186,13 +183,13 @@ void testIgnoreCarAvailability_Never() { PopulationUtils.createAndAddLeg( plan, TransportMode.pt ); PopulationUtils.createAndAddActivityFromCoord(plan, "work", new Coord((double) 0, (double) 0)); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); } @Test @@ -206,7 +203,7 @@ void testIgnoreCarAvailability_Never_noChoice() { PopulationUtils.createAndAddLeg( plan, TransportMode.pt ); PopulationUtils.createAndAddActivityFromCoord(plan, "work", new Coord((double) 0, (double) 0)); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); } @Test @@ -220,13 +217,13 @@ void testIgnoreCarAvailability_Always() { PopulationUtils.createAndAddLeg( plan, TransportMode.pt ); PopulationUtils.createAndAddActivityFromCoord(plan, "work", new Coord((double) 0, (double) 0)); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.car, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.car, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.pt, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.car, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.car, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); algo.run(plan); - assertEquals("unexpected leg mode in leg 1.", TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode()); + assertEquals(TransportMode.bike, ((Leg) plan.getPlanElements().get(1)).getMode(), "unexpected leg mode in leg 1."); } } diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ParallelPersonAlgorithmRunnerTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ParallelPersonAlgorithmRunnerTest.java index 319411270e0..5090918a377 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ParallelPersonAlgorithmRunnerTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ParallelPersonAlgorithmRunnerTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -54,11 +54,11 @@ void testNumberOfThreads() { PersonAlgorithmTester algo = new PersonAlgorithmTester(); PersonAlgoProviderTester tester = new PersonAlgoProviderTester(algo); ParallelPersonAlgorithmUtils.run(population, 2, tester); - Assert.assertEquals(2, tester.counter); + Assertions.assertEquals(2, tester.counter); PersonAlgoProviderTester tester2 = new PersonAlgoProviderTester(algo); ParallelPersonAlgorithmUtils.run(population, 4, tester2); - Assert.assertEquals(4, tester2.counter); + Assertions.assertEquals(4, tester2.counter); } /** @@ -77,7 +77,7 @@ void testNofPersons() { final PersonAlgorithmTester tester = new PersonAlgorithmTester(); ParallelPersonAlgorithmUtils.run(population, 2, tester); - Assert.assertEquals(100, tester.personIds.size()); + Assertions.assertEquals(100, tester.personIds.size()); // test that all 100 different persons got handled, and not 1 person 100 times int sum = 0; @@ -87,7 +87,7 @@ void testNofPersons() { sumRef += i; sum += Integer.parseInt(population.getPersons().get(tester.personIds.get(i)).getId().toString()); } - Assert.assertEquals(sumRef, sum); + Assertions.assertEquals(sumRef, sum); } @Test @@ -105,7 +105,7 @@ public void run(Person person) { person.getPlans().get(0).setScore(null); // this will result in an IndexOutOfBoundsException } }); - Assert.fail("Expected Exception, got none."); + Assertions.fail("Expected Exception, got none."); } catch (RuntimeException e) { LogManager.getLogger(ParallelPersonAlgorithmRunnerTest.class).info("Catched expected exception.", e); } diff --git a/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java b/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java index e4889cb2097..02181c75683 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java @@ -19,8 +19,8 @@ * *********************************************************************** */ package org.matsim.population.algorithms; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.ArrayList; import java.util.Arrays; @@ -141,13 +141,13 @@ private static void assertListsAreCompatible( final List expected, final Collection actual) { assertEquals( - expected+" and "+actual+" have incompatible sizes for fixture "+fixtureName, expected.size(), - actual.size()); + actual.size(), + expected+" and "+actual+" have incompatible sizes for fixture "+fixtureName); assertTrue( - expected+" and "+actual+" are not compatible for fixture "+fixtureName, - expected.containsAll( actual )); + expected.containsAll( actual ), + expected+" and "+actual+" are not compatible for fixture "+fixtureName); } } diff --git a/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java b/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java index f7766a370df..883bef1aa26 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java @@ -22,8 +22,8 @@ import java.util.HashSet; import java.util.Set; -import org.junit.Assert; import org.junit.Ignore; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -85,8 +85,8 @@ void testRun_MultimodalNetwork() { new PersonPrepareForSim(new DummyRouter(), sc).run(person); - Assert.assertEquals(link1id, activity1.getLinkId()); - Assert.assertEquals(link1id, activity2.getLinkId()); // must also be linked to l1, as l2 has no car mode + Assertions.assertEquals(link1id, activity1.getLinkId()); + Assertions.assertEquals(link1id, activity2.getLinkId()); // must also be linked to l1, as l2 has no car mode } @Test @@ -117,8 +117,8 @@ void testRun_MultimodalScenario() { new PersonPrepareForSim(new DummyRouter(), sc).run(person); - Assert.assertEquals(link1id, a1.getLinkId()); - Assert.assertEquals(link1id, a2.getLinkId()); // must also be linked to l1, as l2 has no car mode + Assertions.assertEquals(link1id, a1.getLinkId()); + Assertions.assertEquals(link1id, a2.getLinkId()); // must also be linked to l1, as l2 has no car mode } @Test @@ -145,8 +145,9 @@ void testSingleLegTripRoutingMode() { new PersonPrepareForSim(new DummyRouter(), sc).run(person); - Assert.assertEquals("wrong routing mode!", TransportMode.pt, - TripStructureUtils.getRoutingMode(leg)); + Assertions.assertEquals(TransportMode.pt, + TripStructureUtils.getRoutingMode(leg), + "wrong routing mode!"); } // test routing mode set @@ -167,8 +168,9 @@ void testSingleLegTripRoutingMode() { new PersonPrepareForSim(new DummyRouter(), sc).run(person); - Assert.assertEquals("wrong routing mode!", TransportMode.pt, - TripStructureUtils.getRoutingMode(leg)); + Assertions.assertEquals(TransportMode.pt, + TripStructureUtils.getRoutingMode(leg), + "wrong routing mode!"); } } @@ -204,7 +206,7 @@ void testSingleFallbackModeLegTrip() { try { new PersonPrepareForSim(new DummyRouter(), sc).run(person); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} } @@ -226,9 +228,10 @@ void testSingleFallbackModeLegTrip() { new PersonPrepareForSim(new DummyRouter(), sc).run(person); - Assert.assertEquals("wrong leg mode replacement", "drt67_fallback", leg.getMode()); - Assert.assertEquals("wrong routing mode set", "drt67_fallback", - TripStructureUtils.getRoutingMode(leg)); + Assertions.assertEquals("drt67_fallback", leg.getMode(), "wrong leg mode replacement"); + Assertions.assertEquals("drt67_fallback", + TripStructureUtils.getRoutingMode(leg), + "wrong routing mode set"); } } @@ -268,14 +271,14 @@ void testCorrectTripsRemainUnchanged() { new PersonPrepareForSim(new DummyRouter(), sc).run(person); // Check leg modes remain unchanged - Assert.assertEquals("wrong routing mode!", TransportMode.walk, leg1.getMode()); - Assert.assertEquals("wrong routing mode!", TransportMode.car, leg2.getMode()); - Assert.assertEquals("wrong routing mode!", TransportMode.walk, leg3.getMode()); + Assertions.assertEquals(TransportMode.walk, leg1.getMode(), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.car, leg2.getMode(), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.walk, leg3.getMode(), "wrong routing mode!"); // Check routing mode: - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg1)); - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg2)); - Assert.assertEquals("wrong routing mode!", TransportMode.car, TripStructureUtils.getRoutingMode(leg3)); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg1), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg2), "wrong routing mode!"); + Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg3), "wrong routing mode!"); } // test complicated intermodal trip with consistent routing modes passes unchanged @@ -345,17 +348,17 @@ void testCorrectTripsRemainUnchanged() { new PersonPrepareForSim(new DummyRouter(), sc).run(person); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg1)); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg2)); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg3)); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg4)); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg5)); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg6)); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg7)); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg8)); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg9)); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg10)); - Assert.assertEquals("wrong routing mode set", TransportMode.pt, TripStructureUtils.getRoutingMode(leg11)); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg1), "wrong routing mode set"); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg2), "wrong routing mode set"); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg3), "wrong routing mode set"); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg4), "wrong routing mode set"); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg5), "wrong routing mode set"); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg6), "wrong routing mode set"); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg7), "wrong routing mode set"); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg8), "wrong routing mode set"); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg9), "wrong routing mode set"); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg10), "wrong routing mode set"); + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg11), "wrong routing mode set"); } } @@ -392,7 +395,7 @@ void testRoutingModeConsistency() { try { new PersonPrepareForSim(new DummyRouter(), sc).run(person); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} } @@ -423,7 +426,7 @@ void testRoutingModeConsistency() { try { new PersonPrepareForSim(new DummyRouter(), sc).run(person); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} } } @@ -467,13 +470,13 @@ void testReplaceExperimentalTransitRoute() { new PersonPrepareForSim(new DummyRouter(), sc).run(person); - Assert.assertEquals(DefaultTransitPassengerRoute.ROUTE_TYPE, leg.getRoute().getRouteType()); - Assert.assertEquals(startLink, leg.getRoute().getStartLinkId()); - Assert.assertEquals(endLink, leg.getRoute().getEndLinkId()); - Assert.assertEquals(stopFacility1.getId(), ((DefaultTransitPassengerRoute) leg.getRoute()).getAccessStopId()); - Assert.assertEquals(stopFacility2.getId(), ((DefaultTransitPassengerRoute) leg.getRoute()).getEgressStopId()); - Assert.assertEquals(line, ((DefaultTransitPassengerRoute) leg.getRoute()).getLineId()); - Assert.assertEquals(route, ((DefaultTransitPassengerRoute) leg.getRoute()).getRouteId()); + Assertions.assertEquals(DefaultTransitPassengerRoute.ROUTE_TYPE, leg.getRoute().getRouteType()); + Assertions.assertEquals(startLink, leg.getRoute().getStartLinkId()); + Assertions.assertEquals(endLink, leg.getRoute().getEndLinkId()); + Assertions.assertEquals(stopFacility1.getId(), ((DefaultTransitPassengerRoute) leg.getRoute()).getAccessStopId()); + Assertions.assertEquals(stopFacility2.getId(), ((DefaultTransitPassengerRoute) leg.getRoute()).getEgressStopId()); + Assertions.assertEquals(line, ((DefaultTransitPassengerRoute) leg.getRoute()).getLineId()); + Assertions.assertEquals(route, ((DefaultTransitPassengerRoute) leg.getRoute()).getRouteId()); } private static class DummyRouter implements PlanAlgorithm { diff --git a/matsim/src/test/java/org/matsim/population/algorithms/TripsToLegsAlgorithmTest.java b/matsim/src/test/java/org/matsim/population/algorithms/TripsToLegsAlgorithmTest.java index 2cb4da8a744..4f3f75738b7 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/TripsToLegsAlgorithmTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/TripsToLegsAlgorithmTest.java @@ -19,8 +19,8 @@ * *********************************************************************** */ package org.matsim.population.algorithms; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.util.ArrayList; import java.util.Iterator; @@ -239,9 +239,9 @@ private static void performTest(final Fixture fixture) { algorithm.run( fixture.plan ); assertEquals( - "wrong structure size for fixture <<"+fixture.name+">>", fixture.expectedPlanStructure.size(), - fixture.plan.getPlanElements().size()); + fixture.plan.getPlanElements().size(), + "wrong structure size for fixture <<"+fixture.name+">>"); final Iterator expIter = fixture.expectedPlanStructure.iterator(); final Iterator actualIter = fixture.plan.getPlanElements().iterator(); @@ -252,23 +252,23 @@ private static void performTest(final Fixture fixture) { if ( actual instanceof Activity ) { assertTrue( - "incompatible Activity/Leg sequence in fixture <<"+fixture.name+">>", - expected instanceof Activity ); + expected instanceof Activity, + "incompatible Activity/Leg sequence in fixture <<"+fixture.name+">>" ); assertEquals( - "incompatible activity types in fixture <<"+fixture.name+">>", ((Activity) expected).getType(), - ((Activity) actual).getType()); + ((Activity) actual).getType(), + "incompatible activity types in fixture <<"+fixture.name+">>"); } else if ( actual instanceof Leg ) { assertTrue( - "incompatible types sequence in fixture <<"+fixture.name+">>", - expected instanceof Leg ); + expected instanceof Leg, + "incompatible types sequence in fixture <<"+fixture.name+">>" ); assertEquals( - "incompatible leg modes in fixture <<"+fixture.name+">>", ((Leg) expected).getMode(), - ((Leg) actual).getMode()); + ((Leg) actual).getMode(), + "incompatible leg modes in fixture <<"+fixture.name+">>"); } else { throw new RuntimeException( actual.getClass().getName() ); diff --git a/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java b/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java index d6b291abc83..6d640a9378c 100644 --- a/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java +++ b/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadIntegrationTest.java @@ -19,7 +19,7 @@ package org.matsim.pt.analysis; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -71,6 +71,6 @@ public void notifyStartup(StartupEvent event) { Departure departure = route.getDepartures().get(Id.create("07", Departure.class)); int load = transitload.getLoadAtDeparture(line, route, stopFacility, departure); - Assert.assertEquals("wrong number of passengers.", 4, load); + Assertions.assertEquals(4, load, "wrong number of passengers."); } } diff --git a/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadTest.java b/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadTest.java index 8e8aa411ba8..b6ecf76b5e0 100644 --- a/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadTest.java +++ b/matsim/src/test/java/org/matsim/pt/analysis/TransitLoadTest.java @@ -23,7 +23,7 @@ import java.util.Collections; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -114,48 +114,48 @@ void testTransitLoad_singleLine() { tl.handleEvent(new PersonLeavesVehicleEvent(7.45*3600-20, Id.create("ptDriver1", Person.class), vehicleIdDep1)); - Assert.assertEquals(1, tl.getLoadAtDeparture(line1, route1, stop1, dep1)); - Assert.assertEquals(2, tl.getLoadAtDeparture(line1, route1, stop2, dep1)); - Assert.assertEquals(2, tl.getLoadAtDeparture(line1, route1, stop3, dep1)); - Assert.assertEquals(2, tl.getLoadAtDeparture(line1, route1, stop4, dep1)); + Assertions.assertEquals(1, tl.getLoadAtDeparture(line1, route1, stop1, dep1)); + Assertions.assertEquals(2, tl.getLoadAtDeparture(line1, route1, stop2, dep1)); + Assertions.assertEquals(2, tl.getLoadAtDeparture(line1, route1, stop3, dep1)); + Assertions.assertEquals(2, tl.getLoadAtDeparture(line1, route1, stop4, dep1)); - Assert.assertEquals(1, tl.getLoadAtDeparture(line1, route1, 0, dep1)); - Assert.assertEquals(2, tl.getLoadAtDeparture(line1, route1, 1, dep1)); - Assert.assertEquals(2, tl.getLoadAtDeparture(line1, route1, 2, dep1)); - Assert.assertEquals(2, tl.getLoadAtDeparture(line1, route1, 3, dep1)); - Assert.assertEquals(0, tl.getLoadAtDeparture(line1, route1, 4, dep1)); + Assertions.assertEquals(1, tl.getLoadAtDeparture(line1, route1, 0, dep1)); + Assertions.assertEquals(2, tl.getLoadAtDeparture(line1, route1, 1, dep1)); + Assertions.assertEquals(2, tl.getLoadAtDeparture(line1, route1, 2, dep1)); + Assertions.assertEquals(2, tl.getLoadAtDeparture(line1, route1, 3, dep1)); + Assertions.assertEquals(0, tl.getLoadAtDeparture(line1, route1, 4, dep1)); TransitLoad.StopInformation si = tl.getDepartureStopInformation(line1, route1, stop1, dep1).get(0); - Assert.assertEquals(7.0*3600-10, si.arrivalTime, MatsimTestUtils.EPSILON); - Assert.assertEquals(7.0*3600+10, si.departureTime, MatsimTestUtils.EPSILON); - Assert.assertEquals(1, si.nOfEntering); - Assert.assertEquals(0, si.nOfLeaving); + Assertions.assertEquals(7.0*3600-10, si.arrivalTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(7.0*3600+10, si.departureTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, si.nOfEntering); + Assertions.assertEquals(0, si.nOfLeaving); si = tl.getDepartureStopInformation(line1, route1, stop2, dep1).get(0); - Assert.assertEquals(7.1*3600-25, si.arrivalTime, MatsimTestUtils.EPSILON); - Assert.assertEquals(7.1*3600+25, si.departureTime, MatsimTestUtils.EPSILON); - Assert.assertEquals(2, si.nOfEntering); - Assert.assertEquals(1, si.nOfLeaving); + Assertions.assertEquals(7.1*3600-25, si.arrivalTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(7.1*3600+25, si.departureTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(2, si.nOfEntering); + Assertions.assertEquals(1, si.nOfLeaving); si = tl.getDepartureStopInformation(line1, route1, stop3, dep1).get(0); - Assert.assertEquals(7.2*3600-15, si.arrivalTime, MatsimTestUtils.EPSILON); - Assert.assertEquals(7.2*3600+20, si.departureTime, MatsimTestUtils.EPSILON); - Assert.assertEquals(1, si.nOfEntering); - Assert.assertEquals(1, si.nOfLeaving); + Assertions.assertEquals(7.2*3600-15, si.arrivalTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(7.2*3600+20, si.departureTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(1, si.nOfEntering); + Assertions.assertEquals(1, si.nOfLeaving); si = tl.getDepartureStopInformation(line1, route1, stop4, dep1).get(0); - Assert.assertEquals(7.3*3600-20, si.arrivalTime, MatsimTestUtils.EPSILON); - Assert.assertEquals(7.3*3600+5, si.departureTime, MatsimTestUtils.EPSILON); - Assert.assertEquals(0, si.nOfEntering); - Assert.assertEquals(0, si.nOfLeaving); + Assertions.assertEquals(7.3*3600-20, si.arrivalTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(7.3*3600+5, si.departureTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0, si.nOfEntering); + Assertions.assertEquals(0, si.nOfLeaving); si = tl.getDepartureStopInformation(line1, route1, stop1, dep1).get(1); - Assert.assertEquals(7.4*3600-20, si.arrivalTime, MatsimTestUtils.EPSILON); - Assert.assertEquals(7.4*3600+5, si.departureTime, MatsimTestUtils.EPSILON); - Assert.assertEquals(0, si.nOfEntering); - Assert.assertEquals(2, si.nOfLeaving); + Assertions.assertEquals(7.4*3600-20, si.arrivalTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(7.4*3600+5, si.departureTime, MatsimTestUtils.EPSILON); + Assertions.assertEquals(0, si.nOfEntering); + Assertions.assertEquals(2, si.nOfLeaving); List siList = tl.getDepartureStopInformation(line1, route1, stop1, dep2); - Assert.assertNull(siList); + Assertions.assertNull(siList); } } diff --git a/matsim/src/test/java/org/matsim/pt/config/TransitConfigGroupTest.java b/matsim/src/test/java/org/matsim/pt/config/TransitConfigGroupTest.java index c00969cd10e..3e57e959245 100644 --- a/matsim/src/test/java/org/matsim/pt/config/TransitConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/pt/config/TransitConfigGroupTest.java @@ -20,7 +20,7 @@ package org.matsim.pt.config; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.HashSet; import java.util.Set; diff --git a/matsim/src/test/java/org/matsim/pt/router/TransitActsRemoverTest.java b/matsim/src/test/java/org/matsim/pt/router/TransitActsRemoverTest.java index e4f2d81ba07..8448d251c7d 100644 --- a/matsim/src/test/java/org/matsim/pt/router/TransitActsRemoverTest.java +++ b/matsim/src/test/java/org/matsim/pt/router/TransitActsRemoverTest.java @@ -20,8 +20,8 @@ package org.matsim.pt.router; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNull; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; diff --git a/matsim/src/test/java/org/matsim/pt/router/TransitRouterConfigTest.java b/matsim/src/test/java/org/matsim/pt/router/TransitRouterConfigTest.java index 3b2f4b585c0..ad473916ea7 100644 --- a/matsim/src/test/java/org/matsim/pt/router/TransitRouterConfigTest.java +++ b/matsim/src/test/java/org/matsim/pt/router/TransitRouterConfigTest.java @@ -19,7 +19,7 @@ package org.matsim.pt.router; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; import org.matsim.core.config.groups.ScoringConfigGroup; @@ -71,33 +71,33 @@ void testConstructor() { // a number of changes related to the fact that the opportunity cost of time is now // included in the pt routing. Either the test here or some scoring // test needs to be adapted; this seems the better place. kai/benjamin, oct'12 - Assert.assertEquals(-15.0/3600, config.getMarginalUtilityOfTravelTimePt_utl_s(), 1e-8); - Assert.assertEquals(-17.0/3600, config.getMarginalUtilityOfTravelTimeWalk_utl_s(), 1e-8); - Assert.assertEquals(-19.0/3600, config.getMarginalUtilityOfWaitingPt_utl_s(), 1e-8); + Assertions.assertEquals(-15.0/3600, config.getMarginalUtilityOfTravelTimePt_utl_s(), 1e-8); + Assertions.assertEquals(-17.0/3600, config.getMarginalUtilityOfTravelTimeWalk_utl_s(), 1e-8); + Assertions.assertEquals(-19.0/3600, config.getMarginalUtilityOfWaitingPt_utl_s(), 1e-8); - Assert.assertEquals(-2.34, config.getUtilityOfLineSwitch_utl(), 1e-8); - Assert.assertEquals(1.37 / 1.2, config.getBeelineWalkSpeed(), 1e-8); + Assertions.assertEquals(-2.34, config.getUtilityOfLineSwitch_utl(), 1e-8); + Assertions.assertEquals(1.37 / 1.2, config.getBeelineWalkSpeed(), 1e-8); - Assert.assertEquals(128.0, config.getAdditionalTransferTime(), 1e-8); - Assert.assertEquals(987.6, config.getSearchRadius(), 1e-8); - Assert.assertEquals(123.4, config.getExtensionRadius(), 1e-8); - Assert.assertEquals(23.4, config.getBeelineWalkConnectionDistance(), 1e-8); + Assertions.assertEquals(128.0, config.getAdditionalTransferTime(), 1e-8); + Assertions.assertEquals(987.6, config.getSearchRadius(), 1e-8); + Assertions.assertEquals(123.4, config.getExtensionRadius(), 1e-8); + Assertions.assertEquals(23.4, config.getBeelineWalkConnectionDistance(), 1e-8); } // test with marginal utl of time: { TransitRouterConfig config = new TransitRouterConfig(planScoring, planRouting, transitRouting, vspConfig ); - Assert.assertEquals(-15.0/3600, config.getMarginalUtilityOfTravelTimePt_utl_s(), 1e-8); - Assert.assertEquals(-17.0/3600, config.getMarginalUtilityOfTravelTimeWalk_utl_s(), 1e-8); - Assert.assertEquals(-19.0/3600, config.getMarginalUtilityOfWaitingPt_utl_s(), 1e-8); - Assert.assertEquals(-2.34, config.getUtilityOfLineSwitch_utl(), 1e-8); - Assert.assertEquals(1.37 / 1.2, config.getBeelineWalkSpeed(), 1e-8); + Assertions.assertEquals(-15.0/3600, config.getMarginalUtilityOfTravelTimePt_utl_s(), 1e-8); + Assertions.assertEquals(-17.0/3600, config.getMarginalUtilityOfTravelTimeWalk_utl_s(), 1e-8); + Assertions.assertEquals(-19.0/3600, config.getMarginalUtilityOfWaitingPt_utl_s(), 1e-8); + Assertions.assertEquals(-2.34, config.getUtilityOfLineSwitch_utl(), 1e-8); + Assertions.assertEquals(1.37 / 1.2, config.getBeelineWalkSpeed(), 1e-8); - Assert.assertEquals(128.0, config.getAdditionalTransferTime(), 1e-8); - Assert.assertEquals(987.6, config.getSearchRadius(), 1e-8); - Assert.assertEquals(123.4, config.getExtensionRadius(), 1e-8); - Assert.assertEquals(23.4, config.getBeelineWalkConnectionDistance(), 1e-8); + Assertions.assertEquals(128.0, config.getAdditionalTransferTime(), 1e-8); + Assertions.assertEquals(987.6, config.getSearchRadius(), 1e-8); + Assertions.assertEquals(123.4, config.getExtensionRadius(), 1e-8); + Assertions.assertEquals(23.4, config.getBeelineWalkConnectionDistance(), 1e-8); } } } diff --git a/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java b/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java index 86df76d670e..a4c44e2631d 100644 --- a/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java +++ b/matsim/src/test/java/org/matsim/pt/router/TransitRouterModuleTest.java @@ -2,7 +2,7 @@ import ch.sbb.matsim.routing.pt.raptor.SwissRailRaptor; import com.google.inject.Injector; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.controler.AbstractModule; @@ -37,7 +37,7 @@ public void install() { Injector injector = controler.getInjector(); TransitRouter router = injector.getInstance(TransitRouter.class); - Assert.assertEquals(SwissRailRaptor.class, router.getClass()); + Assertions.assertEquals(SwissRailRaptor.class, router.getClass()); } private static class DummyMobsim implements Mobsim { diff --git a/matsim/src/test/java/org/matsim/pt/routes/DefaultTransitPassengerRouteTest.java b/matsim/src/test/java/org/matsim/pt/routes/DefaultTransitPassengerRouteTest.java index b0dcdd68f44..3875db6a088 100644 --- a/matsim/src/test/java/org/matsim/pt/routes/DefaultTransitPassengerRouteTest.java +++ b/matsim/src/test/java/org/matsim/pt/routes/DefaultTransitPassengerRouteTest.java @@ -20,7 +20,7 @@ package org.matsim.pt.routes; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.Collections; diff --git a/matsim/src/test/java/org/matsim/pt/routes/ExperimentalTransitRouteTest.java b/matsim/src/test/java/org/matsim/pt/routes/ExperimentalTransitRouteTest.java index 68439b3b087..2f09a6e3491 100644 --- a/matsim/src/test/java/org/matsim/pt/routes/ExperimentalTransitRouteTest.java +++ b/matsim/src/test/java/org/matsim/pt/routes/ExperimentalTransitRouteTest.java @@ -20,7 +20,7 @@ package org.matsim.pt.routes; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.Collections; diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java index 57b725f2d9b..a05de0bfb4e 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/DepartureTest.java @@ -20,8 +20,8 @@ package org.matsim.pt.transitSchedule; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNull; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/MinimalTransferTimesImplTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/MinimalTransferTimesImplTest.java index f58e13bf1fd..4c6c8c0a8fc 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/MinimalTransferTimesImplTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/MinimalTransferTimesImplTest.java @@ -19,7 +19,7 @@ package org.matsim.pt.transitSchedule; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.pt.transitSchedule.api.MinimalTransferTimes; @@ -41,51 +41,51 @@ public class MinimalTransferTimesImplTest { @Test void testSetGet() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); - Assert.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); + Assertions.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); mtt.set(this.stopId1, this.stopId2, 180.0); mtt.set(this.stopId1, this.stopId3, 240.0); - Assert.assertEquals(180.0, mtt.get(this.stopId1, this.stopId2), 0.0); - Assert.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3), 0.0); + Assertions.assertEquals(180.0, mtt.get(this.stopId1, this.stopId2), 0.0); + Assertions.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3), 0.0); // overwrite a value mtt.set(this.stopId1, this.stopId2, 300.0); - Assert.assertEquals(300.0, mtt.get(this.stopId1, this.stopId2), 0.0); + Assertions.assertEquals(300.0, mtt.get(this.stopId1, this.stopId2), 0.0); - Assert.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId4), 0.0); + Assertions.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId4), 0.0); } @Test void testGetWithDefault() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); double defaultSeconds = 60.0; - Assert.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); - Assert.assertEquals(60.0, mtt.get(this.stopId1, this.stopId2, defaultSeconds), 0.0); + Assertions.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); + Assertions.assertEquals(60.0, mtt.get(this.stopId1, this.stopId2, defaultSeconds), 0.0); mtt.set(this.stopId1, this.stopId2, 180.0); mtt.set(this.stopId1, this.stopId3, 240.0); - Assert.assertEquals(180.0, mtt.get(this.stopId1, this.stopId2, defaultSeconds), 0.0); - Assert.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3, defaultSeconds), 0.0); + Assertions.assertEquals(180.0, mtt.get(this.stopId1, this.stopId2, defaultSeconds), 0.0); + Assertions.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3, defaultSeconds), 0.0); - Assert.assertEquals(defaultSeconds, mtt.get(this.stopId1, this.stopId4, defaultSeconds), 0.0); + Assertions.assertEquals(defaultSeconds, mtt.get(this.stopId1, this.stopId4, defaultSeconds), 0.0); } @Test void testRemove() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); - Assert.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); + Assertions.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); mtt.set(this.stopId1, this.stopId2, 180.0); mtt.set(this.stopId1, this.stopId3, 240.0); - Assert.assertEquals(180.0, mtt.get(this.stopId1, this.stopId2), 0.0); - Assert.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3), 0.0); + Assertions.assertEquals(180.0, mtt.get(this.stopId1, this.stopId2), 0.0); + Assertions.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3), 0.0); - Assert.assertEquals(180.0, mtt.remove(this.stopId1, this.stopId2), 0.0); - Assert.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); - Assert.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3), 0.0); + Assertions.assertEquals(180.0, mtt.remove(this.stopId1, this.stopId2), 0.0); + Assertions.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId2), 0.0); + Assertions.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3), 0.0); - Assert.assertEquals(Double.NaN, mtt.remove(this.stopId1, this.stopId4), 0.0); // we never set it, let's not throw an exception - Assert.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId4), 0.0); + Assertions.assertEquals(Double.NaN, mtt.remove(this.stopId1, this.stopId4), 0.0); // we never set it, let's not throw an exception + Assertions.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId4), 0.0); } @Test @@ -94,14 +94,14 @@ void testNotBidirection() { mtt.set(this.stopId1, this.stopId2, 180.0); mtt.set(this.stopId1, this.stopId3, 240.0); - Assert.assertEquals(180.0, mtt.get(this.stopId1, this.stopId2), 0.0); - Assert.assertEquals(Double.NaN, mtt.get(this.stopId2, this.stopId1), 0.0); - Assert.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3), 0.0); - Assert.assertEquals(Double.NaN, mtt.get(this.stopId3, this.stopId1), 0.0); + Assertions.assertEquals(180.0, mtt.get(this.stopId1, this.stopId2), 0.0); + Assertions.assertEquals(Double.NaN, mtt.get(this.stopId2, this.stopId1), 0.0); + Assertions.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3), 0.0); + Assertions.assertEquals(Double.NaN, mtt.get(this.stopId3, this.stopId1), 0.0); mtt.set(this.stopId3, this.stopId1, 120.0); - Assert.assertEquals(120.0, mtt.get(this.stopId3, this.stopId1), 0.0); - Assert.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3), 0.0); + Assertions.assertEquals(120.0, mtt.get(this.stopId3, this.stopId1), 0.0); + Assertions.assertEquals(240.0, mtt.get(this.stopId1, this.stopId3), 0.0); } @Test @@ -110,13 +110,13 @@ void testNotTransitive() { mtt.set(this.stopId1, this.stopId2, 180.0); mtt.set(this.stopId2, this.stopId3, 240.0); - Assert.assertEquals(180.0, mtt.get(this.stopId1, this.stopId2), 0.0); - Assert.assertEquals(240.0, mtt.get(this.stopId2, this.stopId3), 0.0); - Assert.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId3), 0.0); - Assert.assertEquals(Double.NaN, mtt.get(this.stopId3, this.stopId1), 0.0); + Assertions.assertEquals(180.0, mtt.get(this.stopId1, this.stopId2), 0.0); + Assertions.assertEquals(240.0, mtt.get(this.stopId2, this.stopId3), 0.0); + Assertions.assertEquals(Double.NaN, mtt.get(this.stopId1, this.stopId3), 0.0); + Assertions.assertEquals(Double.NaN, mtt.get(this.stopId3, this.stopId1), 0.0); mtt.set(this.stopId1, this.stopId3, 480.0); - Assert.assertEquals(480.0, mtt.get(this.stopId1, this.stopId3), 0.0); + Assertions.assertEquals(480.0, mtt.get(this.stopId1, this.stopId3), 0.0); } @Test @@ -125,30 +125,30 @@ void testIterator_empty() { MinimalTransferTimes.MinimalTransferTimesIterator iter = mtt.iterator(); - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); try { iter.getFromStopId(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (NoSuchElementException expected) {} try { iter.getToStopId(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (NoSuchElementException expected) {} try { iter.getSeconds(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (NoSuchElementException expected) {} try { iter.next(); - Assert.fail("expected Exception"); + Assertions.fail("expected Exception"); } catch (NoSuchElementException expected) {} try { iter.getFromStopId(); // there should still be an exception after calling next() - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (NoSuchElementException expected) {} } @@ -158,32 +158,32 @@ void testIterator() { MinimalTransferTimes mtt = new MinimalTransferTimesImpl(); MinimalTransferTimes.MinimalTransferTimesIterator iter = mtt.iterator(); - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); mtt.set(this.stopId1, this.stopId2, 120.0); iter = mtt.iterator(); - Assert.assertTrue(iter.hasNext()); + Assertions.assertTrue(iter.hasNext()); try { iter.getFromStopId(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (NoSuchElementException expected) {} iter.next(); - Assert.assertEquals(this.stopId1, iter.getFromStopId()); - Assert.assertEquals(this.stopId2, iter.getToStopId()); - Assert.assertEquals(120, iter.getSeconds(), 0.0); + Assertions.assertEquals(this.stopId1, iter.getFromStopId()); + Assertions.assertEquals(this.stopId2, iter.getToStopId()); + Assertions.assertEquals(120, iter.getSeconds(), 0.0); - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); try { iter.next(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (NoSuchElementException expected) {} try { iter.getFromStopId(); - Assert.fail("expected Exception, got none."); + Assertions.fail("expected Exception, got none."); } catch (NoSuchElementException expected) {} mtt.set(this.stopId1, this.stopId3, 180); @@ -209,15 +209,15 @@ void testIterator() { } else if (fromStopId == this.stopId2 && toStopId == this.stopId3 && seconds == 240) { found2to3 = true; } else { - Assert.fail("found unexcpected minimal transfer time: " + fromStopId + " / " + toStopId + " / " + seconds); + Assertions.fail("found unexcpected minimal transfer time: " + fromStopId + " / " + toStopId + " / " + seconds); } if (count > 3) { - Assert.fail("too many elements in iterator."); + Assertions.fail("too many elements in iterator."); } } - Assert.assertTrue(found1to2); - Assert.assertTrue(found1to3); - Assert.assertTrue(found2to3); + Assertions.assertTrue(found1to2); + Assertions.assertTrue(found1to3); + Assertions.assertTrue(found2to3); } @@ -235,7 +235,7 @@ void testIterator_withRemove() { count++; iter.next(); } - Assert.assertEquals(3, count); + Assertions.assertEquals(3, count); mtt.remove(this.stopId2, this.stopId3); count = 0; @@ -244,7 +244,7 @@ void testIterator_withRemove() { count++; iter.next(); } - Assert.assertEquals(2, count); + Assertions.assertEquals(2, count); mtt.remove(this.stopId1, this.stopId2); count = 0; @@ -253,10 +253,10 @@ void testIterator_withRemove() { count++; iter.next(); } - Assert.assertEquals(1, count); + Assertions.assertEquals(1, count); mtt.remove(this.stopId3, this.stopId1); iter = mtt.iterator(); - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); } } \ No newline at end of file diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java index fa5bd256eb4..67720561b2e 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitLineTest.java @@ -20,7 +20,7 @@ package org.matsim.pt.transitSchedule; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; @@ -62,7 +62,7 @@ void testInitialization() { Id id = Id.create(511, TransitLine.class); TransitLine tLine = createTransitLine(id); assertNotNull(tLine); - assertEquals("different ids.", id.toString(), tLine.getId().toString()); + assertEquals(id.toString(), tLine.getId().toString(), "different ids."); } @Test diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java index 812205dc8e8..2e005b801fe 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteStopTest.java @@ -20,7 +20,7 @@ package org.matsim.pt.transitSchedule; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java index 58da3c5f807..9a92aabe151 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitRouteTest.java @@ -20,7 +20,7 @@ package org.matsim.pt.transitSchedule; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; import java.util.List; @@ -78,8 +78,8 @@ void testInitialization() { stops.add(stop); TransitRoute tRoute = createTransitRoute(id, route, stops, "train"); - assertEquals("wrong id.", id.toString(), tRoute.getId().toString()); - assertEquals("wrong route.", route, tRoute.getRoute()); + assertEquals(id.toString(), tRoute.getId().toString(), "wrong id."); + assertEquals(route, tRoute.getRoute(), "wrong route."); assertEquals(stops.size(), tRoute.getStops().size()); assertEquals(stop, tRoute.getStops().get(0)); assertEquals("train", tRoute.getTransportMode()); diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFactoryTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFactoryTest.java index 1940a5c8976..2b3747ed202 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFactoryTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFactoryTest.java @@ -23,7 +23,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -53,7 +53,7 @@ protected TransitScheduleFactory createTransitScheduleBuilder() { void testCreateTransitSchedule() { TransitScheduleFactory builder = createTransitScheduleBuilder(); TransitSchedule schedule = builder.createTransitSchedule(); - Assert.assertEquals(builder, schedule.getFactory()); + Assertions.assertEquals(builder, schedule.getFactory()); } @Test @@ -61,7 +61,7 @@ void testCreateTransitLine() { TransitScheduleFactory builder = createTransitScheduleBuilder(); Id id = Id.create(1, TransitLine.class); TransitLine line = builder.createTransitLine(id); - Assert.assertEquals(id, line.getId()); + Assertions.assertEquals(id, line.getId()); } @Test @@ -74,11 +74,11 @@ void testCreateTransitRoute() { stops.add(stop1); String mode = TransportMode.pt; TransitRoute tRoute = builder.createTransitRoute(id, route, stops, mode); - Assert.assertEquals(id, tRoute.getId()); - Assert.assertEquals(route, tRoute.getRoute()); - Assert.assertEquals(1, tRoute.getStops().size()); - Assert.assertEquals(stop1, tRoute.getStops().get(0)); - Assert.assertEquals(mode, tRoute.getTransportMode()); + Assertions.assertEquals(id, tRoute.getId()); + Assertions.assertEquals(route, tRoute.getRoute()); + Assertions.assertEquals(1, tRoute.getStops().size()); + Assertions.assertEquals(stop1, tRoute.getStops().get(0)); + Assertions.assertEquals(mode, tRoute.getTransportMode()); } @Test @@ -88,9 +88,9 @@ void testCreateTransitRouteStop() { double arrivalOffset = 23; double departureOffset = 42; TransitRouteStop stop = builder.createTransitRouteStop(stopFacility, 23, 42); - Assert.assertEquals(stopFacility, stop.getStopFacility()); - Assert.assertEquals(arrivalOffset, stop.getArrivalOffset().seconds(), MatsimTestUtils.EPSILON); - Assert.assertEquals(departureOffset, stop.getDepartureOffset().seconds(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(stopFacility, stop.getStopFacility()); + Assertions.assertEquals(arrivalOffset, stop.getArrivalOffset().seconds(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(departureOffset, stop.getDepartureOffset().seconds(), MatsimTestUtils.EPSILON); } @Test @@ -101,15 +101,15 @@ void testCreateTransitStopFacility() { Id id2 = Id.create(7, TransitStopFacility.class); Coord coord2 = new Coord((double) 105, (double) 1979); TransitStopFacility stopFacility1 = builder.createTransitStopFacility(id1, coord1, false); - Assert.assertEquals(id1, stopFacility1.getId()); - Assert.assertEquals(coord1.getX(), stopFacility1.getCoord().getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals(coord1.getY(), stopFacility1.getCoord().getY(), MatsimTestUtils.EPSILON); - Assert.assertFalse(stopFacility1.getIsBlockingLane()); + Assertions.assertEquals(id1, stopFacility1.getId()); + Assertions.assertEquals(coord1.getX(), stopFacility1.getCoord().getX(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(coord1.getY(), stopFacility1.getCoord().getY(), MatsimTestUtils.EPSILON); + Assertions.assertFalse(stopFacility1.getIsBlockingLane()); TransitStopFacility stopFacility2 = builder.createTransitStopFacility(id2, coord2, true); - Assert.assertEquals(id2, stopFacility2.getId()); - Assert.assertEquals(coord2.getX(), stopFacility2.getCoord().getX(), MatsimTestUtils.EPSILON); - Assert.assertEquals(coord2.getY(), stopFacility2.getCoord().getY(), MatsimTestUtils.EPSILON); - Assert.assertTrue(stopFacility2.getIsBlockingLane()); + Assertions.assertEquals(id2, stopFacility2.getId()); + Assertions.assertEquals(coord2.getX(), stopFacility2.getCoord().getX(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(coord2.getY(), stopFacility2.getCoord().getY(), MatsimTestUtils.EPSILON); + Assertions.assertTrue(stopFacility2.getIsBlockingLane()); } @Test @@ -118,8 +118,8 @@ void testCreateDeparture() { Id id = Id.create(8, Departure.class); double time = 9.0*3600; Departure dep = builder.createDeparture(id, time); - Assert.assertEquals(id, dep.getId()); - Assert.assertEquals(time, dep.getDepartureTime(), MatsimTestUtils.EPSILON); + Assertions.assertEquals(id, dep.getId()); + Assertions.assertEquals(time, dep.getDepartureTime(), MatsimTestUtils.EPSILON); } } diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java index d43aee23f33..f3593cf5120 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleFormatV1Test.java @@ -20,7 +20,7 @@ package org.matsim.pt.transitSchedule; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.IOException; import java.util.ArrayList; @@ -158,60 +158,60 @@ void testWriteRead() throws IOException, SAXException, ParserConfigurationExcept private static void assertEqualSchedules(final TransitSchedule expected, final TransitSchedule actual) { - assertEquals("different number of stopFacilities.", expected.getFacilities().size(), actual.getFacilities().size()); + assertEquals(expected.getFacilities().size(), actual.getFacilities().size(), "different number of stopFacilities."); for (TransitStopFacility stopE : expected.getFacilities().values()) { TransitStopFacility stopA = actual.getFacilities().get(stopE.getId()); - assertNotNull("stopFacility not found: " + stopE.getId().toString(), stopA); - assertEquals("different x coordinates.", stopE.getCoord().getX(), stopA.getCoord().getX(), MatsimTestUtils.EPSILON); - assertEquals("different y coordinates.", stopE.getCoord().getY(), stopA.getCoord().getY(), MatsimTestUtils.EPSILON); - assertEquals("different link information.", stopE.getLinkId(), stopA.getLinkId()); - assertEquals("different isBlocking.", stopE.getIsBlockingLane(), stopA.getIsBlockingLane()); - assertEquals("different names.", stopE.getName(), stopA.getName()); + assertNotNull(stopA, "stopFacility not found: " + stopE.getId().toString()); + assertEquals(stopE.getCoord().getX(), stopA.getCoord().getX(), MatsimTestUtils.EPSILON, "different x coordinates."); + assertEquals(stopE.getCoord().getY(), stopA.getCoord().getY(), MatsimTestUtils.EPSILON, "different y coordinates."); + assertEquals(stopE.getLinkId(), stopA.getLinkId(), "different link information."); + assertEquals(stopE.getIsBlockingLane(), stopA.getIsBlockingLane(), "different isBlocking."); + assertEquals(stopE.getName(), stopA.getName(), "different names."); } - assertEquals("different number of transitLines.", expected.getTransitLines().size(), actual.getTransitLines().size()); + assertEquals(expected.getTransitLines().size(), actual.getTransitLines().size(), "different number of transitLines."); for (TransitLine lineE : expected.getTransitLines().values()) { // *E = expected, *A = actual TransitLine lineA = actual.getTransitLines().get(lineE.getId()); - assertNotNull("transit line not found: " + lineE.getId().toString(), lineA); - assertEquals("different number of routes in line.", lineE.getRoutes().size(), lineA.getRoutes().size()); + assertNotNull(lineA, "transit line not found: " + lineE.getId().toString()); + assertEquals(lineE.getRoutes().size(), lineA.getRoutes().size(), "different number of routes in line."); for (TransitRoute routeE : lineE.getRoutes().values()) { TransitRoute routeA = lineA.getRoutes().get(routeE.getId()); - assertNotNull("transit route not found: " + routeE.getId().toString(), routeA); - assertEquals("different route descriptions.", routeE.getDescription(), routeA.getDescription()); + assertNotNull(routeA, "transit route not found: " + routeE.getId().toString()); + assertEquals(routeE.getDescription(), routeA.getDescription(), "different route descriptions."); - assertEquals("different number of stops.", routeE.getStops().size(), routeA.getStops().size()); + assertEquals(routeE.getStops().size(), routeA.getStops().size(), "different number of stops."); for (int i = 0, n = routeE.getStops().size(); i < n; i++) { TransitRouteStop stopE = routeE.getStops().get(i); TransitRouteStop stopA = routeA.getStops().get(i); - assertNotNull("stop not found", stopA); - assertEquals("different stop facilities.", stopE.getStopFacility().getId(), stopA.getStopFacility().getId()); - assertEquals("different arrival delay.", stopE.getArrivalOffset(), stopA.getArrivalOffset()); - assertEquals("different departure delay.", stopE.getDepartureOffset(), stopA.getDepartureOffset()); - assertEquals("different awaitDepartureTime.", stopE.isAwaitDepartureTime(), stopA.isAwaitDepartureTime()); + assertNotNull(stopA, "stop not found"); + assertEquals(stopE.getStopFacility().getId(), stopA.getStopFacility().getId(), "different stop facilities."); + assertEquals(stopE.getArrivalOffset(), stopA.getArrivalOffset(), "different arrival delay."); + assertEquals(stopE.getDepartureOffset(), stopA.getDepartureOffset(), "different departure delay."); + assertEquals(stopE.isAwaitDepartureTime(), stopA.isAwaitDepartureTime(), "different awaitDepartureTime."); } NetworkRoute netRouteE = routeE.getRoute(); if (netRouteE == null) { - assertNull("bad network route, must be null.", routeA.getRoute()); + assertNull(routeA.getRoute(), "bad network route, must be null."); } else { NetworkRoute netRouteA = routeA.getRoute(); - assertNotNull("bad network route, must not be null.", netRouteA); - assertEquals("wrong start link.", netRouteE.getStartLinkId(), netRouteA.getStartLinkId()); - assertEquals("wrong end link.", netRouteE.getEndLinkId(), netRouteA.getEndLinkId()); + assertNotNull(netRouteA, "bad network route, must not be null."); + assertEquals(netRouteE.getStartLinkId(), netRouteA.getStartLinkId(), "wrong start link."); + assertEquals(netRouteE.getEndLinkId(), netRouteA.getEndLinkId(), "wrong end link."); List> linkIdsE = netRouteE.getLinkIds(); List> linkIdsA = netRouteA.getLinkIds(); for (int i = 0, n = linkIdsE.size(); i < n; i++) { - assertEquals("wrong link in network route", linkIdsE.get(i), linkIdsA.get(i)); + assertEquals(linkIdsE.get(i), linkIdsA.get(i), "wrong link in network route"); } } - assertEquals("different number of departures in route.", routeE.getDepartures().size(), routeA.getDepartures().size()); + assertEquals(routeE.getDepartures().size(), routeA.getDepartures().size(), "different number of departures in route."); for (Departure departureE : routeE.getDepartures().values()) { Departure departureA = routeA.getDepartures().get(departureE.getId()); - assertNotNull("departure not found: " + departureE.getId().toString(), departureA); - assertEquals("different departure times.", departureE.getDepartureTime(), departureA.getDepartureTime(), MatsimTestUtils.EPSILON); - assertEquals("different vehicle ids.", departureE.getVehicleId(), departureA.getVehicleId()); + assertNotNull(departureA, "departure not found: " + departureE.getId().toString()); + assertEquals(departureE.getDepartureTime(), departureA.getDepartureTime(), MatsimTestUtils.EPSILON, "different departure times."); + assertEquals(departureE.getVehicleId(), departureA.getVehicleId(), "different vehicle ids."); } } } diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleIOTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleIOTest.java index 8157150e23a..8b4f9688a6d 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleIOTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleIOTest.java @@ -24,7 +24,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -112,45 +112,45 @@ void testWriteRead_V2() { TransitSchedule schedule2 = scenario.getTransitSchedule(); // assert schedule - Assert.assertEquals("myImagination", schedule2.getAttributes().getAttribute("source")); + Assertions.assertEquals("myImagination", schedule2.getAttributes().getAttribute("source")); // assert stop facilities TransitStopFacility stop1 = schedule2.getFacilities().get(Id.create(1, TransitStopFacility.class)); - Assert.assertTrue(AttributesUtils.isEmpty(stop1.getAttributes())); + Assertions.assertTrue(AttributesUtils.isEmpty(stop1.getAttributes())); TransitStopFacility stop2 = schedule2.getFacilities().get(Id.create(2, TransitStopFacility.class)); - Assert.assertFalse(AttributesUtils.isEmpty(stop2.getAttributes())); - Assert.assertEquals("thin", stop2.getAttributes().getAttribute("air")); - Assert.assertTrue(stop2.getCoord().hasZ()); - Assert.assertEquals(98765.0, stop2.getCoord().getZ(), 0.0); - Assert.assertEquals("GZ", stop2.getStopAreaId().toString()); + Assertions.assertFalse(AttributesUtils.isEmpty(stop2.getAttributes())); + Assertions.assertEquals("thin", stop2.getAttributes().getAttribute("air")); + Assertions.assertTrue(stop2.getCoord().hasZ()); + Assertions.assertEquals(98765.0, stop2.getCoord().getZ(), 0.0); + Assertions.assertEquals("GZ", stop2.getStopAreaId().toString()); // assert minmal transfer times - Assert.assertEquals(300, schedule2.getMinimalTransferTimes().get(stop1.getId(), stop2.getId()), 0.0); - Assert.assertEquals(360, schedule2.getMinimalTransferTimes().get(stop2.getId(), stop1.getId()), 0.0); - Assert.assertEquals(Double.NaN, schedule2.getMinimalTransferTimes().get(stop1.getId(), stop1.getId()), 0.0); + Assertions.assertEquals(300, schedule2.getMinimalTransferTimes().get(stop1.getId(), stop2.getId()), 0.0); + Assertions.assertEquals(360, schedule2.getMinimalTransferTimes().get(stop2.getId(), stop1.getId()), 0.0); + Assertions.assertEquals(Double.NaN, schedule2.getMinimalTransferTimes().get(stop1.getId(), stop1.getId()), 0.0); // assert transit lines TransitLine line1 = schedule2.getTransitLines().get(Id.create("blue", TransitLine.class)); - Assert.assertNotNull(line1); - Assert.assertFalse(AttributesUtils.isEmpty(line1.getAttributes())); - Assert.assertEquals("like the sky", line1.getAttributes().getAttribute("color")); - Assert.assertEquals("higher being", line1.getAttributes().getAttribute("operator")); + Assertions.assertNotNull(line1); + Assertions.assertFalse(AttributesUtils.isEmpty(line1.getAttributes())); + Assertions.assertEquals("like the sky", line1.getAttributes().getAttribute("color")); + Assertions.assertEquals("higher being", line1.getAttributes().getAttribute("operator")); // assert transit routes TransitRoute route1 = line1.getRoutes().get(Id.create("upwards", TransitRoute.class)); - Assert.assertNotNull(route1); - Assert.assertFalse(AttributesUtils.isEmpty(route1.getAttributes())); - Assert.assertTrue(route1.getAttributes().getAttribute("bidirectional") instanceof Boolean); - Assert.assertFalse((Boolean) route1.getAttributes().getAttribute("bidirectional")); + Assertions.assertNotNull(route1); + Assertions.assertFalse(AttributesUtils.isEmpty(route1.getAttributes())); + Assertions.assertTrue(route1.getAttributes().getAttribute("bidirectional") instanceof Boolean); + Assertions.assertFalse((Boolean) route1.getAttributes().getAttribute("bidirectional")); // assert departures Departure dep1 = route1.getDepartures().get(Id.create("first", Departure.class)); - Assert.assertNotNull(dep1); - Assert.assertFalse(AttributesUtils.isEmpty(dep1.getAttributes())); - Assert.assertEquals("yes", dep1.getAttributes().getAttribute("early")); + Assertions.assertNotNull(dep1); + Assertions.assertFalse(AttributesUtils.isEmpty(dep1.getAttributes())); + Assertions.assertEquals("yes", dep1.getAttributes().getAttribute("early")); Departure dep2 = route1.getDepartures().get(Id.create("last", Departure.class)); - Assert.assertNotNull(dep2); - Assert.assertTrue(AttributesUtils.isEmpty(dep2.getAttributes())); + Assertions.assertNotNull(dep2); + Assertions.assertTrue(AttributesUtils.isEmpty(dep2.getAttributes())); } } diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java index d65d912f554..666a764319c 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderTest.java @@ -20,8 +20,8 @@ package org.matsim.pt.transitSchedule; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; import java.io.IOException; import java.util.List; @@ -75,28 +75,28 @@ void testReadFileV1() throws SAXException, ParserConfigurationException, IOExcep TransitSchedule schedule = builder.createTransitSchedule(); new TransitScheduleReaderV1(schedule, scenario.getPopulation().getFactory().getRouteFactories()).readFile(inputDir + INPUT_TEST_FILE_TRANSITSCHEDULE); - assertEquals("wrong number of transit lines.", 1, schedule.getTransitLines().size()); - assertEquals("wrong line id.", Id.create("T1", TransitLine.class), schedule.getTransitLines().keySet().iterator().next()); + assertEquals(1, schedule.getTransitLines().size(), "wrong number of transit lines."); + assertEquals(Id.create("T1", TransitLine.class), schedule.getTransitLines().keySet().iterator().next(), "wrong line id."); TransitLine lineT1 = schedule.getTransitLines().get(Id.create("T1", TransitLine.class)); - assertNotNull("could not find line with id T1.", lineT1); + assertNotNull(lineT1, "could not find line with id T1."); TransitRoute route1 = lineT1.getRoutes().get(Id.create("1", TransitRoute.class)); - assertNotNull("could not find route 1 in line T1.", route1); + assertNotNull(route1, "could not find route 1 in line T1."); Map, Departure> departures = route1.getDepartures(); - assertNotNull("could not get departures of route 1 in line T1.", departures); - assertEquals("wrong number of departures.", 3, departures.size()); + assertNotNull(departures, "could not get departures of route 1 in line T1."); + assertEquals(3, departures.size(), "wrong number of departures."); List stops = route1.getStops(); - assertNotNull("could not get transit route stops.", stops); - assertEquals("wrong number of stops.", 6, stops.size()); + assertNotNull(stops, "could not get transit route stops."); + assertEquals(6, stops.size(), "wrong number of stops."); NetworkRoute route = route1.getRoute(); - assertNotNull("could not get route.", route); - assertEquals("wrong start link.", network.getLinks().get(Id.create("1", Link.class)).getId(), route.getStartLinkId()); - assertEquals("wrong end link.", network.getLinks().get(Id.create("8", Link.class)).getId(), route.getEndLinkId()); - assertEquals("wrong number of links in route.", 4, route.getLinkIds().size()); + assertNotNull(route, "could not get route."); + assertEquals(network.getLinks().get(Id.create("1", Link.class)).getId(), route.getStartLinkId(), "wrong start link."); + assertEquals(network.getLinks().get(Id.create("8", Link.class)).getId(), route.getEndLinkId(), "wrong end link."); + assertEquals(4, route.getLinkIds().size(), "wrong number of links in route."); } @Test @@ -111,7 +111,7 @@ void testReadFile() throws IOException, SAXException, ParserConfigurationExcepti new TransitScheduleReader(scenario).readFile(inputDir + INPUT_TEST_FILE_TRANSITSCHEDULE); // only a minimal test, the actual reader used should be tested somewhere separately - assertEquals("wrong number of transit lines.", 1, scenario.getTransitSchedule().getTransitLines().size()); + assertEquals(1, scenario.getTransitSchedule().getTransitLines().size(), "wrong number of transit lines."); // in the end, we mostly test that there is no Exception when reading the file. } diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderV1Test.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderV1Test.java index c7e8c372a5e..f6375a034b2 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderV1Test.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReaderV1Test.java @@ -20,7 +20,7 @@ package org.matsim.pt.transitSchedule; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.Stack; diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java index d53fb2163cd..4be9bbe91fb 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleReprojectionIOTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -49,7 +49,7 @@ import java.io.File; import java.net.URL; - /** + /** * @author thibautd */ public class TransitScheduleReprojectionIOTest { @@ -124,10 +124,10 @@ void testWithControlerAndConfigParameters() { final Coord originalCoord = originalScenario.getTransitSchedule().getFacilities().get( id ).getCoord(); final Coord internalCoord = scenario.getTransitSchedule().getFacilities().get( id ).getCoord(); - Assert.assertEquals( - "No coordinates transform performed!", + Assertions.assertEquals( transformation.transform(originalCoord), - internalCoord); + internalCoord, + "No coordinates transform performed!"); } final Controler controler = new Controler( scenario ); @@ -144,10 +144,10 @@ void testWithControlerAndConfigParameters() { final Coord internalCoord = scenario.getTransitSchedule().getFacilities().get( id ).getCoord(); final Coord dumpedCoord = dumpedScenario.getTransitSchedule().getFacilities().get( id ).getCoord(); - Assert.assertEquals( - "coordinates were reprojected for dump", + Assertions.assertEquals( internalCoord, - dumpedCoord); + dumpedCoord, + "coordinates were reprojected for dump"); } } @@ -196,16 +196,16 @@ void testWithControlerAndAttributes() { final Coord originalCoord = originalScenario.getTransitSchedule().getFacilities().get( id ).getCoord(); final Coord internalCoord = scenario.getTransitSchedule().getFacilities().get( id ).getCoord(); - Assert.assertEquals( - "No coordinates transform performed!", + Assertions.assertEquals( transformation.transform(originalCoord), - internalCoord); + internalCoord, + "No coordinates transform performed!"); } - Assert.assertEquals( - "wrong CRS information after loading", + Assertions.assertEquals( TARGET_CRS, - ProjectionUtils.getCRS(scenario.getTransitSchedule())); + ProjectionUtils.getCRS(scenario.getTransitSchedule()), + "wrong CRS information after loading"); final Controler controler = new Controler( scenario ); controler.run(); @@ -221,29 +221,29 @@ void testWithControlerAndAttributes() { final Coord internalCoord = scenario.getTransitSchedule().getFacilities().get( id ).getCoord(); final Coord dumpedCoord = dumpedScenario.getTransitSchedule().getFacilities().get( id ).getCoord(); - Assert.assertEquals( - "coordinates were reprojected for dump", + Assertions.assertEquals( internalCoord, - dumpedCoord); + dumpedCoord, + "coordinates were reprojected for dump"); } } private void assertCorrectlyReprojected( final TransitSchedule originalSchedule, final TransitSchedule transformedSchedule) { - Assert.assertEquals( - "unexpected number of stops", + Assertions.assertEquals( originalSchedule.getFacilities().size(), - transformedSchedule.getFacilities().size() ); + transformedSchedule.getFacilities().size(), + "unexpected number of stops" ); for ( Id stopId : originalSchedule.getFacilities().keySet() ) { final Coord original = originalSchedule.getFacilities().get( stopId ).getCoord(); final Coord transformed = transformedSchedule.getFacilities().get( stopId ).getCoord(); - Assert.assertEquals( - "wrong reprojected X value", + Assertions.assertEquals( transformation.transform(original), - transformed); + transformed, + "wrong reprojected X value"); } } diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleTest.java index dc67a806b9d..6c4c787eec9 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleTest.java @@ -20,12 +20,12 @@ package org.matsim.pt.transitSchedule; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.fail; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.fail; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -168,9 +168,9 @@ void testRemoveStopFacility() { TransitStopFacility stop1 = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 0, (double) 0), false); TransitStopFacility stop1b = new TransitStopFacilityImpl(Id.create(1, TransitStopFacility.class), new Coord((double) 10, (double) 10), false); schedule.addStopFacility(stop1); - Assert.assertFalse(schedule.removeStopFacility(stop1b)); - Assert.assertTrue(schedule.removeStopFacility(stop1)); - Assert.assertFalse(schedule.removeStopFacility(stop1)); + Assertions.assertFalse(schedule.removeStopFacility(stop1b)); + Assertions.assertTrue(schedule.removeStopFacility(stop1)); + Assertions.assertFalse(schedule.removeStopFacility(stop1)); } @Test @@ -179,9 +179,9 @@ void testRemoveTransitLine() { TransitLine line1 = new TransitLineImpl(Id.create(1, TransitLine.class)); TransitLine line1b = new TransitLineImpl(Id.create(1, TransitLine.class)); schedule.addTransitLine(line1); - Assert.assertFalse(schedule.removeTransitLine(line1b)); - Assert.assertTrue(schedule.removeTransitLine(line1)); - Assert.assertFalse(schedule.removeTransitLine(line1)); + Assertions.assertFalse(schedule.removeTransitLine(line1b)); + Assertions.assertTrue(schedule.removeTransitLine(line1)); + Assertions.assertFalse(schedule.removeTransitLine(line1)); } } diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java index ad6a354bbff..bf8b2ae254c 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitScheduleWriterTest.java @@ -24,7 +24,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -65,7 +65,7 @@ void testDefaultV2() throws IOException, SAXException, ParserConfigurationExcept TransitScheduleFactory builder2 = new TransitScheduleFactoryImpl(); TransitSchedule schedule2 = builder2.createTransitSchedule(); new TransitScheduleReaderV2(schedule2, new RouteFactories()).readFile(filename); - Assert.assertEquals(1, schedule2.getTransitLines().size()); + Assertions.assertEquals(1, schedule2.getTransitLines().size()); } @Test @@ -84,7 +84,7 @@ void testTransitLineName() { TransitScheduleFactory builder2 = new TransitScheduleFactoryImpl(); TransitSchedule schedule2 = builder2.createTransitSchedule(); new TransitScheduleReaderV1(schedule2, new RouteFactories()).readFile(filename); - Assert.assertEquals(1, schedule2.getTransitLines().size()); - Assert.assertEquals("Blue line", schedule2.getTransitLines().get(Id.create(1, TransitLine.class)).getName()); + Assertions.assertEquals(1, schedule2.getTransitLines().size()); + Assertions.assertEquals("Blue line", schedule2.getTransitLines().get(Id.create(1, TransitLine.class)).getName()); } } diff --git a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java index 1f0a7edb5ec..e44a9b616af 100644 --- a/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java +++ b/matsim/src/test/java/org/matsim/pt/transitSchedule/TransitStopFacilityTest.java @@ -20,7 +20,7 @@ package org.matsim.pt.transitSchedule; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java b/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java index 721bdffe4ec..e191c160ff8 100644 --- a/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java +++ b/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java @@ -22,7 +22,7 @@ package org.matsim.pt.utils; import org.assertj.core.api.Assertions; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -89,11 +89,11 @@ void testValidator_Transfers_implausibleTime() { schedule.getMinimalTransferTimes().set(id1, id2, 120); TransitScheduleValidator.ValidationResult result = TransitScheduleValidator.validateTransfers(schedule); - Assert.assertTrue(result.getIssues().isEmpty()); + Assertions.assertTrue(result.getIssues().isEmpty()); schedule.getMinimalTransferTimes().set(id1, id2, 0); result = TransitScheduleValidator.validateTransfers(schedule); - Assert.assertEquals("Should warn against implausible transfer time.", 1, result.getIssues().size()); + Assertions.assertEquals(1, result.getIssues().size(), "Should warn against implausible transfer time."); } @Test @@ -112,14 +112,14 @@ void testValidator_Transfers_missingStop() { schedule.getMinimalTransferTimes().set(id1, id3, 120); TransitScheduleValidator.ValidationResult result = TransitScheduleValidator.validateTransfers(schedule); - Assert.assertEquals("Should warn against missing stop3.", 1, result.getIssues().size()); - Assert.assertTrue("Message should contain hint about stop3 being missing. " + result.getIssues().get(0).getMessage(), result.getIssues().get(0).getMessage().contains("stop3")); + Assertions.assertEquals(1, result.getIssues().size(), "Should warn against missing stop3."); + Assertions.assertTrue(result.getIssues().get(0).getMessage().contains("stop3"), "Message should contain hint about stop3 being missing. " + result.getIssues().get(0).getMessage()); schedule.getMinimalTransferTimes().remove(id1, id3); schedule.getMinimalTransferTimes().set(id4, id2, 120); result = TransitScheduleValidator.validateTransfers(schedule); - Assert.assertEquals("Should warn against missing stop4.", 1, result.getIssues().size()); - Assert.assertTrue("Message should contain hint about stop4 being missing. " + result.getIssues().get(0).getMessage(), result.getIssues().get(0).getMessage().contains("stop4")); + Assertions.assertEquals(1, result.getIssues().size(), "Should warn against missing stop4."); + Assertions.assertTrue(result.getIssues().get(0).getMessage().contains("stop4"), "Message should contain hint about stop4 being missing. " + result.getIssues().get(0).getMessage()); } } diff --git a/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java b/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java index fafc8d3307a..f0c40562681 100644 --- a/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java +++ b/matsim/src/test/java/org/matsim/run/CreateFullConfigTest.java @@ -23,7 +23,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -43,10 +43,10 @@ void testMain() { args[0] = helper.getOutputDirectory() + "newConfig.xml"; File configFile = new File(args[0]); - Assert.assertFalse(configFile.exists()); + Assertions.assertFalse(configFile.exists()); CreateFullConfig.main(args); - Assert.assertTrue(configFile.exists()); + Assertions.assertTrue(configFile.exists()); } } diff --git a/matsim/src/test/java/org/matsim/run/InitRoutesTest.java b/matsim/src/test/java/org/matsim/run/InitRoutesTest.java index ae311cd6fc6..afeac78d8cb 100644 --- a/matsim/src/test/java/org/matsim/run/InitRoutesTest.java +++ b/matsim/src/test/java/org/matsim/run/InitRoutesTest.java @@ -20,7 +20,7 @@ package org.matsim.run; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.File; @@ -93,24 +93,24 @@ void testMain() throws Exception { new ConfigWriter(config).write(CONFIG_FILE); // some pre-tests - assertFalse("Output-File should not yet exist.", new File(PLANS_FILE_TESTOUTPUT).exists()); + assertFalse(new File(PLANS_FILE_TESTOUTPUT).exists(), "Output-File should not yet exist."); // now run the tested class InitRoutes.main(new String[] {CONFIG_FILE, PLANS_FILE_TESTOUTPUT}); // now perform some tests - assertTrue("no output generated.", new File(PLANS_FILE_TESTOUTPUT).exists()); + assertTrue(new File(PLANS_FILE_TESTOUTPUT).exists(), "no output generated."); Population population2 = scenario.getPopulation(); new PopulationReader(scenario).readFile(PLANS_FILE_TESTOUTPUT); - assertEquals("wrong number of persons.", 1, population2.getPersons().size()); + assertEquals(1, population2.getPersons().size(), "wrong number of persons."); Person person2 = population2.getPersons().get(Id.create("1", Person.class)); - assertNotNull("person 1 missing", person2); - assertEquals("wrong number of plans in person 1", 1, person2.getPlans().size()); + assertNotNull(person2, "person 1 missing"); + assertEquals(1, person2.getPlans().size(), "wrong number of plans in person 1"); Plan plan2 = person2.getPlans().get(0); Leg leg2 = (Leg) plan2.getPlanElements().get(1); NetworkRoute route2 = (NetworkRoute) leg2.getRoute(); - assertNotNull("no route assigned.", route2); - assertEquals("wrong route", 2, route2.getLinkIds().size()); + assertNotNull(route2, "no route assigned."); + assertEquals(2, route2.getLinkIds().size(), "wrong route"); } } diff --git a/matsim/src/test/java/org/matsim/run/XY2LinksTest.java b/matsim/src/test/java/org/matsim/run/XY2LinksTest.java index 5d0e67a2f27..2c878e990b7 100644 --- a/matsim/src/test/java/org/matsim/run/XY2LinksTest.java +++ b/matsim/src/test/java/org/matsim/run/XY2LinksTest.java @@ -20,7 +20,7 @@ package org.matsim.run; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.File; @@ -88,22 +88,22 @@ void testMain() throws Exception { new ConfigWriter(config).write(CONFIG_FILE); // some pre-tests - assertFalse("Output-File should not yet exist.", new File(PLANS_FILE_TESTOUTPUT).exists()); + assertFalse(new File(PLANS_FILE_TESTOUTPUT).exists(), "Output-File should not yet exist."); // now run the tested class XY2Links.main(new String[] {CONFIG_FILE, PLANS_FILE_TESTOUTPUT}); // now perform some tests - assertTrue("no output generated.", new File(PLANS_FILE_TESTOUTPUT).exists()); + assertTrue(new File(PLANS_FILE_TESTOUTPUT).exists(), "no output generated."); Population population2 = scenario.getPopulation(); new PopulationReader(scenario).readFile(PLANS_FILE_TESTOUTPUT); - assertEquals("wrong number of persons.", 1, population2.getPersons().size()); + assertEquals(1, population2.getPersons().size(), "wrong number of persons."); Person person2 = population2.getPersons().get(Id.create("1", Person.class)); - assertNotNull("person 1 missing", person2); - assertEquals("wrong number of plans in person 1", 1, person2.getPlans().size()); + assertNotNull(person2, "person 1 missing"); + assertEquals(1, person2.getPlans().size(), "wrong number of plans in person 1"); Plan plan2 = person2.getPlans().get(0); Activity act2 = (Activity) plan2.getPlanElements().get(0); - assertNotNull("no link assigned.", act2.getLinkId()); + assertNotNull(act2.getLinkId(), "no link assigned."); } } diff --git a/matsim/src/test/java/org/matsim/testcases/utils/LogCounterTest.java b/matsim/src/test/java/org/matsim/testcases/utils/LogCounterTest.java index 0c32d32d939..daf219efed9 100644 --- a/matsim/src/test/java/org/matsim/testcases/utils/LogCounterTest.java +++ b/matsim/src/test/java/org/matsim/testcases/utils/LogCounterTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import java.io.IOException; @@ -41,12 +41,12 @@ void testLogCounter_INFO() throws IOException { LOG.info("hello world - this is just a test"); LOG.warn("hello world - this is just a test"); counter.deactivate(); - Assert.assertEquals(1, counter.getInfoCount()); - Assert.assertEquals(1, counter.getWarnCount()); + Assertions.assertEquals(1, counter.getInfoCount()); + Assertions.assertEquals(1, counter.getWarnCount()); LOG.info("hello world - this is just a test"); // this should not be counted LOG.warn("hello world - this is just a test"); // this should not be counted - Assert.assertEquals(1, counter.getInfoCount()); - Assert.assertEquals(1, counter.getWarnCount()); + Assertions.assertEquals(1, counter.getInfoCount()); + Assertions.assertEquals(1, counter.getWarnCount()); } @Test @@ -56,11 +56,11 @@ void testLogCounter_WARN() throws IOException { LOG.info("hello world - this is just a test"); LOG.warn("hello world - this is just a test"); counter.deactivate(); - Assert.assertEquals(0, counter.getInfoCount()); - Assert.assertEquals(1, counter.getWarnCount()); + Assertions.assertEquals(0, counter.getInfoCount()); + Assertions.assertEquals(1, counter.getWarnCount()); LOG.info("hello world - this is just a test"); // this should not be counted LOG.warn("hello world - this is just a test"); // this should not be counted - Assert.assertEquals(0, counter.getInfoCount()); - Assert.assertEquals(1, counter.getWarnCount()); + Assertions.assertEquals(0, counter.getInfoCount()); + Assertions.assertEquals(1, counter.getWarnCount()); } } diff --git a/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java b/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java index b0870fa8b7b..6618b85dc17 100644 --- a/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java +++ b/matsim/src/test/java/org/matsim/utils/eventsfilecomparison/EventsFileComparatorTest.java @@ -19,7 +19,7 @@ package org.matsim.utils.eventsfilecomparison; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import static org.matsim.utils.eventsfilecomparison.EventsFileComparator.Result.*; import org.junit.jupiter.api.Test; @@ -40,44 +40,44 @@ public class EventsFileComparatorTest { void testRetCode0() { String f1 = utils.getClassInputDirectory() + "/events0.xml.gz"; String f2 = utils.getClassInputDirectory() + "/events5.xml.gz"; - assertEquals("return val = " + FILES_ARE_EQUAL, FILES_ARE_EQUAL, EventsFileComparator.compare(f1, f2)); + assertEquals(FILES_ARE_EQUAL, EventsFileComparator.compare(f1, f2), "return val = " + FILES_ARE_EQUAL); - assertEquals("return val = " + FILES_ARE_EQUAL, FILES_ARE_EQUAL, EventsFileComparator.compare(f2, f1)); + assertEquals(FILES_ARE_EQUAL, EventsFileComparator.compare(f2, f1), "return val = " + FILES_ARE_EQUAL); } @Test void testRetCodeM1() { String f1 = utils.getClassInputDirectory() + "/events0.xml.gz"; String f2 = utils.getClassInputDirectory() + "/events1.xml.gz"; - assertEquals("return val " +DIFFERENT_NUMBER_OF_TIMESTEPS, DIFFERENT_NUMBER_OF_TIMESTEPS, EventsFileComparator.compare(f1, f2)); + assertEquals(DIFFERENT_NUMBER_OF_TIMESTEPS, EventsFileComparator.compare(f1, f2), "return val " +DIFFERENT_NUMBER_OF_TIMESTEPS); - assertEquals("return val " +DIFFERENT_NUMBER_OF_TIMESTEPS, DIFFERENT_NUMBER_OF_TIMESTEPS, EventsFileComparator.compare(f2, f1)); + assertEquals(DIFFERENT_NUMBER_OF_TIMESTEPS, EventsFileComparator.compare(f2, f1), "return val " +DIFFERENT_NUMBER_OF_TIMESTEPS); } @Test void testRetCodeM2() { String f1 = utils.getClassInputDirectory() + "/events0.xml.gz"; String f2 = utils.getClassInputDirectory() + "/events2.xml.gz"; - assertEquals("return val = " + DIFFERENT_TIMESTEPS, DIFFERENT_TIMESTEPS, EventsFileComparator.compare(f1, f2)); + assertEquals(DIFFERENT_TIMESTEPS, EventsFileComparator.compare(f1, f2), "return val = " + DIFFERENT_TIMESTEPS); - assertEquals("return val = " + DIFFERENT_TIMESTEPS, DIFFERENT_TIMESTEPS, EventsFileComparator.compare(f2, f1)); + assertEquals(DIFFERENT_TIMESTEPS, EventsFileComparator.compare(f2, f1), "return val = " + DIFFERENT_TIMESTEPS); } @Test void testRetCodeM3() { String f1 = utils.getClassInputDirectory() + "/events0.xml.gz"; String f2 = utils.getClassInputDirectory() + "/events3.xml.gz"; - assertEquals("return val = " + MISSING_EVENT, MISSING_EVENT, EventsFileComparator.compare(f1, f2)); + assertEquals(MISSING_EVENT, EventsFileComparator.compare(f1, f2), "return val = " + MISSING_EVENT); - assertEquals("return val = " + MISSING_EVENT, MISSING_EVENT, EventsFileComparator.compare(f2, f1)); + assertEquals(MISSING_EVENT, EventsFileComparator.compare(f2, f1), "return val = " + MISSING_EVENT); } @Test void testRetCodeM4() { String f1 = utils.getClassInputDirectory() + "/events0.xml.gz"; String f2 = utils.getClassInputDirectory() + "/events4.xml.gz"; - assertEquals("return val = " + WRONG_EVENT_COUNT, WRONG_EVENT_COUNT, EventsFileComparator.compare(f1, f2)); + assertEquals(WRONG_EVENT_COUNT, EventsFileComparator.compare(f1, f2), "return val = " + WRONG_EVENT_COUNT); - assertEquals("return val = " + WRONG_EVENT_COUNT, WRONG_EVENT_COUNT, EventsFileComparator.compare(f2, f1)); + assertEquals(WRONG_EVENT_COUNT, EventsFileComparator.compare(f2, f1), "return val = " + WRONG_EVENT_COUNT); } } diff --git a/matsim/src/test/java/org/matsim/utils/geometry/CoordUtilsTest.java b/matsim/src/test/java/org/matsim/utils/geometry/CoordUtilsTest.java index d2c2fc47982..da953b9fa65 100644 --- a/matsim/src/test/java/org/matsim/utils/geometry/CoordUtilsTest.java +++ b/matsim/src/test/java/org/matsim/utils/geometry/CoordUtilsTest.java @@ -20,7 +20,7 @@ package org.matsim.utils.geometry; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.core.utils.geometry.CoordUtils; @@ -39,8 +39,8 @@ void testPlus() { Coord coord1 = new Coord(1., 2.); Coord coord2 = new Coord(3., 4.); Coord result = CoordUtils.plus( coord1, coord2 ) ; - Assert.assertEquals( 4., result.getX(), delta) ; - Assert.assertEquals( 6., result.getY(), delta) ; + Assertions.assertEquals( 4., result.getX(), delta) ; + Assertions.assertEquals( 6., result.getY(), delta) ; } /** @@ -51,8 +51,8 @@ void testMinus() { Coord coord1 = new Coord(1., 2.); Coord coord2 = new Coord(3., 5.); Coord result = CoordUtils.minus( coord1, coord2 ) ; - Assert.assertEquals( -2., result.getX(), delta) ; - Assert.assertEquals( -3., result.getY(), delta) ; + Assertions.assertEquals( -2., result.getX(), delta) ; + Assertions.assertEquals( -3., result.getY(), delta) ; } /** @@ -62,8 +62,8 @@ void testMinus() { void testScalarMult() { Coord coord1 = new Coord(1., 2.); Coord result = CoordUtils.scalarMult( -0.33 , coord1 ) ; - Assert.assertEquals( -0.33, result.getX(), delta) ; - Assert.assertEquals( -0.66, result.getY(), delta) ; + Assertions.assertEquals( -0.33, result.getX(), delta) ; + Assertions.assertEquals( -0.66, result.getY(), delta) ; } /** @@ -74,8 +74,8 @@ void testGetCenter() { Coord coord1 = new Coord(1., 2.); Coord coord2 = new Coord(3., 5.); Coord result = CoordUtils.getCenter( coord1, coord2 ) ; - Assert.assertEquals( 2., result.getX(), delta) ; - Assert.assertEquals( 3.5, result.getY(), delta) ; + Assertions.assertEquals( 2., result.getX(), delta) ; + Assertions.assertEquals( 3.5, result.getY(), delta) ; } /** @@ -85,6 +85,6 @@ void testGetCenter() { void testLength() { Coord coord1 = new Coord(3., 2.); double result = CoordUtils.length( coord1 ) ; - Assert.assertEquals( Math.sqrt( 9. + 4. ), result, delta) ; + Assertions.assertEquals( Math.sqrt( 9. + 4. ), result, delta) ; } } diff --git a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/LanesBasedWidthCalculatorTest.java b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/LanesBasedWidthCalculatorTest.java index dfb2d043f62..1515e9e5009 100644 --- a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/LanesBasedWidthCalculatorTest.java +++ b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/LanesBasedWidthCalculatorTest.java @@ -19,7 +19,7 @@ package org.matsim.utils.gis.matsim2esri.network; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -44,11 +44,11 @@ void testGetWidth_laneWidthNaN() { l1.setNumberOfLanes(2.0); - Assert.assertEquals("The default in the Network is set to a value that is possibly not conform to the default in network_v1.dtd", 3.75, net.getEffectiveLaneWidth(), 1e-10); + Assertions.assertEquals(3.75, net.getEffectiveLaneWidth(), 1e-10, "The default in the Network is set to a value that is possibly not conform to the default in network_v1.dtd"); ((Network)net).setEffectiveLaneWidth(1.0); double w = new LanesBasedWidthCalculator((Network) net, 1.0).getWidth(l1); - Assert.assertFalse(Double.isNaN(w)); - Assert.assertEquals(2.0, w, 1e-10); + Assertions.assertFalse(Double.isNaN(w)); + Assertions.assertEquals(2.0, w, 1e-10); } } diff --git a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java index 4a5d5f918eb..6700340ee8f 100755 --- a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java +++ b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/network/Network2ESRIShapeTest.java @@ -22,7 +22,7 @@ import java.util.Collection; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -61,7 +61,7 @@ void testPolygonCapacityShape() { new Links2ESRIShape(network,outputFileP, builder).write(); Collection writtenFeatures = ShapeFileReader.getAllFeatures(outputFileP); - Assert.assertEquals(network.getLinks().size(), writtenFeatures.size()); + Assertions.assertEquals(network.getLinks().size(), writtenFeatures.size()); } @Test @@ -84,7 +84,7 @@ void testPolygonLanesShape() { new Links2ESRIShape(network,outputFileP, builder).write(); Collection writtenFeatures = ShapeFileReader.getAllFeatures(outputFileP); - Assert.assertEquals(network.getLinks().size(), writtenFeatures.size()); + Assertions.assertEquals(network.getLinks().size(), writtenFeatures.size()); } @Test @@ -107,7 +107,7 @@ void testPolygonFreespeedShape() { new Links2ESRIShape(network,outputFileP, builder).write(); Collection writtenFeatures = ShapeFileReader.getAllFeatures(outputFileP); - Assert.assertEquals(network.getLinks().size(), writtenFeatures.size()); + Assertions.assertEquals(network.getLinks().size(), writtenFeatures.size()); } @Test @@ -130,7 +130,7 @@ void testLineStringShape() { new Links2ESRIShape(network,outputFileShp, builder).write(); Collection writtenFeatures = ShapeFileReader.getAllFeatures(outputFileShp); - Assert.assertEquals(network.getLinks().size(), writtenFeatures.size()); + Assertions.assertEquals(network.getLinks().size(), writtenFeatures.size()); } @Test @@ -146,6 +146,6 @@ void testNodesShape() { new Nodes2ESRIShape(network,outputFileShp, "DHDN_GK4").write(); Collection writtenFeatures = ShapeFileReader.getAllFeatures(outputFileShp); - Assert.assertEquals(network.getNodes().size(), writtenFeatures.size()); + Assertions.assertEquals(network.getNodes().size(), writtenFeatures.size()); } } diff --git a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java index 13f5e0eb3c4..f5ec5a13be3 100755 --- a/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java +++ b/matsim/src/test/java/org/matsim/utils/gis/matsim2esri/plans/SelectedPlans2ESRIShapeTest.java @@ -24,7 +24,7 @@ import java.util.Collection; import java.util.zip.GZIPInputStream; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -67,7 +67,7 @@ void testSelectedPlansActsShape() throws IOException { sp.write(); Collection writtenFeatures = ShapeFileReader.getAllFeatures(outShp); - Assert.assertEquals(2235, writtenFeatures.size()); + Assertions.assertEquals(2235, writtenFeatures.size()); } @Test @@ -92,7 +92,7 @@ void testSelectedPlansLegsShape() throws IOException { sp.write(); Collection writtenFeatures = ShapeFileReader.getAllFeatures(outShp); - Assert.assertEquals(1431, writtenFeatures.size()); + Assertions.assertEquals(1431, writtenFeatures.size()); } } diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesConverterTest.java index 3ae0e9ed2ab..d7d60c4cde6 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesConverterTest.java @@ -21,7 +21,7 @@ package org.matsim.utils.objectattributes; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import java.time.Month; @@ -30,10 +30,10 @@ import java.util.HashMap; import java.util.Map; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNull; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNull; - /** + /** * @author thibautd */ public class ObjectAttributesConverterTest { @@ -45,14 +45,14 @@ void testEnumToString() { // And is thus unavailable to the ObjectAttributesConverter // So use something from the standard library, as there is no way this goes away String converted = converter.convertToString(Month.JANUARY); - Assert.assertEquals("unexpected string converted from enum value", "JANUARY", converted); + Assertions.assertEquals("JANUARY", converted, "unexpected string converted from enum value"); } @Test void testStringToEnum() { final ObjectAttributesConverter converter = new ObjectAttributesConverter(); Object converted = converter.convert(Month.class.getCanonicalName(), "JANUARY"); - Assert.assertEquals("unexpected enum converted from String value", Month.JANUARY, converted); + Assertions.assertEquals(Month.JANUARY, converted, "unexpected enum converted from String value"); } @Test diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesTest.java index 68d563e731a..11a28b9d41e 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesTest.java @@ -19,7 +19,7 @@ package org.matsim.utils.objectattributes; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** @@ -30,10 +30,10 @@ public class ObjectAttributesTest { @Test void testPutGet() { ObjectAttributes linkAttributes = new ObjectAttributes(); - Assert.assertNull(linkAttributes.getAttribute("1", "osm:roadtype")); - Assert.assertNull(linkAttributes.putAttribute("1", "osm:roadtype", "trunk")); - Assert.assertEquals("trunk", linkAttributes.getAttribute("1", "osm:roadtype")); - Assert.assertEquals("trunk", linkAttributes.putAttribute("1", "osm:roadtype", "motorway")); - Assert.assertEquals("motorway", linkAttributes.getAttribute("1", "osm:roadtype")); + Assertions.assertNull(linkAttributes.getAttribute("1", "osm:roadtype")); + Assertions.assertNull(linkAttributes.putAttribute("1", "osm:roadtype", "trunk")); + Assertions.assertEquals("trunk", linkAttributes.getAttribute("1", "osm:roadtype")); + Assertions.assertEquals("trunk", linkAttributes.putAttribute("1", "osm:roadtype", "motorway")); + Assertions.assertEquals("motorway", linkAttributes.getAttribute("1", "osm:roadtype")); } } diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesUtilsTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesUtilsTest.java index 44b32343163..df0f6588c36 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesUtilsTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesUtilsTest.java @@ -22,7 +22,7 @@ import java.util.Collection; import java.util.Iterator; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** @@ -38,11 +38,11 @@ void testGetAllAttributes() { oa.putAttribute("1", "c", "C"); Collection names = ObjectAttributesUtils.getAllAttributeNames(oa, "1"); - Assert.assertEquals(3, names.size()); - Assert.assertTrue(names.contains("a")); - Assert.assertTrue(names.contains("b")); - Assert.assertTrue(names.contains("c")); - Assert.assertFalse(names.contains("d")); + Assertions.assertEquals(3, names.size()); + Assertions.assertTrue(names.contains("a")); + Assertions.assertTrue(names.contains("b")); + Assertions.assertTrue(names.contains("c")); + Assertions.assertFalse(names.contains("d")); } @Test @@ -55,13 +55,13 @@ void testGetAllAttributes_isImmutable() { Collection names = ObjectAttributesUtils.getAllAttributeNames(oa, "1"); try { names.add("d"); - Assert.fail("Expected immutability-exception"); + Assertions.fail("Expected immutability-exception"); } catch (Exception everythingOkay) { } try { names.remove("b"); - Assert.fail("Expected immutability-exception"); + Assertions.fail("Expected immutability-exception"); } catch (Exception everythingOkay) { } @@ -69,7 +69,7 @@ void testGetAllAttributes_isImmutable() { Iterator iter = names.iterator(); iter.next(); iter.remove(); - Assert.fail("Expected immutability-exception"); + Assertions.fail("Expected immutability-exception"); } catch (Exception everythingOkay) { } diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java index dd98dd5db7b..f28041ceb6a 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlIOTest.java @@ -23,7 +23,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -48,10 +48,10 @@ void testReadWrite() throws IOException, SAXException, ParserConfigurationExcept ObjectAttributes oa2 = new ObjectAttributes(); new ObjectAttributesXmlReader(oa2).readFile(this.utils.getOutputDirectory() + "oa.xml"); - Assert.assertEquals("A", oa2.getAttribute("one", "a")); - Assert.assertEquals(Integer.valueOf(1), oa2.getAttribute("one", "b")); - Assert.assertEquals(Double.valueOf(1.5), oa2.getAttribute("two", "c")); - Assert.assertEquals(Boolean.TRUE, oa2.getAttribute("two", "d")); + Assertions.assertEquals("A", oa2.getAttribute("one", "a")); + Assertions.assertEquals(Integer.valueOf(1), oa2.getAttribute("one", "b")); + Assertions.assertEquals(Double.valueOf(1.5), oa2.getAttribute("two", "c")); + Assertions.assertEquals(Boolean.TRUE, oa2.getAttribute("two", "d")); } @Test @@ -64,7 +64,7 @@ void testReadWrite_CustomAttribute() { writer.putAttributeConverter(MyTuple.class, converter); writer.writeFile(this.utils.getOutputDirectory() + "oa.xml"); - Assert.assertFalse("toString() should return something different from converter to test functionality.", t.toString().equals(converter.convertToString(t))); + Assertions.assertFalse(t.toString().equals(converter.convertToString(t)), "toString() should return something different from converter to test functionality."); ObjectAttributes oa2 = new ObjectAttributes(); ObjectAttributesXmlReader reader = new ObjectAttributesXmlReader(oa2); @@ -72,11 +72,11 @@ void testReadWrite_CustomAttribute() { reader.readFile(this.utils.getOutputDirectory() + "oa.xml"); Object o = oa2.getAttribute("1", "A"); - Assert.assertNotNull(o); - Assert.assertEquals(MyTuple.class, o.getClass()); + Assertions.assertNotNull(o); + Assertions.assertEquals(MyTuple.class, o.getClass()); MyTuple t2 = (MyTuple) o; - Assert.assertEquals(3, t2.a); - Assert.assertEquals(4, t2.b); + Assertions.assertEquals(3, t2.a); + Assertions.assertEquals(4, t2.b); } } diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java index b9b0f592bb0..dcb6644cbf0 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/ObjectAttributesXmlReaderTest.java @@ -24,7 +24,7 @@ import javax.xml.parsers.ParserConfigurationException; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -55,14 +55,14 @@ void testParse_customConverter() throws SAXException, ParserConfigurationExcepti reader.parse(new ByteArrayInputStream(str.getBytes())); Object o = attributes.getAttribute("one", "a"); - Assert.assertTrue(o instanceof MyTuple); - Assert.assertEquals(1, ((MyTuple) o).a); - Assert.assertEquals(2, ((MyTuple) o).b); + Assertions.assertTrue(o instanceof MyTuple); + Assertions.assertEquals(1, ((MyTuple) o).a); + Assertions.assertEquals(2, ((MyTuple) o).b); o = attributes.getAttribute("two", "b"); - Assert.assertTrue(o instanceof MyTuple); - Assert.assertEquals(3, ((MyTuple) o).a); - Assert.assertEquals(4, ((MyTuple) o).b); + Assertions.assertTrue(o instanceof MyTuple); + Assertions.assertEquals(3, ((MyTuple) o).a); + Assertions.assertEquals(4, ((MyTuple) o).b); } @Test @@ -84,16 +84,16 @@ void testParse_missingConverter() throws SAXException, ParserConfigurationExcept reader.parse(new ByteArrayInputStream(str.getBytes())); Object o = attributes.getAttribute("one", "a1"); - Assert.assertNull(o); + Assertions.assertNull(o); o = attributes.getAttribute("one", "a2"); - Assert.assertTrue(o instanceof String); - Assert.assertEquals("foo", o); + Assertions.assertTrue(o instanceof String); + Assertions.assertEquals("foo", o); o = attributes.getAttribute("two", "b1"); - Assert.assertNull(o); + Assertions.assertNull(o); o = attributes.getAttribute("two", "b2"); - Assert.assertTrue(o instanceof Integer); - Assert.assertEquals(1980, ((Integer) o).intValue()); + Assertions.assertTrue(o instanceof Integer); + Assertions.assertEquals(1980, ((Integer) o).intValue()); } @Test @@ -103,16 +103,16 @@ void testParse_withDtd() throws SAXException, ParserConfigurationException, IOEx new ObjectAttributesXmlReader(oa).readFile(filename); Object o = oa.getAttribute("one", "a"); - Assert.assertTrue(o instanceof String); - Assert.assertEquals("foobar", o); + Assertions.assertTrue(o instanceof String); + Assertions.assertEquals("foobar", o); o = oa.getAttribute("two", "b"); - Assert.assertTrue(o instanceof Boolean); - Assert.assertTrue(((Boolean) o).booleanValue()); + Assertions.assertTrue(o instanceof Boolean); + Assertions.assertTrue(((Boolean) o).booleanValue()); o = oa.getAttribute("two", "ccc"); - Assert.assertTrue(o instanceof Integer); - Assert.assertEquals(42, ((Integer) o).intValue()); + Assertions.assertTrue(o instanceof Integer); + Assertions.assertEquals(42, ((Integer) o).intValue()); } @Test @@ -122,16 +122,16 @@ void testParse_withoutDtd() throws SAXException, ParserConfigurationException, I new ObjectAttributesXmlReader(oa).readFile(filename); Object o = oa.getAttribute("one", "a"); - Assert.assertTrue(o instanceof String); - Assert.assertEquals("foobar", o); + Assertions.assertTrue(o instanceof String); + Assertions.assertEquals("foobar", o); o = oa.getAttribute("two", "b"); - Assert.assertTrue(o instanceof Boolean); - Assert.assertTrue(((Boolean) o).booleanValue()); + Assertions.assertTrue(o instanceof Boolean); + Assertions.assertTrue(((Boolean) o).booleanValue()); o = oa.getAttribute("two", "ccc"); - Assert.assertTrue(o instanceof Integer); - Assert.assertEquals(42, ((Integer) o).intValue()); + Assertions.assertTrue(o instanceof Integer); + Assertions.assertEquals(42, ((Integer) o).intValue()); } } diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesTest.java index 6b43346e33c..353c7b5476b 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesTest.java @@ -21,14 +21,14 @@ package org.matsim.utils.objectattributes.attributable; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import java.util.Iterator; import java.util.Map; import java.util.NoSuchElementException; - /** + /** * @author thibautd */ public class AttributesTest { @@ -41,24 +41,23 @@ void testInsertion() { attributes.putAttribute( "the answer" , 42 ); attributes.putAttribute( "1 the begin" , 1L ); - Assert.assertEquals( "unexpected number of elements in "+attributes , - 4 , attributes.size() ); + Assertions.assertEquals( 4 , attributes.size(), "unexpected number of elements in "+attributes ); - Assert.assertEquals( "unexpected value " , - "nice" , - attributes.getAttribute( "sun" ) ); + Assertions.assertEquals( "nice" , + attributes.getAttribute( "sun" ), + "unexpected value " ); - Assert.assertEquals( "unexpected value " , - false , - attributes.getAttribute( "rain is nice" ) ); + Assertions.assertEquals( false , + attributes.getAttribute( "rain is nice" ), + "unexpected value " ); - Assert.assertEquals( "unexpected value " , - 42 , - attributes.getAttribute( "the answer" ) ); + Assertions.assertEquals( 42 , + attributes.getAttribute( "the answer" ), + "unexpected value " ); - Assert.assertEquals( "unexpected value " , - 1L , - attributes.getAttribute( "1 the begin" ) ); + Assertions.assertEquals( 1L , + attributes.getAttribute( "1 the begin" ), + "unexpected value " ); } @Test @@ -73,15 +72,13 @@ void testReplacement() { // that was wrong! final Object wrong = attributes.putAttribute( "the answer" , 42 ); - Assert.assertEquals( "unexpected number of elements in "+attributes , - 4 , attributes.size() ); + Assertions.assertEquals( 4 , attributes.size(), "unexpected number of elements in "+attributes ); - Assert.assertEquals( "unexpected replaced value " , - 7 , wrong ); + Assertions.assertEquals( 7 , wrong, "unexpected replaced value " ); - Assert.assertEquals( "unexpected value " , - 42 , - attributes.getAttribute( "the answer" ) ); + Assertions.assertEquals( 42 , + attributes.getAttribute( "the answer" ), + "unexpected value " ); } @Test @@ -96,14 +93,12 @@ void testRemoval() { // no need to store such a stupid statement final Object wrong = attributes.removeAttribute( "rain is nice" ); - Assert.assertEquals( "unexpected number of elements in "+attributes , - 3 , attributes.size() ); + Assertions.assertEquals( 3 , attributes.size(), "unexpected number of elements in "+attributes ); - Assert.assertEquals( "unexpected removed value " , - false , wrong ); + Assertions.assertEquals( false , wrong, "unexpected removed value " ); - Assert.assertNull( "unexpected mapping " , - attributes.getAttribute( "rain is nice" ) ); + Assertions.assertNull( attributes.getAttribute( "rain is nice" ), + "unexpected mapping " ); } @Test @@ -114,15 +109,15 @@ void testGetAsMap() { attributes.putAttribute( "rain is nice" , false ); Map map = attributes.getAsMap(); - Assert.assertEquals(2, map.size()); + Assertions.assertEquals(2, map.size()); - Assert.assertEquals("nice", map.get("sun")); - Assert.assertEquals(false, map.get("rain is nice")); + Assertions.assertEquals("nice", map.get("sun")); + Assertions.assertEquals(false, map.get("rain is nice")); Iterator> iter = map.entrySet().iterator(); boolean foundSun = false; boolean foundRain = false; - Assert.assertTrue(iter.hasNext()); + Assertions.assertTrue(iter.hasNext()); Map.Entry e = iter.next(); if (e.getKey().equals("sun") && e.getValue().equals("nice")) { foundSun = true; @@ -130,7 +125,7 @@ void testGetAsMap() { if (e.getKey().equals("rain is nice") && e.getValue().equals(false)) { foundRain = true; } - Assert.assertTrue(iter.hasNext()); + Assertions.assertTrue(iter.hasNext()); e = iter.next(); if (e.getKey().equals("sun") && e.getValue().equals("nice")) { foundSun = true; @@ -138,19 +133,19 @@ void testGetAsMap() { if (e.getKey().equals("rain is nice") && e.getValue().equals(false)) { foundRain = true; } - Assert.assertFalse(iter.hasNext()); + Assertions.assertFalse(iter.hasNext()); - Assert.assertTrue(foundSun); - Assert.assertTrue(foundRain); + Assertions.assertTrue(foundSun); + Assertions.assertTrue(foundRain); try { iter.next(); - Assert.fail("Expected NoSuchElementException, but got none."); + Assertions.fail("Expected NoSuchElementException, but got none."); } catch (NoSuchElementException ignore) { // expected } catch (Exception ex) { ex.printStackTrace(); - Assert.fail("Expected NoSuchElementException, but caught a different one."); + Assertions.fail("Expected NoSuchElementException, but caught a different one."); } } } diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesUtilsTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesUtilsTest.java index 7507806be8e..8f5527253e7 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesUtilsTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributable/AttributesUtilsTest.java @@ -1,6 +1,6 @@ package org.matsim.utils.objectattributes.attributable; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordArrayConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordArrayConverterTest.java index c57aa1a4b75..72165d592a6 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordArrayConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordArrayConverterTest.java @@ -20,7 +20,7 @@ package org.matsim.utils.objectattributes.attributeconverters; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -31,25 +31,25 @@ void testFromToString() { final CoordArrayConverter converter = new CoordArrayConverter(); String a = "[(223380.4988791829;6758072.4280857295),(223404.67545027257;6758049.17275259),(223417.0127605943;6758038.021038004),(223450.67625251273;6757924.791645723),(223456.13332351885;6757906.359813054)]"; Coord[] coords = converter.convert(a); - Assert.assertEquals(coords.length, 5); - Assert.assertEquals(coords[0].hasZ(), false); - Assert.assertEquals(coords[0].getX(), 223380.4988791829, 0.00005); - Assert.assertEquals(coords[0].getY(), 6758072.4280857295, 0.00005); - Assert.assertEquals(coords[1].hasZ(), false); - Assert.assertEquals(coords[1].getX(), 223404.67545027257, 0.00005); - Assert.assertEquals(coords[1].getY(), 6758049.17275259, 0.00005); - Assert.assertEquals(coords[2].hasZ(), false); - Assert.assertEquals(coords[2].getX(), 223417.0127605943, 0.00005); - Assert.assertEquals(coords[2].getY(), 6758038.021038004, 0.00005); - Assert.assertEquals(coords[3].hasZ(), false); - Assert.assertEquals(coords[3].getX(), 223450.67625251273, 0.00005); - Assert.assertEquals(coords[3].getY(), 6757924.791645723, 0.00005); - Assert.assertEquals(coords[4].hasZ(), false); - Assert.assertEquals(coords[4].getX(), 223456.13332351885, 0.00005); - Assert.assertEquals(coords[4].getY(), 6757906.359813054, 0.00005); + Assertions.assertEquals(coords.length, 5); + Assertions.assertEquals(coords[0].hasZ(), false); + Assertions.assertEquals(coords[0].getX(), 223380.4988791829, 0.00005); + Assertions.assertEquals(coords[0].getY(), 6758072.4280857295, 0.00005); + Assertions.assertEquals(coords[1].hasZ(), false); + Assertions.assertEquals(coords[1].getX(), 223404.67545027257, 0.00005); + Assertions.assertEquals(coords[1].getY(), 6758049.17275259, 0.00005); + Assertions.assertEquals(coords[2].hasZ(), false); + Assertions.assertEquals(coords[2].getX(), 223417.0127605943, 0.00005); + Assertions.assertEquals(coords[2].getY(), 6758038.021038004, 0.00005); + Assertions.assertEquals(coords[3].hasZ(), false); + Assertions.assertEquals(coords[3].getX(), 223450.67625251273, 0.00005); + Assertions.assertEquals(coords[3].getY(), 6757924.791645723, 0.00005); + Assertions.assertEquals(coords[4].hasZ(), false); + Assertions.assertEquals(coords[4].getX(), 223456.13332351885, 0.00005); + Assertions.assertEquals(coords[4].getY(), 6757906.359813054, 0.00005); String b = converter.convertToString(coords); - Assert.assertEquals(a, b); + Assertions.assertEquals(a, b); } } diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordConverterTest.java index ee8b2db2c58..7395273817d 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/CoordConverterTest.java @@ -20,7 +20,7 @@ package org.matsim.utils.objectattributes.attributeconverters; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -32,12 +32,12 @@ void testFromToString() { final CoordConverter converter = new CoordConverter(); String a = "(224489.3667496938;6757449.720111595)"; Coord coord = converter.convert(a); - Assert.assertEquals(coord.hasZ(), false); - Assert.assertEquals(coord.getX(), 224489.3667496938, 0.00005); - Assert.assertEquals(coord.getY(), 6757449.720111595, 0.00005); + Assertions.assertEquals(coord.hasZ(), false); + Assertions.assertEquals(coord.getX(), 224489.3667496938, 0.00005); + Assertions.assertEquals(coord.getY(), 6757449.720111595, 0.00005); String b = converter.convertToString(coord); - Assert.assertEquals(a, b); + Assertions.assertEquals(a, b); } } diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/DoubleArrayConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/DoubleArrayConverterTest.java index e97d61653a8..35a30b580e7 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/DoubleArrayConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/DoubleArrayConverterTest.java @@ -21,10 +21,10 @@ package org.matsim.utils.objectattributes.attributeconverters; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; - /** + /** * @author jbischoff */ public class DoubleArrayConverterTest { @@ -35,15 +35,15 @@ void testFromToString() { final DoubleArrayConverter converter = new DoubleArrayConverter(); String a = "-0.1,0,0.0005,17.3,5.2E22"; double[] array = converter.convert(a); - Assert.assertEquals(array.length, 5); - Assert.assertEquals(array[0], -0.1, 0.00005); - Assert.assertEquals(array[1], 0.0, 0.00005); - Assert.assertEquals(array[2], 0.0005, 0.00005); - Assert.assertEquals(array[3], 17.3, 0.00005); - Assert.assertEquals(array[4], 5.2E22, 0.00005); + Assertions.assertEquals(array.length, 5); + Assertions.assertEquals(array[0], -0.1, 0.00005); + Assertions.assertEquals(array[1], 0.0, 0.00005); + Assertions.assertEquals(array[2], 0.0005, 0.00005); + Assertions.assertEquals(array[3], 17.3, 0.00005); + Assertions.assertEquals(array[4], 5.2E22, 0.00005); String b = converter.convertToString(array); - Assert.assertEquals("-0.1,0.0,5.0E-4,17.3,5.2E22", b); + Assertions.assertEquals("-0.1,0.0,5.0E-4,17.3,5.2E22", b); } diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/EnumConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/EnumConverterTest.java index 63318c6c71a..d69151a9db7 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/EnumConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/EnumConverterTest.java @@ -21,10 +21,10 @@ package org.matsim.utils.objectattributes.attributeconverters; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; - /** + /** * @author thibautd */ public class EnumConverterTest { @@ -45,15 +45,15 @@ void testFromString() { MyEnum some = converter.convert( "SOME_CONSTANT" ); MyEnum other = converter.convert( "SOME_OTHER_CONSTANT" ); - Assert.assertEquals("unexpected enum", MyEnum.SOME_CONSTANT, some); - Assert.assertEquals("unexpected enum", MyEnum.SOME_OTHER_CONSTANT, other); + Assertions.assertEquals(MyEnum.SOME_CONSTANT, some, "unexpected enum"); + Assertions.assertEquals(MyEnum.SOME_OTHER_CONSTANT, other, "unexpected enum"); } @Test void testToString() { final EnumConverter converter = new EnumConverter<>( MyEnum.class ); - Assert.assertEquals( "unexpected String value", "SOME_CONSTANT", converter.convertToString( MyEnum.SOME_CONSTANT ) ); - Assert.assertEquals( "unexpected String value", "SOME_OTHER_CONSTANT", converter.convertToString( MyEnum.SOME_OTHER_CONSTANT ) ); + Assertions.assertEquals( "SOME_CONSTANT", converter.convertToString( MyEnum.SOME_CONSTANT ), "unexpected String value" ); + Assertions.assertEquals( "SOME_OTHER_CONSTANT", converter.convertToString( MyEnum.SOME_OTHER_CONSTANT ), "unexpected String value" ); } } diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringCollectionConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringCollectionConverterTest.java index 7470881f42d..bdaa3ee6977 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringCollectionConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringCollectionConverterTest.java @@ -3,10 +3,10 @@ import java.util.Collection; import java.util.Map; -import static org.junit.Assert.assertEquals; - import org.junit.jupiter.api.Test; +import static org.junit.jupiter.api.Assertions.assertEquals; + public class StringCollectionConverterTest { @Test diff --git a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringStringMapConverterTest.java b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringStringMapConverterTest.java index 686cc3efe37..a6884a90965 100644 --- a/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringStringMapConverterTest.java +++ b/matsim/src/test/java/org/matsim/utils/objectattributes/attributeconverters/StringStringMapConverterTest.java @@ -1,6 +1,6 @@ package org.matsim.utils.objectattributes.attributeconverters; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; diff --git a/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java b/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java index 152586c364d..d50dbb5234e 100644 --- a/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java +++ b/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java @@ -19,7 +19,7 @@ package org.matsim.vehicles; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.File; import java.io.FileNotFoundException; diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java index 7f6716c5acd..79e3ca7e10d 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java @@ -19,7 +19,7 @@ package org.matsim.vehicles; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.Map; diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java index 599b853217d..83e51b5bdf3 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java @@ -19,7 +19,7 @@ package org.matsim.vehicles; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.Map; diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java index d103a29f287..1e970b893f4 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java @@ -19,7 +19,7 @@ package org.matsim.vehicles; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.File; import java.util.Map; diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java index 9b65d2f6608..e3ebbe417bf 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java @@ -19,7 +19,7 @@ package org.matsim.vehicles; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.io.File; import java.io.IOException; diff --git a/matsim/src/test/java/org/matsim/vehicles/VehiclesImplTest.java b/matsim/src/test/java/org/matsim/vehicles/VehiclesImplTest.java index 2cace0fd2e6..4835940bbef 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehiclesImplTest.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehiclesImplTest.java @@ -19,7 +19,7 @@ package org.matsim.vehicles; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -40,7 +40,7 @@ void testAddVehicle() { /* Must add vehicle type before adding vehicle. */ try{ vehicles.addVehicle(v1); - Assert.fail("Should not allow adding a vehicle if vehicle type has not been added to container first."); + Assertions.fail("Should not allow adding a vehicle if vehicle type has not been added to container first."); } catch(IllegalArgumentException e){ /* Pass. */ } @@ -51,7 +51,7 @@ void testAddVehicle() { Vehicle v2 = vehicles.getFactory().createVehicle(Id.create("v1", Vehicle.class), testType); try{ vehicles.addVehicle(v2); - Assert.fail("Cannot add another vehicle with the same Id."); + Assertions.fail("Cannot add another vehicle with the same Id."); } catch (IllegalArgumentException e){ /* Pass. */ } @@ -70,7 +70,7 @@ void testGetVehicles(){ try{ vehicles.getVehicles().put(Id.create("v1", Vehicle.class), v1 ); vehicles.getVehicles(); - Assert.fail("Should not be able to add to an unmodiafiable Map"); + Assertions.fail("Should not be able to add to an unmodiafiable Map"); } catch (UnsupportedOperationException e){ /* Pass. */ } @@ -85,7 +85,7 @@ void testGetVehicleTypes(){ /* Should get an unmodifiable Map of the Vehicles container. */ try{ vehicles.getVehicleTypes().put(Id.create("type1", VehicleType.class), t1 ); - Assert.fail("Should not be able to add to an unmodiafiable Map"); + Assertions.fail("Should not be able to add to an unmodiafiable Map"); } catch (UnsupportedOperationException e){ /* Pass. */ } @@ -101,7 +101,7 @@ void testAddVehicleType(){ vehicles.addVehicleType(t1); try{ vehicles.addVehicleType(t2); - Assert.fail("Cannot add another vehicle type with the same Id"); + Assertions.fail("Cannot add another vehicle type with the same Id"); } catch (IllegalArgumentException e){ /* Pass. */ } @@ -115,11 +115,11 @@ void testRemoveVehicle() { Vehicle v1 = vehicles.getFactory().createVehicle(Id.create("v1", Vehicle.class), t1); - Assert.assertEquals(0, vehicles.getVehicles().size()); + Assertions.assertEquals(0, vehicles.getVehicles().size()); vehicles.addVehicle(v1); - Assert.assertEquals(1, vehicles.getVehicles().size()); + Assertions.assertEquals(1, vehicles.getVehicles().size()); vehicles.removeVehicle(Id.create("v1", Vehicle.class)); - Assert.assertEquals(0, vehicles.getVehicles().size()); + Assertions.assertEquals(0, vehicles.getVehicles().size()); } @Test @@ -132,7 +132,7 @@ void testRemoveVehicleType() { try { vehicles.removeVehicleType(t1.getId()); - Assert.fail("expected exception, as vehicle type is still in use."); + Assertions.fail("expected exception, as vehicle type is still in use."); } catch (IllegalArgumentException e) { // pass } diff --git a/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java b/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java index 178b07d1236..cd8c7e9a449 100644 --- a/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java +++ b/matsim/src/test/java/org/matsim/vis/snapshotwriters/PositionInfoTest.java @@ -20,7 +20,7 @@ package org.matsim.vis.snapshotwriters; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java b/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java index 88ee4b705a2..bad57d42cc7 100644 --- a/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java +++ b/matsim/src/test/java/org/matsim/withinday/controller/ExperiencedPlansWriterTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -124,7 +124,7 @@ public void install() { */ File file = new File(this.utils.getOutputDirectory() + "/ITERS/it.0/0." + ExecutedPlansServiceImpl.EXECUTEDPLANSFILE); - Assert.assertTrue(file.exists()); + Assertions.assertTrue(file.exists()); Config experiencedConfig = ConfigUtils.createConfig(); experiencedConfig.plans().setInputFile(this.utils.getOutputDirectory() + "/ITERS/it.0/0." + @@ -139,10 +139,10 @@ public void install() { Leg leg02 = (Leg) p02.getSelectedPlan().getPlanElements().get(1); // expect leg from p01 to be unchanged - Assert.assertEquals(1, ((NetworkRoute) leg01.getRoute()).getLinkIds().size()); + Assertions.assertEquals(1, ((NetworkRoute) leg01.getRoute()).getLinkIds().size()); // expect leg from p02 to be adapted - Assert.assertEquals(3, ((NetworkRoute) leg02.getRoute()).getLinkIds().size()); + Assertions.assertEquals(3, ((NetworkRoute) leg02.getRoute()).getLinkIds().size()); } private static class WriterInitializer implements StartupListener { diff --git a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java index f0870a25f99..cde10531df3 100644 --- a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java +++ b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/ActivityReplanningMapTest.java @@ -20,12 +20,12 @@ package org.matsim.withinday.replanning.identifiers.tools; -import static org.junit.Assert.assertEquals; - import java.util.LinkedHashMap; import java.util.Map; import jakarta.inject.Inject; + +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; diff --git a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java index ed3ffd5c1a7..6b37b4707d3 100644 --- a/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java +++ b/matsim/src/test/java/org/matsim/withinday/replanning/identifiers/tools/LinkReplanningMapTest.java @@ -20,7 +20,7 @@ package org.matsim.withinday.replanning.identifiers.tools; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import jakarta.inject.Inject; import org.junit.jupiter.api.Test; diff --git a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/TtmobsimListener.java b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/TtmobsimListener.java index 7d8dab36738..e1330840f24 100644 --- a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/TtmobsimListener.java +++ b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/TtmobsimListener.java @@ -18,8 +18,7 @@ * *********************************************************************** */ package org.matsim.withinday.trafficmonitoring; - -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.network.Link; import org.matsim.core.mobsim.framework.events.MobsimAfterSimStepEvent; @@ -59,7 +58,7 @@ public TtmobsimListener(NetworkChangeEvent nce) { this.networkChangeEventTime = nce.getStartTime(); this.reducedFreespeed = nce.getFreespeedChange().getValue(); - Assert.assertEquals(true, this.reducedFreespeed < this.link.getFreespeed()); + Assertions.assertEquals(true, this.reducedFreespeed < this.link.getFreespeed()); } } } @@ -69,18 +68,18 @@ public void notifyMobsimAfterSimStep(MobsimAfterSimStepEvent e) { if (e.getSimulationTime() <= networkChangeEventTime) { - Assert.assertEquals("Wrong travel time at time step " + e.getSimulationTime() + ". Should be the freespeed travel time.", - Math.ceil(link.getLength()/link.getFreespeed()), + Assertions.assertEquals(Math.ceil(link.getLength()/link.getFreespeed()), Math.ceil(travelTime.getLinkTravelTime(link, e.getSimulationTime(), null, null)), - testUtils.EPSILON); + testUtils.EPSILON, + "Wrong travel time at time step " + e.getSimulationTime() + ". Should be the freespeed travel time."); case1 = true; } else { - Assert.assertEquals("Wrong travel time at time step " + e.getSimulationTime() + ". Should be the travel time resulting from the network change event (reduced freespeed).", - Math.ceil(link.getLength() / reducedFreespeed), + Assertions.assertEquals(Math.ceil(link.getLength() / reducedFreespeed), Math.ceil(travelTime.getLinkTravelTime(link, e.getSimulationTime(), null, null)), - testUtils.EPSILON); + testUtils.EPSILON, + "Wrong travel time at time step " + e.getSimulationTime() + ". Should be the travel time resulting from the network change event (reduced freespeed)."); case2 = true; } diff --git a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java index 8bb4b9ca4f6..22473f07d16 100644 --- a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java +++ b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeTest.java @@ -20,7 +20,7 @@ package org.matsim.withinday.trafficmonitoring; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; diff --git a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java index 85961c100a2..2b63bbb9f0d 100644 --- a/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java +++ b/matsim/src/test/java/org/matsim/withinday/trafficmonitoring/WithinDayTravelTimeWithNetworkChangeEventsTest.java @@ -24,7 +24,7 @@ import java.util.List; import java.util.Set; -import org.junit.Assert; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -130,8 +130,8 @@ final void testTTviaMobSimAfterSimStepListener() { controler.run(); - Assert.assertEquals(true, ttmobsimListener.isCase1()); - Assert.assertEquals(true, ttmobsimListener.isCase2()); + Assertions.assertEquals(true, ttmobsimListener.isCase1()); + Assertions.assertEquals(true, ttmobsimListener.isCase2()); } diff --git a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java index 6931b60b91f..5b0d8f2883b 100644 --- a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java +++ b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java @@ -20,7 +20,7 @@ package org.matsim.withinday.utils; -import static org.junit.Assert.*; +import static org.junit.jupiter.api.Assertions.*; import java.util.ArrayList; import java.util.Arrays; diff --git a/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java b/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java index 3d2f16c8350..ffd14815885 100644 --- a/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java +++ b/matsim/src/test/java/org/matsim/withinday/utils/ReplacePlanElementsTest.java @@ -20,7 +20,7 @@ package org.matsim.withinday.utils; -import static org.junit.Assert.assertEquals; +import static org.junit.jupiter.api.Assertions.assertEquals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; From b64024fbe32599135a4bcc57bdec34961c246998 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 19:51:50 +0100 Subject: [PATCH 30/43] fixed imports --- .../freight/carriers/jsprit/MatsimTransformerTest.java | 1 + .../freight/carriers/utils/CarrierControlerUtilsTest.java | 1 + .../modules/InsertionRemovalIterativeActionTest.java | 1 + .../socnetsim/usage/replanning/GroupPlanStrategyTest.java | 6 +++--- .../matsim/analysis/ScoreStatsControlerListenerTest.java | 7 ++++--- matsim/src/test/java/org/matsim/counts/CountsV2Test.java | 4 ++-- .../algorithms/ChooseRandomSingleLegModeTest.java | 3 ++- .../org/matsim/pt/utils/TransitScheduleValidatorTest.java | 7 ++++--- 8 files changed, 18 insertions(+), 12 deletions(-) diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java index a3e187a4fe2..310c1942ad4 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java @@ -50,6 +50,7 @@ import static org.hamcrest.CoreMatchers.is; import static org.hamcrest.CoreMatchers.not; +import static org.hamcrest.MatcherAssert.assertThat; import static org.junit.jupiter.api.Assertions.*; public class MatsimTransformerTest { diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java index 143a2a45a6b..55d1c268c7a 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java @@ -31,6 +31,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java index fe45fa49200..bae28cc67cf 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java @@ -29,6 +29,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.Before; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java index 08ff8da07ce..5202da7e0ed 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/usage/replanning/GroupPlanStrategyTest.java @@ -19,8 +19,6 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.usage.replanning; -import static org.junit.jupiter.api.Assertions.assertFalse; - import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; @@ -46,6 +44,8 @@ import org.matsim.contrib.socnetsim.framework.replanning.selectors.EmptyIncompatiblePlansIdentifierFactory; import org.matsim.contrib.socnetsim.framework.replanning.selectors.HighestScoreSumSelector; +import static org.junit.jupiter.api.Assertions.*; + /** * @author thibautd */ @@ -212,7 +212,7 @@ private static Person createPerson( return person; } - + private static ReplanningContext createContext() { return null; } diff --git a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java index 1a25c737c17..1cf98effe1f 100644 --- a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java @@ -5,7 +5,6 @@ import java.util.Collections; import java.util.ListIterator; -import org.assertj.core.api.Assertions; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -34,6 +33,8 @@ import org.matsim.core.scenario.ScenarioUtils; import org.matsim.testcases.MatsimTestUtils; +import static org.assertj.core.api.Assertions.assertThat; + /** * @author Aravind * @@ -559,10 +560,10 @@ private void readAndValidateValues(String outDir, int itr, Population populatio iteration++; } - Assertions.assertThat(new File(outDir, "scorestats_group1.csv")) + assertThat(new File(outDir, "scorestats_group1.csv")) .isFile(); - Assertions.assertThat(new File(outDir, "scorestats_group2.csv")) + assertThat(new File(outDir, "scorestats_group2.csv")) .isFile(); } diff --git a/matsim/src/test/java/org/matsim/counts/CountsV2Test.java b/matsim/src/test/java/org/matsim/counts/CountsV2Test.java index 85c211033ee..d8aacb1146a 100644 --- a/matsim/src/test/java/org/matsim/counts/CountsV2Test.java +++ b/matsim/src/test/java/org/matsim/counts/CountsV2Test.java @@ -1,6 +1,5 @@ package org.matsim.counts; -import org.assertj.core.api.Assertions; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -22,6 +21,7 @@ import java.util.SplittableRandom; import static org.assertj.core.api.Assertions.assertThat; +import static org.assertj.core.api.Assertions.assertThatNoException; import static org.junit.jupiter.api.Assertions.assertThrows; public class CountsV2Test { @@ -63,7 +63,7 @@ void test_reader_writer() throws IOException { Counts counts = new Counts<>(); CountsReaderMatsimV2 reader = new CountsReaderMatsimV2(counts, Link.class); - Assertions.assertThatNoException().isThrownBy(() -> reader.readFile(filename)); + Assertions.assertDoesNotThrow(() -> reader.readFile(filename)); Map, MeasurementLocation> countMap = counts.getMeasureLocations(); Assertions.assertEquals(21, countMap.size()); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java index 4acfb093c05..331a2fc5de3 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomSingleLegModeTest.java @@ -20,10 +20,11 @@ package org.matsim.population.algorithms; -import static org.junit.jupiter.api.Assertions.fail; +import static org.junit.jupiter.api.Assertions.*; import java.util.Random; +import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; diff --git a/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java b/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java index e191c160ff8..fb97f3b1ecd 100644 --- a/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java +++ b/matsim/src/test/java/org/matsim/pt/utils/TransitScheduleValidatorTest.java @@ -21,7 +21,6 @@ package org.matsim.pt.utils; -import org.assertj.core.api.Assertions; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -39,6 +38,8 @@ import java.util.Collections; import java.util.List; +import static org.assertj.core.api.Assertions.assertThat; + public class TransitScheduleValidatorTest { @Test @@ -47,7 +48,7 @@ void testPtTutorial() { ConfigUtils.loadConfig("test/scenarios/pt-tutorial/0.config.xml")); TransitScheduleValidator.ValidationResult validationResult = TransitScheduleValidator.validateAll( scenario.getTransitSchedule(), scenario.getNetwork()); - Assertions.assertThat(validationResult.getIssues()).isEmpty(); + assertThat(validationResult.getIssues()).isEmpty(); } @Test @@ -65,7 +66,7 @@ void testPtTutorialWithError() { scenario.getTransitSchedule(), scenario.getNetwork()); System.out.println(validationResult); - Assertions.assertThat(validationResult.getIssues()).usingRecursiveFieldByFieldElementComparator() + assertThat(validationResult.getIssues()).usingRecursiveFieldByFieldElementComparator() .containsExactly(new TransitScheduleValidator.ValidationResult.ValidationIssue<>( TransitScheduleValidator.ValidationResult.Severity.ERROR, "Transit line Blue Line, route 3to1: Stop 2b cannot be reached along network route.", From 58b12657b4de803399c1aab99869bac7257ffccc Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 20:15:10 +0100 Subject: [PATCH 31/43] fixed compile --- .../analysis/ModeStatsControlerListenerTest.java | 2 +- .../analysis/ScoreStatsControlerListenerTest.java | 6 +++--- .../org/matsim/analysis/TravelDistanceStatsTest.java | 2 +- .../core/config/groups/ControllerConfigGroupTest.java | 10 +++++----- 4 files changed, 10 insertions(+), 10 deletions(-) diff --git a/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java index 8182e8d3032..9b744c8d1b8 100644 --- a/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ModeStatsControlerListenerTest.java @@ -454,7 +454,7 @@ private void readAndcompareValues(HashMap modes, int itr) { } iteration++; } - Assert.assertEquals(itr, iteration); + Assertions.assertEquals(itr, iteration); } catch (IOException e) { e.printStackTrace(); } diff --git a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java index 7837bcb9e2f..2bc0864ed85 100644 --- a/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java +++ b/matsim/src/test/java/org/matsim/analysis/ScoreStatsControlerListenerTest.java @@ -563,10 +563,10 @@ private void readAndValidateValues(String outDir, int itr, Population populatio Assertions.assertEquals(itr, iteration); - assertThat(new File(outDir, "scorestats_group1.csv")) - Assert.assertEquals(itr, iteration); + assertThat(new File(outDir, "scorestats_group1.csv")).isFile(); + Assertions.assertEquals(itr, iteration); - Assertions.assertThat(new File(outDir, "scorestats_group1.csv")) + assertThat(new File(outDir, "scorestats_group1.csv")) .isFile(); assertThat(new File(outDir, "scorestats_group2.csv")) diff --git a/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java b/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java index cfb2ffa8b61..1bd013dbb2b 100644 --- a/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java +++ b/matsim/src/test/java/org/matsim/analysis/TravelDistanceStatsTest.java @@ -397,7 +397,7 @@ private void readAndValidateValues(int itr, Double legSum, int totalTrip, long t } iteration++; } - Assert.assertEquals("There are too less entries.", itr, iteration); + Assertions.assertEquals(itr, iteration, "There are too less entries."); } catch (IOException e) { e.printStackTrace(); } diff --git a/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java b/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java index d524334f96a..431dd6a5d3c 100644 --- a/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java +++ b/matsim/src/test/java/org/matsim/core/config/groups/ControllerConfigGroupTest.java @@ -165,17 +165,17 @@ void testWriteSnapshotInterval(){ public void testCreateGraphsInterval() { ControllerConfigGroup cg = new ControllerConfigGroup(); //initial value - Assert.assertEquals(1, cg.getCreateGraphsInterval()); + Assertions.assertEquals(1, cg.getCreateGraphsInterval()); //modify by string cg.addParam("createGraphsInterval", "10"); - Assert.assertEquals(10, cg.getCreateGraphsInterval()); + Assertions.assertEquals(10, cg.getCreateGraphsInterval()); //modify by setter cg.setCreateGraphsInterval(42); - Assert.assertEquals("42", cg.getValue("createGraphsInterval")); - Assert.assertEquals(42, cg.getCreateGraphsInterval()); + Assertions.assertEquals("42", cg.getValue("createGraphsInterval")); + Assertions.assertEquals(42, cg.getCreateGraphsInterval()); //modify by deprecated setter cg.setCreateGraphs(true); - Assert.assertEquals(1, cg.getCreateGraphsInterval()); + Assertions.assertEquals(1, cg.getCreateGraphsInterval()); } From e10a3920a11b08cf8374ab4468c150eb1e809d8d Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Mon, 11 Dec 2023 20:30:55 +0100 Subject: [PATCH 32/43] fix before and after --- benchmark/pom.xml | 4 -- .../kai/KNAnalysisEventsHandlerTest.java | 8 +-- .../BicycleLinkSpeedCalculatorTest.java | 4 +- .../IsTheRightCustomerScoredTest.java | 4 +- .../util/WeightedRandomSelectionTest.java | 4 +- .../MultiModaFixedDrtLegEstimatorTest.java | 4 +- .../MultiModalDrtLegEstimatorTest.java | 4 +- ...ultiInsertionDetourPathCalculatorTest.java | 4 +- ...ngleInsertionDetourPathCalculatorTest.java | 4 +- .../path/OneToManyPathCalculatorTest.java | 4 +- ...issionAnalysisModuleTrafficSituations.java | 14 ++-- .../freight/carriers/CarrierModuleTest.java | 4 +- .../carriers/CarrierPlanXmlReaderV2Test.java | 4 +- .../CarrierPlanXmlReaderV2WithDtdTest.java | 4 +- .../carriers/CarrierPlanXmlWriterV2Test.java | 4 +- .../CarrierPlanXmlWriterV2_1Test.java | 4 +- .../CarrierVehicleTypeLoaderTest.java | 4 +- .../CarrierVehicleTypeReaderTest.java | 4 +- .../carriers/CarrierVehicleTypeTest.java | 4 +- .../EquilWithCarrierWithPersonsIT.java | 4 +- .../carriers/jsprit/FixedCostsTest.java | 4 +- .../utils/CarrierControlerUtilsIT.java | 4 +- .../utils/CarrierControlerUtilsTest.java | 4 +- .../hybridsim/utils/IdIntMapperTest.java | 8 +-- .../matsim/modechoice/EstimateRouterTest.java | 4 +- .../org/matsim/modechoice/ScenarioTest.java | 4 +- ...RelaxedMassConservationConstraintTest.java | 6 +- .../RelaxedSubtourConstraintTest.java | 6 +- .../MultinomialLogitSelectorTest.java | 4 +- .../modechoice/search/TopKMinMaxTest.java | 4 +- .../frozenepsilons/SamplerTest.java | 4 +- .../matrixbasedptrouter/PtMatrixTest.java | 4 +- .../genericUtils/TerminusStopFinderTest.java | 52 +++++++------- ...eaBtwLinksVsTerminiBeelinePenaltyTest.java | 32 ++++----- .../RouteDesignScoringManagerTest.java | 72 +++++++++---------- .../StopServedMultipleTimesPenaltyTest.java | 28 ++++---- .../networkReader/OsmNetworkParserTest.java | 4 +- .../networkReader/OsmSignalsParserTest.java | 4 +- contribs/pom.xml | 4 -- .../railsim/qsimengine/RailsimEngineTest.java | 4 +- .../matsim/mobsim/qsim/SBBQSimModuleTest.java | 4 +- .../simwrapper/viz/PlotlyExamplesTest.java | 4 +- .../org/matsim/simwrapper/viz/PlotlyTest.java | 4 +- .../replanning/grouping/GroupPlansTest.java | 10 +-- .../replanning/modules/MergingTest.java | 10 +-- .../selectors/HighestWeightSelectorTest.java | 10 +-- .../selectors/RandomSelectorsTest.java | 16 ++--- .../WhoIsTheBossSelectorTest.java | 2 +- .../GroupCompositionPenalizerTest.java | 2 +- .../jointtrips/JointTravelUtilsTest.java | 22 +++--- ...InsertionRemovalIgnoranceBehaviorTest.java | 8 +-- .../InsertionRemovalIterativeActionTest.java | 4 +- .../JointTripRemoverAlgorithmTest.java | 8 +-- ...nchronizeCoTravelerPlansAlgorithmTest.java | 10 +-- .../router/JointTripRouterFactoryTest.java | 4 +- ...ehicleToPlansInGroupPlanAlgorithmTest.java | 8 +-- ...omPersonAttributesNoSubpopulationTest.java | 4 +- ...ingParametersFromPersonAttributesTest.java | 4 +- .../analysis/RunFreightAnalysisIT.java | 4 +- .../java/playground/vsp/ev/UrbanEVTests.java | 2 +- ...rarchicalFLowEfficiencyCalculatorTest.java | 4 +- .../PlanFileModifierTest.java | 4 +- .../vsp/pt/fare/PtTripFareEstimatorTest.java | 4 +- ...nScoringParametersNoSubpopulationTest.java | 4 +- ...ityOfMoneyPersonScoringParametersTest.java | 4 +- matsim/pom.xml | 4 -- .../SwissRailRaptorConfigGroupTest.java | 4 +- .../routing/pt/raptor/RaptorUtilsTest.java | 4 +- .../pt/raptor/SwissRailRaptorModuleTest.java | 4 +- .../org/matsim/analysis/CalcLegTimesTest.java | 8 +-- .../api/core/v01/DemandGenerationTest.java | 8 +-- .../core/v01/IdDeSerializationModuleTest.java | 4 +- .../core/controler/ControlerEventsTest.java | 8 +-- .../events/ParallelEventsManagerTest.java | 6 +- .../core/mobsim/hermes/FlowCapacityTest.java | 4 +- .../matsim/core/mobsim/hermes/HermesTest.java | 4 +- .../core/mobsim/hermes/HermesTransitTest.java | 4 +- .../mobsim/jdeqsim/AbstractJDEQSimTest.java | 8 +-- .../core/mobsim/qsim/pt/UmlaufDriverTest.java | 4 +- .../algorithms/NetworkSimplifierTest.java | 26 +++---- .../filter/NetworkFilterManagerTest.java | 4 +- .../annealing/ReplanningAnnealerTest.java | 4 +- .../modules/ExternalModuleTest.java | 4 +- .../selectors/ExpBetaPlanSelectorTest.java | 8 +-- .../selectors/PathSizeLogitSelectorTest.java | 8 +-- .../router/TestActivityWrapperFacility.java | 4 +- .../core/router/TripStructureUtilsTest.java | 16 ++--- ...yparNagelOpenTimesScoringFunctionTest.java | 8 +-- .../java/org/matsim/counts/CountTest.java | 4 +- .../PermissibleModesCalculatorImplTest.java | 16 ++--- .../vehicles/MatsimVehicleWriterTest.java | 4 +- .../matsim/vehicles/VehicleReaderV1Test.java | 4 +- .../matsim/vehicles/VehicleReaderV2Test.java | 4 +- .../matsim/vehicles/VehicleWriteReadTest.java | 4 +- .../matsim/vehicles/VehicleWriterV1Test.java | 4 +- .../matsim/vehicles/VehicleWriterV2Test.java | 4 +- pom.xml | 6 -- 97 files changed, 349 insertions(+), 367 deletions(-) diff --git a/benchmark/pom.xml b/benchmark/pom.xml index dd8bbafda2c..f8104490737 100644 --- a/benchmark/pom.xml +++ b/benchmark/pom.xml @@ -40,10 +40,6 @@ matsim-examples 16.0-SNAPSHOT - - org.junit.vintage - junit-vintage-engine - org.junit.jupiter junit-jupiter-engine diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java index a42e5780cc4..ec4fa06dd61 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java @@ -22,8 +22,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.Ignore; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; @@ -68,7 +68,7 @@ public class KNAnalysisEventsHandlerTest { private Population population = null ; private Network network = null ; - @Before + @BeforeEach public void setUp() throws Exception { scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -101,7 +101,7 @@ public void setUp() throws Exception { this.network.addLink(link); } - @After + @AfterEach public void tearDown() throws Exception { this.population = null; this.network = null; diff --git a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java index bb131f1005a..8d58af0313f 100644 --- a/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java +++ b/contribs/bicycle/src/test/java/org/matsim/contrib/bicycle/BicycleLinkSpeedCalculatorTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.bicycle; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -42,7 +42,7 @@ public class BicycleLinkSpeedCalculatorTest { private BicycleConfigGroup configGroup; private final Network unusedNetwork = NetworkUtils.createNetwork(); - @Before + @BeforeEach public void before() { configGroup = ConfigUtils.addOrGetModule( config, BicycleConfigGroup.class ); configGroup.setMaxBicycleSpeedForRouting(MAX_BICYCLE_SPEED); diff --git a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java index 8e083962c5d..813601153ce 100644 --- a/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java +++ b/contribs/commercialTrafficApplications/src/test/java/org/matsim/contrib/commercialTrafficApplications/jointDemand/IsTheRightCustomerScoredTest.java @@ -18,7 +18,7 @@ package org.matsim.contrib.commercialTrafficApplications.jointDemand; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -41,7 +41,7 @@ public class IsTheRightCustomerScoredTest { Scenario scenario; - @Before + @BeforeEach public void setUp() { Config config = ConfigUtils.loadConfig("./scenarios/grid/jointDemand_config.xml"); diff --git a/contribs/common/src/test/java/org/matsim/contrib/common/util/WeightedRandomSelectionTest.java b/contribs/common/src/test/java/org/matsim/contrib/common/util/WeightedRandomSelectionTest.java index fb30100ab83..2c33545ebe5 100644 --- a/contribs/common/src/test/java/org/matsim/contrib/common/util/WeightedRandomSelectionTest.java +++ b/contribs/common/src/test/java/org/matsim/contrib/common/util/WeightedRandomSelectionTest.java @@ -26,7 +26,7 @@ import java.util.Random; import org.apache.commons.lang3.mutable.MutableDouble; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; /** @@ -37,7 +37,7 @@ public class WeightedRandomSelectionTest { private final MutableDouble randomDouble = new MutableDouble(); private WeightedRandomSelection weightedRandomSelection; - @Before + @BeforeEach public void init() { weightedRandomSelection = new WeightedRandomSelection<>(new Random() { @Override diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java index cb93757590c..5d4a8a1d5b6 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModaFixedDrtLegEstimatorTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.drt.extension.estimator; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.application.MATSimApplication; @@ -67,7 +67,7 @@ private static void prepare(Config config) { } - @Before + @BeforeEach public void setUp() throws Exception { Config config = DrtTestScenario.loadConfig(utils); diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java index 4f57b22744e..90601b72b29 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/estimator/MultiModalDrtLegEstimatorTest.java @@ -1,6 +1,6 @@ package org.matsim.contrib.drt.extension.estimator; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.application.MATSimApplication; @@ -31,7 +31,7 @@ public class MultiModalDrtLegEstimatorTest { private Controler controler; - @Before + @BeforeEach public void setUp() throws Exception { Config config = DrtTestScenario.loadConfig(utils); diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/MultiInsertionDetourPathCalculatorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/MultiInsertionDetourPathCalculatorTest.java index 9c604cb7acd..b11903b01df 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/MultiInsertionDetourPathCalculatorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/extensive/MultiInsertionDetourPathCalculatorTest.java @@ -31,7 +31,7 @@ import java.util.List; import java.util.Map; -import org.junit.After; +import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -70,7 +70,7 @@ public class MultiInsertionDetourPathCalculatorTest { private final MultiInsertionDetourPathCalculator detourPathCalculator = new MultiInsertionDetourPathCalculator( pathSearch, pathSearch, pathSearch, pathSearch, 1); - @After + @AfterEach public void after() { detourPathCalculator.notifyMobsimBeforeCleanup(null); } diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SingleInsertionDetourPathCalculatorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SingleInsertionDetourPathCalculatorTest.java index 62a8f56f9e6..19897df2149 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SingleInsertionDetourPathCalculatorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/optimizer/insertion/selective/SingleInsertionDetourPathCalculatorTest.java @@ -30,7 +30,7 @@ import java.util.List; -import org.junit.After; +import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -74,7 +74,7 @@ public class SingleInsertionDetourPathCalculatorTest { private final SingleInsertionDetourPathCalculator detourPathCalculator = new SingleInsertionDetourPathCalculator( null, new FreeSpeedTravelTime(), null, 1, (network, travelCosts, travelTimes) -> pathCalculator); - @After + @AfterEach public void after() { detourPathCalculator.notifyMobsimBeforeCleanup(null); } diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/OneToManyPathCalculatorTest.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/OneToManyPathCalculatorTest.java index 8730f17dcb9..2db1640cdf5 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/OneToManyPathCalculatorTest.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/path/OneToManyPathCalculatorTest.java @@ -26,7 +26,7 @@ import java.util.List; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -68,7 +68,7 @@ public class OneToManyPathCalculatorTest { private final LeastCostPathTree dijkstraTree = new LeastCostPathTree(new SpeedyGraph(network), travelTime, new TimeAsTravelDisutility(travelTime)); - @Before + @BeforeEach public void init() { for (Node node : List.of(nodeA, nodeB, nodeC, nodeD, nodeE)) { nodeMap.put(node.getId(), node); diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleTrafficSituations.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleTrafficSituations.java index c275756af07..6f555874356 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleTrafficSituations.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleTrafficSituations.java @@ -19,7 +19,7 @@ * *********************************************************************** */ import org.junit.Assert; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; @@ -44,7 +44,7 @@ /** * @author joe - + /* * test for playground.vsp.emissions.WarmEmissionAnalysisModule @@ -96,7 +96,7 @@ public static Collection createCombinations() { return list; } - @Before + @BeforeEach public void setUp() { Map avgHbefaWarmTable = new HashMap<>(); Map detailedHbefaWarmTable = new HashMap<>(); @@ -257,7 +257,7 @@ private void fillDetailedTable( Map avgHbefaWarmTable) { @@ -282,7 +282,7 @@ private void fillAverageTable( Map vehicleTypeId = Id.create( "medium", VehicleType.class ); VehicleType mediumType = VehicleUtils.getFactory().createVehicleType( vehicleTypeId ); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java index 507326c6e2b..acfb8eab226 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/controler/EquilWithCarrierWithPersonsIT.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers.controler; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -60,7 +60,7 @@ static Config commonConfig( MatsimTestUtils testUtils ) { return config; } - @Before + @BeforeEach public void setUp(){ Config config = commonConfig( testUtils ); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java index d9aeaf17ef7..07ea6e5ac60 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/FixedCostsTest.java @@ -29,7 +29,7 @@ import com.graphhopper.jsprit.core.util.Solutions; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -64,7 +64,7 @@ public class FixedCostsTest { private final Carriers carriers = new Carriers(); private final Carriers carriersPlannedAndRouted = new Carriers(); - @Before + @BeforeEach public void setUp() throws Exception { // Create carrier with services; service1 nearby the depot, service2 at the opposite side of the network CarrierService service1 = createMatsimService("Service1", "i(3,0)", 1); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java index 3cdf13513c1..a50b4c5430d 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsIT.java @@ -26,7 +26,7 @@ import com.graphhopper.jsprit.core.problem.VehicleRoutingProblem; import com.graphhopper.jsprit.core.problem.solution.VehicleRoutingProblemSolution; import com.graphhopper.jsprit.core.util.Solutions; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -67,7 +67,7 @@ public class CarrierControlerUtilsIT { @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); - @Before + @BeforeEach public void setUp() { //Create carrier with services and shipments diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java index 55d1c268c7a..678b2727ff1 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/utils/CarrierControlerUtilsTest.java @@ -30,7 +30,7 @@ import com.graphhopper.jsprit.core.util.Solutions; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -79,7 +79,7 @@ public class CarrierControlerUtilsTest { @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); - @Before + @BeforeEach public void setUp() { //Create carrier with services and shipments diff --git a/contribs/hybridsim/src/test/java/org/matsim/contrib/hybridsim/utils/IdIntMapperTest.java b/contribs/hybridsim/src/test/java/org/matsim/contrib/hybridsim/utils/IdIntMapperTest.java index fad773395d3..7f2c5802c1a 100644 --- a/contribs/hybridsim/src/test/java/org/matsim/contrib/hybridsim/utils/IdIntMapperTest.java +++ b/contribs/hybridsim/src/test/java/org/matsim/contrib/hybridsim/utils/IdIntMapperTest.java @@ -13,8 +13,8 @@ // /****************************************************************************/ -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; @@ -33,12 +33,12 @@ public class IdIntMapperTest { private IdIntMapper mapper; - @Before + @BeforeEach public void setup() { this.mapper = new IdIntMapper(); } - @After + @AfterEach public void tearDown() { this.mapper = null; } diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java index fae4abb3ab1..b91a3b8ea45 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/EstimateRouterTest.java @@ -1,7 +1,7 @@ package org.matsim.modechoice; import com.google.inject.Injector; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -27,7 +27,7 @@ public class EstimateRouterTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Before + @BeforeEach public void setUp() throws Exception { Config config = TestScenario.loadConfig(utils); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java index 2042b6c03a0..4d5ea25153e 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/ScenarioTest.java @@ -1,7 +1,7 @@ package org.matsim.modechoice; import com.google.inject.Injector; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.application.MATSimApplication; import org.matsim.core.config.Config; @@ -18,7 +18,7 @@ public class ScenarioTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Before + @BeforeEach public void setUp() throws Exception { Config config = TestScenario.loadConfig(utils); diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedMassConservationConstraintTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedMassConservationConstraintTest.java index abd2614acbb..5e060d2be5d 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedMassConservationConstraintTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedMassConservationConstraintTest.java @@ -1,6 +1,6 @@ package org.matsim.modechoice.constraints; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -18,7 +18,7 @@ public class RelaxedMassConservationConstraintTest { private RelaxedMassConservationConstraint constraint; - @Before + @BeforeEach public void setUp() throws Exception { SubtourModeChoiceConfigGroup config = new SubtourModeChoiceConfigGroup(); @@ -135,4 +135,4 @@ void openEnd() { // TODO: test 5th agent from list -} \ No newline at end of file +} diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java index 3be3bbb887a..7f58c6e14c1 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/constraints/RelaxedSubtourConstraintTest.java @@ -1,6 +1,6 @@ package org.matsim.modechoice.constraints; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -22,7 +22,7 @@ public class RelaxedSubtourConstraintTest { private RelaxedSubtourConstraint constraint; - @Before + @BeforeEach public void setUp() throws Exception { SubtourModeChoiceConfigGroup config = new SubtourModeChoiceConfigGroup(); @@ -133,4 +133,4 @@ void openEnd() { } -} \ No newline at end of file +} diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/MultinomialLogitSelectorTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/MultinomialLogitSelectorTest.java index 44658a957bb..851404656f9 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/MultinomialLogitSelectorTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/replanning/MultinomialLogitSelectorTest.java @@ -1,7 +1,7 @@ package org.matsim.modechoice.replanning; import org.assertj.core.data.Offset; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.modechoice.PlanCandidate; @@ -16,7 +16,7 @@ public class MultinomialLogitSelectorTest { private static final int N = 500_000; - @Before + @BeforeEach public void setUp() throws Exception { selector = new MultinomialLogitSelector(1, new Random(0)); } diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java index a32fc12df0c..f307a5b77c3 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java @@ -5,7 +5,7 @@ import com.google.inject.multibindings.Multibinder; import org.assertj.core.api.InstanceOfAssertFactories; import org.assertj.core.data.Offset; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.runner.RunWith; @@ -62,7 +62,7 @@ public class TopKMinMaxTest { @Mock private EventsManager em; - @Before + @BeforeEach public void setUp() throws Exception { TestModule testModule = new TestModule(); diff --git a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java index df26aac50ab..c54db135674 100644 --- a/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java +++ b/contribs/locationchoice/src/test/java/org/matsim/contrib/locationchoice/frozenepsilons/SamplerTest.java @@ -24,7 +24,7 @@ import static org.junit.jupiter.api.Assertions.assertTrue; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -44,7 +44,7 @@ public class SamplerTest { private DestinationChoiceContext context; private Scenario scenario; - @Before + @BeforeEach public void setUp() throws Exception { Config config = ConfigUtils.loadConfig("test/scenarios/chessboard/config.xml", new FrozenTastesConfigGroup() ); ConfigUtils.loadConfig(config, utils.getPackageInputDirectory() + "/config.xml"); diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java index f1cfe36973c..35bb1f4dbd3 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -76,7 +76,7 @@ public class PtMatrixTest { @TempDir public File folder; - @Before + @BeforeEach public void setUp() throws Exception { OutputDirectoryLogging.catchLogEntries(); // (collect log messages internally before they can be written to file. Can be called multiple times without harm.) diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java index 0809f0e6bf3..455a61840a9 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/genericUtils/TerminusStopFinderTest.java @@ -30,23 +30,23 @@ import org.matsim.pt.transitSchedule.api.TransitScheduleFactory; import org.matsim.pt.transitSchedule.api.TransitStopFacility; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; /** - * + * * @author gleich * */ public class TerminusStopFinderTest { - + TransitSchedule schedule; TransitScheduleFactory stopFactory; @Test void testFindSecondTerminusStop() { - /* + /* * straight line - * + * * /----------------------\ * X------->--------------{>} */ @@ -54,13 +54,13 @@ void testFindSecondTerminusStop() { stops.add(getOrCreateStopAtCoord(0, 0)); stops.add(getOrCreateStopAtCoord(10, 0)); stops.add(getOrCreateStopAtCoord(40, 0)); - + int indexSecondTerminusStop = TerminusStopFinder.findSecondTerminusStop(stops); Assertions.assertEquals(2, indexSecondTerminusStop); - - /* + + /* * rectangular line - * + * * <------{^} * | | * | | @@ -72,13 +72,13 @@ void testFindSecondTerminusStop() { stops.add(getOrCreateStopAtCoord(10, 0)); stops.add(getOrCreateStopAtCoord(10, 10)); stops.add(getOrCreateStopAtCoord(0, 10)); - + indexSecondTerminusStop = TerminusStopFinder.findSecondTerminusStop(stops); Assertions.assertEquals(2, indexSecondTerminusStop); - - /* + + /* * triangular line both candidate stops at same distance from first terminus - * + * * <---\ * | \ * | \ @@ -92,10 +92,10 @@ void testFindSecondTerminusStop() { indexSecondTerminusStop = TerminusStopFinder.findSecondTerminusStop(stops); Assertions.assertEquals(1, indexSecondTerminusStop); - - /* + + /* * triangular line many stops - * + * * <-\ * | \ * | \--{<}----\ @@ -110,16 +110,16 @@ void testFindSecondTerminusStop() { stops.add(getOrCreateStopAtCoord(40, 0)); stops.add(getOrCreateStopAtCoord(20, 10)); stops.add(getOrCreateStopAtCoord(0, 20)); - + indexSecondTerminusStop = TerminusStopFinder.findSecondTerminusStop(stops); Assertions.assertEquals(5, indexSecondTerminusStop); - - /* + + /* * TODO: Currently failing, would require a more elaborate algorithm to determine the terminus stop * More complex example: - * + * * Back- and forth directions have different lengths. For the human eye the second terminus is obvious - * + * * {<}------<---<---<---^ * \------>---> | * | ^ @@ -151,17 +151,17 @@ void testFindSecondTerminusStop() { stops.add(getOrCreateStopAtCoord(30, 10)); stops.add(getOrCreateStopAtCoord(20, 10)); stops.add(getOrCreateStopAtCoord(10, 10)); - + indexSecondTerminusStop = TerminusStopFinder.findSecondTerminusStop(stops); // Assert.assertEquals(11, indexSecondTerminusStop); } - - @Before + + @BeforeEach public void setUp() { schedule = ScenarioUtils.loadScenario(ConfigUtils.createConfig()).getTransitSchedule(); stopFactory = schedule.getFactory(); } - + private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { Id stopId = getStopId(x, y); if (schedule.getFacilities().containsKey(stopId)) { @@ -171,7 +171,7 @@ private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { stopId, CoordUtils.createCoord(x, y), false); } } - + private Id getStopId(int x, int y) { return Id.create(x + "," + y, TransitStopFacility.class); } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java index c4a80910840..e09e1424dfd 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/AreaBtwLinksVsTerminiBeelinePenaltyTest.java @@ -22,7 +22,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -47,18 +47,18 @@ import org.matsim.pt.transitSchedule.api.TransitStopFacility; /** - * + * * Tests {@link AreaBtwLinksVsTerminiBeelinePenalty}. - * + * * @author gleich - * + * */ public class AreaBtwLinksVsTerminiBeelinePenaltyTest { - + Scenario scenario; TransitScheduleFactory factory; - - @Before + + @BeforeEach public void setUp() { scenario = ScenarioUtils.loadScenario(ConfigUtils.createConfig()); factory = scenario.getTransitSchedule().getFactory(); @@ -68,14 +68,14 @@ public void setUp() { void testRectangularLine() { ArrayList stopsToBeServed = new ArrayList<>(); ArrayList stops = new ArrayList<>(); - + stopsToBeServed.add(getOrCreateStopAtCoord(0, 0)); stopsToBeServed.add(getOrCreateStopAtCoord(10, 0)); - + stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(0, 0), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(10, 0), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(10, 10), 0, 0)); - + // Nodes a-d are passed by TransitRoute, Node e not Id idNodeA = Id.createNodeId("a"); Id idNodeB = Id.createNodeId("b"); @@ -87,7 +87,7 @@ void testRectangularLine() { NetworkUtils.createAndAddNode(scenario.getNetwork(), idNodeC, CoordUtils.createCoord(10, 10)); NetworkUtils.createAndAddNode(scenario.getNetwork(), idNodeD, CoordUtils.createCoord(0, 10)); NetworkUtils.createAndAddNode(scenario.getNetwork(), idNodeE, CoordUtils.createCoord(5, 5)); - + Id idLinkAB = Id.createLinkId("a>b"); Id idLinkBC = Id.createLinkId("b>c"); Id idLinkCD = Id.createLinkId("c>d"); @@ -112,14 +112,14 @@ void testRectangularLine() { linkIds.add(idLinkBC); linkIds.add(idLinkCD); route.setLinkIds(idLinkAB, linkIds, idLinkDA); - + PPlan pPlan1 = new PPlan(Id.create("PPlan1", PPlan.class), "creator1", Id.create("PPlanParent1", PPlan.class)); pPlan1.setStopsToBeServed(stopsToBeServed); TransitLine line1 = factory.createTransitLine(Id.create("line1", TransitLine.class)); TransitRoute route1 = factory.createTransitRoute(Id.create("TransitRoute1", TransitRoute.class), route, stops, "bus"); line1.addRoute(route1); pPlan1.setLine(line1); - + /* option StopListToEvaluate.transitRouteAllStops */ PConfigGroup pConfig = new PConfigGroup(); RouteDesignScoreParams params = new RouteDesignScoreParams(); @@ -128,14 +128,14 @@ void testRectangularLine() { params.setStopListToEvaluate(StopListToEvaluate.transitRouteAllStops); params.setValueToStartScoring(1); pConfig.addRouteDesignScoreParams(params); - + AreaBtwLinksVsTerminiBeelinePenalty penalty = new AreaBtwLinksVsTerminiBeelinePenalty(params, scenario.getNetwork()); double actual = penalty.getScore(pPlan1, route1); // area 10 x 10 = 100; beeline termini ({0,0}, {10,0}) = 10 double expected = -1 * ((10.0 * 10.0 / 10.0) - 1); Assertions.assertEquals(expected, actual, 0.001); } - + private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { Id stopId = getStopId(x, y); if (scenario.getTransitSchedule().getFacilities().containsKey(stopId)) { @@ -145,7 +145,7 @@ private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { stopId, CoordUtils.createCoord(x, y), false); } } - + private Id getStopId(int x, int y) { return Id.create(x + "," + y, TransitStopFacility.class); } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java index bd2ee9230a3..375d9d814d0 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/RouteDesignScoringManagerTest.java @@ -22,7 +22,7 @@ import java.util.ArrayList; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -44,23 +44,23 @@ import org.matsim.pt.transitSchedule.api.TransitStopFacility; /** - * + * * Tests {@link RouteDesignScoringManager}, * {@link AreaBtwStopsVsTerminiBeelinePenalty}, * {@link Stop2StopVsTerminiBeelinePenalty}. - * + * * The latter two are tested here, because they are also used as two example * RouteDesignScoringFunctions managed by RouteDesignScoringManager. - * + * * @author gleich - * + * */ public class RouteDesignScoringManagerTest { - + Scenario scenario; TransitScheduleFactory factory; - - @Before + + @BeforeEach public void setUp() { scenario = ScenarioUtils.loadScenario(ConfigUtils.createConfig()); factory = scenario.getTransitSchedule().getFactory(); @@ -70,28 +70,28 @@ public void setUp() { void testRectangularLine() { ArrayList stopsToBeServed = new ArrayList<>(); ArrayList stops = new ArrayList<>(); - + stopsToBeServed.add(getOrCreateStopAtCoord(0, 0)); stopsToBeServed.add(getOrCreateStopAtCoord(10, 0)); stopsToBeServed.add(getOrCreateStopAtCoord(10, 10)); stopsToBeServed.add(getOrCreateStopAtCoord(0, 10)); - + stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(0, 0), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(10, 0), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(10, 10), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(0, 10), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(-10, 10), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(-10, 0), 0, 0)); - + NetworkRoute route = RouteUtils.createLinkNetworkRouteImpl(Id.createLinkId("dummy1.1"), Id.createLinkId("dummy1.2")); - + PPlan pPlan1 = new PPlan(Id.create("PPlan1", PPlan.class), "creator1", Id.create("PPlanParent1", PPlan.class)); pPlan1.setStopsToBeServed(stopsToBeServed); TransitLine line1 = factory.createTransitLine(Id.create("line1", TransitLine.class)); TransitRoute route1 = factory.createTransitRoute(Id.create("TransitRoute1", TransitRoute.class), route, stops, "bus"); line1.addRoute(route1); pPlan1.setLine(line1); - + /* stop2StopVsBeelinePenalty */ /* option StopListToEvaluate.transitRouteAllStops */ PConfigGroup pConfig = new PConfigGroup(); @@ -101,26 +101,26 @@ void testRectangularLine() { stop2stopVsBeeline.setStopListToEvaluate(StopListToEvaluate.transitRouteAllStops); stop2stopVsBeeline.setValueToStartScoring(1); pConfig.addRouteDesignScoreParams(stop2stopVsBeeline); - + RouteDesignScoringManager manager1 = new RouteDesignScoringManager(); manager1.init(pConfig, scenario.getNetwork()); double actual = manager1.scoreRouteDesign(pPlan1); // 6 stop->stop distances of 10 units each in the stops (not stopsToBeServed) double expected = -1 * ((6 * 10 / (10 * Math.sqrt(2))) - 1); Assertions.assertEquals(expected, actual, 0.001); - + /* option StopListToEvaluate.pPlanStopsToBeServed */ stop2stopVsBeeline.setStopListToEvaluate(StopListToEvaluate.pPlanStopsToBeServed); - + manager1 = new RouteDesignScoringManager(); manager1.init(pConfig, scenario.getNetwork()); actual = manager1.scoreRouteDesign(pPlan1); // 4 stop->stop distances of 10 units each in the stops expected = -1 * ((4 * 10 / (10 * Math.sqrt(2))) - 1); Assertions.assertEquals(expected, actual, 0.001); - + pConfig.removeRouteDesignScoreParams(RouteDesignScoreFunctionName.stop2StopVsBeelinePenalty); - + /* areaVsBeelinePenalty */ /* option StopListToEvaluate.transitRouteAllStops */ RouteDesignScoreParams areaVsBeeline = new RouteDesignScoreParams(); @@ -129,77 +129,77 @@ void testRectangularLine() { areaVsBeeline.setStopListToEvaluate(StopListToEvaluate.transitRouteAllStops); areaVsBeeline.setValueToStartScoring(1); pConfig.addRouteDesignScoreParams(areaVsBeeline); - + manager1 = new RouteDesignScoringManager(); manager1.init(pConfig, scenario.getNetwork()); actual = manager1.scoreRouteDesign(pPlan1); // x=[-10,10], y=[0,10] -> 20 X 10 expected = -1 * ((20 * 10 / (10 * Math.sqrt(2))) - 1); Assertions.assertEquals(expected, actual, 0.001); - + /* option StopListToEvaluate.pPlanStopsToBeServed */ areaVsBeeline.setStopListToEvaluate(StopListToEvaluate.pPlanStopsToBeServed); - + manager1 = new RouteDesignScoringManager(); manager1.init(pConfig, scenario.getNetwork()); actual = manager1.scoreRouteDesign(pPlan1); // x=[0,10], y=[0,10] -> 10 X 10 expected = -1 * ((10 * 10 / (10 * Math.sqrt(2))) - 1); Assertions.assertEquals(expected, actual, 0.001); - + /* check summing up of both */ pConfig.addRouteDesignScoreParams(stop2stopVsBeeline); - + manager1 = new RouteDesignScoringManager(); manager1.init(pConfig, scenario.getNetwork()); actual = manager1.scoreRouteDesign(pPlan1); // x=[0,10], y=[0,10] -> 10 X 10 ; 4 stop->stop distances of 10 units each in the stops expected = -1 * ((10 * 10 / (10 * Math.sqrt(2))) - 1) + (-1) * ((4 * 10 / (10 * Math.sqrt(2))) - 1); Assertions.assertEquals(expected, actual, 0.001); - + /* Check route with only two stops */ stopsToBeServed = new ArrayList<>(); stops = new ArrayList<>(); - + stopsToBeServed.add(getOrCreateStopAtCoord(0, 0)); stopsToBeServed.add(getOrCreateStopAtCoord(10, 0)); - + stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(0, 0), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(10, 0), 0, 0)); - + route = RouteUtils.createLinkNetworkRouteImpl(Id.createLinkId("dummy2.1"), Id.createLinkId("dummy2.2")); - + PPlan pPlan2 = new PPlan(Id.create("PPlan2", PPlan.class), "creator2", Id.create("PPlanParent2", PPlan.class)); pPlan2.setStopsToBeServed(stopsToBeServed); TransitLine line2 = factory.createTransitLine(Id.create("line2", TransitLine.class)); TransitRoute route2 = factory.createTransitRoute(Id.create("TransitRoute2", TransitRoute.class), route, stops, "bus"); line2.addRoute(route2); pPlan2.setLine(line2); - + manager1 = new RouteDesignScoringManager(); manager1.init(pConfig, scenario.getNetwork()); actual = manager1.scoreRouteDesign(pPlan2); // would be positive expected = -1; Assertions.assertEquals(expected, actual, 0.001); - + /* check that no subsidy emerges (no positive route design score) */ // high valueToStartScoring -> all scores below would be positive, check that they are capped at 0 stop2stopVsBeeline.setValueToStartScoring(10); areaVsBeeline.setValueToStartScoring(10); - + // add a third stop stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(5, 0), 0, 0)); - + route = RouteUtils.createLinkNetworkRouteImpl(Id.createLinkId("dummy2.1"), Id.createLinkId("dummy2.2")); - + PPlan pPlan3 = new PPlan(Id.create("PPlan3", PPlan.class), "creator3", Id.create("PPlanParent3", PPlan.class)); pPlan3.setStopsToBeServed(stopsToBeServed); TransitLine line3 = factory.createTransitLine(Id.create("line3", TransitLine.class)); TransitRoute route3 = factory.createTransitRoute(Id.create("TransitRoute3", TransitRoute.class), route, stops, "bus"); line3.addRoute(route3); pPlan3.setLine(line3); - + manager1 = new RouteDesignScoringManager(); manager1.init(pConfig, scenario.getNetwork()); actual = manager1.scoreRouteDesign(pPlan3); @@ -207,7 +207,7 @@ void testRectangularLine() { expected = 0; Assertions.assertEquals(expected, actual, 0.001); } - + private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { Id stopId = getStopId(x, y); if (scenario.getTransitSchedule().getFacilities().containsKey(stopId)) { @@ -217,7 +217,7 @@ private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { stopId, CoordUtils.createCoord(x, y), false); } } - + private Id getStopId(int x, int y) { return Id.create(x + "," + y, TransitStopFacility.class); } diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java index 1a5d848bfe1..9bcb9a50fe3 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/scoring/routeDesignScoring/StopServedMultipleTimesPenaltyTest.java @@ -21,7 +21,7 @@ import java.util.ArrayList; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -43,18 +43,18 @@ import org.matsim.pt.transitSchedule.api.TransitStopFacility; /** - * + * * Tests {@link StopServedMultipleTimesPenalty} - * + * * @author gleich * */ public class StopServedMultipleTimesPenaltyTest { - + Scenario scenario; TransitScheduleFactory factory; - - @Before + + @BeforeEach public void setUp() { scenario = ScenarioUtils.loadScenario(ConfigUtils.createConfig()); factory = scenario.getTransitSchedule().getFactory(); @@ -64,24 +64,24 @@ public void setUp() { void testRouteServingSameStopTwice() { ArrayList stopsToBeServed = new ArrayList<>(); ArrayList stops = new ArrayList<>(); - + stopsToBeServed.add(getOrCreateStopAtCoord(0, 0)); stopsToBeServed.add(getOrCreateStopAtCoord(10, 0)); - + stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(0, 0), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(10, 0), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(10, 10), 0, 0)); stops.add(factory.createTransitRouteStop(getOrCreateStopAtCoord(0, 0), 0, 0)); - + NetworkRoute route = RouteUtils.createLinkNetworkRouteImpl(Id.createLinkId("dummy1.1"), Id.createLinkId("dummy1.2")); - + PPlan pPlan1 = new PPlan(Id.create("PPlan1", PPlan.class), "creator1", Id.create("PPlanParent1", PPlan.class)); pPlan1.setStopsToBeServed(stopsToBeServed); TransitLine line1 = factory.createTransitLine(Id.create("line1", TransitLine.class)); TransitRoute route1 = factory.createTransitRoute(Id.create("TransitRoute1", TransitRoute.class), route, stops, "bus"); line1.addRoute(route1); pPlan1.setLine(line1); - + /* option StopListToEvaluate.transitRouteAllStops */ PConfigGroup pConfig = new PConfigGroup(); RouteDesignScoreParams params = new RouteDesignScoreParams(); @@ -90,14 +90,14 @@ void testRouteServingSameStopTwice() { params.setStopListToEvaluate(StopListToEvaluate.transitRouteAllStops); params.setValueToStartScoring(1); pConfig.addRouteDesignScoreParams(params); - + StopServedMultipleTimesPenalty penalty = new StopServedMultipleTimesPenalty(params); double actual = penalty.getScore(pPlan1, route1); // 4 stops served, but only 3 different stop ids double expected = -1 * ((4.0 / 3) - 1); Assertions.assertEquals(expected, actual, 0.001); } - + private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { Id stopId = getStopId(x, y); if (scenario.getTransitSchedule().getFacilities().containsKey(stopId)) { @@ -107,7 +107,7 @@ private TransitStopFacility getOrCreateStopAtCoord(int x, int y) { stopId, CoordUtils.createCoord(x, y), false); } } - + private Id getStopId(int x, int y) { return Id.create(x + "," + y, TransitStopFacility.class); } diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java index be16614ebf8..1f9324b51f6 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmNetworkParserTest.java @@ -3,7 +3,7 @@ import de.topobyte.osm4j.core.model.iface.OsmNode; import de.topobyte.osm4j.core.model.iface.OsmWay; -import org.junit.After; +import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -28,7 +28,7 @@ public class OsmNetworkParserTest { @RegisterExtension private MatsimTestUtils matsimUtils = new MatsimTestUtils(); - @After + @AfterEach public void shutDownExecutor() { executor.shutdown(); } diff --git a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java index 96a13bec584..2e150c78b6e 100644 --- a/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java +++ b/contribs/osm/src/test/java/org/matsim/contrib/osm/networkReader/OsmSignalsParserTest.java @@ -6,7 +6,7 @@ import de.topobyte.osm4j.core.model.impl.RelationMember; import de.topobyte.osm4j.core.model.impl.Tag; -import org.junit.After; +import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.utils.geometry.CoordinateTransformation; @@ -34,7 +34,7 @@ public class OsmSignalsParserTest { private MatsimTestUtils utils = new MatsimTestUtils(); - @After + @AfterEach public void shutDownExecutor() { executor.shutdown(); } diff --git a/contribs/pom.xml b/contribs/pom.xml index 49124a6bd25..e901a081789 100644 --- a/contribs/pom.xml +++ b/contribs/pom.xml @@ -103,10 +103,6 @@ - - org.junit.vintage - junit-vintage-engine - org.junit.jupiter junit-jupiter-engine diff --git a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java index c2bb085c360..8b5aee8695e 100644 --- a/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java +++ b/contribs/railsim/src/test/java/ch/sbb/matsim/contrib/railsim/qsimengine/RailsimEngineTest.java @@ -23,7 +23,7 @@ import ch.sbb.matsim.contrib.railsim.config.RailsimConfigGroup; import ch.sbb.matsim.contrib.railsim.qsimengine.disposition.SimpleDisposition; import ch.sbb.matsim.contrib.railsim.qsimengine.router.TrainRouter; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.network.Link; @@ -45,7 +45,7 @@ public class RailsimEngineTest { private EventsManager eventsManager; private RailsimTestUtils.EventCollector collector; - @Before + @BeforeEach public void setUp() { eventsManager = EventsUtils.createEventsManager(); collector = new RailsimTestUtils.EventCollector(); diff --git a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java index 3484f72f2f3..cc89d2c14a6 100644 --- a/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java +++ b/contribs/sbb-extensions/src/test/java/ch/sbb/matsim/mobsim/qsim/SBBQSimModuleTest.java @@ -24,7 +24,7 @@ import com.google.inject.Provides; import java.io.ByteArrayInputStream; import java.nio.charset.StandardCharsets; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -46,7 +46,7 @@ public class SBBQSimModuleTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Before + @BeforeEach public void setUp() { System.setProperty("matsim.preferLocalDtds", "true"); } diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java index 7d03f3966ae..11ed885109b 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyExamplesTest.java @@ -1,7 +1,7 @@ package org.matsim.simwrapper.viz; import com.fasterxml.jackson.databind.ObjectWriter; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -32,7 +32,7 @@ public class PlotlyExamplesTest { private ObjectWriter writer; - @Before + @BeforeEach public void setUp() throws Exception { writer = createWriter(); } diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java index 3956c9d505c..7642c997e8d 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/viz/PlotlyTest.java @@ -10,7 +10,7 @@ import com.fasterxml.jackson.dataformat.yaml.YAMLGenerator; import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule; import org.assertj.core.api.Assertions; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.simwrapper.ComponentMixin; @@ -48,7 +48,7 @@ public static ObjectWriter createWriter() { return mapper.writerFor(Plotly.class); } - @Before + @BeforeEach public void setUp() throws Exception { writer = createWriter(); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java index bb64b0ae091..e524cbc56a1 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/grouping/GroupPlansTest.java @@ -27,8 +27,8 @@ import java.util.List; import java.util.Map; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -48,7 +48,7 @@ public class GroupPlansTest { private final List testPlans = new ArrayList(); private final JointPlanFactory factory = new JointPlanFactory(); - @Before + @BeforeEach public void initPlanWithoutJointPlan() { final List plans = new ArrayList(); @@ -59,7 +59,7 @@ public void initPlanWithoutJointPlan() { testPlans.add( new GroupPlans( Collections.EMPTY_LIST , plans ) ); } - @Before + @BeforeEach public void initPlanWithoutIndividualPlans() { final List plans = new ArrayList(); @@ -78,7 +78,7 @@ public void initPlanWithoutIndividualPlans() { testPlans.add( new GroupPlans( plans , Collections.EMPTY_LIST ) ); } - @After + @AfterEach public void clear() { testPlans.clear(); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java index 51f2365c46f..390347380fc 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/modules/MergingTest.java @@ -26,10 +26,10 @@ import java.util.Map; import java.util.Random; -import org.junit.After; +import org.junit.jupiter.api.AfterEach; import static org.junit.jupiter.api.Assertions.assertEquals; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -49,13 +49,13 @@ public class MergingTest { // ///////////////////////////////////////////////////////////////////////// // fixtures management // ///////////////////////////////////////////////////////////////////////// - @After + @AfterEach public void clean() { testPlans.clear(); jointPlans = new JointPlans(); } - @Before + @BeforeEach public void allIndividuals() { List plans = new ArrayList(); @@ -66,7 +66,7 @@ public void allIndividuals() { testPlans.add( new GroupPlans( Collections.EMPTY_LIST , plans ) ); } - @Before + @BeforeEach public void allJoints() { List plans = new ArrayList(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java index 41316c90707..9962f22480c 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java @@ -31,7 +31,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; @@ -1200,11 +1200,11 @@ public static Fixture createDifferentForbidGroupsPerJointPlan() { GroupPlans expected = new GroupPlans( Arrays.asList( jointPlan2 , jointPlan4 ), - Collections.emptyList()); + Collections.emptyList()); GroupPlans expectedForbidding = new GroupPlans( Arrays.asList( jointPlan2 , jointPlan3 ), - Collections.emptyList()); + Collections.emptyList()); return new Fixture( "different forbids in jointPlans", @@ -1224,7 +1224,7 @@ public IncompatiblePlansIdentifier createIdentifier( jointPlans); } - @Before + @BeforeEach public void setupLogging() { //Logger.getRootLogger().setLevel( Level.TRACE ); } @@ -1301,7 +1301,7 @@ private void testSelectedPlans( throw new RuntimeException( "exception thrown for instance <<"+fixture.name+">>", e ); } - final GroupPlans expected = + final GroupPlans expected = blocking ? fixture.expectedSelectedPlansWhenBlocking : (forbidding ? diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java index deeb0b00ed6..4d55d689c81 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/RandomSelectorsTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -55,13 +55,13 @@ public class RandomSelectorsTest { private final List testGroups = new ArrayList(); private JointPlans jointPlans = new JointPlans(); - @After + @AfterEach public void clear() { testGroups.clear(); jointPlans = new JointPlans(); } - @Before + @BeforeEach public void createIndividualPlans() { ReplanningGroup group = new ReplanningGroup(); testGroups.add( group ); @@ -99,7 +99,7 @@ public void createIndividualPlans() { plan.setScore( -5000d ); } - @Before + @BeforeEach public void createFullyJointPlans() { ReplanningGroup group = new ReplanningGroup(); testGroups.add( group ); @@ -172,7 +172,7 @@ public void createFullyJointPlans() { jointPlans.getFactory().createJointPlan( jp3 ) ); } - @Before + @BeforeEach public void createPartiallyJointPlansMessOfJointPlans() { ReplanningGroup group = new ReplanningGroup(); testGroups.add( group ); @@ -284,7 +284,7 @@ public void createPartiallyJointPlansMessOfJointPlans() { jointPlans.getFactory().createJointPlan( jp8 ) ); } - @Before + @BeforeEach public void createPartiallyJointPlans() { ReplanningGroup group = new ReplanningGroup(); testGroups.add( group ); @@ -338,7 +338,7 @@ public void createPartiallyJointPlans() { jointPlans.getFactory().createJointPlan( jp2 ) ); } - @Before + @BeforeEach public void createRandomFixtures() { final Random random = new Random( 42 ); for ( int i=0; i < 100; i++ ) { diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java index 50823516b3e..518ba077207 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java @@ -31,7 +31,7 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.Ignore; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java index e341cb726ae..fc04d7684f0 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/scoring/GroupCompositionPenalizerTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java index 5d5f3ecea96..44377a842a6 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/JointTravelUtilsTest.java @@ -19,8 +19,8 @@ * *********************************************************************** */ package org.matsim.contrib.socnetsim.jointtrips; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -50,12 +50,12 @@ public class JointTravelUtilsTest { private final List fixtures = new ArrayList(); - @After + @AfterEach public void clearFixtures() { fixtures.clear(); } - @Before + @BeforeEach public void initOnePassengerFixture() { final Person driver = PopulationUtils.getFactory().createPerson(Id.createPersonId("Alain Prost")); final Person passenger1 = PopulationUtils.getFactory().createPerson(Id.createPersonId("Tintin")); @@ -115,7 +115,7 @@ public void initOnePassengerFixture() { new JointPlanFactory().createJointPlan( plans ))); } - @Before + @BeforeEach public void initTwoPassengerTwoOdFixture() { final Person driver = PopulationUtils.getFactory().createPerson(Id.create("Alain Prost", Person.class)); final Person passenger1 = PopulationUtils.getFactory().createPerson(Id.create("Tintin", Person.class)); @@ -206,7 +206,7 @@ public void initTwoPassengerTwoOdFixture() { new JointPlanFactory().createJointPlan( plans ))); } - @Before + @BeforeEach public void initTwoPassengersTwoOdsTwoJtFixture() { final Person driver = PopulationUtils.getFactory().createPerson(Id.createPersonId("Alain Prost")); final Person passenger1 = PopulationUtils.getFactory().createPerson(Id.createPersonId("Tintin")); @@ -327,7 +327,7 @@ public void initTwoPassengersTwoOdsTwoJtFixture() { new JointPlanFactory().createJointPlan( plans ))); } - @Before + @BeforeEach public void initTwoPassengersMiddleTripFixture() { final Person driver = PopulationUtils.getFactory().createPerson(Id.createPersonId("Alain Prost")); final Person passenger1 = PopulationUtils.getFactory().createPerson(Id.createPersonId("Tintin")); @@ -426,7 +426,7 @@ public void initTwoPassengersMiddleTripFixture() { new JointPlanFactory().createJointPlan( plans ))); } - @Before + @BeforeEach public void initOnePassengerTwoTripsFixture() { final Person driver = PopulationUtils.getFactory().createPerson(Id.createPersonId("Alain Prost")); final Person passenger1 = PopulationUtils.getFactory().createPerson(Id.createPersonId("Tintin")); @@ -515,7 +515,7 @@ public void initOnePassengerTwoTripsFixture() { new JointPlanFactory().createJointPlan( plans ))); } - @Before + @BeforeEach public void initOnePassengerTwoTripsWithDifferentDriversFixture() { final Person driver1 = PopulationUtils.getFactory().createPerson(Id.createPersonId("Alain Prost")); final Person driver2 = PopulationUtils.getFactory().createPerson(Id.createPersonId("Michel Vaillant")); @@ -611,7 +611,7 @@ public void initOnePassengerTwoTripsWithDifferentDriversFixture() { } // bugs may depend on iteration order... - @Before + @BeforeEach public void initOnePassengerTwoTripsWithDifferentDriversSecondDriverFirstFixture() { final Person driver1 = PopulationUtils.getFactory().createPerson(Id.createPersonId("Alain Prost")); final Person driver2 = PopulationUtils.getFactory().createPerson(Id.createPersonId("Michel Vaillant")); @@ -712,7 +712,7 @@ public void initOnePassengerTwoTripsWithDifferentDriversSecondDriverFirstFixture * the same way going to the bus station when no bus is running is a valid, though stupid, * plan. */ - @Before + @BeforeEach public void initOnePassengerTwoTripsInconsistentSequenceFixture() { final Person driver = PopulationUtils.getFactory().createPerson(Id.createPersonId("Alain Prost")); final Person passenger1 = PopulationUtils.getFactory().createPerson(Id.createPersonId("Tintin")); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java index 83420c9ea39..7a0e431fbe3 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIgnoranceBehaviorTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -57,7 +57,7 @@ public class InsertionRemovalIgnoranceBehaviorTest { private TripRouter tripRouter; private Random random; - @Before + @BeforeEach public void init() { config = JointScenarioUtils.createConfig(); // tripRouter = new TripRouter(); @@ -68,7 +68,7 @@ public void init() { @Test void testRemoverIgnorance() throws Exception { final JointTripRemoverAlgorithm algo = new JointTripRemoverAlgorithm( random , new MainModeIdentifierImpl() ); - + JointPlan jointPlan = createPlanWithJointTrips(); assertNull( @@ -85,7 +85,7 @@ void testInsertorIgnorance() throws Exception { null, (JointTripInsertorConfigGroup) config.getModule( JointTripInsertorConfigGroup.GROUP_NAME ), TripStructureUtils.getRoutingModeIdentifier() ); // yyyyyy ?????? - + JointPlan jointPlan = createPlanWithoutJointTrips(); assertNull( diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java index bae28cc67cf..f8ad25b6757 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/InsertionRemovalIterativeActionTest.java @@ -28,7 +28,7 @@ import static org.junit.jupiter.api.Assertions.assertEquals; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -62,7 +62,7 @@ public class InsertionRemovalIterativeActionTest { private TripRouter tripRouter; private Random random; - @Before + @BeforeEach public void init() { config = JointScenarioUtils.createConfig(); // tripRouter = new TripRouter(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java index 34cd73df76f..98d2dc63d83 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/JointTripRemoverAlgorithmTest.java @@ -33,7 +33,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -65,7 +65,7 @@ public class JointTripRemoverAlgorithmTest { // ///////////////////////////////////////////////////////////////////////// // init routines // ///////////////////////////////////////////////////////////////////////// - @Before + @BeforeEach public void initFixtures() { fixtures = new ArrayList(); @@ -537,7 +537,7 @@ private Fixture createMultiDriverStageFixture() { expectedAfterRemoval.put( passenger.getId(), Arrays.asList( pAct1 , PopulationUtils.createLeg(TransportMode.pt) , pAct2 )); - + return new Fixture( "complex access trip driver", new JointPlanFactory().createJointPlan( plans ), @@ -608,7 +608,7 @@ private Fixture createMultiPassengerStageFixture() { expectedAfterRemoval.put( passenger.getId(), Arrays.asList( pAct1 , PopulationUtils.createLeg(TransportMode.pt) , pAct2 )); - + Set stageActivityTypes = new HashSet<>(); stageActivityTypes.add(stageType); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java index d5f974964b5..6ef60d64652 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/replanning/modules/SynchronizeCoTravelerPlansAlgorithmTest.java @@ -24,8 +24,8 @@ import java.util.List; import java.util.Map; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -72,12 +72,12 @@ public Fixture( } } - @After + @AfterEach public void clear() { fixtures.clear(); } - @Before + @BeforeEach public void createSimpleFixture() { final FixtureBuilder builder = new FixtureBuilder(); @@ -170,7 +170,7 @@ public void createSimpleFixture() { fixtures.add( builder.build() ); } - @Before + @BeforeEach public void createFixtureWithPotentiallyNegativeEndTimes() { final FixtureBuilder builder = new FixtureBuilder(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java index d3e427f262c..993cfdb52bb 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/jointtrips/router/JointTripRouterFactoryTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -77,7 +77,7 @@ public class JointTripRouterFactoryTest { private Provider factory; private Scenario scenario; - @Before + @BeforeEach public void initFixtures() { this.scenario = createScenario(); this.factory = createFactory( scenario ); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java index 5ba2aa6069a..f8be251b899 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/AllocateVehicleToPlansInGroupPlanAlgorithmTest.java @@ -62,7 +62,7 @@ public class AllocateVehicleToPlansInGroupPlanAlgorithmTest { private static final String MODE = "the_vehicular_mode"; // uncomment to get more information in case of failure - //@Before + //@BeforeEach //public void setupLog() { // LogManager.getLogger( AllocateVehicleToPlansInGroupPlanAlgorithm.class ).setLevel( Level.TRACE ); //} @@ -205,7 +205,7 @@ void testRandomness() { if ( v == null ) continue; final Id person = p.getPerson().getId(); final Id oldV = allocations.get( person ); - + if ( oldV == null ) { allocations.put( person , v ); } @@ -244,7 +244,7 @@ void testDeterminism() { if ( v == null ) continue; final Id person = p.getPerson().getId(); final Id oldV = allocations.get( person ); - + if ( oldV == null ) { allocations.put( person , v ); } @@ -269,7 +269,7 @@ private static Id assertSingleVehicleAndGetVehicleId(final Plan p) { if ( !MODE.equals( leg.getMode() ) ) continue; final NetworkRoute r = (NetworkRoute) leg.getRoute(); - + Assertions.assertNotNull( r.getVehicleId(), "null vehicle id in route" ); diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java index 57fcaa18660..3e089eaf6c9 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java @@ -19,7 +19,7 @@ package org.matsim.core.scoring.functions; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -55,7 +55,7 @@ public class PersonScoringParametersFromPersonAttributesNoSubpopulationTest { private PersonScoringParametersFromPersonAttributes personScoringParams; private Population population; - @Before + @BeforeEach public void setUp() { TransitConfigGroup transitConfigGroup = new TransitConfigGroup(); ScenarioConfigGroup scenarioConfigGroup = new ScenarioConfigGroup(); diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java index 69d5bb6835f..6202e3c83b5 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java @@ -19,7 +19,7 @@ package org.matsim.core.scoring.functions; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -55,7 +55,7 @@ public class PersonScoringParametersFromPersonAttributesTest { private PersonScoringParametersFromPersonAttributes personScoringParams; private Population population; - @Before + @BeforeEach public void setUp() { TransitConfigGroup transitConfigGroup = new TransitConfigGroup(); ScenarioConfigGroup scenarioConfigGroup = new ScenarioConfigGroup(); diff --git a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java index b64c9eca7a8..4b8c08a4d04 100644 --- a/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java +++ b/contribs/vsp/src/test/java/org/matsim/freight/carriers/analysis/RunFreightAnalysisIT.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers.analysis; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -44,7 +44,7 @@ public class RunFreightAnalysisIT { @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); - @Before + @BeforeEach public void runAnalysis(){ final String packageInputDirectory = testUtils.getClassInputDirectory(); final String outputDirectory = testUtils.getOutputDirectory(); diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java index 15bd18ad185..ce74cd04415 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java @@ -60,7 +60,7 @@ public class UrbanEVTests { private static UrbanEVTestHandler handler; private static Map, List> plannedActivitiesPerPerson; - @BeforeClass + @BeforeEachClass public static void run() { Scenario scenario = CreateUrbanEVTestScenario.createTestScenario(); scenario.getConfig().controller().setOutputDirectory("test/output/playground/vsp/ev/UrbanEVTests/"); diff --git a/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java b/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java index 2eeae6af2fe..4e11d41f780 100644 --- a/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/flowEfficiency/HierarchicalFLowEfficiencyCalculatorTest.java @@ -1,7 +1,7 @@ package playground.vsp.flowEfficiency; import com.google.inject.Provides; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -82,7 +82,7 @@ void testThatDrtAVMoveFaster(){ } - @Before + @BeforeEach public void simulate(){ URL configUrl = IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("dvrp-grid"), "eight_shared_taxi_config.xml"); diff --git a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java index d6d72219e1d..35500e7f900 100644 --- a/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/openberlinscenario/planmodification/PlanFileModifierTest.java @@ -2,7 +2,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -32,7 +32,7 @@ public class PlanFileModifierTest { private Population modifiedPopulationCase1; private Population modifiedPopulationCase2; - @Before + @BeforeEach public void initializeTestPopulations() { String formatedInputPlansFile = utils.getClassInputDirectory() + "testPlansFormated.xml"; diff --git a/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java b/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java index 875a03eb3ae..7c3527d08b4 100644 --- a/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/pt/fare/PtTripFareEstimatorTest.java @@ -4,7 +4,7 @@ import com.google.inject.Injector; import org.assertj.core.api.InstanceOfAssertFactories; import org.assertj.core.data.Offset; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -47,7 +47,7 @@ public class PtTripFareEstimatorTest { private Map> tripEstimator; private PtTripWithDistanceBasedFareEstimator estimator; - @Before + @BeforeEach public void setUp() throws Exception { Config config = TestScenario.loadConfig(utils); diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java index dc39db4c237..e5c151a010e 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java @@ -1,6 +1,6 @@ package playground.vsp.scoring; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -33,7 +33,7 @@ public class IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulation private IncomeDependentUtilityOfMoneyPersonScoringParameters personScoringParams; private Population population; - @Before + @BeforeEach public void setUp() { TransitConfigGroup transitConfigGroup = new TransitConfigGroup(); ScenarioConfigGroup scenarioConfigGroup = new ScenarioConfigGroup(); diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java index 35fa3d927ba..215d1c5816e 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java @@ -1,6 +1,6 @@ package playground.vsp.scoring; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -33,7 +33,7 @@ public class IncomeDependentUtilityOfMoneyPersonScoringParametersTest { private IncomeDependentUtilityOfMoneyPersonScoringParameters personScoringParams; private Population population; - @Before + @BeforeEach public void setUp() { TransitConfigGroup transitConfigGroup = new TransitConfigGroup(); ScenarioConfigGroup scenarioConfigGroup = new ScenarioConfigGroup(); diff --git a/matsim/pom.xml b/matsim/pom.xml index 5f88ffc874b..dcd4afd69c3 100644 --- a/matsim/pom.xml +++ b/matsim/pom.xml @@ -159,10 +159,6 @@ jfreechart 1.5.4 - - org.junit.vintage - junit-vintage-engine - org.junit.jupiter junit-jupiter-engine diff --git a/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java b/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java index b9b49e15c95..d206be9f32b 100644 --- a/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/config/SwissRailRaptorConfigGroupTest.java @@ -25,7 +25,7 @@ import ch.sbb.matsim.config.SwissRailRaptorConfigGroup.RouteSelectorParameterSet; import ch.sbb.matsim.routing.pt.raptor.RaptorStopFinder.Direction; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.TransportMode; @@ -44,7 +44,7 @@ */ public class SwissRailRaptorConfigGroupTest { - @Before + @BeforeEach public void setup() { System.setProperty("matsim.preferLocalDtds", "true"); } diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java index 6033cbdfdbd..5b6460c3b95 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/RaptorUtilsTest.java @@ -20,7 +20,7 @@ package ch.sbb.matsim.routing.pt.raptor; import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.core.config.Config; @@ -38,7 +38,7 @@ */ public class RaptorUtilsTest { - @Before + @BeforeEach public void setup() { System.setProperty("matsim.preferLocalDtds", "true"); } diff --git a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java index 5085ec806b2..102b9c0e9a6 100644 --- a/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java +++ b/matsim/src/test/java/ch/sbb/matsim/routing/pt/raptor/SwissRailRaptorModuleTest.java @@ -23,7 +23,7 @@ import java.util.Arrays; import java.util.List; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -85,7 +85,7 @@ public class SwissRailRaptorModuleTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Before + @BeforeEach public void setUp() { System.setProperty("matsim.preferLocalDtds", "true"); } diff --git a/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java b/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java index d2b5219d8b5..c6ac0a9324a 100644 --- a/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java +++ b/matsim/src/test/java/org/matsim/analysis/CalcLegTimesTest.java @@ -23,8 +23,8 @@ import java.io.BufferedReader; import java.io.IOException; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -67,7 +67,7 @@ public class CalcLegTimesTest { private Population population = null; private Network network = null; - @Before public void setUp() { + @BeforeEach public void setUp() { utils.loadConfig((String)null); MutableScenario s = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); @@ -97,7 +97,7 @@ public class CalcLegTimesTest { this.network.addLink(link); } - @After public void tearDown() { + @AfterEach public void tearDown() { this.population = null; this.network = null; } diff --git a/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java b/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java index 7c026b15ca4..885d7b721b6 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/DemandGenerationTest.java @@ -23,8 +23,8 @@ import java.io.File; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.network.Link; @@ -60,11 +60,11 @@ public class DemandGenerationTest { private int personCount = 6; private int linkCount = 6; - @Before public void setUp() { + @BeforeEach public void setUp() { this.sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); } - @After public void tearDown() { + @AfterEach public void tearDown() { this.sc = null; } diff --git a/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java b/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java index 04c48fcafe8..1dbf78b8f61 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/IdDeSerializationModuleTest.java @@ -3,7 +3,7 @@ import java.util.LinkedHashMap; import java.util.Map; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.network.Link; @@ -20,7 +20,7 @@ public class IdDeSerializationModuleTest { private static final TypeFactory TYPE_FACTORY = TypeFactory.defaultInstance(); private final ObjectMapper objectMapper = new ObjectMapper(); - @Before + @BeforeEach public void init() { this.objectMapper.registerModule(IdDeSerializationModule.getInstance()); } diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java b/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java index e889fb576ea..33c4efd272e 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerEventsTest.java @@ -26,8 +26,8 @@ import java.util.ArrayList; import java.util.List; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.core.config.Config; @@ -52,11 +52,11 @@ void addCalledStartupListenerNumber(int i) { this.calledStartupListener.add(i); } - @Before public void setUp() { + @BeforeEach public void setUp() { this.calledStartupListener = new ArrayList<>(3); } - @After public void tearDown() { + @AfterEach public void tearDown() { this.calledStartupListener = null; } diff --git a/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java b/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java index 24ce9763e4c..c77b7a72521 100644 --- a/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java +++ b/matsim/src/test/java/org/matsim/core/events/ParallelEventsManagerTest.java @@ -1,6 +1,6 @@ package org.matsim.core.events; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.events.Event; import org.matsim.core.api.experimental.events.EventsManager; @@ -14,7 +14,7 @@ public class ParallelEventsManagerTest { private EventsManagerImplTest.CountingMyEventHandler handler; - @Before + @BeforeEach public void setUp() throws Exception { handler = new EventsManagerImplTest.CountingMyEventHandler(); } @@ -49,4 +49,4 @@ void lateHandler() { assertEquals(0, handler.counter); } -} \ No newline at end of file +} diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java index 60ca78d0d54..2a8a10cb7a4 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/FlowCapacityTest.java @@ -20,7 +20,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.analysis.VolumesAnalyzer; @@ -51,7 +51,7 @@ public class FlowCapacityTest { private final static Logger log = LogManager.getLogger(FlowCapacityTest.class); - @Before + @BeforeEach public void setup() { Id.resetCaches(); } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java index 8d6dce636f6..09cb1763746 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTest.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -101,7 +101,7 @@ protected static Hermes createHermes(Scenario scenario, EventsManager events, bo return new HermesBuilder().build(scenario, events); } - @Before + @BeforeEach public void prepareTest() { // TODO - fix these two! Id.resetCaches(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java index 4dfd0d0c319..69c49091a42 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java @@ -1,6 +1,6 @@ package org.matsim.core.mobsim.hermes; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.runner.RunWith; @@ -103,7 +103,7 @@ protected static Hermes createHermes(Scenario scenario, EventsManager events, bo return new HermesBuilder().build(scenario, events); } - @Before + @BeforeEach public void prepareTest() { Id.resetCaches(); ScenarioImporter.flush(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java index a9220f145a8..166dd6bca81 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/jdeqsim/AbstractJDEQSimTest.java @@ -30,8 +30,8 @@ import java.util.Map; import java.util.Map.Entry; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -76,14 +76,14 @@ public abstract class AbstractJDEQSimTest { protected Map, List> eventsByPerson = null; public LinkedList allEvents = null; - @Before + @BeforeEach public final void setUp() throws Exception { this.eventsByPerson = new HashMap, List>(); this.vehicleToDriver = new HashMap<>(); this.allEvents = new LinkedList(); } - @After + @AfterEach public final void tearDown() throws Exception { this.eventsByPerson = null; this.vehicleToDriver = null; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java index e73ea8ae49f..7b7def63c73 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/pt/UmlaufDriverTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -80,7 +80,7 @@ public class UmlaufDriverTest { private static final Logger log = LogManager.getLogger(UmlaufDriverTest.class); - @Before public void setUp() { + @BeforeEach public void setUp() { utils.loadConfig((String)null); } diff --git a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java index ae5d22abaf3..fc63a2e9b7d 100644 --- a/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java +++ b/matsim/src/test/java/org/matsim/core/network/algorithms/NetworkSimplifierTest.java @@ -25,7 +25,7 @@ import java.util.Map; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -38,7 +38,7 @@ public class NetworkSimplifierTest { - @Before + @BeforeEach public void setUp() { Id.resetCaches(); } @@ -66,19 +66,19 @@ void testRun() { @Test void testRunMergeLinkStats() { Network network = buildNetwork(); - + NetworkSimplifier nst = new NetworkSimplifier(); nst.setMergeLinkStats(true); nst.run(network, 20.0); assertEquals(2, network.getLinks().size(), "Wrong number of links"); assertNotNull(network.getLinks().get(Id.createLinkId("AB-BC")), "Expected link not found."); assertNotNull(network.getLinks().get(Id.createLinkId("CD-DE-EF")), "Expected link not found."); - + network = buildNetwork(); nst.run(network, 40.0); assertEquals(1, network.getLinks().size(), "Wrong number of links"); assertNotNull(network.getLinks().get(Id.createLinkId("AB-BC-CD-DE-EF")), "Expected link not found."); - + network = buildNetwork(); nst.run(network, 5.0); assertEquals(5, network.getLinks().size(), "Wrong number of links"); @@ -198,16 +198,16 @@ void testDifferentAttributesPerDirection() { Assertions.assertEquals(10.0, links.get(idHGGF).getFreespeed(), 1e-8); Assertions.assertEquals(10.0, links.get(idFEED).getFreespeed(), 1e-8); } - - + + /** * Builds a test network like the following diagram. - * + * * A--->B--->C===>D--->E--->F - * - * with each link having length 10m. Links AB, BC, DE, and EF have one + * + * with each link having length 10m. Links AB, BC, DE, and EF have one * lanes each, while CD has two lanes. All free-flow speeds are 60km/h. - * + * * @return */ private Network buildNetwork(){ @@ -218,13 +218,13 @@ private Network buildNetwork(){ Node d = NetworkUtils.createAndAddNode(network, Id.createNodeId("D"), CoordUtils.createCoord(30.0, 0.0)); Node e = NetworkUtils.createAndAddNode(network, Id.createNodeId("E"), CoordUtils.createCoord(40.0, 0.0)); Node f = NetworkUtils.createAndAddNode(network, Id.createNodeId("F"), CoordUtils.createCoord(50.0, 0.0)); - + NetworkUtils.createAndAddLink(network, Id.createLinkId("AB"), a, b, 10.0, 60.0/3.6, 1000.0, 1); NetworkUtils.createAndAddLink(network, Id.createLinkId("BC"), b, c, 10.0, 60.0/3.6, 1000.0, 1); NetworkUtils.createAndAddLink(network, Id.createLinkId("CD"), c, d, 10.0, 60.0/3.6, 1000.0, 2); NetworkUtils.createAndAddLink(network, Id.createLinkId("DE"), d, e, 10.0, 60.0/3.6, 1000.0, 1); NetworkUtils.createAndAddLink(network, Id.createLinkId("EF"), e, f, 10.0, 60.0/3.6, 1000.0, 1); - + return network; } diff --git a/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java b/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java index 16d9b4283cb..0a294ca7a01 100644 --- a/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java +++ b/matsim/src/test/java/org/matsim/core/network/filter/NetworkFilterManagerTest.java @@ -21,7 +21,7 @@ package org.matsim.core.network.filter; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -54,7 +54,7 @@ public class NetworkFilterManagerTest { private Network filterNetwork; - @Before + @BeforeEach public void prepareTestAllowedModes() { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); Network network = scenario.getNetwork(); diff --git a/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java b/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java index fc56e540746..d16b44098a6 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/annealing/ReplanningAnnealerTest.java @@ -3,7 +3,7 @@ import java.io.BufferedReader; import java.io.IOException; import java.util.List; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -158,7 +158,7 @@ private static String readResult(String filePath) throws IOException { return sb.toString(); } - @Before + @BeforeEach public void setup() { this.config = ConfigUtils.createConfig(); config.global().setDefaultDelimiter(";"); diff --git a/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java b/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java index 61f0dff7923..e9c44723123 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/modules/ExternalModuleTest.java @@ -22,7 +22,7 @@ package org.matsim.core.replanning.modules; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -48,7 +48,7 @@ public class ExternalModuleTest { private OutputDirectoryHierarchy outputDirectoryHierarchy; private Scenario originalScenario; - @Before + @BeforeEach public void setUp() { scenario = ScenarioUtils.loadScenario(utils.loadConfig("test/scenarios/equil/config.xml")); originalScenario = ScenarioUtils.loadScenario(utils.loadConfig("test/scenarios/equil/config.xml")); diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java index 62ffb7eaaeb..37016e60ad4 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/ExpBetaPlanSelectorTest.java @@ -24,8 +24,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; @@ -44,11 +44,11 @@ public class ExpBetaPlanSelectorTest extends AbstractPlanSelectorTest { private final static Logger log = LogManager.getLogger(ExpBetaPlanSelectorTest.class); private Config config = null; - @Before public void setUp() { + @BeforeEach public void setUp() { this.config = utils.loadConfig((String)null); // required for planCalcScore.beta to be defined } - @After public void tearDown() { + @AfterEach public void tearDown() { this.config = null; } diff --git a/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java b/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java index 905a8f32cdb..0607540583f 100644 --- a/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java +++ b/matsim/src/test/java/org/matsim/core/replanning/selectors/PathSizeLogitSelectorTest.java @@ -27,8 +27,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -58,14 +58,14 @@ public class PathSizeLogitSelectorTest extends AbstractPlanSelectorTest { private Network network = null; private Config config = null; - @Before public void setUp() { + @BeforeEach public void setUp() { this.config = utils.loadConfig((String)null); // required for planCalcScore.beta to be defined config.scoring().setBrainExpBeta(2.0); config.scoring().setPathSizeLogitBeta(2.0); this.network = null; } - @After public void tearDown() { + @AfterEach public void tearDown() { this.network = null; this.config = null; } diff --git a/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java b/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java index 0b924a0c516..d0c234ad0dd 100644 --- a/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java +++ b/matsim/src/test/java/org/matsim/core/router/TestActivityWrapperFacility.java @@ -22,7 +22,7 @@ import java.util.ArrayList; import java.util.List; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -39,7 +39,7 @@ public class TestActivityWrapperFacility { private List activities; - @Before + @BeforeEach public void init() { activities = new ArrayList(); diff --git a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java index 2f28185b50f..6cf9f409b72 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsTest.java @@ -25,8 +25,8 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -77,12 +77,12 @@ public Fixture( } } - @After + @AfterEach public void clean() { fixtures.clear(); } - @Before + @BeforeEach public void createSimpleFixture() { final Plan plan = populationFactory.createPlan(); @@ -146,7 +146,7 @@ public void createSimpleFixture() { nTrips)); } - @Before + @BeforeEach public void createFixtureWithComplexTrips() { final Plan plan = populationFactory.createPlan(); @@ -241,7 +241,7 @@ public void createFixtureWithComplexTrips() { } - @Before + @BeforeEach public void createFixtureWithSuccessiveActivities() { final Plan plan = populationFactory.createPlan(); @@ -330,7 +330,7 @@ public void createFixtureWithSuccessiveActivities() { nTrips)); } - @Before + @BeforeEach public void createFixtureWithAccessEgress() { final Plan plan = populationFactory.createPlan() ; @@ -383,7 +383,7 @@ void testActivities() throws Exception { for (Fixture fixture : fixtures) { final List acts = TripStructureUtils.getActivities( - fixture.plan, + fixture.plan, StageActivityHandling.ExcludeStageActivities); assertEquals( diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java index 18f059766b9..4f92d9ffb8e 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelOpenTimesScoringFunctionTest.java @@ -22,8 +22,8 @@ import static org.junit.jupiter.api.Assertions.assertEquals; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; @@ -53,7 +53,7 @@ public class CharyparNagelOpenTimesScoringFunctionTest { private Person person = null; private ActivityFacilities facilities = null; - @Before public void setUp() { + @BeforeEach public void setUp() { final Config config = ConfigUtils.createConfig(); final Scenario scenario = ScenarioUtils.createScenario( config ); @@ -86,7 +86,7 @@ public class CharyparNagelOpenTimesScoringFunctionTest { act.setEndTime(16.0 * 3600); } - @After public void tearDown() { + @AfterEach public void tearDown() { this.person = null; this.facilities = null; } diff --git a/matsim/src/test/java/org/matsim/counts/CountTest.java b/matsim/src/test/java/org/matsim/counts/CountTest.java index 641e9dd4c73..3864f3a3c1d 100644 --- a/matsim/src/test/java/org/matsim/counts/CountTest.java +++ b/matsim/src/test/java/org/matsim/counts/CountTest.java @@ -22,7 +22,7 @@ import java.util.Iterator; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import static org.junit.jupiter.api.Assertions.assertTrue; import org.junit.jupiter.api.Test; @@ -38,7 +38,7 @@ public class CountTest { private Counts counts; - @Before + @BeforeEach public void setUp() throws Exception { this.counts = new Counts<>(); } diff --git a/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java b/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java index 02181c75683..f75e0c37861 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/PermissibleModesCalculatorImplTest.java @@ -26,8 +26,8 @@ import java.util.Arrays; import java.util.Collection; import java.util.List; -import org.junit.After; -import org.junit.Before; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -49,7 +49,7 @@ private static class Fixture { public final Plan plan; public final boolean carAvail; - public Fixture( + public Fixture( final String name, final Plan plan, final boolean carAvail ) { @@ -60,12 +60,12 @@ public Fixture( } private final List fixtures = new ArrayList(); - @After + @AfterEach public void clean() { fixtures.clear(); } - @Before + @BeforeEach public void fixtureWithNothing() { String name = "no information"; Person person = PopulationUtils.getFactory().createPerson(Id.create(name, Person.class)); @@ -73,7 +73,7 @@ public void fixtureWithNothing() { fixtures.add( new Fixture( name , plan , true ) ); } - @Before + @BeforeEach public void fixtureWithNoLicense() { String name = "no License"; Person person = PopulationUtils.getFactory().createPerson(Id.create(name, Person.class)); @@ -82,7 +82,7 @@ public void fixtureWithNoLicense() { fixtures.add( new Fixture( name , plan , false ) ); } - @Before + @BeforeEach public void fixtureWithNoCar() { String name = "no car" ; Person person = PopulationUtils.getFactory().createPerson(Id.create(name, Person.class)); @@ -91,7 +91,7 @@ public void fixtureWithNoCar() { fixtures.add( new Fixture( name , plan , false ) ); } - @Before + @BeforeEach public void fixtureWithCarSometimes() { String name = "car sometimes"; Person person = PopulationUtils.getFactory().createPerson(Id.create(name, Person.class)); diff --git a/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java b/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java index d50dbb5234e..ca6facbf262 100644 --- a/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java +++ b/matsim/src/test/java/org/matsim/vehicles/MatsimVehicleWriterTest.java @@ -28,7 +28,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -50,7 +50,7 @@ public class MatsimVehicleWriterTest { private Id id42; private Id id42_23; - @Before public void setUp() { + @BeforeEach public void setUp() { id23 = Id.create("23", Vehicle.class); id42 = Id.create("42", Vehicle.class); diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java index 79e3ca7e10d..d883adc3ed2 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV1Test.java @@ -23,7 +23,7 @@ import java.util.Map; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -47,7 +47,7 @@ public class VehicleReaderV1Test { private Map, VehicleType> vehicleTypes; private Map, Vehicle> vehicles; - @Before public void setUp() { + @BeforeEach public void setUp() { Vehicles veh = VehicleUtils.createVehiclesContainer(); MatsimVehicleReader reader = new MatsimVehicleReader(veh); reader.readFile(utils.getPackageInputDirectory() + TESTXML); diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java index 83e51b5bdf3..30547c26436 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleReaderV2Test.java @@ -23,7 +23,7 @@ import java.util.Map; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -47,7 +47,7 @@ public class VehicleReaderV2Test { private Map, VehicleType> vehicleTypes; private Map, Vehicle> vehicles; - @Before public void setUp() { + @BeforeEach public void setUp() { Vehicles veh = VehicleUtils.createVehiclesContainer(); MatsimVehicleReader reader = new MatsimVehicleReader(veh); diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java index 3caafd4c6af..dd2d695f04e 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriteReadTest.java @@ -5,7 +5,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -23,7 +23,7 @@ public class VehicleWriteReadTest{ private static final String OUTXML_v2 = "testOutputVehicles_v2.xml"; - @Before + @BeforeEach public void setUp() throws IOException { } diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java index 1e970b893f4..2aa9ad71223 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV1Test.java @@ -26,7 +26,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -49,7 +49,7 @@ public class VehicleWriterV1Test { private Id id42; private Id id42_23; - @Before public void setUp() { + @BeforeEach public void setUp() { id23 = Id.create("23", Vehicle.class); id42 = Id.create("42", Vehicle.class); diff --git a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java index e3ebbe417bf..1bd89738340 100644 --- a/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java +++ b/matsim/src/test/java/org/matsim/vehicles/VehicleWriterV2Test.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Before; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -52,7 +52,7 @@ public class VehicleWriterV2Test { private Map, VehicleType> vehicleTypes; private Map, Vehicle> vehicles; - @Before public void setUp() throws IOException { + @BeforeEach public void setUp() throws IOException { String outfileName = utils.getOutputDirectory() + "../testOutputVehicles.xml"; // read it diff --git a/pom.xml b/pom.xml index c9e328d64fb..2b03c25e29d 100644 --- a/pom.xml +++ b/pom.xml @@ -216,12 +216,6 @@ 4.2.2 - - org.junit.vintage - junit-vintage-engine - ${junit.version} - test - org.junit.jupiter junit-jupiter-engine From 684bf9887bda8c04845ec495b793d377b7095513 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Tue, 12 Dec 2023 10:51:59 +0100 Subject: [PATCH 33/43] changed parameterized runners from junit 4 to junit 5 --- .../TestWarmEmissionAnalysisModule.java | 91 ++++---- .../TestWarmEmissionAnalysisModuleCase1.java | 78 +++---- .../TestWarmEmissionAnalysisModuleCase2.java | 50 ++--- .../TestWarmEmissionAnalysisModuleCase3.java | 50 ++--- .../TestWarmEmissionAnalysisModuleCase4.java | 47 ++-- .../TestWarmEmissionAnalysisModuleCase5.java | 101 ++++----- ...issionAnalysisModuleTrafficSituations.java | 66 +++--- .../CreateAutomatedFDTest.java | 70 +++--- .../run/RunWithParkingProxyIT.java | 4 +- .../SignalsAndLanesOsmNetworkReaderTest.java | 61 +++-- .../selectors/HighestWeightSelectorTest.java | 76 +++---- .../CoalitionSelectorTest.java | 31 +-- .../drtAndPt/PtAlongALine2Test.java | 1 - .../ModalDistanceAndCountsCadytsIT.java | 36 +-- .../matsim/core/controler/ControlerIT.java | 47 ++-- .../core/mobsim/hermes/HermesTransitTest.java | 143 ++++++------ .../mobsim/qsim/FlowStorageSpillbackTest.java | 25 +-- .../core/mobsim/qsim/NodeTransitionTest.java | 55 ++--- .../org/matsim/core/mobsim/qsim/QSimTest.java | 209 ++++++++++-------- .../core/mobsim/qsim/VehicleSourceTest.java | 64 ++---- .../mobsim/qsim/qnetsimengine/QLinkTest.java | 59 +++-- .../qsim/qnetsimengine/SeepageTest.java | 39 ++-- .../qnetsimengine/VehVsLinkSpeedTest.java | 41 ++-- .../TripStructureUtilsSubtoursTest.java | 83 ++++--- .../CharyparNagelScoringFunctionTest.java | 68 +++--- .../java/org/matsim/examples/EquilTest.java | 25 +-- .../matsim/examples/simple/PtScoringTest.java | 50 ++--- .../ActivityFacilitiesSourceTest.java | 49 ++-- .../matsim/modules/ScoreStatsModuleTest.java | 37 +--- ...ndomLegModeForSubtourComplexTripsTest.java | 35 +-- ...eRandomLegModeForSubtourDiffModesTest.java | 64 +++--- .../ChooseRandomLegModeForSubtourTest.java | 83 ++++--- 32 files changed, 836 insertions(+), 1102 deletions(-) diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java index 92440ecfd30..cd88c087a65 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModule.java @@ -20,10 +20,12 @@ package org.matsim.contrib.emissions; -import org.junit.jupiter.api.Assertions; +import org.geotools.metadata.iso.quality.TemporalAccuracyImpl; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Node; @@ -38,6 +40,7 @@ import org.matsim.vehicles.VehiclesFactory; import java.util.*; +import java.util.stream.Stream; import static org.matsim.contrib.emissions.Pollutant.*; @@ -48,8 +51,8 @@ /* * test for playground.vsp.emissions.WarmEmissionAnalysisModule * - * WarmEmissionAnalysisModule (weam) - * public methods and corresponding tests: + * WarmEmissionAnalysisModule (weam) + * public methods and corresponding tests: * weamParameter - testWarmEmissionAnalysisParameter * throw warm EmissionEvent - testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent*, testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions * check vehicle info and calculate warm emissions -testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent*, testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions @@ -61,7 +64,7 @@ * get top go km couter - testCounters*() * get warm emission event counter - testCounters*() * - * private methods and corresponding tests: + * private methods and corresponding tests: * rescale warm emissions - rescaleWarmEmissionsTest() * calculate warm emissions - implicitly tested * convert string 2 tuple - implicitly tested @@ -70,7 +73,6 @@ * see test methods for details on the particular test cases **/ -@RunWith(Parameterized.class) public class TestWarmEmissionAnalysisModule { // This used to be one large test class, which had separate table entries for each test, but put them all into the same table. The result was // difficult if not impossible to debug, and the resulting detailed table was inconsistent in the sense that it did not contain all combinations of @@ -78,12 +80,8 @@ public class TestWarmEmissionAnalysisModule { // single class before was so large that I could not fully comprehend it, there may now be errors in the ripped-apart classes. Hopefully, over time, // this will help to sort things out. kai, feb'20 - - - private static final Set pollutants = new HashSet<>( Arrays.asList( Pollutant.values() )); static final String HBEFA_ROAD_CATEGORY = "URB"; - private final EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod; private boolean excep = false; private static final String PASSENGER_CAR = "PASSENGER_CAR"; @@ -113,24 +111,18 @@ public class TestWarmEmissionAnalysisModule { private final String sgffConcept = "sg ff concept"; private final String sgffSizeClass = "sg ff size class"; - - @Parameterized.Parameters( name = "{index}: ComputationMethod={0}") - public static Collection createCombinations() { - List list = new ArrayList<>(); - list.add( new Object [] {EmissionsConfigGroup.EmissionsComputationMethod.StopAndGoFraction} ) ; - list.add( new Object [] {EmissionsConfigGroup.EmissionsComputationMethod.AverageSpeed} ) ; - return list; + public static Stream arguments() { + return Stream.of( + EmissionsConfigGroup.EmissionsComputationMethod.StopAndGoFraction, + EmissionsConfigGroup.EmissionsComputationMethod.AverageSpeed + ); } - public TestWarmEmissionAnalysisModule( EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod ) { - this.emissionsComputationMethod = emissionsComputationMethod; - } - - - @Test - void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent6(){ + @ParameterizedTest + @MethodSource("arguments") + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent6(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ //-- set up tables, event handler, parameters, module - setUp(); + setUp(emissionsComputationMethod); Id sgffVehicleId = Id.create("vehicle sg equals ff", Vehicle.class); double sgffLinklength = 4000.; @@ -164,10 +156,11 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent6() } } - @Test - void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions1(){ + @ParameterizedTest + @MethodSource("arguments") + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions1(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ //-- set up tables, event handler, parameters, module - setUp(); + setUp(emissionsComputationMethod); // case 5 - no entry in any table - must be different to other test case's strings //With the bug fix to handle missing values - this test should no longer throw an error - jm oct'18 @@ -196,10 +189,11 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Ex excep=false; } - @Test - void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions2(){ + @ParameterizedTest + @MethodSource("arguments") + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions2(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ //-- set up tables, event handler, parameters, module - setUp(); + setUp(emissionsComputationMethod); // no vehicle information given Id noeVehicleId = Id.create("veh 6", Vehicle.class); @@ -221,12 +215,13 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Ex Assertions.assertTrue(excep); excep=false; } - @Test - void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions3(){ + @ParameterizedTest + @MethodSource("arguments") + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions3(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ //-- set up tables, event handler, parameters, module - setUp(); + setUp(emissionsComputationMethod); - // empty vehicle information + // empty vehicle information Id noeVehicleId = Id.create("veh 7", Vehicle.class); Id noeVehicleTypeId = Id.create(";;;", VehicleType.class); VehiclesFactory vehFac = VehicleUtils.getFactory(); @@ -245,10 +240,11 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Ex Assertions.assertTrue(excep); excep=false; } - @Test - void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions4(){ + @ParameterizedTest + @MethodSource("arguments") + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions4(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ //-- set up tables, event handler, parameters, module - setUp(); + setUp(emissionsComputationMethod); // vehicle information string is 'null' Id noeVehicleId = Id.create("veh 8", Vehicle.class); VehiclesFactory vehFac = VehicleUtils.getFactory(); @@ -268,9 +264,10 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Ex } - @Test - void testCounters7(){ - setUp(); + @ParameterizedTest + @MethodSource("arguments") + void testCounters7(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ + setUp(emissionsComputationMethod); emissionsModule.reset(); // case 10 - data in detailed table, stop go speed > free flow speed @@ -295,7 +292,7 @@ void testCounters7(){ emissionsModule.reset(); // ff < sg < avg - handled like free flow as well - no additional test needed - // avg < ff < sg - handled like stop go + // avg < ff < sg - handled like stop go emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(tableVehicle, tableLink, 2* tableLinkLength/(AVG_PASSENGER_CAR_SPEED_FF_KMH)*3.6 ); Assertions.assertEquals(0, emissionsModule.getFractionOccurences() ); Assertions.assertEquals(0., emissionsModule.getFreeFlowKmCounter(), MatsimTestUtils.EPSILON ); @@ -308,7 +305,7 @@ void testCounters7(){ } - private void setUp() { + private void setUp(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod) { Map avgHbefaWarmTable = new HashMap<>(); Map detailedHbefaWarmTable = new HashMap<>(); @@ -322,7 +319,7 @@ private void setUp() { EventsManager emissionEventManager = new HandlerToTestEmissionAnalysisModules(); EmissionsConfigGroup ecg = new EmissionsConfigGroup(); ecg.setHbefaVehicleDescriptionSource( EmissionsConfigGroup.HbefaVehicleDescriptionSource.usingVehicleTypeId ); - ecg.setEmissionsComputationMethod( this.emissionsComputationMethod ); + ecg.setEmissionsComputationMethod( emissionsComputationMethod ); ecg.setDetailedVsAverageLookupBehavior( DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ); emissionsModule = new WarmEmissionAnalysisModule( avgHbefaWarmTable, detailedHbefaWarmTable, hbefaRoadTrafficSpeeds, pollutants, emissionEventManager, ecg ); @@ -451,7 +448,7 @@ static void addDetailedRecordsToTestSpeedsTable( } - - + + diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java index 48734493dce..2bc080b1bc3 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestWarmEmissionAnalysisModuleCase1.java @@ -22,8 +22,10 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.EnumSource; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.contrib.emissions.utils.EmissionsConfigGroup; @@ -36,6 +38,7 @@ import org.matsim.vehicles.VehiclesFactory; import java.util.*; +import java.util.stream.Stream; import static org.matsim.contrib.emissions.Pollutant.CO2_TOTAL; import static org.matsim.contrib.emissions.TestWarmEmissionAnalysisModule.HBEFA_ROAD_CATEGORY; @@ -55,8 +58,8 @@ /* * test for playground.vsp.emissions.WarmEmissionAnalysisModule * - * WarmEmissionAnalysisModule (weam) - * public methods and corresponding tests: + * WarmEmissionAnalysisModule (weam) + * public methods and corresponding tests: * weamParameter - testWarmEmissionAnalysisParameter * throw warm EmissionEvent - testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent*, testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions * check vehicle info and calculate warm emissions -testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent*, testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent_Exceptions @@ -68,7 +71,7 @@ * get top go km couter - testCounters*() * get warm emission event counter - testCounters*() * - * private methods and corresponding tests: + * private methods and corresponding tests: * rescale warm emissions - rescaleWarmEmissionsTest() * calculate warm emissions - implicitly tested * convert string 2 tuple - implicitly tested @@ -77,7 +80,6 @@ * see test methods for details on the particular test cases **/ -@RunWith(Parameterized.class) public class TestWarmEmissionAnalysisModuleCase1{ // This used to be one large test class, which had separate table entries for each test, but put them all into the same table. The result was // difficult if not impossible to debug, and the resulting detailed table was inconsistent in the sense that it did not contain all combinations of @@ -89,7 +91,6 @@ public class TestWarmEmissionAnalysisModuleCase1{ private static final Set pollutants = new HashSet<>( Arrays.asList( Pollutant.values() )); private static final int leaveTime = 0; - private final EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod; private static final String PASSENGER_CAR = "PASSENGER_CAR"; @@ -104,20 +105,7 @@ public class TestWarmEmissionAnalysisModuleCase1{ private static final Double PETROL_SPEED_FF = 20.; //km/h private static final Double PETROL_SPEED_SG = 10.; //km/h - - @Parameterized.Parameters( name = "{index}: ComputationMethod={0}") - public static Collection createCombinations() { - List list = new ArrayList<>(); - list.add( new Object [] {EmissionsConfigGroup.EmissionsComputationMethod.StopAndGoFraction} ) ; - list.add( new Object [] {EmissionsConfigGroup.EmissionsComputationMethod.AverageSpeed} ) ; - return list; - } - - public TestWarmEmissionAnalysisModuleCase1( EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod ) { - this.emissionsComputationMethod = emissionsComputationMethod; - } - - private WarmEmissionAnalysisModule setUp() { + private WarmEmissionAnalysisModule setUp(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod) { Map avgHbefaWarmTable = new HashMap<>(); Map detailedHbefaWarmTable = new HashMap<>(); TestWarmEmissionAnalysisModule.fillAverageTable( avgHbefaWarmTable ); @@ -128,7 +116,7 @@ private WarmEmissionAnalysisModule setUp() { EventsManager emissionEventManager = TestWarmEmissionAnalysisModuleCase1.emissionEventManager; EmissionsConfigGroup ecg = new EmissionsConfigGroup(); ecg.setHbefaVehicleDescriptionSource( EmissionsConfigGroup.HbefaVehicleDescriptionSource.usingVehicleTypeId ); - ecg.setEmissionsComputationMethod( this.emissionsComputationMethod ); + ecg.setEmissionsComputationMethod( emissionsComputationMethod ); ecg.setDetailedVsAverageLookupBehavior( DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ); return new WarmEmissionAnalysisModule( avgHbefaWarmTable, detailedHbefaWarmTable, hbefaRoadTrafficSpeeds, pollutants, emissionEventManager, ecg ); } @@ -137,10 +125,11 @@ private WarmEmissionAnalysisModule setUp() { //this test method creates a mock link and mock vehicle with a complete vehicleTypId --> detailed values are used //the CO2_TOTAL warm Emissions are compared to a given value --> computed by using detailed Petrol and traffic state freeflow //the "Sum" of all emissions is tested - @Test - void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent1(){ + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent1(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ //-- set up tables, event handler, parameters, module - WarmEmissionAnalysisModule warmEmissionAnalysisModule = setUp(); + WarmEmissionAnalysisModule warmEmissionAnalysisModule = setUp(emissionsComputationMethod); // case 1 - data in both tables -> use detailed Id vehicleId = Id.create("veh 1", Vehicle.class); double linkLength = 200.; @@ -167,9 +156,10 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent1() * the counters for all possible combinations of avg, stop go and free flow speed are tested * for the cases: > s&g speed, use detailed // free flow velocity inconsistent -> different value in table @@ -308,10 +299,11 @@ void testCounters5(){ } - @Test - void testCounters1fractional(){ + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + void testCounters1fractional(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ - WarmEmissionAnalysisModule emissionsModule = setUp(); + WarmEmissionAnalysisModule emissionsModule = setUp(emissionsComputationMethod); emissionsModule.getEcg().setEmissionsComputationMethod(StopAndGoFraction ); // yyyyyy !!!!!! @@ -394,10 +386,11 @@ void testCounters1fractional(){ } - @Test - void testCounters6(){ + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + void testCounters6(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ - WarmEmissionAnalysisModule emissionsModule = setUp(); + WarmEmissionAnalysisModule emissionsModule = setUp(emissionsComputationMethod); emissionsModule.getEcg().setEmissionsComputationMethod(StopAndGoFraction ); // case 1 - data in both tables -> use detailed @@ -431,10 +424,11 @@ void testCounters6(){ emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(inconffVehicle, inconLink, 2 * inconff / (PETROL_SPEED_FF + PETROL_SPEED_SG) * 3.6); } - @Test - void testCounters8(){ + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + void testCounters8(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ - WarmEmissionAnalysisModule emissionsModule = setUp(); + WarmEmissionAnalysisModule emissionsModule = setUp(emissionsComputationMethod); // test summing up of counters @@ -516,7 +510,7 @@ private static void fillDetailedTable( Map pollutants = new HashSet<>( Arrays.asList( Pollutant.values() )); static final String HBEFA_ROAD_CATEGORY = "URB"; private static final int leaveTime = 0; - private final EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod; private static final String PASSENGER_CAR = "PASSENGER_CAR"; @@ -106,30 +106,17 @@ public class TestWarmEmissionAnalysisModuleCase2{ private static final Double PCSG_VELOCITY_KMH = 10.; //km/h private static final double DETAILED_PC_FACTOR_FF = .0001; - - @Parameterized.Parameters( name = "{index}: ComputationMethod={0}") - public static Collection createCombinations() { - List list = new ArrayList<>(); - list.add( new Object [] {EmissionsConfigGroup.EmissionsComputationMethod.StopAndGoFraction} ) ; - list.add( new Object [] {EmissionsConfigGroup.EmissionsComputationMethod.AverageSpeed} ) ; - return list; - } - - public TestWarmEmissionAnalysisModuleCase2( EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod ) { - this.emissionsComputationMethod = emissionsComputationMethod; - } - - /* * this test method creates a mock link and mock vehicle with a complete vehicleTypId --> lookUpBehaviour: tryDetailedThenTechnologyAverageThenAverageTable * for two speed cases: avg speed = free flow speed & avg speed = stop go speed the NMHC warm emissions and emissions sum are computed using the two emissionsComputationMethods StopAndGoFraction & AverageSpeed */ - @Test - void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent2(){ + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent2(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ //-- set up tables, event handler, parameters, module - WarmEmissionAnalysisModule emissionsModule = setUp(); + WarmEmissionAnalysisModule emissionsModule = setUp(emissionsComputationMethod); // case 2 - free flow entry in both tables, stop go entry in average table -> use average // see (*) below. kai, jan'20 @@ -185,10 +172,11 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent2() * for three cases: "current speed equals free flow speed" & "current speed equals stop go speed" & "current speed equals stop go speed" the counters are tested * average values are used */ - @Test - void testCounters3(){ + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + void testCounters3(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ - WarmEmissionAnalysisModule emissionsModule = setUp(); + WarmEmissionAnalysisModule emissionsModule = setUp(emissionsComputationMethod); // case 2 - free flow entry in both tables, stop go entry in average table -> use average Id pcVehicleId = Id.create("vehicle 2", Vehicle.class); @@ -221,7 +209,7 @@ void testCounters3(){ } - private WarmEmissionAnalysisModule setUp() { + private WarmEmissionAnalysisModule setUp(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod) { Map avgHbefaWarmTable = new HashMap<>(); Map detailedHbefaWarmTable = new HashMap<>(); @@ -234,7 +222,7 @@ private WarmEmissionAnalysisModule setUp() { EventsManager emissionEventManager = this.emissionEventManager; EmissionsConfigGroup ecg = new EmissionsConfigGroup(); ecg.setHbefaVehicleDescriptionSource( EmissionsConfigGroup.HbefaVehicleDescriptionSource.usingVehicleTypeId ); - ecg.setEmissionsComputationMethod( this.emissionsComputationMethod ); + ecg.setEmissionsComputationMethod( emissionsComputationMethod ); ecg.setDetailedVsAverageLookupBehavior( DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ); return new WarmEmissionAnalysisModule( avgHbefaWarmTable, detailedHbefaWarmTable, hbefaRoadTrafficSpeeds, pollutants, emissionEventManager, ecg ); @@ -331,7 +319,7 @@ private void fillDetailedTable( Map pollutants = new HashSet<>( Arrays.asList( Pollutant.values() )); static final String HBEFA_ROAD_CATEGORY = "URB"; private static final int leaveTime = 0; - private final EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod; private static final String PASSENGER_CAR = "PASSENGER_CAR"; private Map warmEmissions; @@ -99,27 +99,16 @@ public class TestWarmEmissionAnalysisModuleCase3{ private final String dieselSizeClass = "diesel"; private final String dieselConcept = ">=2L"; - @Parameterized.Parameters( name = "{index}: ComputationMethod={0}") - public static Collection createCombinations() { - List list = new ArrayList<>(); - list.add( new Object [] {EmissionsConfigGroup.EmissionsComputationMethod.StopAndGoFraction} ) ; - list.add( new Object [] {EmissionsConfigGroup.EmissionsComputationMethod.AverageSpeed} ) ; - return list; - } - - public TestWarmEmissionAnalysisModuleCase3( EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod ) { - this.emissionsComputationMethod = emissionsComputationMethod; - } - /* * this test method creates a diesel vehicle and mock link * for two cases: "avg speed = free flow speed" & "avg speed = stop go speed" the average values are used to calculate the PM warm emissions */ - @Test - void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent3(){ + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent3(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ //-- set up tables, event handler, parameters, module - WarmEmissionAnalysisModule emissionsModule = setUp(); + WarmEmissionAnalysisModule emissionsModule = setUp(emissionsComputationMethod); // case 3 - stop go entry in both tables, free flow entry in average table -> use average Id dieselVehicleId = Id.create("veh 3", Vehicle.class); @@ -154,10 +143,11 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent3() * this test method creates a diesel vehicle and mock link * for two cases: "current speed equals free flow speed" & "current speed equals stop go speed" the counters are tested */ - @Test - void testCounters4(){ + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + void testCounters4(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ - WarmEmissionAnalysisModule emissionsModule = setUp(); + WarmEmissionAnalysisModule emissionsModule = setUp(emissionsComputationMethod); // case 3 - stop go entry in both tables, free flow entry in average table -> use average Id dieselVehicleId = Id.create("vehicle 3", Vehicle.class); @@ -191,7 +181,7 @@ void testCounters4(){ emissionsModule.reset(); } - private WarmEmissionAnalysisModule setUp() { + private WarmEmissionAnalysisModule setUp(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod) { Map avgHbefaWarmTable = new HashMap<>(); Map detailedHbefaWarmTable = new HashMap<>(); @@ -204,7 +194,7 @@ private WarmEmissionAnalysisModule setUp() { EventsManager emissionEventManager = this.emissionEventManager; EmissionsConfigGroup ecg = new EmissionsConfigGroup(); ecg.setHbefaVehicleDescriptionSource( EmissionsConfigGroup.HbefaVehicleDescriptionSource.usingVehicleTypeId ); - ecg.setEmissionsComputationMethod( this.emissionsComputationMethod ); + ecg.setEmissionsComputationMethod( emissionsComputationMethod ); ecg.setDetailedVsAverageLookupBehavior( DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ); return new WarmEmissionAnalysisModule( avgHbefaWarmTable, detailedHbefaWarmTable, hbefaRoadTrafficSpeeds, pollutants, emissionEventManager, ecg ); @@ -286,7 +276,7 @@ private void fillDetailedTable( Map pollutants = new HashSet<>( Arrays.asList( Pollutant.values() )); private static final String HBEFA_ROAD_CATEGORY = "URB"; private static final int leaveTime = 0; - private final EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod; private static final String PASSENGER_CAR = "PASSENGER_CAR"; private Map warmEmissions; @@ -105,29 +103,17 @@ public class TestWarmEmissionAnalysisModuleCase4{ private static final Double SPEED_FF = 20.; //km/h private static final Double SPEED_SG = 10.; //km/h - @Parameterized.Parameters( name = "{index}: ComputationMethod={0}") - public static Collection createCombinations() { - List list = new ArrayList<>(); - list.add(new Object[]{EmissionsConfigGroup.EmissionsComputationMethod.StopAndGoFraction}); - list.add(new Object[]{EmissionsConfigGroup.EmissionsComputationMethod.AverageSpeed}); - return list; - } - - public TestWarmEmissionAnalysisModuleCase4(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod) { - this.emissionsComputationMethod = emissionsComputationMethod; - } - - /* * this test method creates a vehicle (lpg properties) and a mock link * for two cases: "avg speed = stop go speed" & "avg speed = free flow speed" the PM warm Emissions and the Emissions "sum" are tested * average values are used */ - @Test - void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent4() { + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent4(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod) { //-- set up tables, event handler, parameters, module - WarmEmissionAnalysisModule emissionsModule = setUp(); + WarmEmissionAnalysisModule emissionsModule = setUp(emissionsComputationMethod); // case 4 - data in average table Id lpgVehicleId = Id.create("veh 4", Vehicle.class); @@ -161,9 +147,10 @@ void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent4() * for two cases: "avg speed = stop go speed" & "avg speed = free flow speed" the PM warm Emissions are tested * average values are used */ - @Test - void testCounters2(){ - WarmEmissionAnalysisModule emissionsModule = setUp(); + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + void testCounters2(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod){ + WarmEmissionAnalysisModule emissionsModule = setUp(emissionsComputationMethod); // ff und sg not part of the detailed table -> use average table Id vehicleId = Id.create("vehicle 4", Vehicle.class); @@ -197,7 +184,7 @@ void testCounters2(){ } - private WarmEmissionAnalysisModule setUp() { + private WarmEmissionAnalysisModule setUp(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod) { Map avgHbefaWarmTable = new HashMap<>(); Map detailedHbefaWarmTable = new HashMap<>(); @@ -209,7 +196,7 @@ private WarmEmissionAnalysisModule setUp() { EventsManager emissionEventManager = this.emissionEventManager; EmissionsConfigGroup ecg = new EmissionsConfigGroup(); ecg.setHbefaVehicleDescriptionSource(EmissionsConfigGroup.HbefaVehicleDescriptionSource.usingVehicleTypeId); - ecg.setEmissionsComputationMethod(this.emissionsComputationMethod); + ecg.setEmissionsComputationMethod(emissionsComputationMethod); ecg.setDetailedVsAverageLookupBehavior(DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable); return new WarmEmissionAnalysisModule( avgHbefaWarmTable, detailedHbefaWarmTable, hbefaRoadTrafficSpeeds, pollutants, emissionEventManager, ecg ); @@ -289,7 +276,7 @@ private void fillDetailedTable(Map pollutants = new HashSet<>( Arrays.asList( Pollutant.values() )); - private final EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod; + private static final Set pollutants = new HashSet<>(Arrays.asList(Pollutant.values())); private static final String PASSENGER_CAR = "PASSENGER_CAR"; - - private static final Double DETAILED_ZERO_FACTOR_FF = .0011; + private static final Double DETAILED_ZERO_FACTOR_FF = .0011; + private final HandlerToTestEmissionAnalysisModules emissionEventManager = new HandlerToTestEmissionAnalysisModules(); // vehicle information for regular test cases - // case 5 - data in detailed table, stop go speed zero private final String zeroRoadCategory = "URB_case6"; private final String zeroTechnology = "zero technology"; @@ -99,76 +101,65 @@ public class TestWarmEmissionAnalysisModuleCase5{ private final Double zeroFreeVelocity = 20.; //km/h private final Double zeroSgVelocity = 0.; //km/h - - - @Parameterized.Parameters( name = "{index}: ComputationMethod={0}") - public static Collection createCombinations() { - List list = new ArrayList<>(); - list.add( new Object [] {EmissionsConfigGroup.EmissionsComputationMethod.StopAndGoFraction} ) ; - list.add( new Object [] {EmissionsConfigGroup.EmissionsComputationMethod.AverageSpeed} ) ; - return list; - } - - public TestWarmEmissionAnalysisModuleCase5( EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod ) { - this.emissionsComputationMethod = emissionsComputationMethod; - } - /* * this test method creates a vehicle and a mock link (both zero properties) * the free flow factor is used to calculate and test the PM warm Emissions and HandlerToTestEmissionAnalysisModules Sum * detailed values are used */ - @Test - void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent5(){ + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + public void testCheckVehicleInfoAndCalculateWarmEmissions_and_throwWarmEmissionEvent5(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod) { //-- set up tables, event handler, parameters, module - WarmEmissionAnalysisModule emissionsModule = setUp(); + WarmEmissionAnalysisModule emissionsModule = setUp(emissionsComputationMethod); // case 6 - data in detailed table, stop go speed zero // use free flow factor to calculate emissions Id zeroVehicleId = Id.create("vehicle zero", Vehicle.class); double zeroLinklength = 3000.; - Link zerolink = TestWarmEmissionAnalysisModule.createMockLink("link zero", zeroLinklength, zeroFreeVelocity / 3.6 ); + Link zerolink = TestWarmEmissionAnalysisModule.createMockLink("link zero", zeroLinklength, zeroFreeVelocity / 3.6); Id lpgLinkId = zerolink.getId(); EmissionUtils.setHbefaRoadType(zerolink, zeroRoadCategory); Id zeroVehicleTypeId = Id.create( - PASSENGER_CAR + ";"+ zeroTechnology + ";" + zeroSizeClass + ";" + zeroConcept, VehicleType.class ); + PASSENGER_CAR + ";" + zeroTechnology + ";" + zeroSizeClass + ";" + zeroConcept, VehicleType.class); VehiclesFactory vehFac = VehicleUtils.getFactory(); Vehicle zeroVehicle = vehFac.createVehicle(zeroVehicleId, vehFac.createVehicleType(zeroVehicleTypeId)); - Map warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(zeroVehicle, zerolink, 2 * zeroLinklength / (zeroFreeVelocity + zeroSgVelocity) * 3.6); - Assertions.assertEquals( DETAILED_ZERO_FACTOR_FF *zeroLinklength/1000., warmEmissions.get(PM ), MatsimTestUtils.EPSILON ); + Map warmEmissions = emissionsModule.checkVehicleInfoAndCalculateWarmEmissions(zeroVehicle, zerolink, + 2 * zeroLinklength / (zeroFreeVelocity + zeroSgVelocity) * 3.6); + Assertions.assertEquals(DETAILED_ZERO_FACTOR_FF * zeroLinklength / 1000., warmEmissions.get(PM), MatsimTestUtils.EPSILON); emissionsModule.throwWarmEmissionEvent(22., lpgLinkId, zeroVehicleId, warmEmissions); - Assertions.assertEquals( pollutants.size() * DETAILED_ZERO_FACTOR_FF *zeroLinklength/1000., emissionEventManager.getSum(), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(pollutants.size() * DETAILED_ZERO_FACTOR_FF * zeroLinklength / 1000., emissionEventManager.getSum(), + MatsimTestUtils.EPSILON); warmEmissions.clear(); } - - private WarmEmissionAnalysisModule setUp() { + private WarmEmissionAnalysisModule setUp(EmissionsConfigGroup.EmissionsComputationMethod emissionsComputationMethod) { Map avgHbefaWarmTable = new HashMap<>(); Map detailedHbefaWarmTable = new HashMap<>(); - TestWarmEmissionAnalysisModule.fillAverageTable( avgHbefaWarmTable ); - fillDetailedTable( detailedHbefaWarmTable ); + TestWarmEmissionAnalysisModule.fillAverageTable(avgHbefaWarmTable); + fillDetailedTable(detailedHbefaWarmTable); Map> hbefaRoadTrafficSpeeds = EmissionUtils.createHBEFASpeedsTable( - avgHbefaWarmTable ); - TestWarmEmissionAnalysisModule.addDetailedRecordsToTestSpeedsTable( hbefaRoadTrafficSpeeds, detailedHbefaWarmTable ); + avgHbefaWarmTable); + TestWarmEmissionAnalysisModule.addDetailedRecordsToTestSpeedsTable(hbefaRoadTrafficSpeeds, detailedHbefaWarmTable); EventsManager emissionEventManager = this.emissionEventManager; EmissionsConfigGroup ecg = new EmissionsConfigGroup(); - ecg.setHbefaVehicleDescriptionSource( EmissionsConfigGroup.HbefaVehicleDescriptionSource.usingVehicleTypeId ); - ecg.setEmissionsComputationMethod( this.emissionsComputationMethod ); - ecg.setDetailedVsAverageLookupBehavior( DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ); + ecg.setHbefaVehicleDescriptionSource(EmissionsConfigGroup.HbefaVehicleDescriptionSource.usingVehicleTypeId); + ecg.setEmissionsComputationMethod(emissionsComputationMethod); + ecg.setDetailedVsAverageLookupBehavior(DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable); - return new WarmEmissionAnalysisModule( avgHbefaWarmTable, detailedHbefaWarmTable, hbefaRoadTrafficSpeeds, pollutants, emissionEventManager, ecg ); + return new WarmEmissionAnalysisModule(avgHbefaWarmTable, detailedHbefaWarmTable, hbefaRoadTrafficSpeeds, pollutants, emissionEventManager, + ecg); } - private void fillDetailedTable( Map detailedHbefaWarmTable) { + private void fillDetailedTable(Map detailedHbefaWarmTable) { //entries for zero case { @@ -204,7 +195,3 @@ private void fillDetailedTable( Map pollutants = new HashSet<>( Arrays.asList( Pollutant.values() ) ); private static final String hbefaRoadCategory = "URB"; - private final EmissionsComputationMethod emissionsComputationMethod; private final String passengercar= "PASSENGER_CAR"; private WarmEmissionAnalysisModule weam; @@ -84,20 +85,7 @@ public class TestWarmEmissionAnalysisModuleTrafficSituations { private static final String pcConcept = "<1,4L"; private static final double[] avgPetrolFactor = {20, 200, 2000, 20000, 200000}; - public TestWarmEmissionAnalysisModuleTrafficSituations( EmissionsComputationMethod emissionsComputationMethod ) { - this.emissionsComputationMethod = emissionsComputationMethod; - } - - @Parameterized.Parameters( name = "{index}: ComputationMethod={0}") - public static Collection createCombinations() { - List list = new ArrayList<>(); - list.add( new Object [] {EmissionsComputationMethod.StopAndGoFraction} ) ; - list.add( new Object [] {EmissionsComputationMethod.AverageSpeed} ) ; - return list; - } - - @BeforeEach - public void setUp() { + public void setUp(EmissionsComputationMethod emissionsComputationMethod) { Map avgHbefaWarmTable = new HashMap<>(); Map detailedHbefaWarmTable = new HashMap<>(); @@ -110,7 +98,7 @@ public void setUp() { EventsManager emissionEventManager = new HandlerToTestEmissionAnalysisModules(); EmissionsConfigGroup ecg = new EmissionsConfigGroup(); ecg.setHbefaVehicleDescriptionSource( EmissionsConfigGroup.HbefaVehicleDescriptionSource.usingVehicleTypeId ); - ecg.setEmissionsComputationMethod( this.emissionsComputationMethod ); + ecg.setEmissionsComputationMethod( emissionsComputationMethod ); ecg.setDetailedVsAverageLookupBehavior(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.onlyTryDetailedElseAbort); //declare using detailed values weam = new WarmEmissionAnalysisModule( avgHbefaWarmTable, detailedHbefaWarmTable, hbefaRoadTrafficSpeeds, pollutants, emissionEventManager, ecg ); @@ -120,8 +108,10 @@ public void setUp() { //Test to check that vehicles not found in the detailed table revert back to average table - ie detailed (petrol, 1,2,3), average (petrol), search pet 4 - @Test - public void testFallBackToAverageTable() { + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + public void testFallBackToAverageTable(EmissionsComputationMethod emissionsComputationMethod) { + setUp(emissionsComputationMethod); Id vehicleId = Id.create("vehicle 1", Vehicle.class); double linkLength = 2*1000.; //in meter Id vehicleTypeId = Id.create(passengercar+ ";"+petrolTechnology+";"+petrolSizeClass+";"+petrolConcept, VehicleType.class); @@ -134,18 +124,20 @@ public void testFallBackToAverageTable() { //allow fallback to average table weam.getEcg().setDetailedVsAverageLookupBehavior( EmissionsConfigGroup.DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable ); warmEmissions = weam.checkVehicleInfoAndCalculateWarmEmissions(vehicle, pcLink, travelTime*3.6); - Assert.assertEquals(detailedPetrolFactor[FF_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(detailedPetrolFactor[FF_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); vehicleTypeId = Id.create(passengercar+ ";"+pcTechnology+";"+pcSizeClass+";"+pcConcept, VehicleType.class); vehicle = vehFac.createVehicle(vehicleId, vehFac.createVehicleType(vehicleTypeId)); warmEmissions = weam.checkVehicleInfoAndCalculateWarmEmissions(vehicle, pcLink, travelTime*3.6); - Assert.assertEquals(avgPetrolFactor[FF_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(avgPetrolFactor[FF_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); } //using the different computation methods, the NOx warm Emissions are calculated for the diffrent trafic Situations (FF;HEAVY;SAT;SG) - @Test - public void testTrafficSituations() { + @ParameterizedTest + @EnumSource(EmissionsConfigGroup.EmissionsComputationMethod.class) + public void testTrafficSituations(EmissionsComputationMethod emissionsComputationMethod) { + setUp(emissionsComputationMethod); Id vehicleId = Id.create("vehicle 1", Vehicle.class); double linkLength = 2*1000.; //in meter Id vehicleTypeId = Id.create(passengercar+ ";"+petrolTechnology+";"+petrolSizeClass+";"+petrolConcept, VehicleType.class); @@ -159,17 +151,17 @@ public void testTrafficSituations() { double actualSpeed = avgPassengerCarSpeed[FF_INDEX]; double travelTime = linkLength/actualSpeed; warmEmissions = weam.checkVehicleInfoAndCalculateWarmEmissions(vehicle, pcLink, travelTime*3.6); - Assert.assertEquals(detailedPetrolFactor[FF_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(detailedPetrolFactor[FF_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); actualSpeed = avgPassengerCarSpeed[HEAVY_INDEX]; travelTime = linkLength/actualSpeed; warmEmissions = weam.checkVehicleInfoAndCalculateWarmEmissions(vehicle, pcLink, travelTime*3.6); switch( emissionsComputationMethod ) { case StopAndGoFraction: - Assert.assertEquals( 1360.1219512195123, warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( 1360.1219512195123, warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); break; case AverageSpeed: - Assert.assertEquals(detailedPetrolFactor[HEAVY_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(detailedPetrolFactor[HEAVY_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); break; default: throw new IllegalStateException( "Unexpected value: " + emissionsComputationMethod ); @@ -180,10 +172,10 @@ public void testTrafficSituations() { warmEmissions = weam.checkVehicleInfoAndCalculateWarmEmissions(vehicle, pcLink, travelTime*3.6); switch( emissionsComputationMethod ) { case StopAndGoFraction: - Assert.assertEquals( 3431.219512195123, warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals( 3431.219512195123, warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); break; case AverageSpeed: - Assert.assertEquals(detailedPetrolFactor[SAT_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(detailedPetrolFactor[SAT_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); break; default: throw new IllegalStateException( "Unexpected value: " + emissionsComputationMethod ); @@ -192,18 +184,18 @@ public void testTrafficSituations() { actualSpeed = avgPassengerCarSpeed[SG_INDEX]; travelTime = linkLength/actualSpeed; warmEmissions = weam.checkVehicleInfoAndCalculateWarmEmissions(vehicle, pcLink, travelTime*3.6); - Assert.assertEquals(detailedPetrolFactor[SG_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(detailedPetrolFactor[SG_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); actualSpeed = avgPassengerCarSpeed[SG_INDEX] + 5; travelTime = linkLength/actualSpeed; warmEmissions = weam.checkVehicleInfoAndCalculateWarmEmissions(vehicle, pcLink, travelTime*3.6); switch( emissionsComputationMethod ) { case StopAndGoFraction: - Assert.assertEquals(11715.609756097561, warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(11715.609756097561, warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); break; case AverageSpeed: - Assert.assertEquals(detailedPetrolFactor[SAT_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); + Assertions.assertEquals(detailedPetrolFactor[SAT_INDEX]*(linkLength/1000.), warmEmissions.get( NOx ), MatsimTestUtils.EPSILON ); break; default: throw new IllegalStateException( "Unexpected value: " + emissionsComputationMethod ); @@ -214,10 +206,10 @@ public void testTrafficSituations() { actualSpeed = avgPassengerCarSpeed[SG_INDEX] - 5; travelTime = linkLength / actualSpeed; warmEmissions = weam.checkVehicleInfoAndCalculateWarmEmissions(vehicle, pcLink, travelTime * 3.6); - Assert.assertEquals(detailedPetrolFactor[SG_INDEX] * (linkLength / 1000.), warmEmissions.get(NOx), MatsimTestUtils.EPSILON); + Assertions.assertEquals(detailedPetrolFactor[SG_INDEX] * (linkLength / 1000.), warmEmissions.get(NOx), MatsimTestUtils.EPSILON); //results should be equal here, because in both cases only the s&g value is relevant (0% freeflow, 100% stop&go). - Assert.assertEquals(20000, warmEmissions.get(NOx), MatsimTestUtils.EPSILON); + Assertions.assertEquals(20000, warmEmissions.get(NOx), MatsimTestUtils.EPSILON); } } diff --git a/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java b/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java index a2bcc7ed20b..2d6b1fffa60 100644 --- a/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java +++ b/contribs/integration/src/test/java/org/matsim/integration/weekly/fundamentaldiagram/CreateAutomatedFDTest.java @@ -30,6 +30,7 @@ import java.util.Map; import java.util.Set; import java.util.TreeMap; +import java.util.stream.Stream; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; @@ -45,9 +46,9 @@ import org.jfree.data.xy.XYSeriesCollection; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -91,64 +92,49 @@ * @author amit */ -@RunWith(Parameterized.class) public class CreateAutomatedFDTest { - - /** - * Constructor. Even if it does not look like one. - */ - public CreateAutomatedFDTest(LinkDynamics linkDynamics, TrafficDynamics trafficDynamics) { - this.linkDynamics = linkDynamics; - this.trafficDynamics = trafficDynamics; - this.travelModes = new String [] {"car","bike"}; - } - - private LinkDynamics linkDynamics; - private TrafficDynamics trafficDynamics; private final Map,String> person2Mode = new HashMap<>(); - @Parameters(name = "{index}: LinkDynamics == {0}; Traffic dynamics == {1};") - // the convention is that the output of the method marked by "@Parameters" is taken as input to the constructor - // before running each test. kai, jul'16 - public static Collection createFds() { - int combos = LinkDynamics.values().length * TrafficDynamics.values().length ; - Object [][] combos2run = new Object [combos][2]; // #ld x #td x #params - int index = 0; + public static Stream arguments() { + List result = new LinkedList<>(); for (LinkDynamics ld : LinkDynamics.values()) { for (TrafficDynamics td : TrafficDynamics.values()) { - combos2run[index] = new Object [] {ld, td}; - index++; + result.add(Arguments.of(ld, td)); } } - return Arrays.asList(combos2run); + return result.stream(); } - @Test - void fdsCarTruck(){ + @ParameterizedTest + @MethodSource("arguments") + void fdsCarTruck(LinkDynamics linkDynamics, TrafficDynamics trafficDynamics){ this.travelModes = new String [] {"car","truck"}; - run(false); + run(false, linkDynamics, trafficDynamics); } - @Test - void fdsCarBike(){ - run(false); + @ParameterizedTest + @MethodSource("arguments") + void fdsCarBike(LinkDynamics linkDynamics, TrafficDynamics trafficDynamics){ + run(false,linkDynamics, trafficDynamics); } - @Test - void fdsCarBikeFastCapacityUpdate(){ - run(true); + @ParameterizedTest + @MethodSource("arguments") + void fdsCarBikeFastCapacityUpdate(LinkDynamics linkDynamics, TrafficDynamics trafficDynamics){ + run(true, linkDynamics, trafficDynamics); } - @Test - void fdsCarOnly(){ + @ParameterizedTest + @MethodSource("arguments") + void fdsCarOnly(LinkDynamics linkDynamics, TrafficDynamics trafficDynamics){ this.travelModes = new String [] {"car"}; - run(false); + run(false, linkDynamics, trafficDynamics); } @RegisterExtension private MatsimTestUtils helper = new MatsimTestUtils(); - private String [] travelModes; + private String [] travelModes = new String [] {"car","bike"}; public final Id flowDynamicsMeasurementLinkId = Id.createLinkId(0); private Map modeVehicleTypes; private Map, TravelModesFlowDynamicsUpdator> mode2FlowData; @@ -156,7 +142,7 @@ void fdsCarOnly(){ private final static Logger LOG = LogManager.getLogger(CreateAutomatedFDTest.class); - private void run(final boolean isUsingFastCapacityUpdate) { + private void run(final boolean isUsingFastCapacityUpdate, LinkDynamics linkDynamics, TrafficDynamics trafficDynamics) { MatsimRandom.reset(); @@ -675,13 +661,13 @@ private void updateFlow900(double nowTime, double pcuVeh){ } else { flowTableReset(); } - this.flowTime = new Double(nowTime); + this.flowTime = nowTime; } updateLastXFlows900(); } private void updateLastXFlows900(){ - Double nowFlow = new Double(this.getCurrentHourlyFlow()); + Double nowFlow = this.getCurrentHourlyFlow(); for (int i=NUMBER_OF_MEMORIZED_FLOWS-2; i>=0; i--){ this.lastXFlows900.set(i+1, this.lastXFlows900.get(i).doubleValue()); } diff --git a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java index abd3e9a34d0..6d17839c44c 100644 --- a/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java +++ b/contribs/parking/src/test/java/org/matsim/contrib/parking/parkingproxy/run/RunWithParkingProxyIT.java @@ -20,7 +20,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.population.Population; @@ -37,7 +37,7 @@ public class RunWithParkingProxyIT { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); @Test - @Ignore + @Disabled void testMain(){ RunWithParkingProxy.main( new String []{ IOUtils.extendUrl( ExamplesUtils.getTestScenarioURL( "chessboard" ), "config.xml" ).toString() , "--config:controler.outputDirectory=" + utils.getOutputDirectory() diff --git a/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java b/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java index 6860c74bd76..4e81fc7628a 100644 --- a/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java +++ b/contribs/signals/src/test/java/org/matsim/contrib/signals/network/SignalsAndLanesOsmNetworkReaderTest.java @@ -10,14 +10,15 @@ import java.util.Collections; import java.util.LinkedList; import java.util.List; +import java.util.stream.Stream; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.Assertions; -import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -58,7 +59,6 @@ @author */ -@RunWith(Parameterized.class) public class SignalsAndLanesOsmNetworkReaderTest { private static final Logger log = LogManager.getLogger(SignalsAndLanesOsmNetworkReaderTest.class); @@ -66,30 +66,19 @@ public class SignalsAndLanesOsmNetworkReaderTest { @RegisterExtension public MatsimTestUtils matsimTestUtils = new MatsimTestUtils(); - @Parameterized.Parameters - public static Collection data() { - Object[][] data = new Object[][]{{true, true, true}, - {true, true, false}, - {true, false, true}, - {false, true, true}, - {true, false, false}, - {false, true, false}, - {false, false, true}, - {false, false, false},}; - return Arrays.asList(data); + public static Stream arguments() { + return Stream.of( + Arguments.of(true, true, true), + Arguments.of(true, true, false), + Arguments.of(true, false, true), + Arguments.of(false, true, true), + Arguments.of(true, false, false), + Arguments.of(false, true, false), + Arguments.of(false, false, true), + Arguments.of(false, false, false) + ); } - @Parameterized.Parameter - public boolean setMergeOnewaySignalSystems; - @Parameterized.Parameter(1) - public boolean setAllowUTurnAtLeftLaneOnly; - @Parameterized.Parameter(2) - public boolean setMakePedestrianSignals; - - - - - private static void writeOsmData(Collection nodes, Collection ways, Path file) { try (OutputStream outputStream = Files.newOutputStream(file)) { @@ -177,8 +166,9 @@ public OsmData constructSignalisedJunction(){ // @SuppressWarnings("ConstantConditions") - @Test - void singleJunction(){ + @ParameterizedTest + @MethodSource("arguments") + void singleJunction(boolean setMergeOnewaySignalSystems, boolean setAllowUTurnAtLeftLaneOnly, boolean setMakePedestrianSignals){ OsmData osmData = constructSignalisedJunction(); Path file = Paths.get(matsimTestUtils.getOutputDirectory(), "singleJunction.xml"); writeOsmData(osmData.getNodes(),osmData.getWays(),file); @@ -239,8 +229,9 @@ void singleJunction(){ Assertions.assertEquals(8, signals, "Assert number of Signals"); } - @Test - void singleJunctionWithBoundingBox(){ + @ParameterizedTest + @MethodSource("arguments") + void singleJunctionWithBoundingBox(boolean setMergeOnewaySignalSystems, boolean setAllowUTurnAtLeftLaneOnly, boolean setMakePedestrianSignals){ OsmData osmData = constructSignalisedJunction(); Path file = Paths.get(matsimTestUtils.getOutputDirectory(), "singleJunction.xml"); writeOsmData(osmData.getNodes(),osmData.getWays(),file); @@ -303,8 +294,9 @@ void singleJunctionWithBoundingBox(){ Assertions.assertEquals(8, signals, "Assert number of Signals"); } - @Test - void singleJunctionBadBoundingBox(){ + @ParameterizedTest + @MethodSource("arguments") + void singleJunctionBadBoundingBox(boolean setMergeOnewaySignalSystems, boolean setAllowUTurnAtLeftLaneOnly, boolean setMakePedestrianSignals){ OsmData osmData = constructSignalisedJunction(); Path file = Paths.get(matsimTestUtils.getOutputDirectory(), "singleJunction.xml"); writeOsmData(osmData.getNodes(),osmData.getWays(),file); @@ -360,8 +352,9 @@ void singleJunctionBadBoundingBox(){ } } - @Test - void berlinSnippet(){ + @ParameterizedTest + @MethodSource("arguments") + void berlinSnippet(boolean setMergeOnewaySignalSystems, boolean setAllowUTurnAtLeftLaneOnly, boolean setMakePedestrianSignals){ Path inputfile = Paths.get(matsimTestUtils.getClassInputDirectory()); inputfile = Paths.get(inputfile.toString(),"berlinSnippet.osm.gz"); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java index 9962f22480c..e59150830b7 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/HighestWeightSelectorTest.java @@ -21,25 +21,23 @@ import java.util.ArrayList; import java.util.Arrays; -import java.util.Collection; import java.util.Collections; import java.util.HashMap; import java.util.HashSet; import java.util.List; import java.util.Map; import java.util.Set; +import java.util.stream.Stream; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; -import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; -import org.matsim.api.core.v01.population.Plan; import org.matsim.core.population.PersonUtils; import org.matsim.core.population.PopulationUtils; import org.matsim.contrib.socnetsim.framework.cliques.Clique; @@ -51,13 +49,10 @@ /** * @author thibautd */ -@RunWith(Parameterized.class) public class HighestWeightSelectorTest { private static final Logger log = LogManager.getLogger(HighestWeightSelectorTest.class); - private final Fixture fixture; - public static class Fixture { final String name; final ReplanningGroup group; @@ -85,29 +80,21 @@ public Fixture( } } - // XXX the SAME instance is used for all tests! - // should ot be a problem, but this is contrary to the idea of "fixture" - public HighestWeightSelectorTest(final Fixture fixture) { - this.fixture = fixture; - log.info( "fixture "+fixture.name ); - } - - @Parameterized.Parameters - public static Collection fixtures() { - return Arrays.asList( - new Fixture[]{createIndividualPlans()}, - new Fixture[]{createFullyJointPlans()}, - new Fixture[]{createPartiallyJointPlansOneSelectedJp()}, - new Fixture[]{createPartiallyJointPlansTwoSelectedJps()}, - new Fixture[]{createPartiallyJointPlansMessOfJointPlans()}, - new Fixture[]{createPartiallyJointPlansNoSelectedJp()}, - new Fixture[]{createOneBigJointPlanDifferentNPlansPerAgent()}, - new Fixture[]{createOneBigJointPlanDifferentNPlansPerAgent2()}, - new Fixture[]{createOneBigJointPlanDifferentNPlansPerAgentWithNullScores()}, - new Fixture[]{createPlanWithDifferentSolutionIfBlocked()}, - new Fixture[]{createPlanWithNoSolutionIfBlocked()}, - new Fixture[]{createIndividualPlansWithSpecialForbidder()}, - new Fixture[]{createDifferentForbidGroupsPerJointPlan()}); + public static Stream arguments() { + return Stream.of( + createIndividualPlans(), + createFullyJointPlans(), + createPartiallyJointPlansOneSelectedJp(), + createPartiallyJointPlansTwoSelectedJps(), + createPartiallyJointPlansMessOfJointPlans(), + createPartiallyJointPlansNoSelectedJp(), + createOneBigJointPlanDifferentNPlansPerAgent(), + createOneBigJointPlanDifferentNPlansPerAgent2(), + createOneBigJointPlanDifferentNPlansPerAgentWithNullScores(), + createPlanWithDifferentSolutionIfBlocked(), + createPlanWithNoSolutionIfBlocked(), + createIndividualPlansWithSpecialForbidder(), + createDifferentForbidGroupsPerJointPlan()); } // ///////////////////////////////////////////////////////////////////////// @@ -1232,27 +1219,31 @@ public void setupLogging() { // ///////////////////////////////////////////////////////////////////////// // Tests // ///////////////////////////////////////////////////////////////////////// - @Test - void testSelectedPlansNonBlocking() throws Exception { - testSelectedPlans( false , false ); + @ParameterizedTest + @MethodSource("arguments") + void testSelectedPlansNonBlocking(Fixture fixture) throws Exception { + testSelectedPlans( fixture, false , false ); } - @Test - void testSelectedPlansForbidding() throws Exception { - testSelectedPlans( false , true ); + @ParameterizedTest + @MethodSource("arguments") + void testSelectedPlansForbidding(Fixture fixture) throws Exception { + testSelectedPlans( fixture, false , true ); } - @Test - void testSelectedPlansBlocking() throws Exception { - testSelectedPlans( true , false ); + @ParameterizedTest + @MethodSource("arguments") + void testSelectedPlansBlocking(Fixture fixture) throws Exception { + testSelectedPlans( fixture, true , false ); } /** * Check that plans are not removed from the plans DB in the selection process, * particularly when pruning unplausible plans. */ - @Test - void testNoSideEffects() throws Exception { + @ParameterizedTest + @MethodSource("arguments") + void testNoSideEffects(Fixture fixture) throws Exception { HighestScoreSumSelector selector = new HighestScoreSumSelector( new EmptyIncompatiblePlansIdentifierFactory(), @@ -1282,6 +1273,7 @@ void testNoSideEffects() throws Exception { } private void testSelectedPlans( + Fixture fixture, final boolean blocking, final boolean forbidding) { if ( blocking && forbidding ) throw new UnsupportedOperationException(); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java index 2209f10164b..fc161bc7cef 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/coalitionselector/CoalitionSelectorTest.java @@ -26,15 +26,16 @@ import java.util.HashMap; import java.util.List; import java.util.Map; +import java.util.stream.Stream; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; -import org.matsim.api.core.v01.population.Plan; import org.matsim.core.population.PersonUtils; import org.matsim.core.population.PopulationUtils; import org.matsim.contrib.socnetsim.framework.population.JointPlan; @@ -45,10 +46,7 @@ /** * @author thibautd */ -@RunWith(Parameterized.class) public class CoalitionSelectorTest { - private final FixtureFactory fixtureFactory; - public interface FixtureFactory { public Fixture create(); } @@ -71,13 +69,8 @@ public Fixture( } } - public CoalitionSelectorTest(final FixtureFactory fixture) { - this.fixtureFactory = fixture; - } - - @Parameterized.Parameters - public static Collection fixtures() { - return toArgList( + public static Stream arguments() { + return Stream.of( new FixtureFactory() { @Override public Fixture create() { @@ -200,13 +193,6 @@ public Fixture create() { } - private static Collection toArgList(final FixtureFactory... args) { - final List list = new ArrayList(); - - for ( FixtureFactory arg : args ) list.add( new FixtureFactory[]{ arg } ); - return list; - } - // ///////////////////////////////////////////////////////////////////////// // fixtures management // ///////////////////////////////////////////////////////////////////////// @@ -214,8 +200,9 @@ private static Collection toArgList(final FixtureFactory... ar // ///////////////////////////////////////////////////////////////////////// // Tests // ///////////////////////////////////////////////////////////////////////// - @Test - void testSelectedPlans() { + @ParameterizedTest + @MethodSource("arguments") + void testSelectedPlans(FixtureFactory fixtureFactory) { final Fixture fixture = fixtureFactory.create(); final CoalitionSelector selector = new CoalitionSelector(); diff --git a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java index 89d9446b529..1cb5418e60e 100644 --- a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java +++ b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java @@ -64,7 +64,6 @@ import ch.sbb.matsim.config.SwissRailRaptorConfigGroup; import ch.sbb.matsim.config.SwissRailRaptorConfigGroup.IntermodalAccessEgressParameterSet; -//@RunWith(Parameterized.class) public class PtAlongALine2Test { private static final Logger log = LogManager.getLogger(PtAlongALine2Test.class); diff --git a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java index 64755202e05..0173d5e8552 100644 --- a/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java +++ b/contribs/vsp/src/test/java/playground/vsp/cadyts/marginals/ModalDistanceAndCountsCadytsIT.java @@ -1,8 +1,9 @@ package playground.vsp.cadyts.marginals; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -37,33 +38,19 @@ import jakarta.inject.Inject; import java.util.*; +import java.util.stream.Stream; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertTrue; -@RunWith(Parameterized.class) public class ModalDistanceAndCountsCadytsIT { - - @Parameterized.Parameters(name = "{index}: countsWeight == {0}; modalDistanceWeight == {1};") - public static Collection parameterObjects() { - return Arrays.asList(new Object[][]{ - {150.0, 0.0}, - {0.0, 150.0}, - {150.0, 150.0} - }); + public static Stream arguments() { + return Stream.of(Arguments.of(0.0, 150.0), Arguments.of(150.0, 0.0), Arguments.of(150.0, 150.0)); } @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - private double countsWeight; - private double modalDistanceWeight; - - public ModalDistanceAndCountsCadytsIT(double countsWeight, double modalDistanceWeight) { - this.modalDistanceWeight = modalDistanceWeight; - this.countsWeight = countsWeight; - } - private static DistanceDistribution createDistanceDistribution() { DistanceDistribution result = new DistanceDistribution(); @@ -252,8 +239,9 @@ private static Plan createPlan(String mode, String endLink, Network network, Pop * One with mode car and one with mode bike. The selected plan is the car plan. Now, the desired distance distribution * is set to have an equal share of car and bike users. The accepted error in the test is 5%, due to stochastic fuzziness */ - @Test - void test() { + @ParameterizedTest + @MethodSource("arguments") + void test(double countsWeight, double modalDistanceWeight) { Config config = createConfig(); CadytsConfigGroup cadytsConfigGroup = new CadytsConfigGroup(); @@ -342,16 +330,16 @@ public ScoringFunction createNewScoringFunction(Person person) { modalDistanceCount.merge(mode + "_" + distance, 1, Integer::sum); } - if (this.modalDistanceWeight > 0 && this.countsWeight == 0) { + if (modalDistanceWeight > 0 && countsWeight == 0) { // don't know how to get a better accuracy than 8% assertEquals(100, modalDistanceCount.get("car_2050.0"), 80); assertEquals(100, modalDistanceCount.get("car_2150.0"), 80); assertEquals(400, modalDistanceCount.get("bike_2050.0"), 80); assertEquals(400, modalDistanceCount.get("bike_2150.0"), 80); - } else if (this.modalDistanceWeight == 0 && this.countsWeight > 0) { + } else if (modalDistanceWeight == 0 && countsWeight > 0) { assertTrue(modalDistanceCount.get("car_2250.0") > 500, "expected more than 500 car trips on the long route but the number of trips was " + modalDistanceCount.get("car_2250.0")); // don't know. one would assume a stronger impact when only running the cadyts count correction but there isn't - } else if (this.modalDistanceWeight > 0 && this.countsWeight > 0) { + } else if (modalDistanceWeight > 0 && countsWeight > 0) { /* This assumes that counts have a higher impact than distance distributions * (because counts request 1000 on car_2250 and the distance distribution requests 100 on car_2050 and car_2150 but 0 on car_2250). * Probably this should rather depend on the weight that is set for counts and distance distributions... diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java index 88478e19bb8..ff8e7c8ca99 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java @@ -36,9 +36,8 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -75,25 +74,11 @@ import com.google.inject.Provider; -@RunWith(Parameterized.class) public class ControlerIT { private final static Logger log = LogManager.getLogger(ControlerIT.class); @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - private final boolean isUsingFastCapacityUpdate; - - public ControlerIT(boolean isUsingFastCapacityUpdate) { - this.isUsingFastCapacityUpdate = isUsingFastCapacityUpdate; - } - - @Parameters(name = "{index}: isUsingfastCapacityUpdate == {0}") - public static Collection parameterObjects () { - Object [] capacityUpdates = new Object [] { false, true }; - return Arrays.asList(capacityUpdates); - // yyyy I am not sure why it is doing this ... it is necessary to do this around the qsim, but why here? kai, aug'16 - } - @Test void testScenarioLoading() { final Config config = utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); @@ -155,8 +140,9 @@ void testConstructor_EventsManagerTypeImmutable() { * * @author mrieser */ - @Test - void testTravelTimeCalculation() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testTravelTimeCalculation(boolean isUsingFastCapacityUpdate) { Fixture f = new Fixture(ConfigUtils.createConfig()); Config config = f.scenario.getConfig(); @@ -213,7 +199,7 @@ void testTravelTimeCalculation() { // - make sure we don't use threads, as they are not deterministic config.global().setNumberOfThreads(0); - config.qsim().setUsingFastCapacityUpdate(this.isUsingFastCapacityUpdate); + config.qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); // Now run the simulation Controler controler = new Controler(f.scenario); @@ -248,12 +234,13 @@ void testTravelTimeCalculation() { * * @author mrieser */ - @Test - void testSetScoringFunctionFactory() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testSetScoringFunctionFactory(boolean isUsingFastCapacityUpdate) { final Config config = this.utils.loadConfig((String) null); config.controller().setLastIteration(0); - config.qsim().setUsingFastCapacityUpdate( this.isUsingFastCapacityUpdate ); + config.qsim().setUsingFastCapacityUpdate( isUsingFastCapacityUpdate ); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); // create a very simple network with one link only and an empty population @@ -296,8 +283,9 @@ public Mobsim get() { * * @author mrieser */ - @Test - void testCalcMissingRoutes() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testCalcMissingRoutes(boolean isUsingFastCapacityUpdate) { Config config = this.utils.loadConfig((String) null); Fixture f = new Fixture(config); @@ -343,7 +331,7 @@ void testCalcMissingRoutes() { // - make sure we don't use threads, as they are not deterministic config.global().setNumberOfThreads(1); - config.qsim().setUsingFastCapacityUpdate( this.isUsingFastCapacityUpdate ); + config.qsim().setUsingFastCapacityUpdate( isUsingFastCapacityUpdate ); // Now run the simulation Controler controler = new Controler(f.scenario); @@ -385,8 +373,9 @@ public Mobsim get() { * * @author mrieser */ - @Test - void testCalcMissingActLinks() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testCalcMissingActLinks(boolean isUsingFastCapacityUpdate) { Config config = this.utils.loadConfig((String) null); Fixture f = new Fixture(config); @@ -441,7 +430,7 @@ void testCalcMissingActLinks() { // - make sure we don't use threads, as they are not deterministic config.global().setNumberOfThreads(1); - config.qsim().setUsingFastCapacityUpdate( this.isUsingFastCapacityUpdate ); + config.qsim().setUsingFastCapacityUpdate( isUsingFastCapacityUpdate ); // Now run the simulation Controler controler = new Controler(f.scenario); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java index 69c49091a42..5fba7f1c420 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/hermes/HermesTransitTest.java @@ -3,9 +3,9 @@ import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.MethodSource; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -67,22 +67,8 @@ * * @author mrieser / Simunto */ -@RunWith(Parameterized.class) public class HermesTransitTest { - private final boolean isDeterministic; - - public HermesTransitTest(boolean isDeterministic) { - this.isDeterministic = isDeterministic; - } - - @Parameters(name = "{index}: isDeterministic == {0}") - public static Collection parameterObjects () { - Object[] states = new Object[] { false, true }; - return Arrays.asList(states); - } - - protected static Hermes createHermes(MutableScenario scenario, EventsManager events) { PrepareForSimUtils.createDefaultPrepareForSim(scenario).run(); return new HermesBuilder().build(scenario, events); @@ -113,11 +99,12 @@ public void prepareTest() { /** * Makes sure Hermes works also when not all stop facilities are used by transit lines. */ - @Test - void testSuperflousStopFacilities() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testSuperflousStopFacilities(boolean isDeterministic) { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); - f.config.hermes().setDeterministicPt(this.isDeterministic); + f.config.hermes().setDeterministicPt(isDeterministic); Vehicles ptVehicles = f.scenario.getTransitVehicles(); @@ -198,11 +185,12 @@ void testSuperflousStopFacilities() { /** * Makes sure Hermes works also when transit routes in different lines have the same Id */ - @Test - void testRepeatedRouteIds() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testRepeatedRouteIds(boolean isDeterministic) { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); - f.config.hermes().setDeterministicPt(this.isDeterministic); + f.config.hermes().setDeterministicPt(isDeterministic); Vehicles ptVehicles = f.scenario.getTransitVehicles(); @@ -300,11 +288,12 @@ void testRepeatedRouteIds() { * Makes sure Hermes works with TransitRoutes where two successive stops are on the same link. * Originally, this resulted in wrong events because there was an exception that there is at most one stop per link. */ - @Test - void testConsecutiveStopsWithSameLink_1() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testConsecutiveStopsWithSameLink_1(boolean isDeterministic) { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); - f.config.hermes().setDeterministicPt(this.isDeterministic); + f.config.hermes().setDeterministicPt(isDeterministic); Vehicles ptVehicles = f.scenario.getTransitVehicles(); @@ -393,11 +382,12 @@ void testConsecutiveStopsWithSameLink_1() { * Originally, this resulted in problems as the distance between the stops was 0 meters, given they are on the same link, * and this 0 meters than resulted in infinite values somewhere later on. */ - @Test - void testConsecutiveStopsWithSameLink_2() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testConsecutiveStopsWithSameLink_2(boolean isDeterministic) { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); - f.config.hermes().setDeterministicPt(this.isDeterministic); + f.config.hermes().setDeterministicPt(isDeterministic); Vehicles ptVehicles = f.scenario.getTransitVehicles(); @@ -486,12 +476,13 @@ void testConsecutiveStopsWithSameLink_2() { /** * Makes sure Hermes does not produce exceptions when the configured end time is before the latest transit event */ - @Test - void testEarlyEnd() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testEarlyEnd(boolean isDeterministic) { double baseTime = 30 * 3600 - 10; // HERMES has a default of 30:00:00 as end time, so let's start later Fixture f = new Fixture(); f.config.transit().setUseTransit(true); - f.config.hermes().setDeterministicPt(this.isDeterministic); + f.config.hermes().setDeterministicPt(isDeterministic); Vehicles ptVehicles = f.scenario.getTransitVehicles(); @@ -557,11 +548,12 @@ void testEarlyEnd() { /** * Makes sure Hermes correctly handles strange transit routes with some links before the first stop is served. */ - @Test - void testLinksAtRouteStart() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testLinksAtRouteStart(boolean isDeterministic) { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); - f.config.hermes().setDeterministicPt(this.isDeterministic); + f.config.hermes().setDeterministicPt(isDeterministic); Vehicles ptVehicles = f.scenario.getTransitVehicles(); @@ -627,11 +619,12 @@ void testLinksAtRouteStart() { /** * In some cases, the time information of linkEnter/linkLeave events was wrong. */ - @Test - void testDeterministicCorrectTiming() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testDeterministicCorrectTiming(boolean isDeterministic) { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); - f.config.hermes().setDeterministicPt(this.isDeterministic); + f.config.hermes().setDeterministicPt(isDeterministic); Vehicles ptVehicles = f.scenario.getTransitVehicles(); @@ -716,47 +709,48 @@ void testDeterministicCorrectTiming() { Assertions.assertEquals(3, arrivesAtFacilityEvents.size(), "wrong number of VehicleArrivesAtFacilityEvents."); Assertions.assertEquals(3, departsAtFacilityEvents.size(), "wrong number of VehicleDepartsAtFacilityEvents."); - if (this.isDeterministic) Assertions.assertEquals(997.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(997.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); - if (this.isDeterministic) Assertions.assertEquals(998.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(998.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(stop1.getId(), arrivesAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1000.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1000.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(stop1.getId(), departsAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(f.link1.getId(), linkLeaveEvents.get(0).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(f.link2.getId(), linkEnterEvents.get(0).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1251.0, linkLeaveEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1251.0, linkLeaveEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(f.link2.getId(), linkLeaveEvents.get(1).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1251.0, linkEnterEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1251.0, linkEnterEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(f.link3.getId(), linkEnterEvents.get(1).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1298.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1298.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(stop2.getId(), arrivesAtFacilityEvents.get(1).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1300.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1300.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(stop2.getId(), departsAtFacilityEvents.get(1).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1598.0, arrivesAtFacilityEvents.get(2).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1598.0, arrivesAtFacilityEvents.get(2).getTime(), 1e-8); Assertions.assertEquals(stop3.getId(), arrivesAtFacilityEvents.get(2).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1600.0, departsAtFacilityEvents.get(2).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1600.0, departsAtFacilityEvents.get(2).getTime(), 1e-8); Assertions.assertEquals(stop3.getId(), departsAtFacilityEvents.get(2).getFacilityId()); } /** * Tests that event times are correct when a transit route starts with some links before arriving at the first stop. */ - @Test - void testDeterministicCorrectTiming_initialLinks() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testDeterministicCorrectTiming_initialLinks(boolean isDeterministic) { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); - f.config.hermes().setDeterministicPt(this.isDeterministic); + f.config.hermes().setDeterministicPt(isDeterministic); Vehicles ptVehicles = f.scenario.getTransitVehicles(); @@ -843,39 +837,40 @@ void testDeterministicCorrectTiming_initialLinks() { Assertions.assertEquals(1000.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); - if (this.isDeterministic) Assertions.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(f.link1.getId(), linkLeaveEvents.get(0).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(f.link2.getId(), linkEnterEvents.get(0).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1058.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1058.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(stop2.getId(), arrivesAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1060.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1060.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(stop2.getId(), departsAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1061.0, linkLeaveEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1061.0, linkLeaveEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(f.link2.getId(), linkLeaveEvents.get(1).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1061.0, linkEnterEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1061.0, linkEnterEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(f.link3.getId(), linkEnterEvents.get(1).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1598.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1598.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(stop3.getId(), arrivesAtFacilityEvents.get(1).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1600.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1600.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(stop3.getId(), departsAtFacilityEvents.get(1).getFacilityId()); } /** * Tests that everything is correct when a transit route ends with some links after arriving at the last stop. */ - @Test - void testTrailingLinksInRoute() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testTrailingLinksInRoute(boolean isDeterministic) { Fixture f = new Fixture(); f.config.transit().setUseTransit(true); - f.config.hermes().setDeterministicPt(this.isDeterministic); + f.config.hermes().setDeterministicPt(isDeterministic); Vehicles ptVehicles = f.scenario.getTransitVehicles(); @@ -962,37 +957,37 @@ void testTrailingLinksInRoute() { Assertions.assertEquals(2, departsAtFacilityEvents.size(), "wrong number of VehicleDepartsAtFacilityEvents."); Assertions.assertEquals(2, personLeavesVehicleEvents.size(), "wrong number of PersonLeavesVehicleEvents."); - if (this.isDeterministic) Assertions.assertEquals(997.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(997.0, transitDriverStartsEvents.get(0).getTime(), 1e-8); Id transitDriverId = transitDriverStartsEvents.get(0).getDriverId(); - if (this.isDeterministic) Assertions.assertEquals(998.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(998.0, arrivesAtFacilityEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(stop1.getId(), arrivesAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1000.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1000.0, departsAtFacilityEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(stop1.getId(), departsAtFacilityEvents.get(0).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1001.0, linkLeaveEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(f.link1.getId(), linkLeaveEvents.get(0).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1001.0, linkEnterEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(f.link2.getId(), linkEnterEvents.get(0).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1298.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1298.0, arrivesAtFacilityEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(stop2.getId(), arrivesAtFacilityEvents.get(1).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1299.0, personLeavesVehicleEvents.get(0).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1299.0, personLeavesVehicleEvents.get(0).getTime(), 1e-8); Assertions.assertEquals(person.getId(), personLeavesVehicleEvents.get(0).getPersonId()); - if (this.isDeterministic) Assertions.assertEquals(1300.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1300.0, departsAtFacilityEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(stop2.getId(), departsAtFacilityEvents.get(1).getFacilityId()); - if (this.isDeterministic) Assertions.assertEquals(1301.0, linkLeaveEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1301.0, linkLeaveEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(f.link2.getId(), linkLeaveEvents.get(1).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1301.0, linkEnterEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1301.0, linkEnterEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(f.link3.getId(), linkEnterEvents.get(1).getLinkId()); - if (this.isDeterministic) Assertions.assertEquals(1312.0, personLeavesVehicleEvents.get(1).getTime(), 1e-8); + if (isDeterministic) Assertions.assertEquals(1312.0, personLeavesVehicleEvents.get(1).getTime(), 1e-8); Assertions.assertEquals(transitDriverId, personLeavesVehicleEvents.get(1).getPersonId()); } diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java index 7577f729919..a46bea6bb90 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/FlowStorageSpillbackTest.java @@ -27,9 +27,8 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -59,24 +58,11 @@ * @author ikaddoura * */ -@RunWith(Parameterized.class) public class FlowStorageSpillbackTest { @RegisterExtension private MatsimTestUtils testUtils = new MatsimTestUtils(); - private final boolean isUsingFastCapacityUpdate; - - public FlowStorageSpillbackTest(boolean isUsingFastCapacityUpdate) { - this.isUsingFastCapacityUpdate = isUsingFastCapacityUpdate; - } - - @Parameters(name = "{index}: isUsingfastCapacityUpdate == {0}") - public static Collection parameterObjects () { - Object [] capacityUpdates = new Object [] { false, true }; - return Arrays.asList(capacityUpdates); - } - private EventsManager events; private Id testAgent1 = Id.create("testAgent1", Person.class); @@ -89,13 +75,14 @@ public static Collection parameterObjects () { private Id linkId3 = Id.create("link3", Link.class); private Id linkId4 = Id.create("link4", Link.class); - @Test - final void testFlowCongestion(){ + @ParameterizedTest + @ValueSource(booleans = {false, true}) + final void testFlowCongestion(boolean isUsingFastCapacityUpdate){ Scenario sc = loadScenario(); setPopulation(sc); - sc.getConfig().qsim().setUsingFastCapacityUpdate(this.isUsingFastCapacityUpdate); + sc.getConfig().qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); final List linkLeaveEvents = new ArrayList(); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java index ac40a182b9d..b57ed217c3e 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/NodeTransitionTest.java @@ -28,8 +28,9 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.MethodSource; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -72,25 +73,11 @@ * @author tthunig * */ -@RunWith(Parameterized.class) public class NodeTransitionTest { - @Parameterized.Parameters(name = "{index}: useFastCapUpdate == {0};") - public static Collection parameterObjects() { - return Arrays.asList(new Object[][]{ - {true}, - {false} - }); - } - - private boolean useFastCapUpdate; - - public NodeTransitionTest(boolean useFastCapUpdate) { - this.useFastCapUpdate = useFastCapUpdate; - } - - @Test - void testMergeSituationWithEmptyBufferAfterBufferRandomDistribution() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testMergeSituationWithEmptyBufferAfterBufferRandomDistribution(boolean useFastCapUpdate) { Scenario scenario = Fixture.createMergeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.emptyBufferAfterBufferRandomDistribution_dontBlockNode); scenario.getConfig().qsim().setUsingFastCapacityUpdate(useFastCapUpdate); @@ -157,8 +144,9 @@ void testMergeSituationWithEmptyBufferAfterBufferRandomDistribution() { Assertions.assertEquals(9./10, avgThroughputCongestedThreeLinks.get(Id.createLinkId("6_7")), delta, "Troughput on link 6_7 is wrong"); // 0.9285714285714286 } - @Test - void testMergeSituationWithMoveVehByVehRandomDistribution() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testMergeSituationWithMoveVehByVehRandomDistribution(boolean useFastCapUpdate) { Scenario scenario = Fixture.createMergeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.moveVehByVehRandomDistribution_dontBlockNode); scenario.getConfig().qsim().setUsingFastCapacityUpdate(useFastCapUpdate); @@ -232,8 +220,9 @@ void testMergeSituationWithMoveVehByVehRandomDistribution() { Assertions.assertEquals(41./50, avgThroughputCongestedThreeLinks.get(Id.createLinkId("6_7")), delta, "Troughput on link 6_7 is wrong"); // 0.8571428571428571 } - @Test - void testMergeSituationWithMoveVehByVehDeterministicPriorities() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testMergeSituationWithMoveVehByVehDeterministicPriorities(boolean useFastCapUpdate) { Scenario scenario = Fixture.createMergeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.moveVehByVehDeterministicPriorities_nodeBlockedWhenSingleOutlinkFull); // note: the deterministic node transition is only implemented for the case when the node is blocked as soon as one outgoing link is full @@ -301,8 +290,9 @@ void testMergeSituationWithMoveVehByVehDeterministicPriorities() { Assertions.assertEquals(2./5 * 2, avgThroughputCongestedThreeLinks.get(Id.createLinkId("6_7")), delta, "Troughput on link 6_7 is wrong"); // 0.8 } - @Test - void testBlockedNodeSituationWithEmptyBufferAfterBufferRandomDistribution() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testBlockedNodeSituationWithEmptyBufferAfterBufferRandomDistribution(boolean useFastCapUpdate) { Scenario scenario = Fixture.createBlockedNodeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.emptyBufferAfterBufferRandomDistribution_nodeBlockedWhenSingleOutlinkFull); scenario.getConfig().qsim().setUsingFastCapacityUpdate(useFastCapUpdate); @@ -382,8 +372,9 @@ void testBlockedNodeSituationWithEmptyBufferAfterBufferRandomDistribution() { Assertions.assertEquals(1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON, "Troughput on link 5_8 is wrong"); } - @Test - void testBlockedNodeSituationWithMoveVehByVehRandomDistribution() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testBlockedNodeSituationWithMoveVehByVehRandomDistribution(boolean useFastCapUpdate) { Scenario scenario = Fixture.createBlockedNodeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.moveVehByVehRandomDistribution_nodeBlockedWhenSingleOutlinkFull); scenario.getConfig().qsim().setUsingFastCapacityUpdate(useFastCapUpdate); @@ -464,8 +455,9 @@ void testBlockedNodeSituationWithMoveVehByVehRandomDistribution() { Assertions.assertEquals(1, avgThroughputCongestedRestrictFlow.get(Id.createLinkId("5_8")), MatsimTestUtils.EPSILON, "Troughput on link 5_8 is wrong"); } - @Test - void testBlockedNodeSituationWithMoveVehByVehDeterministicPriorities() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testBlockedNodeSituationWithMoveVehByVehDeterministicPriorities(boolean useFastCapUpdate) { Scenario scenario = Fixture.createBlockedNodeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.moveVehByVehDeterministicPriorities_nodeBlockedWhenSingleOutlinkFull); scenario.getConfig().qsim().setUsingFastCapacityUpdate(useFastCapUpdate); @@ -553,8 +545,9 @@ void testBlockedNodeSituationWithMoveVehByVehDeterministicPriorities() { * 2. correct storage capacity bounds for a time bin size smaller than 1 (see e.g. former bug in QueueWithBuffer calculateStorageCapacity); * 3. both streams are independently (because blockNode=false). */ - @Test - void testNodeTransitionWithTimeStepSizeSmallerOne() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testNodeTransitionWithTimeStepSizeSmallerOne(boolean useFastCapUpdate) { Scenario scenario = Fixture.createBlockedNodeScenario(); scenario.getConfig().qsim().setNodeTransitionLogic(NodeTransition.emptyBufferAfterBufferRandomDistribution_dontBlockNode); scenario.getConfig().qsim().setTimeStepSize(0.5); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java index fcded837c33..e33947ee22f 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/QSimTest.java @@ -21,19 +21,18 @@ package org.matsim.core.mobsim.qsim; import java.util.ArrayList; -import java.util.Arrays; import java.util.Collection; import java.util.Collections; import java.util.List; +import java.util.stream.Stream; import org.apache.logging.log4j.Level; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.Assertions; -import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.analysis.VolumesAnalyzer; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -95,28 +94,16 @@ import org.matsim.vehicles.VehicleType; import org.matsim.vehicles.VehicleUtils; -@RunWith(Parameterized.class) public class QSimTest { private final static Logger log = LogManager.getLogger(QSimTest.class); - private final boolean isUsingFastCapacityUpdate; - private final int numberOfThreads; - - public QSimTest(boolean isUsingFastCapacityUpdate, int numberOfThreads) { - this.isUsingFastCapacityUpdate = isUsingFastCapacityUpdate; - this.numberOfThreads = numberOfThreads; - } -// - @Parameters(name = "{index}: isUsingfastCapacityUpdate == {0}; numberOfThreads == {1};") - public static Collection parameterObjects () { - Object[][] capacityUpdates = new Object [][] { - new Object[] {true, 1}, - new Object[] {false, 1}, - new Object[] {true, 2}, - new Object[] {false, 2} - }; - return Arrays.asList(capacityUpdates); + public static Stream arguments () { + return Stream.of( + Arguments.of(true, 1), + Arguments.of(false, 1), + Arguments.of(true, 2), + Arguments.of(false, 2)); } private static QSim createQSim(MutableScenario scenario, EventsManager events) { @@ -143,8 +130,9 @@ private static QSim createQSim(Fixture f, EventsManager events) { * * @author mrieser */ - @Test - void testSingleAgent() { + @ParameterizedTest + @MethodSource("arguments") + void testSingleAgent(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a single person with leg from link1 to link3 @@ -183,8 +171,9 @@ void testSingleAgent() { * @author mrieser * @author Kai Nagel */ - @Test - void testSingleAgentWithEndOnLeg() { + @ParameterizedTest + @MethodSource("arguments") + void testSingleAgentWithEndOnLeg(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a single person with leg from link1 to link3 @@ -249,8 +238,9 @@ void testSingleAgentWithEndOnLeg() { * * @author mrieser */ - @Test - void testTwoAgent() { + @ParameterizedTest + @MethodSource("arguments") + void testTwoAgent(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add two persons with leg from link1 to link3, the first starting at 6am, the second at 7am @@ -290,8 +280,9 @@ void testTwoAgent() { * * @author mrieser */ - @Test - void testTeleportationSingleAgent() { + @ParameterizedTest + @MethodSource("arguments") + void testTeleportationSingleAgent(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a single person with leg from link1 to link3 @@ -337,8 +328,9 @@ void testTeleportationSingleAgent() { * * @author cdobler */ - @Test - void testSingleAgentImmediateDeparture() { + @ParameterizedTest + @MethodSource("arguments") + void testSingleAgentImmediateDeparture(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a single person with leg from link1 to link3 @@ -382,8 +374,9 @@ void testSingleAgentImmediateDeparture() { * * @author mrieser */ - @Test - void testSingleAgent_EmptyRoute() { + @ParameterizedTest + @MethodSource("arguments") + void testSingleAgent_EmptyRoute(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a single person with leg from link1 to link1 @@ -459,8 +452,9 @@ void testSingleAgent_EmptyRoute() { * * @author mrieser */ - @Test - void testSingleAgent_LastLinkIsLoop() { + @ParameterizedTest + @MethodSource("arguments") + void testSingleAgent_LastLinkIsLoop(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Link loopLink = NetworkUtils.createAndAddLink(f.network,Id.create("loop", Link.class), f.node4, f.node4, 100.0, 10.0, 500, 1 ); @@ -529,8 +523,9 @@ public void reset(final int iteration) { * * @author mrieser */ - @Test - void testAgentWithoutLeg() { + @ParameterizedTest + @MethodSource("arguments") + void testAgentWithoutLeg(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -556,8 +551,9 @@ void testAgentWithoutLeg() { * * @author mrieser */ - @Test - void testAgentWithoutLegWithEndtime() { + @ParameterizedTest + @MethodSource("arguments") + void testAgentWithoutLegWithEndtime(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -584,8 +580,9 @@ void testAgentWithoutLegWithEndtime() { * * @author mrieser */ - @Test - void testAgentWithLastActWithEndtime() { + @ParameterizedTest + @MethodSource("arguments") + void testAgentWithLastActWithEndtime(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -619,8 +616,9 @@ void testAgentWithLastActWithEndtime() { * * @author mrieser */ - @Test - void testFlowCapacityDriving() { + @ParameterizedTest + @MethodSource("arguments") + void testFlowCapacityDriving(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a lot of persons with legs from link1 to link3, starting at 6:30 @@ -684,8 +682,9 @@ void testFlowCapacityDriving() { * * @author michaz */ - @Test - void testFlowCapacityDrivingFraction() { + @ParameterizedTest + @MethodSource("arguments") + void testFlowCapacityDrivingFraction(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.link2.setCapacity(900.0); // One vehicle every 4 seconds @@ -739,8 +738,9 @@ void testFlowCapacityDrivingFraction() { * * @author mrieser */ - @Test - void testFlowCapacityStarting() { + @ParameterizedTest + @MethodSource("arguments") + void testFlowCapacityStarting(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a lot of persons with legs from link2 to link3 @@ -794,8 +794,9 @@ void testFlowCapacityStarting() { * * @author mrieser */ - @Test - void testFlowCapacityMixed() { + @ParameterizedTest + @MethodSource("arguments") + void testFlowCapacityMixed(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); // add a lot of persons with legs from link2 to link3 @@ -862,8 +863,9 @@ void testFlowCapacityMixed() { * * @author mrieser */ - @Test - void testVehicleTeleportationTrue() { + @ParameterizedTest + @MethodSource("arguments") + void testVehicleTeleportationTrue(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); Plan plan = PersonUtils.createAndAddPlan(person, true); @@ -917,8 +919,9 @@ void testVehicleTeleportationTrue() { * * @author michaz */ - @Test - void testWaitingForCar() { + @ParameterizedTest + @MethodSource("arguments") + void testWaitingForCar(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.scenario.getConfig().qsim().setVehicleBehavior(QSimConfigGroup.VehicleBehavior.wait); f.scenario.getConfig().qsim().setEndTime(24.0 * 60.0 * 60.0); @@ -1012,8 +1015,9 @@ void testWaitingForCar() { * * @author mrieser */ - @Test - void testVehicleTeleportationFalse() { + @ParameterizedTest + @MethodSource("arguments") + void testVehicleTeleportationFalse(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.scenario.getConfig().qsim().setVehicleBehavior(QSimConfigGroup.VehicleBehavior.exception); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); @@ -1065,8 +1069,9 @@ void testVehicleTeleportationFalse() { * * @author mrieser */ - @Test - void testAssignedVehicles() { + @ParameterizedTest + @MethodSource("arguments") + void testAssignedVehicles(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Person person = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); // do not add person to population, we'll do it ourselves for the test Plan plan = PersonUtils.createAndAddPlan(person, true); @@ -1121,8 +1126,9 @@ void testAssignedVehicles() { * * @author mrieser */ - @Test - void testCircleAsRoute() { + @ParameterizedTest + @MethodSource("arguments") + void testCircleAsRoute(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Link link4 = NetworkUtils.createAndAddLink(f.network,Id.create(4, Link.class), f.node4, f.node1, 1000.0, 100.0, 6000, 1.0 ); // close the network @@ -1179,8 +1185,9 @@ void testCircleAsRoute() { * * @author mrieser */ - @Test - void testRouteWithEndLinkTwice() { + @ParameterizedTest + @MethodSource("arguments") + void testRouteWithEndLinkTwice(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); Link link4 = NetworkUtils.createAndAddLink(f.network,Id.create(4, Link.class), f.node4, f.node1, 1000.0, 100.0, 6000, 1.0 ); // close the network @@ -1240,12 +1247,13 @@ void testRouteWithEndLinkTwice() { * * @author mrieser */ - @Test - void testConsistentRoutes_WrongRoute() { + @ParameterizedTest + @MethodSource("arguments") + void testConsistentRoutes_WrongRoute(boolean isUsingFastCapacityUpdate, int numberOfThreads) { EventsManager events = EventsUtils.createEventsManager(); EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); - LogCounter logger = runConsistentRoutesTestSim("1", "2 3", "5", events); // route should continue on link 4 + LogCounter logger = runConsistentRoutesTestSim("1", "2 3", "5", events, isUsingFastCapacityUpdate, numberOfThreads); // route should continue on link 4 Assertions.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there Assertions.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning } @@ -1256,12 +1264,13 @@ void testConsistentRoutes_WrongRoute() { * * @author mrieser */ - @Test - void testConsistentRoutes_WrongStartLink() { + @ParameterizedTest + @MethodSource("arguments") + void testConsistentRoutes_WrongStartLink(boolean isUsingFastCapacityUpdate, int numberOfThreads) { EventsManager events = EventsUtils.createEventsManager(); EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); - LogCounter logger = runConsistentRoutesTestSim("2", "3 4", "5", events); // first act is on link 1, not 2 + LogCounter logger = runConsistentRoutesTestSim("2", "3 4", "5", events, isUsingFastCapacityUpdate, numberOfThreads); // first act is on link 1, not 2 Assertions.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there Assertions.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning } @@ -1272,12 +1281,13 @@ void testConsistentRoutes_WrongStartLink() { * * @author mrieser */ - @Test - void testConsistentRoutes_WrongEndLink() { + @ParameterizedTest + @MethodSource("arguments") + void testConsistentRoutes_WrongEndLink(boolean isUsingFastCapacityUpdate, int numberOfThreads) { EventsManager events = EventsUtils.createEventsManager(); EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); - LogCounter logger = runConsistentRoutesTestSim("1", "2 3", "4", events); // second act is on link 5, not 4 + LogCounter logger = runConsistentRoutesTestSim("1", "2 3", "4", events, isUsingFastCapacityUpdate, numberOfThreads); // second act is on link 5, not 4 Assertions.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there Assertions.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning } @@ -1289,12 +1299,13 @@ void testConsistentRoutes_WrongEndLink() { * * @author mrieser */ - @Test - void testConsistentRoutes_ImpossibleRoute() { + @ParameterizedTest + @MethodSource("arguments") + void testConsistentRoutes_ImpossibleRoute(boolean isUsingFastCapacityUpdate, int numberOfThreads) { EventsManager events = EventsUtils.createEventsManager(); EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); - LogCounter logger = runConsistentRoutesTestSim("1", "2 4", "5", events); // link 3 is missing + LogCounter logger = runConsistentRoutesTestSim("1", "2 4", "5", events,isUsingFastCapacityUpdate, numberOfThreads); // link 3 is missing Assertions.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there Assertions.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning } @@ -1305,29 +1316,32 @@ void testConsistentRoutes_ImpossibleRoute() { * * @author mrieser */ - @Test - void testConsistentRoutes_MissingRoute() { + @ParameterizedTest + @MethodSource("arguments") + void testConsistentRoutes_MissingRoute(boolean isUsingFastCapacityUpdate, int numberOfThreads) { EventsManager events = EventsUtils.createEventsManager(); EnterLinkEventCounter counter = new EnterLinkEventCounter("6"); events.addHandler(counter); - LogCounter logger = runConsistentRoutesTestSim("1", "", "5", events); // no links at all + LogCounter logger = runConsistentRoutesTestSim("1", "", "5", events, isUsingFastCapacityUpdate, numberOfThreads); // no links at all Assertions.assertEquals(0, counter.getCounter()); // the agent should have been removed from the sim, so nobody travels there Assertions.assertTrue((logger.getWarnCount() + logger.getErrorCount()) > 0); // there should have been at least a warning } - /** Prepares miscellaneous data for the testConsistentRoutes() tests: + /** + * Prepares miscellaneous data for the testConsistentRoutes() tests: * Creates a network of 6 links, and a population of one person driving from * link 1 to link 5, and then from link 5 to link 6. * - * @param startLinkId the start link of the route for the first leg - * @param linkIds the links the agent should travel along on the first leg - * @param endLinkId the end link of the route for the first leg - * @param events the Events object to be used by the simulation. + * @param startLinkId the start link of the route for the first leg + * @param linkIds the links the agent should travel along on the first leg + * @param endLinkId the end link of the route for the first leg + * @param events the Events object to be used by the simulation. + * @param isUsingFastCapacityUpdate + * @param numberOfThreads * @return A QueueSimulation which can be started immediately. - * * @author mrieser **/ - private LogCounter runConsistentRoutesTestSim(final String startLinkId, final String linkIds, final String endLinkId, final EventsManager events) { + private LogCounter runConsistentRoutesTestSim(final String startLinkId, final String linkIds, final String endLinkId, final EventsManager events, boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); /* enhance network */ @@ -1374,8 +1388,9 @@ private LogCounter runConsistentRoutesTestSim(final String startLinkId, final St return logger; } - @Test - void testStartAndEndTime() { + @ParameterizedTest + @MethodSource("arguments") + void testStartAndEndTime(boolean isUsingFastCapacityUpdate, int numberOfThreads) { final Config config = ConfigUtils.createConfig(); config.qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); @@ -1440,8 +1455,9 @@ void testStartAndEndTime() { * * @author mrieser */ - @Test - void testCleanupSim_EarlyEnd() { + @ParameterizedTest + @MethodSource("arguments") + void testCleanupSim_EarlyEnd(boolean isUsingFastCapacityUpdate, int numberOfThreads) { MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(ConfigUtils.createConfig()); Config config = scenario.getConfig(); @@ -1538,8 +1554,9 @@ void testCleanupSim_EarlyEnd() { * * @author ikaddoura based on mrieser */ - @Test - void testFlowCapacityDrivingKinematicWavesWithFlowReductionCorrectionBehavior() { + @ParameterizedTest + @MethodSource("arguments") + void testFlowCapacityDrivingKinematicWavesWithFlowReductionCorrectionBehavior(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.config.qsim().setTrafficDynamics(TrafficDynamics.kinematicWaves); f.config.qsim().setInflowCapacitySetting(QSimConfigGroup.InflowCapacitySetting.INFLOW_FROM_FDIAG); @@ -1598,8 +1615,9 @@ void testFlowCapacityDrivingKinematicWavesWithFlowReductionCorrectionBehavior() * * @author ikaddoura based on mrieser */ - @Test - void testFlowCapacityDrivingKinematicWavesWithLaneIncreaseCorrectionBehavior() { + @ParameterizedTest + @MethodSource("arguments") + void testFlowCapacityDrivingKinematicWavesWithLaneIncreaseCorrectionBehavior(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.config.qsim().setTrafficDynamics(TrafficDynamics.kinematicWaves); f.config.qsim().setInflowCapacitySetting(QSimConfigGroup.InflowCapacitySetting.NR_OF_LANES_FROM_FDIAG); @@ -1658,8 +1676,9 @@ void testFlowCapacityDrivingKinematicWavesWithLaneIncreaseCorrectionBehavior() { * * @author tschlenther based on ikaddoura based on mrieser */ - @Test - void testFlowCapacityDrivingKinematicWavesWithInflowEqualToMaxCapForOneLane() { + @ParameterizedTest + @MethodSource("arguments") + void testFlowCapacityDrivingKinematicWavesWithInflowEqualToMaxCapForOneLane(boolean isUsingFastCapacityUpdate, int numberOfThreads) { Fixture f = new Fixture(isUsingFastCapacityUpdate, numberOfThreads); f.config.qsim().setTrafficDynamics(TrafficDynamics.kinematicWaves); f.config.qsim().setInflowCapacitySetting(QSimConfigGroup.InflowCapacitySetting.MAX_CAP_FOR_ONE_LANE); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java index f91acc6e562..ac787bb7de9 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/VehicleSourceTest.java @@ -21,9 +21,9 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -54,6 +54,7 @@ import org.matsim.vehicles.VehiclesFactory; import java.util.*; +import java.util.stream.Stream; /** * A test to check the functionality of the VehicleSource. @@ -61,42 +62,20 @@ * @author amit */ -@RunWith(Parameterized.class) public class VehicleSourceTest { - - private final VehiclesSource vehiclesSource; - private final boolean usingPersonIdForMissingVehicleId; - - /** - * testing if there is a meaningful error message if vehicles are _not_ added to person - */ - private final boolean providingVehiclesInPerson ; - - public VehicleSourceTest( VehiclesSource vehiclesSource, boolean usingPersonIdForMissingVehicleId, boolean providingVehiclesInPerson ) { - this.vehiclesSource = vehiclesSource; - this.usingPersonIdForMissingVehicleId = usingPersonIdForMissingVehicleId; - this.providingVehiclesInPerson = providingVehiclesInPerson; - } - - @Parameters(name = "{index}: vehicleSource == {0}; isUsingPersonIdForMissingVehicleId == {1}") - public static Collection parameterObjects () { + public static Stream arguments () { // create the combinations manually, since 'fromVehiclesData' in combination with 'isUsingPersonIdForMissingVehicleId' doesn't make sense - return Arrays.asList( - new Object[]{VehiclesSource.defaultVehicle, true, true}, + return Stream.of(Arguments.of(VehiclesSource.defaultVehicle, true, true), // new Object[]{VehiclesSource.defaultVehicle, true, false}, // not meaningful for defaultVehicle - - new Object[]{VehiclesSource.defaultVehicle, false, true}, + Arguments.of(VehiclesSource.defaultVehicle, false, true), // new Object[]{VehiclesSource.defaultVehicle, false, false}, // not meaningful for defaultVehicle - - new Object[]{VehiclesSource.modeVehicleTypesFromVehiclesData, true, true}, - new Object[]{VehiclesSource.modeVehicleTypesFromVehiclesData, true, false}, - - new Object[]{VehiclesSource.modeVehicleTypesFromVehiclesData, false, true }, - new Object[]{VehiclesSource.modeVehicleTypesFromVehiclesData, false, false }, - - new Object[]{VehiclesSource.fromVehiclesData, false, true }, - new Object[]{VehiclesSource.fromVehiclesData, false, false } + Arguments.of(VehiclesSource.modeVehicleTypesFromVehiclesData, true, true), + Arguments.of(VehiclesSource.modeVehicleTypesFromVehiclesData, true, false), + Arguments.of(VehiclesSource.modeVehicleTypesFromVehiclesData, false, true), + Arguments.of(VehiclesSource.modeVehicleTypesFromVehiclesData, false, false), + Arguments.of(VehiclesSource.fromVehiclesData, false, true), + Arguments.of(VehiclesSource.fromVehiclesData, false, false) ); } @@ -107,12 +86,13 @@ public static Collection parameterObjects () { private Link link2; private Link link3; - @Test - void main() { + @ParameterizedTest + @MethodSource("arguments") + void main(VehiclesSource vehiclesSource, boolean usingPersonIdForMissingVehicleId, boolean providingVehiclesInPerson) { scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createNetwork(); - createPlans(); + createPlans(vehiclesSource, providingVehiclesInPerson); Config config = scenario.getConfig(); config.qsim().setFlowCapFactor(1.0); @@ -121,8 +101,8 @@ void main() { //config.plansCalcRoute().setNetworkModes(Arrays.asList(transportModes)); config.qsim().setLinkDynamics(QSimConfigGroup.LinkDynamics.PassingQ); - config.qsim().setVehiclesSource(this.vehiclesSource ); - config.qsim().setUsePersonIdForMissingVehicleId(this.usingPersonIdForMissingVehicleId ); + config.qsim().setVehiclesSource(vehiclesSource ); + config.qsim().setUsePersonIdForMissingVehicleId(usingPersonIdForMissingVehicleId ); config.controller().setOutputDirectory(helper.getOutputDirectory()); config.controller().setLastIteration(0); @@ -187,7 +167,7 @@ public void install() { int bikeTravelTime = travelTime1.get(Id.create("2", Link.class)).intValue(); int carTravelTime = travelTime2.get(Id.create("2", Link.class)).intValue(); - switch (this.vehiclesSource ) { + switch (vehiclesSource ) { case defaultVehicle: // both bike and car are default vehicles (i.e. identical) Assertions.assertEquals(0, bikeTravelTime - carTravelTime, MatsimTestUtils.EPSILON, "Both car, bike are default vehicles (i.e. identical), thus should have same travel time."); break; @@ -214,7 +194,7 @@ private void createNetwork(){ link3 = NetworkUtils.createAndAddLink(network, Id.create("3", Link.class), node3, node4, 100, 25, 600, 1, null, "22"); } - private void createPlans(){ + private void createPlans(VehiclesSource vehiclesSource, boolean providingVehiclesInPerson){ Population population = scenario.getPopulation(); VehiclesFactory vehiclesFactory = scenario.getVehicles().getFactory(); @@ -259,7 +239,7 @@ private void createPlans(){ } //adding vehicle type and vehicle to scenario as needed: - switch (this.vehiclesSource ) { + switch (vehiclesSource ) { case defaultVehicle: //don't add anything break; diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java index 6bcba7b34bc..ff153e4a86f 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/QLinkTest.java @@ -30,9 +30,8 @@ import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -85,7 +84,6 @@ * @author mrieser */ -@RunWith(Parameterized.class) public final class QLinkTest { @RegisterExtension @@ -93,21 +91,9 @@ public final class QLinkTest { private static final Logger logger = LogManager.getLogger( QLinkTest.class ); - private final boolean isUsingFastCapacityUpdate; - - public QLinkTest(boolean isUsingFastCapacityUpdate) { - this.isUsingFastCapacityUpdate = isUsingFastCapacityUpdate; - } - - @Parameters(name = "{index}: isUsingfastCapacityUpdate == {0}") - public static Collection parameterObjects () { - Object [] capacityUpdates = new Object [] { false, true }; - return Arrays.asList(capacityUpdates); - } - - - @Test - void testInit() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testInit(boolean isUsingFastCapacityUpdate) { Fixture f = new Fixture(isUsingFastCapacityUpdate); assertNotNull(f.qlink1); assertEquals(1.0, f.qlink1.getSimulatedFlowCapacityPerTimeStep(), MatsimTestUtils.EPSILON); @@ -121,8 +107,9 @@ void testInit() { } - @Test - void testAdd() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testAdd(boolean isUsingFastCapacityUpdate) { Fixture f = new Fixture(isUsingFastCapacityUpdate); assertEquals(0, ((QueueWithBuffer) f.qlink1.getAcceptingQLane()).getAllVehicles().size()); QVehicle v = new QVehicleImpl(f.basicVehicle); @@ -153,8 +140,9 @@ private static PersonDriverAgentImpl createAndInsertPersonDriverAgentImpl(Person * @author mrieser */ - @Test - void testGetVehicle_Driving() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testGetVehicle_Driving(boolean isUsingFastCapacityUpdate) { Fixture f = new Fixture(isUsingFastCapacityUpdate); Id id1 = Id.create("1", Vehicle.class); @@ -219,8 +207,9 @@ void testGetVehicle_Driving() { * @author mrieser */ - @Test - void testGetVehicle_Parking() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testGetVehicle_Parking(boolean isUsingFastCapacityUpdate) { Fixture f = new Fixture(isUsingFastCapacityUpdate); Id id1 = Id.create("1", Vehicle.class); @@ -257,8 +246,9 @@ void testGetVehicle_Parking() { * @author mrieser */ - @Test - void testGetVehicle_Departing() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testGetVehicle_Departing(boolean isUsingFastCapacityUpdate) { Fixture f = new Fixture(isUsingFastCapacityUpdate); Id id1 = Id.create("1", Vehicle.class); @@ -322,8 +312,9 @@ void testGetVehicle_Departing() { * @author mrieser */ - @Test - void testBuffer() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testBuffer(boolean isUsingFastCapacityUpdate) { Config conf = utils.loadConfig((String)null); conf.qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); @@ -446,8 +437,9 @@ private static Person createPerson(Id personId, MutableScenario scenario } - @Test - void testStorageSpaceDifferentVehicleSizes() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testStorageSpaceDifferentVehicleSizes(boolean isUsingFastCapacityUpdate) { Fixture f = new Fixture(isUsingFastCapacityUpdate); @@ -548,8 +540,9 @@ private Person createPerson2(Id personId, Fixture f) { } - @Test - void testStuckEvents() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testStuckEvents(boolean isUsingFastCapacityUpdate) { Scenario scenario = ScenarioUtils.createScenario(ConfigUtils.createConfig()); scenario.getConfig().qsim().setStuckTime(100); scenario.getConfig().qsim().setRemoveStuckVehicles(true); diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java index 8cfe3e14e1e..89e0f598b0a 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/SeepageTest.java @@ -22,9 +22,8 @@ import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -58,24 +57,11 @@ /** * Tests that in congested part, walk (seep mode) can overtake (seep) car mode. - * + * */ -@RunWith(Parameterized.class) public class SeepageTest { static private final Logger log = LogManager.getLogger( SeepageTest.class); - private final boolean isUsingFastCapacityUpdate; - - public SeepageTest(boolean isUsingFastCapacityUpdate) { - this.isUsingFastCapacityUpdate = isUsingFastCapacityUpdate; - } - - @Parameters(name = "{index}: isUsingfastCapacityUpdate == {0}") - public static Collection parameterObjects () { - Object [] capacityUpdates = new Object [] { false, true }; - return Arrays.asList(capacityUpdates); - } - /** * Two carAgents end act at time 948 and 949 sec and walkAgent ends act at 49 sec. * Link length is 1 km and flow capacity 1 PCU/min. Speed of car and walk is 20 mps and 1 mps. @@ -83,16 +69,17 @@ public static Collection parameterObjects () { * WalkAgent joins queue at 1050 sec but leave link before second car at 1060 sec and thus blocking link for another 6 sec(flowCap*PCU) * Thus, second car leaves link after walkAgent. */ - @Test - void seepageOfWalkInCongestedRegime(){ + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void seepageOfWalkInCongestedRegime(boolean isUsingFastCapacityUpdate){ SimpleNetwork net = new SimpleNetwork(); - + Scenario sc = net.scenario; sc.getConfig().qsim().setVehiclesSource(VehiclesSource.fromVehiclesData); - sc.getConfig().qsim().setUsingFastCapacityUpdate(this.isUsingFastCapacityUpdate); - + sc.getConfig().qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); + Map modesType = new HashMap(); VehicleType car = VehicleUtils.getFactory().createVehicleType(Id.create(TransportMode.car,VehicleType.class)); car.setMaximumVelocity(20); @@ -136,7 +123,7 @@ void seepageOfWalkInCongestedRegime(){ Vehicle vehicle = VehicleUtils.getFactory().createVehicle(vehicleId, modesType.get(leg.getMode())); sc.getVehicles().addVehicle(vehicle); } - + Map, Map, Double>> vehicleLinkTravelTimes = new HashMap<>(); EventsManager manager = EventsUtils.createEventsManager(); @@ -152,7 +139,7 @@ void seepageOfWalkInCongestedRegime(){ Map, Double> travelTime1 = vehicleLinkTravelTimes.get(Id.createVehicleId("2")); Map, Double> travelTime2 = vehicleLinkTravelTimes.get(Id.createVehicleId("1")); - int walkTravelTime = travelTime1.get(Id.createLinkId("2")).intValue(); + int walkTravelTime = travelTime1.get(Id.createLinkId("2")).intValue(); int carTravelTime = travelTime2.get(Id.createLinkId("2")).intValue(); // if(this.isUsingFastCapacityUpdate) { @@ -184,7 +171,7 @@ public SimpleNetwork(){ config.qsim().setStorageCapFactor(1.0); config.qsim().setMainModes(Arrays.asList(TransportMode.car,TransportMode.walk)); config.qsim().setLinkDynamics(LinkDynamics.SeepageQ); - + config.qsim().setSeepModes(Arrays.asList(TransportMode.walk) ); config.qsim().setSeepModeStorageFree(false); config.qsim().setRestrictingSeepage(true); @@ -256,4 +243,4 @@ public void handleEvent(LinkLeaveEvent event) { public void reset(int iteration) { } } -} \ No newline at end of file +} diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java index 19f03965a02..10ec18198e2 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/qnetsimengine/VehVsLinkSpeedTest.java @@ -22,9 +22,8 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -61,28 +60,14 @@ * @author amit */ -@RunWith(Parameterized.class) public class VehVsLinkSpeedTest { - - public VehVsLinkSpeedTest(final double vehSpeed) { - this.vehSpeed = vehSpeed; - } - - private double vehSpeed ; private final static double MAX_SPEED_ON_LINK = 25; //in m/s - @Parameters(name = "{index}: vehicleSpeed == {0};") - public static Collection createFds() { - Object [] vehSpeeds = new Object [] { - 30, 20 - }; - return Arrays.asList(vehSpeeds); - } - - @Test - void testVehicleSpeed(){ + @ParameterizedTest + @ValueSource(doubles = {20, 30}) + void testVehicleSpeed(double vehSpeed){ SimpleNetwork net = new SimpleNetwork(); - + Id id = Id.createPersonId(0); Person p = net.population.getFactory().createPerson(id); Plan plan = net.population.getFactory().createPlan(); @@ -92,7 +77,7 @@ void testVehicleSpeed(){ Leg leg = net.population.getFactory().createLeg(TransportMode.car); plan.addActivity(a1); plan.addLeg(leg); - + LinkNetworkRouteFactory factory = new LinkNetworkRouteFactory(); NetworkRoute route = (NetworkRoute) factory.createRoute(net.link1.getId(), net.link3.getId()); route.setLinkIds(net.link1.getId(), Arrays.asList(net.link2.getId()), net.link3.getId()); @@ -107,7 +92,7 @@ void testVehicleSpeed(){ manager.addHandler(new VehicleLinkTravelTimeHandler(vehicleLinkTravelTime)); VehicleType car = VehicleUtils.getFactory().createVehicleType(Id.create("car", VehicleType.class)); - car.setMaximumVelocity(this.vehSpeed); + car.setMaximumVelocity(vehSpeed); car.setPcuEquivalents(1.0); net.scenario.getVehicles().addVehicleType(car); @@ -118,9 +103,9 @@ void testVehicleSpeed(){ .run(); Map, Double> travelTime1 = vehicleLinkTravelTime.get(Id.create("0", Vehicle.class)); - + Link desiredLink = net.scenario.getNetwork().getLinks().get(Id.createLinkId(2)); - + double carTravelTime = travelTime1.get(desiredLink.getId()); // 1000 / min(25, vehSpeed) double speedUsedInSimulation = Math.round( desiredLink.getLength() / (carTravelTime - 1) ); @@ -160,10 +145,10 @@ public SimpleNetwork(){ link1 = NetworkUtils.createAndAddLink(network,Id.create("1", Link.class), fromNode, toNode, (double) 100, MAX_SPEED_ON_LINK, (double) 60, (double) 1, null, "22"); final Node fromNode1 = node2; - final Node toNode1 = node3; + final Node toNode1 = node3; link2 = NetworkUtils.createAndAddLink(network,Id.create("2", Link.class), fromNode1, toNode1, (double) 1000, MAX_SPEED_ON_LINK, (double) 60, (double) 1, null, "22"); final Node fromNode2 = node3; - final Node toNode2 = node4; + final Node toNode2 = node4; link3 = NetworkUtils.createAndAddLink(network,Id.create("3", Link.class), fromNode2, toNode2, (double) 100, MAX_SPEED_ON_LINK, (double) 60, (double) 1, null, "22"); population = scenario.getPopulation(); @@ -203,4 +188,4 @@ public void handleEvent(LinkLeaveEvent event) { public void reset(int iteration) { } } -} \ No newline at end of file +} diff --git a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java index 106ea1e7790..7dae5a07ce9 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripStructureUtilsSubtoursTest.java @@ -30,9 +30,8 @@ import java.util.List; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.population.Activity; @@ -49,20 +48,8 @@ /** * @author thibautd */ -@RunWith( Parameterized.class ) public class TripStructureUtilsSubtoursTest { private static final String STAGE = "stage_activity interaction"; - private final boolean useFacilitiesAsAnchorPoint; - - @Parameters - public static Collection contructorParameters() { - return Arrays.asList( new Boolean[]{true} , new Boolean[]{false} ); - } - - public TripStructureUtilsSubtoursTest(final boolean useFacilitiesAsAnchorPoint) { - this.useFacilitiesAsAnchorPoint = useFacilitiesAsAnchorPoint; - } - // ///////////////////////////////////////////////////////////////////////// // fixtures // ///////////////////////////////////////////////////////////////////////// @@ -97,7 +84,7 @@ private static Activity createActivityFromLocationId( return act; } - + private static Id createId(long no, boolean anchorAtFacilities){ Id id; if (anchorAtFacilities){ @@ -107,7 +94,7 @@ private static Id createId(long no, boolean anchorAtFacilities){ id = Id.create(no, Link.class); } - + return id; } @@ -267,7 +254,7 @@ private static Fixture createComplexSubtours(final boolean anchorAtFacilities) { final Activity act5 = createActivityFromLocationId( anchorAtFacilities , fact , "aa" , createId(3,anchorAtFacilities) ); plan.addActivity( act5 ); - + final List trip5 = new ArrayList(); final Leg leg7 = fact.createLeg( "skateboard" ); plan.addLeg( leg7 ); @@ -748,46 +735,55 @@ private static Collection allFixtures(final boolean anchorAtFacilities) // ///////////////////////////////////////////////////////////////////////// // tests // ///////////////////////////////////////////////////////////////////////// - @Test - void testOneSubtour() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testOneSubtour(boolean useFacilitiesAsAnchorPoint) { performTest( createMonoSubtourFixture( useFacilitiesAsAnchorPoint ) ); } - @Test - void testTwoNestedSubtours() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testTwoNestedSubtours(boolean useFacilitiesAsAnchorPoint) { performTest( createTwoNestedSubtours(useFacilitiesAsAnchorPoint) ); } - @Test - void testTwoChildren() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testTwoChildren(boolean useFacilitiesAsAnchorPoint) { performTest( createTwoChildren(useFacilitiesAsAnchorPoint) ); } - @Test - void testComplexSubtours() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testComplexSubtours(boolean useFacilitiesAsAnchorPoint) { performTest( createComplexSubtours(useFacilitiesAsAnchorPoint) ); } - @Test - void testOpenPlan() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testOpenPlan(boolean useFacilitiesAsAnchorPoint) { performTest( createOpenPlan(useFacilitiesAsAnchorPoint) ); } - @Test - void testLoops() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testLoops(boolean useFacilitiesAsAnchorPoint) { performTest( createPlanWithLoops(useFacilitiesAsAnchorPoint) ); } - @Test - void testTwoIndependentTours() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testTwoIndependentTours(boolean useFacilitiesAsAnchorPoint) { performTest( createTwoIndependentTours(useFacilitiesAsAnchorPoint) ); } - @Test - void testTripFromSomewhereElse() { performTest( createSingleTourComingFromSomewhereElse(useFacilitiesAsAnchorPoint));} + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testTripFromSomewhereElse(boolean useFacilitiesAsAnchorPoint) { performTest( createSingleTourComingFromSomewhereElse(useFacilitiesAsAnchorPoint));} - @Test - void testTripToSomewhereElse() { performTest( createSingleTourGoingToSomewhereElse(useFacilitiesAsAnchorPoint));} + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testTripToSomewhereElse(boolean useFacilitiesAsAnchorPoint) { performTest( createSingleTourGoingToSomewhereElse(useFacilitiesAsAnchorPoint));} private static void performTest(final Fixture fixture) { final Collection subtours = @@ -806,8 +802,9 @@ private static void performTest(final Fixture fixture) { "uncompatible subtours" ); } - @Test - void testInconsistentPlan() throws Exception { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testInconsistentPlan(boolean useFacilitiesAsAnchorPoint) throws Exception { final Fixture fixture = createInconsistentTrips( useFacilitiesAsAnchorPoint ); boolean hadException = false; try { @@ -823,8 +820,9 @@ void testInconsistentPlan() throws Exception { "no exception was thrown!"); } - @Test - void testGetTripsWithoutSubSubtours() throws Exception { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testGetTripsWithoutSubSubtours(boolean useFacilitiesAsAnchorPoint) throws Exception { for (Fixture f : allFixtures( useFacilitiesAsAnchorPoint )) { final int nTrips = TripStructureUtils.getTrips( f.plan ).size(); final Collection subtours = @@ -843,8 +841,9 @@ void testGetTripsWithoutSubSubtours() throws Exception { } } - @Test - void testFatherhood() throws Exception { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testFatherhood(boolean useFacilitiesAsAnchorPoint) throws Exception { for (Fixture f : allFixtures( useFacilitiesAsAnchorPoint )) { final Collection subtours = TripStructureUtils.getSubtours( f.plan ); diff --git a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java index b63e771c6f9..9b83941165a 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java +++ b/matsim/src/test/java/org/matsim/core/scoring/functions/CharyparNagelScoringFunctionTest.java @@ -26,9 +26,8 @@ import java.util.Arrays; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameter; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.EnumSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -73,20 +72,10 @@ * @author mrieser */ -@RunWith(Parameterized.class) public class CharyparNagelScoringFunctionTest { private static final double EPSILON =1e-9; - @Parameter - public TypicalDurationScoreComputation typicalDurationComputation; - - @Parameterized.Parameters - public static Object[] testParameters() { - return new Object[] {TypicalDurationScoreComputation.relative,TypicalDurationScoreComputation.uniform}; - } - - private ScoringFunction getScoringFunctionInstance(final Fixture f, final Person person) { CharyparNagelScoringFunctionFactory charyparNagelScoringFunctionFactory = new CharyparNagelScoringFunctionFactory( f.scenario ); @@ -117,7 +106,7 @@ private double calcScore(final Fixture f) { * @param priority * @return the duration (in hours) at which the activity has a utility of 0. */ - private double getZeroUtilDuration_hrs(final double typicalDuration_hrs, final double priority) { + private double getZeroUtilDuration_hrs(final double typicalDuration_hrs, final double priority, TypicalDurationScoreComputation typicalDurationComputation) { // yy could/should use static function from CharyparNagelScoringUtils. kai, nov'13 if(typicalDurationComputation.equals(TypicalDurationScoreComputation.uniform)){ @@ -130,14 +119,15 @@ private double getZeroUtilDuration_hrs(final double typicalDuration_hrs, final d /** * Test the calculation of the zero-utility-duration. */ - @Test - void testZeroUtilityDuration() { - double zeroUtilDurW = getZeroUtilDuration_hrs(8.0, 1.0); - double zeroUtilDurH = getZeroUtilDuration_hrs(16.0, 1.0); - double zeroUtilDurW2 = getZeroUtilDuration_hrs(8.0, 2.0); + @ParameterizedTest + @EnumSource(TypicalDurationScoreComputation.class) + void testZeroUtilityDuration(TypicalDurationScoreComputation typicalDurationComputation) { + double zeroUtilDurW = getZeroUtilDuration_hrs(8.0, 1.0, typicalDurationComputation); + double zeroUtilDurH = getZeroUtilDuration_hrs(16.0, 1.0, typicalDurationComputation); + double zeroUtilDurW2 = getZeroUtilDuration_hrs(8.0, 2.0, typicalDurationComputation); ZeroUtilityComputation computation; - if(this.typicalDurationComputation.equals(TypicalDurationScoreComputation.uniform)){ + if(typicalDurationComputation.equals(TypicalDurationScoreComputation.uniform)){ computation = new ActivityUtilityParameters.SameAbsoluteScore(); } else { computation = new ActivityUtilityParameters.SameRelativeScore(); @@ -233,13 +223,14 @@ void testTravelingBikeAndConstantBike(){ /** * Test the performing part of the scoring function. */ - @Test - void testPerforming() { + @ParameterizedTest + @EnumSource(TypicalDurationScoreComputation.class) + void testPerforming(TypicalDurationScoreComputation typicalDurationComputation) { Fixture f = new Fixture(); double perf = +6.0; - double zeroUtilDurW = getZeroUtilDuration_hrs(3.0, 1.0); - double zeroUtilDurH = getZeroUtilDuration_hrs(15.0, 1.0); + double zeroUtilDurW = getZeroUtilDuration_hrs(3.0, 1.0, typicalDurationComputation); + double zeroUtilDurH = getZeroUtilDuration_hrs(15.0, 1.0, typicalDurationComputation); f.config.scoring().setPerforming_utils_hr(perf); @@ -301,8 +292,9 @@ void testClosingTime() { /** * Test the performing part of the scoring function when an activity has OpeningTime and ClosingTime set. */ - @Test - void testOpeningClosingTime() { + @ParameterizedTest + @EnumSource(TypicalDurationScoreComputation.class) + void testOpeningClosingTime(TypicalDurationScoreComputation typicalDurationComputation) { Fixture f = new Fixture(); double perf_hrs = +6.0; f.config.scoring().setPerforming_utils_hr(perf_hrs); @@ -336,10 +328,10 @@ void testOpeningClosingTime() { // // only the home-activity should add to the score // assertEquals(perf * 15.0 * Math.log(14.75 / zeroUtilDurH), calcScore(f), EPSILON); // not longer true, since not doing a scheduled activity now carries a penalty. kai, nov'13 - double score_home = perf_hrs * 15.0 * Math.log(14.75 / getZeroUtilDuration_hrs(15.0, 1.0)) ; + double score_home = perf_hrs * 15.0 * Math.log(14.75 / getZeroUtilDuration_hrs(15.0, 1.0, typicalDurationComputation)) ; final double typicalDuration_work_sec = wParams.getTypicalDuration().seconds(); - final double zeroUtilityDuration_work_sec = 3600. * getZeroUtilDuration_hrs(typicalDuration_work_sec/3600., 1. ); + final double zeroUtilityDuration_work_sec = 3600. * getZeroUtilDuration_hrs(typicalDuration_work_sec/3600., 1., typicalDurationComputation ); double slope_work_at_zero_utility_h = perf_hrs * typicalDuration_work_sec / zeroUtilityDuration_work_sec ; double score_work = - zeroUtilityDuration_work_sec * slope_work_at_zero_utility_h / 3600. ; assertEquals( score_home+3.*score_work , calcScore(f), EPSILON ) ; @@ -509,8 +501,9 @@ void testDistanceCostScoringPt() { /** * Test how the scoring function reacts when the first and the last activity do not have the same act-type. */ - @Test - void testDifferentFirstLastAct() { + @ParameterizedTest + @EnumSource(TypicalDurationScoreComputation.class) + void testDifferentFirstLastAct(TypicalDurationScoreComputation typicalDurationComputation) { Fixture f = new Fixture(); // change the last act to something different than the first act ((Activity) f.plan.getPlanElements().get(8)).setType("h2"); @@ -529,9 +522,9 @@ void testDifferentFirstLastAct() { double perf = +6.0; f.config.scoring().setPerforming_utils_hr(perf); - double zeroUtilDurW = getZeroUtilDuration_hrs(3.0, 1.0); - double zeroUtilDurH = getZeroUtilDuration_hrs(6.0, 1.0); - double zeroUtilDurH2 = getZeroUtilDuration_hrs(8.0, 1.0); + double zeroUtilDurW = getZeroUtilDuration_hrs(3.0, 1.0, typicalDurationComputation); + double zeroUtilDurH = getZeroUtilDuration_hrs(6.0, 1.0, typicalDurationComputation); + double zeroUtilDurH2 = getZeroUtilDuration_hrs(8.0, 1.0, typicalDurationComputation); assertEquals(perf * 3.0 * Math.log(2.5 / zeroUtilDurW) + perf * 3.0 * Math.log(2.75/zeroUtilDurW) @@ -545,11 +538,12 @@ void testDifferentFirstLastAct() { * don't end the day with an ongoing activity at all. This is half of the case * when the first and last activity aren't the same. */ - @Test - void testNoNightActivity() { + @ParameterizedTest + @EnumSource(TypicalDurationScoreComputation.class) + void testNoNightActivity(TypicalDurationScoreComputation typicalDurationComputation) { - double zeroUtilDurW = getZeroUtilDuration_hrs(3.0, 1.0); - double zeroUtilDurH = getZeroUtilDuration_hrs(7.0, 1.0); + double zeroUtilDurW = getZeroUtilDuration_hrs(3.0, 1.0, typicalDurationComputation); + double zeroUtilDurH = getZeroUtilDuration_hrs(7.0, 1.0, typicalDurationComputation); double perf = +3.0; Fixture f = new Fixture(); diff --git a/matsim/src/test/java/org/matsim/examples/EquilTest.java b/matsim/src/test/java/org/matsim/examples/EquilTest.java index ded2c6a9777..30b722f1065 100644 --- a/matsim/src/test/java/org/matsim/examples/EquilTest.java +++ b/matsim/src/test/java/org/matsim/examples/EquilTest.java @@ -28,9 +28,8 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.core.api.experimental.events.EventsManager; import org.matsim.core.api.internal.MatsimReader; import org.matsim.core.config.Config; @@ -47,29 +46,17 @@ import org.matsim.testcases.MatsimTestUtils; import org.matsim.utils.eventsfilecomparison.EventsFileComparator; -@RunWith(Parameterized.class) public class EquilTest { private static final Logger log = LogManager.getLogger( EquilTest.class ) ; @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - private final boolean isUsingFastCapacityUpdate; - - public EquilTest(boolean isUsingFastCapacityUpdate) { - this.isUsingFastCapacityUpdate = isUsingFastCapacityUpdate; - } - - @Parameters(name = "{index}: isUsingfastCapacityUpdate == {0}") - public static Collection parameterObjects () { - Object [] capacityUpdates = new Object [] { false, true }; - return Arrays.asList(capacityUpdates); - } - - @Test - void testEquil() { + @ParameterizedTest + @ValueSource(booleans = {true, false}) + void testEquil(boolean isUsingFastCapacityUpdate) { Config config = ConfigUtils.createConfig() ; config.controller().setOutputDirectory( utils.getOutputDirectory() ); - config.qsim().setUsingFastCapacityUpdate(this.isUsingFastCapacityUpdate); + config.qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); config.facilities().setFacilitiesSource( FacilitiesConfigGroup.FacilitiesSource.onePerActivityLinkInPlansFile ); String netFileName = "test/scenarios/equil/network.xml"; diff --git a/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java b/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java index c8b41781421..bf0fda1ee5c 100644 --- a/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java +++ b/matsim/src/test/java/org/matsim/examples/simple/PtScoringTest.java @@ -24,9 +24,8 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameter; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.EnumSource; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.events.Event; @@ -50,25 +49,17 @@ * */ -@RunWith(Parameterized.class) public class PtScoringTest { - @Parameter - public TypicalDurationScoreComputation typicalDurationScoreComputation; - - @Parameterized.Parameters - public static Object[] testParameters() { - return new Object[] {TypicalDurationScoreComputation.relative, TypicalDurationScoreComputation.uniform}; - } - @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Test - void test_PtScoringLineswitch() { + @ParameterizedTest + @EnumSource(TypicalDurationScoreComputation.class) + void test_PtScoringLineswitch(TypicalDurationScoreComputation typicalDurationScoreComputation) { Config config = this.utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-simple-lineswitch"), "config.xml")); ScoringConfigGroup pcs = config.scoring() ; - if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ + if(typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ for(ActivityParams params : pcs.getActivityParams()){ params.setTypicalDurationScoreComputation(typicalDurationScoreComputation); } @@ -205,7 +196,7 @@ void test_PtScoringLineswitch() { System.out.println(" score: " + pp.getSelectedPlan().getScore() ) ; - if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ + if(typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ Assertions.assertEquals(-21.280962467387187, pp.getSelectedPlan().getScore(), MatsimTestUtils.EPSILON ) ; } else{ @@ -216,12 +207,13 @@ void test_PtScoringLineswitch() { } - @Test - void test_PtScoringLineswitchAndPtConstant() { + @ParameterizedTest + @EnumSource(TypicalDurationScoreComputation.class) + void test_PtScoringLineswitchAndPtConstant(TypicalDurationScoreComputation typicalDurationScoreComputation) { Config config = this.utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-simple-lineswitch"), "config.xml")); ScoringConfigGroup pcs = config.scoring() ; - if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)) + if(typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)) for(ActivityParams params : pcs.getActivityParams()){ params.setTypicalDurationScoreComputation(typicalDurationScoreComputation); } @@ -360,7 +352,7 @@ void test_PtScoringLineswitchAndPtConstant() { System.out.println(" score: " + pp.getSelectedPlan().getScore() ) ; - if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ + if(typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ // Assert.assertEquals(89.14608279715044, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; Assertions.assertEquals(-19.280962467387187, pp.getSelectedPlan().getScore(), MatsimTestUtils.EPSILON ) ; } @@ -372,12 +364,13 @@ void test_PtScoringLineswitchAndPtConstant() { } - @Test - void test_PtScoring_Wait() { + @ParameterizedTest + @EnumSource(TypicalDurationScoreComputation.class) + void test_PtScoring_Wait(TypicalDurationScoreComputation typicalDurationScoreComputation) { Config config = this.utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-simple"), "config.xml")); ScoringConfigGroup pcs = config.scoring(); - if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ + if(typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ for(ActivityParams params : pcs.getActivityParams()){ params.setTypicalDurationScoreComputation(typicalDurationScoreComputation); } @@ -448,7 +441,7 @@ void test_PtScoring_Wait() { System.out.println("agent score: " + pp.getSelectedPlan().getScore() ) ; - if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ + if(typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ Assertions.assertEquals(89.13108279715044, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; } else{ @@ -458,12 +451,13 @@ void test_PtScoring_Wait() { } - @Test - void test_PtScoring() { + @ParameterizedTest + @EnumSource(TypicalDurationScoreComputation.class) + void test_PtScoring(TypicalDurationScoreComputation typicalDurationScoreComputation) { Config config = this.utils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("pt-simple"), "config.xml")); ScoringConfigGroup pcs = config.scoring() ; - if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)) + if(typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)) for(ActivityParams params : pcs.getActivityParams()){ params.setTypicalDurationScoreComputation(typicalDurationScoreComputation); } @@ -530,7 +524,7 @@ void test_PtScoring() { System.out.println(" score: " + pp.getSelectedPlan().getScore() ) ; - if(this.typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ + if(typicalDurationScoreComputation.equals(TypicalDurationScoreComputation.uniform)){ Assertions.assertEquals(89.87441613048377, pp.getSelectedPlan().getScore(),MatsimTestUtils.EPSILON ) ; } else{ diff --git a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java index 7fa5c7b47f8..de9dddfc5d5 100644 --- a/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java +++ b/matsim/src/test/java/org/matsim/facilities/ActivityFacilitiesSourceTest.java @@ -22,8 +22,9 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -45,47 +46,37 @@ import java.io.File; import java.util.Arrays; import java.util.Collection; +import java.util.stream.Stream; /** * Created by amit on 05.02.18. */ -@RunWith(Parameterized.class) public class ActivityFacilitiesSourceTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils() ; - // private static final String outDir = "test/output/"+ActivityFacilitiesSourceTest.class.getCanonicalName().replace('.','/')+"/"; - - private final FacilitiesConfigGroup.FacilitiesSource facilitiesSource; - private final boolean facilitiesWithCoordOnly ; - - public ActivityFacilitiesSourceTest(FacilitiesConfigGroup.FacilitiesSource facilitiesSource, boolean facilitiesWithCoordOnly) { - this.facilitiesSource = facilitiesSource; - this.facilitiesWithCoordOnly = facilitiesWithCoordOnly; - } - - @Parameterized.Parameters(name = "{index}: FacilitiesSource - {0}; facilitiesWithCoordOnly - {1}") - public static Collection parametersForFacilitiesSourceTest() { + public static Stream arguments() { // it is not clear to me why/how this works. The documentation of JUnitParamsRunner says that such // implicit behavior ("dirty tricks") should no longer be necessary when using it. kai, jul'18 - return Arrays.asList( - new Object[]{FacilitiesConfigGroup.FacilitiesSource.none, true} // true/false doen't matter here - ,new Object[]{FacilitiesConfigGroup.FacilitiesSource.fromFile, true}// true/false doen't matter here - ,new Object[]{FacilitiesConfigGroup.FacilitiesSource.setInScenario, true} - ,new Object[]{FacilitiesConfigGroup.FacilitiesSource.setInScenario, false} - ,new Object[]{FacilitiesConfigGroup.FacilitiesSource.onePerActivityLinkInPlansFile, true} // true/false doen't matter here - ,new Object[]{FacilitiesConfigGroup.FacilitiesSource.onePerActivityLocationInPlansFile, true} // true/false doen't matter here + return Stream.of( + Arguments.of(FacilitiesConfigGroup.FacilitiesSource.none, true), // true/false doen't matter here + Arguments.of(FacilitiesConfigGroup.FacilitiesSource.fromFile, true),// true/false doen't matter here + Arguments.of(FacilitiesConfigGroup.FacilitiesSource.setInScenario, true), + Arguments.of(FacilitiesConfigGroup.FacilitiesSource.setInScenario, false), + Arguments.of(FacilitiesConfigGroup.FacilitiesSource.onePerActivityLinkInPlansFile, true), // true/false doen't matter here + Arguments.of(FacilitiesConfigGroup.FacilitiesSource.onePerActivityLocationInPlansFile, true) // true/false doen't matter here ); } - @Test - void test(){ + @ParameterizedTest + @MethodSource("arguments") + void test(FacilitiesConfigGroup.FacilitiesSource facilitiesSource, boolean facilitiesWithCoordOnly){ String outDir = utils.getOutputDirectory() ; String testOutDir = outDir + "/" + facilitiesSource.toString() + "_facilitiesWithCoordOnly_" + String.valueOf(facilitiesWithCoordOnly) + "/"; new File(testOutDir).mkdirs(); - Scenario scenario = prepareScenario(); + Scenario scenario = prepareScenario(facilitiesSource, facilitiesWithCoordOnly); scenario.getConfig().controller().setOutputDirectory(testOutDir); scenario.getConfig().controller().setOverwriteFileSetting(OutputDirectoryHierarchy.OverwriteFileSetting.overwriteExistingFiles); // (overwriteExistingFiles is needed here for the parameterized test since otherwise all output directories except for @@ -94,7 +85,7 @@ void test(){ // checks ActivityFacilities activityFacilities = getFacilities(scenario.getConfig().controller().getOutputDirectory()); - switch (this.facilitiesSource) { + switch (facilitiesSource) { case none: break; case fromFile: @@ -138,7 +129,7 @@ private ActivityFacilities getFacilities(String outputDir){ // create basic scenario - private Scenario prepareScenario() { + private Scenario prepareScenario(FacilitiesConfigGroup.FacilitiesSource facilitiesSource, boolean facilitiesWithCoordOnly) { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); config.plans().setInputFile(null); config.controller().setLastIteration(0); @@ -213,7 +204,7 @@ private Scenario prepareScenario() { } // activity from link only - if (! this.facilitiesSource.equals(FacilitiesConfigGroup.FacilitiesSource.onePerActivityLocationInPlansFile)){ + if (! facilitiesSource.equals(FacilitiesConfigGroup.FacilitiesSource.onePerActivityLocationInPlansFile)){ Person person = populationFactory.createPerson(Id.createPersonId("1")); Plan plan = populationFactory.createPlan(); Activity home = populationFactory.createActivityFromLinkId("h", Id.createLinkId("1")); @@ -250,7 +241,7 @@ private Scenario prepareScenario() { plan.addLeg(populationFactory.createLeg( mode ) ); Activity work = populationFactory.createActivityFromLinkId("w", Id.createLinkId("20")); - if ( this.facilitiesSource.equals(FacilitiesConfigGroup.FacilitiesSource.onePerActivityLocationInPlansFile)){ + if (facilitiesSource.equals(FacilitiesConfigGroup.FacilitiesSource.onePerActivityLocationInPlansFile)){ work.setCoord(new Coord(10000.0, 0.0)); } diff --git a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java index b0ee67d400c..a128a9ff6ea 100644 --- a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java +++ b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java @@ -25,14 +25,15 @@ import java.util.Arrays; import java.util.Collection; import java.util.Map; +import java.util.stream.Stream; import jakarta.inject.Inject; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameters; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; import org.matsim.analysis.ScoreStats; import org.matsim.analysis.ScoreStatsControlerListener.ScoreItem; import org.matsim.core.config.Config; @@ -43,38 +44,24 @@ import org.matsim.core.controler.listener.ShutdownListener; import org.matsim.testcases.MatsimTestUtils; -@RunWith(Parameterized.class) public class ScoreStatsModuleTest { public static final double DELTA = 0.0000000001; + @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - private final boolean isUsingFastCapacityUpdate; - private final boolean isInsertingAccessEgressWalk; - - public ScoreStatsModuleTest(boolean isUsingFastCapacityUpdate, boolean isInsertingAccessEgressWalk) { - this.isUsingFastCapacityUpdate = isUsingFastCapacityUpdate; - this.isInsertingAccessEgressWalk = isInsertingAccessEgressWalk; - } - - @Parameters(name = "{index}: isUsingfastCapacityUpdate == {0}; isInsertingAccessEgressWalk = {1}") - public static Collection parameterObjects () { - Object [] [] os = new Object [][] { - // { false, true }, - // { true, true }, - { false, false }, - { true, false } - }; - return Arrays.asList(os); + public static Stream arguments () { + return Stream.of(Arguments.of(false, false), Arguments.of(true, false)); } - @Test - void testScoreStats() { + @ParameterizedTest + @MethodSource("arguments") + void testScoreStats(boolean isUsingFastCapacityUpdate, boolean isInsertingAccessEgressWalk) { Config config = utils.loadConfig("test/scenarios/equil/config.xml"); - config.qsim().setUsingFastCapacityUpdate(this.isUsingFastCapacityUpdate); - config.routing().setAccessEgressType(this.isInsertingAccessEgressWalk? AccessEgressType.accessEgressModeToLink : AccessEgressType.none); + config.qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); + config.routing().setAccessEgressType(isInsertingAccessEgressWalk? AccessEgressType.accessEgressModeToLink : AccessEgressType.none); config.controller().setLastIteration(1); Controler controler = new Controler(config); diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java index 4f65ed8e50d..364e2ead7f1 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourComplexTripsTest.java @@ -25,9 +25,8 @@ import java.util.List; import java.util.Random; import org.junit.jupiter.api.Assertions; -import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -51,7 +50,6 @@ * as possible. * @author thibautd */ -@RunWith(Parameterized.class) public class ChooseRandomLegModeForSubtourComplexTripsTest { // transit_walk is not here but is in the fixtures: thus, pt trips are // identified as "known mode" only if trip-level mode detection is done @@ -60,8 +58,7 @@ public class ChooseRandomLegModeForSubtourComplexTripsTest { private static final String[] CHAIN_BASED_MODES = new String[]{TransportMode.car}; private static final String STAGE = PtConstants.TRANSIT_ACTIVITY_TYPE; - private final double probaForRandomSingleTripMode; - + // ///////////////////////////////////////////////////////////////////////// // Fixtures // ///////////////////////////////////////////////////////////////////////// @@ -80,7 +77,7 @@ public Plan createNewPlanInstance() { final Id id3 = Id.create( 3, Link.class ); final Plan plan = fact.createPlan(); - + plan.addActivity( fact.createActivityFromLinkId( "h" , id1 ) ); plan.addLeg( fact.createLeg( TransportMode.transit_walk ) ); @@ -123,7 +120,7 @@ public Plan createNewPlanInstance() { final Id id3 = Id.create( 3, Link.class ); final Plan plan = fact.createPlan(); - + plan.addActivity( fact.createActivityFromLinkId( "h" , id1 ) ); for (int i =0; i < 2; i++) { @@ -169,7 +166,7 @@ public Plan createNewPlanInstance() { final Id id4 = Id.create( 4, Link.class ); final Plan plan = fact.createPlan(); - + plan.addActivity( fact.createActivityFromLinkId( "h" , id1 ) ); plan.addLeg( fact.createLeg( TransportMode.transit_walk ) ); @@ -265,7 +262,7 @@ public Plan createNewPlanInstance() { final Id id4 = Id.create( 4, Link.class ); final Plan plan = fact.createPlan(); - + plan.addActivity( fact.createActivityFromLinkId( "h" , id1 ) ); plan.addLeg( fact.createLeg( TransportMode.car ) ); @@ -340,7 +337,7 @@ public Plan createNewPlanInstance() { final Id id4 = Id.create( 4, Link.class ); final Plan plan = fact.createPlan(); - + plan.addActivity( fact.createActivityFromLinkId( "sleep" , id1 ) ); plan.addActivity( fact.createActivityFromLinkId( "shower" , id1 ) ); plan.addActivity( fact.createActivityFromLinkId( "breakfast" , id1 ) ); @@ -450,17 +447,9 @@ private static PopulationFactory createPopulationFactory() { // ///////////////////////////////////////////////////////////////////////// // tests // ///////////////////////////////////////////////////////////////////////// - @Parameterized.Parameters(name = "{index}: probaForChooseRandomSingleTripMode == {0}") - public static Collection createTests() { - return Arrays.asList(0., 0.5); - } - public ChooseRandomLegModeForSubtourComplexTripsTest( double proba ) { - this.probaForRandomSingleTripMode = proba ; - } - - - @Test - void testMutatedTrips() { + @ParameterizedTest + @ValueSource(doubles = {0.0, 0.5}) + void testMutatedTrips(double probaForRandomSingleTripMode) { Config config = ConfigUtils.createConfig(); config.subtourModeChoice().setModes(MODES); config.subtourModeChoice().setConsiderCarAvailability(false); @@ -481,7 +470,7 @@ void testMutatedTrips() { testee.run( plan ); final List newTrips = TripStructureUtils.getTrips( plan ); - + Assertions.assertEquals( initNTrips, newTrips.size(), diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java index cac43bb101c..6246fb409a6 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourDiffModesTest.java @@ -26,8 +26,8 @@ import java.util.Random; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; @@ -47,17 +47,14 @@ /** * Tests specific to the 'probability-for-random-single-trip-mode' parameter. - * + * * @author ikaddoura based on thibautd */ -@RunWith(Parameterized.class) public class ChooseRandomLegModeForSubtourDiffModesTest { - + private static final String[] MODES = new String[]{TransportMode.pt, TransportMode.car, TransportMode.walk}; private static final String[] CHAIN_BASED_MODES = new String[]{TransportMode.car}; - - private final double probaForRandomSingleTripMode; - + // ///////////////////////////////////////////////////////////////////////// // Fixtures // ///////////////////////////////////////////////////////////////////////// @@ -75,7 +72,7 @@ public Plan createNewPlanInstance() { final Id id3 = Id.create( 3, Link.class ); final Plan plan = fact.createPlan(); - + plan.addActivity( fact.createActivityFromLinkId( "h" , id1 ) ); plan.addLeg( fact.createLeg( TransportMode.walk ) ); @@ -90,7 +87,7 @@ public Plan createNewPlanInstance() { } }; } - + private static Collection createFixtures() { return Arrays.asList( createOneTourFixture()); @@ -102,16 +99,9 @@ private static PopulationFactory createPopulationFactory() { // ///////////////////////////////////////////////////////////////////////// // tests // ///////////////////////////////////////////////////////////////////////// - @Parameterized.Parameters(name = "{index}: probaForChooseRandomSingleTripMode == {0}") - public static Collection createTests() { - return Arrays.asList(0., 1.0); - } - public ChooseRandomLegModeForSubtourDiffModesTest( double proba ) { - this.probaForRandomSingleTripMode = proba ; - } - - @Test - void testMutatedTrips() { + @ParameterizedTest + @ValueSource(doubles = {0., 1.}) + void testMutatedTrips(double probaForRandomSingleTripMode) { Config config = ConfigUtils.createConfig(); config.subtourModeChoice().setModes(MODES); config.subtourModeChoice().setConsiderCarAvailability(false); @@ -132,7 +122,7 @@ void testMutatedTrips() { testee.run( plan ); final List newTrips = TripStructureUtils.getTrips( plan ); - + Assertions.assertEquals( initNTrips, newTrips.size(), @@ -174,11 +164,11 @@ void testMutatedTrips() { 1, nMutatedWithoutMutatedFather, "unexpected number of roots in mutated subtours"); - - + + for ( Subtour subtour : newSubtours ) { if (subtour.getChildren().isEmpty()) { - checkSubtour(subtour); + checkSubtour(subtour, probaForRandomSingleTripMode); } else { throw new RuntimeException("This test is not (yet) made for subtours with children."); } @@ -186,8 +176,8 @@ void testMutatedTrips() { } } } - - private void checkSubtour(Subtour subtour) { + + private void checkSubtour(Subtour subtour, double probaForRandomSingleTripMode) { boolean atLeastOneSubtourWithDifferentNonChainBasedModes = false; boolean atLeastOneSubtourWithDifferentChainBasedModes = false; @@ -195,22 +185,22 @@ private void checkSubtour(Subtour subtour) { String modePreviousTripSameSubtour = null; for (Trip trip: subtour.getTrips()) { - + for (Leg leg : trip.getLegsOnly()) { - + if (modePreviousTripSameSubtour == null) { // first trip during this subtour } else { if (leg.getMode().equals(modePreviousTripSameSubtour)) { - // same mode - + // same mode + } else { // different modes, should only occur for non-chain-based modes - + if (isChainBasedMode(leg.getMode()) || isChainBasedMode(modePreviousTripSameSubtour)) { // one of the two different modes is a chain-based mode which shouldn't just fall from the sky atLeastOneSubtourWithDifferentChainBasedModes = true; - + } else { // not a chain-based mode atLeastOneSubtourWithDifferentNonChainBasedModes = true; @@ -221,18 +211,18 @@ private void checkSubtour(Subtour subtour) { } } } - + if (atLeastOneSubtourWithDifferentChainBasedModes) { Assertions.fail("Two different modes during one subtour where one of the two different modes is a chain-based mode."); } - - if (this.probaForRandomSingleTripMode > 0.) { + + if (probaForRandomSingleTripMode > 0.) { if (atLeastOneSubtourWithDifferentNonChainBasedModes == false) { - Assertions.fail("There is not a single subtour with different non-chain-based modes even though the probability for random single trip mode is " + this.probaForRandomSingleTripMode); + Assertions.fail("There is not a single subtour with different non-chain-based modes even though the probability for random single trip mode is " + probaForRandomSingleTripMode); } } else { if (atLeastOneSubtourWithDifferentNonChainBasedModes == true) { - Assertions.fail("There is at least one subtour with different non-chain-based modes even though the probability for random single trip mode is " + this.probaForRandomSingleTripMode); + Assertions.fail("There is at least one subtour with different non-chain-based modes even though the probability for random single trip mode is " + probaForRandomSingleTripMode); } } } diff --git a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java index e6dc7997e19..394fe8398fe 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/ChooseRandomLegModeForSubtourTest.java @@ -32,8 +32,8 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.ValueSource; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -63,11 +63,8 @@ /** * @author mrieser, michaz */ -@RunWith(Parameterized.class) public class ChooseRandomLegModeForSubtourTest { - private double probaForRandomSingleTripMode; - private static class AllowTheseModesForEveryone implements PermissibleModesCalculator { @@ -109,17 +106,9 @@ public static enum TripStructureAnalysisLayerOption {facility,link} "1 2 2 3 2 2 2 1 4 1", "1 2 3 4 3 1"); - @Parameterized.Parameters(name = "{index}: probaForRandomSingleTripMode == {0}") - public static Collection createTests() { - return Arrays.asList(0., 0.5); - } - public ChooseRandomLegModeForSubtourTest( double proba ) { - this.probaForRandomSingleTripMode = proba ; - } - - - @Test - void testHandleEmptyPlan() { + @ParameterizedTest + @ValueSource(doubles = {0.0, 0.5}) + void testHandleEmptyPlan(double probaForRandomSingleTripMode) { String[] modes = new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}; ChooseRandomLegModeForSubtour algo = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() , new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, MatsimRandom.getRandom(), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); @@ -128,8 +117,9 @@ void testHandleEmptyPlan() { // no specific assert, but there should also be no NullPointerException or similar stuff that could theoretically happen } - @Test - void testHandlePlanWithoutLeg() { + @ParameterizedTest + @ValueSource(doubles = {0.0, 0.5}) + void testHandlePlanWithoutLeg(double probaForRandomSingleTripMode) { String[] modes = new String[] {TransportMode.car, TransportMode.pt, TransportMode.walk}; ChooseRandomLegModeForSubtour algo = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, MatsimRandom.getRandom(), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); @@ -140,40 +130,44 @@ void testHandlePlanWithoutLeg() { } - @Test - void testSubTourMutationNetworkBased() { + @ParameterizedTest + @ValueSource(doubles = {0.0, 0.5}) + void testSubTourMutationNetworkBased(double probaForRandomSingleTripMode) { Config config = utils.loadConfig(CONFIGFILE); Scenario scenario = ScenarioUtils.createScenario(config); Network network = scenario.getNetwork(); new MatsimNetworkReader(scenario.getNetwork()).parse(config.network().getInputFileURL(config.getContext())); - this.testSubTourMutationToCar(network); - this.testSubTourMutationToPt(network); - this.testUnknownModeDoesntMutate(network); + this.testSubTourMutationToCar(network, probaForRandomSingleTripMode); + this.testSubTourMutationToPt(network, probaForRandomSingleTripMode); + this.testUnknownModeDoesntMutate(network, probaForRandomSingleTripMode); } - @Test - void testSubTourMutationFacilitiesBased() { + @ParameterizedTest + @ValueSource(doubles = {0.0, 0.5}) + void testSubTourMutationFacilitiesBased(double probaForRandomSingleTripMode) { Config config = utils.loadConfig(CONFIGFILE); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); ActivityFacilitiesImpl facilities = (ActivityFacilitiesImpl) scenario.getActivityFacilities(); new MatsimFacilitiesReader(scenario).parse(config.facilities().getInputFileURL(config.getContext())); - this.testSubTourMutationToCar(facilities); - this.testSubTourMutationToPt(facilities); - this.testUnknownModeDoesntMutate(facilities); + this.testSubTourMutationToCar(facilities, probaForRandomSingleTripMode); + this.testSubTourMutationToPt(facilities, probaForRandomSingleTripMode); + this.testUnknownModeDoesntMutate(facilities, probaForRandomSingleTripMode); } - @Test - void testCarDoesntTeleportFromHome() { + @ParameterizedTest + @ValueSource(doubles = {0.0, 0.5}) + void testCarDoesntTeleportFromHome(double probaForRandomSingleTripMode) { Config config = utils.loadConfig(CONFIGFILE); Scenario scenario = ScenarioUtils.createScenario(config); Network network = scenario.getNetwork(); new MatsimNetworkReader(scenario.getNetwork()).parse(config.network().getInputFileURL(config.getContext())); - testCarDoesntTeleport(network, TransportMode.car, TransportMode.pt); - testCarDoesntTeleport(network, TransportMode.pt, TransportMode.car); + testCarDoesntTeleport(network, TransportMode.car, TransportMode.pt, probaForRandomSingleTripMode); + testCarDoesntTeleport(network, TransportMode.pt, TransportMode.car, probaForRandomSingleTripMode); } - @Test - void testSingleTripSubtourHandling() { + @ParameterizedTest + @ValueSource(doubles = {0.0, 0.5}) + void testSingleTripSubtourHandling(double probaForRandomSingleTripMode) { String[] modes = new String[] {"car", "pt", "walk"}; ChooseRandomLegModeForSubtour testee = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, new Random(15102011), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); @@ -257,8 +251,9 @@ void testSingleTripSubtourHandling() { } - @Test - void testUnclosedSubtour() { + @ParameterizedTest + @ValueSource(doubles = {0.0, 0.5}) + void testUnclosedSubtour(double probaForRandomSingleTripMode) { String[] modes = new String[] {"car", "pt", "walk"}; @@ -287,7 +282,7 @@ void testUnclosedSubtour() { } - private void testSubTourMutationToCar(Network network) { + private void testSubTourMutationToCar(Network network, double probaForRandomSingleTripMode) { String expectedMode = TransportMode.car; String originalMode = TransportMode.pt; String[] modes = new String[] {expectedMode, originalMode}; @@ -303,7 +298,7 @@ private void testSubTourMutationToCar(Network network) { } } - private void testSubTourMutationToCar(ActivityFacilities facilities) { + private void testSubTourMutationToCar(ActivityFacilities facilities, double probaForRandomSingleTripMode) { String expectedMode = TransportMode.car; String originalMode = TransportMode.pt; String[] modes = new String[] {expectedMode, originalMode}; @@ -319,7 +314,7 @@ private void testSubTourMutationToCar(ActivityFacilities facilities) { } } - private void testUnknownModeDoesntMutate(Network network) { + private void testUnknownModeDoesntMutate(Network network, double probaForRandomSingleTripMode) { String originalMode = TransportMode.walk; String[] modes = new String[] {TransportMode.car, TransportMode.pt}; ChooseRandomLegModeForSubtour testee = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, MatsimRandom.getRandom(), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); @@ -334,7 +329,7 @@ private void testUnknownModeDoesntMutate(Network network) { } } - private void testUnknownModeDoesntMutate(ActivityFacilities facilities) { + private void testUnknownModeDoesntMutate(ActivityFacilities facilities, double probaForRandomSingleTripMode) { String originalMode = TransportMode.walk; String[] modes = new String[] {TransportMode.car, TransportMode.pt}; ChooseRandomLegModeForSubtour testee = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, MatsimRandom.getRandom(), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); @@ -349,7 +344,7 @@ private void testUnknownModeDoesntMutate(ActivityFacilities facilities) { } } - private void testSubTourMutationToPt(ActivityFacilities facilities) { + private void testSubTourMutationToPt(ActivityFacilities facilities, double probaForRandomSingleTripMode) { String expectedMode = TransportMode.pt; String originalMode = TransportMode.car; String[] modes = new String[] {expectedMode, originalMode}; @@ -365,7 +360,7 @@ private void testSubTourMutationToPt(ActivityFacilities facilities) { } } - private void testSubTourMutationToPt(Network network) { + private void testSubTourMutationToPt(Network network, double probaForRandomSingleTripMode) { String expectedMode = TransportMode.pt; String originalMode = TransportMode.car; String[] modes = new String[] {expectedMode, originalMode}; @@ -381,7 +376,7 @@ private void testSubTourMutationToPt(Network network) { } } - private void testCarDoesntTeleport(Network network, String originalMode, String otherMode) { + private void testCarDoesntTeleport(Network network, String originalMode, String otherMode, double probaForRandomSingleTripMode) { String[] modes = new String[] {originalMode, otherMode}; ChooseRandomLegModeForSubtour testee = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, MatsimRandom.getRandom(), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); @@ -415,7 +410,7 @@ private void testCarDoesntTeleport(Network network, String originalMode, String } } - private void testCarDoesntTeleport(ActivityFacilities facilities, String originalMode, String otherMode) { + private void testCarDoesntTeleport(ActivityFacilities facilities, String originalMode, String otherMode, double probaForRandomSingleTripMode) { String[] modes = new String[] {originalMode, otherMode}; ChooseRandomLegModeForSubtour testee = new ChooseRandomLegModeForSubtour( new MainModeIdentifierImpl() ,new AllowTheseModesForEveryone(modes), modes, CHAIN_BASED_MODES, MatsimRandom.getRandom(), SubtourModeChoice.Behavior.fromSpecifiedModesToSpecifiedModes, probaForRandomSingleTripMode); From ae945824c233b85da7facccd70e6431a12e22fad Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Tue, 12 Dec 2023 16:45:55 +0100 Subject: [PATCH 34/43] removed last junit 4 imports --- .../run/AccessibilityIntegrationTest.java | 6 +- .../run/TinyMultimodalAccessibilityTest.java | 4 +- .../kai/KNAnalysisEventsHandlerTest.java | 6 +- .../application/MATSimApplicationTest.java | 8 +- .../application/options/CsvOptionsTest.java | 1 - .../application/options/ShpOptionsTest.java | 9 +- .../prepare/CreateLandUseShpTest.java | 4 +- .../prepare/ShapeFileTextLookupTest.java | 4 +- .../cadyts/car/CadytsCarWithPtScenarioIT.java | 4 +- .../DiversityGeneratingPlansRemoverTest.java | 21 ++-- .../DrtWithExtensionsConfigGroupTest.java | 1 - .../drt/sharingmetrics/SharingFactorTest.java | 108 +++++++++--------- .../RunOneTaxiWithPrebookingExampleIT.java | 4 +- .../TestColdEmissionAnalysisModule.java | 36 +++--- .../emissions/TestPositionEmissionModule.java | 4 +- ...EmissionToolOnlineExampleIT_vehTypeV1.java | 4 +- ...EmissionToolOnlineExampleIT_vehTypeV2.java | 4 +- .../CarrierPlanXmlReaderV2WithDtdTest.java | 20 ++-- .../jsprit/MatsimTransformerTest.java | 2 +- ...istanceScoringFunctionFactoryForTests.java | 4 +- .../ScoringFunctionFactoryForTests.java | 4 +- .../StrategyManagerFactoryForTests.java | 4 +- .../TimeScoringFunctionFactoryForTests.java | 4 +- contribs/informed-mode-choice/pom.xml | 5 + .../modechoice/search/TopKMinMaxTest.java | 6 +- contribs/integration/README.txt | 2 +- .../MatrixBasedPtRouterIT.java | 1 - .../matrixbasedptrouter/PtMatrixTest.java | 1 - .../integration/SubsidyContextTestIT.java | 6 +- .../MultiModalControlerListenerTest.java | 8 +- .../contrib/protobuf/EventWriterPBTest.java | 1 - .../contrib/pseudosimulation/RunPSimTest.java | 6 +- .../SimulatedAnnealingConfigGroupTest.java | 1 - .../dashboard/EmissionsDashboardTest.java | 4 +- .../FullExplorationVsCuttoffTest.java | 4 +- .../WhoIsTheBossSelectorTest.java | 4 +- ...imizeVehicleAllocationAtTourLevelTest.java | 6 +- .../drtAndPt/PtAlongALine2Test.java | 4 +- .../drtAndPt/PtAlongALineTest.java | 10 +- .../bvgAna/level1/StopId2LineId2PulkTest.java | 4 +- ...tionHandlerFlowSpillbackQueueQsimTest.java | 16 +-- .../java/playground/vsp/ev/UrbanEVTests.java | 5 +- .../TransitRouteTrimmerTest.java | 46 ++++---- matsim/pom.xml | 4 + .../api/core/v01/AutoResetIdCaches.java | 18 ++- .../controler/MatsimServicesImplTest.java | 4 +- .../mobsim/qsim/AgentNotificationTest.java | 7 +- .../core/network/DisallowedNextLinksTest.java | 1 - .../NetworkChangeEventsParserWriterTest.java | 2 +- ...ScoringFunctionsForPopulationStressIT.java | 4 +- .../TravelTimeCalculatorModuleTest.java | 22 ++-- .../core/utils/geometry/CoordUtilsTest.java | 50 ++++---- .../core/utils/io/MatsimXmlParserTest.java | 1 - .../core/utils/misc/ConfigUtilsTest.java | 6 +- .../matsim/other/DownloadAndReadXmlTest.java | 5 +- .../algorithms/PersonPrepareForSimTest.java | 40 +++---- .../population/algorithms/TestsUtil.java | 4 +- pom.xml | 26 +++-- 58 files changed, 309 insertions(+), 291 deletions(-) diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java index e859cf969bb..25b3a4598eb 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/AccessibilityIntegrationTest.java @@ -27,7 +27,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -76,7 +76,7 @@ public class AccessibilityIntegrationTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Ignore + @Disabled @Test void testRunAccessibilityExample() { Config config = ConfigUtils.loadConfig("./examples/RunAccessibilityExample/config.xml"); @@ -350,7 +350,7 @@ public void install() { } - @Ignore + @Disabled @Test void testWithFile(){ /*TODO Complete - JWJ, Dec'16 */ diff --git a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java index d7ab5eaaf3c..43574962078 100644 --- a/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java +++ b/contribs/accessibility/src/test/java/org/matsim/contrib/accessibility/run/TinyMultimodalAccessibilityTest.java @@ -21,7 +21,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -69,7 +69,7 @@ public class TinyMultimodalAccessibilityTest { // non-deterministic presumably because of multi-threading. kai, sep'19 @Test - @Ignore + @Disabled void testWithBoundingBox() { final Config config = createTestConfig(); diff --git a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java index ec4fa06dd61..67352fcabbf 100644 --- a/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java +++ b/contribs/analysis/src/test/java/org/matsim/contrib/analysis/kai/KNAnalysisEventsHandlerTest.java @@ -24,7 +24,7 @@ import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.BeforeEach; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -108,7 +108,7 @@ public void tearDown() throws Exception { } @Test - @Ignore + @Disabled void testNoEvents() { KNAnalysisEventsHandler testee = new KNAnalysisEventsHandler(this.scenario); @@ -122,7 +122,7 @@ void testNoEvents() { } @Test - @Ignore + @Disabled void testAveraging() { // yy this test is probably not doing anything with respect to some of the newer statistics, such as money. kai, mar'14 diff --git a/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java b/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java index 0db41fd13eb..9d9d2052338 100644 --- a/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java +++ b/contribs/application/src/test/java/org/matsim/application/MATSimApplicationTest.java @@ -1,7 +1,7 @@ package org.matsim.application; -import org.junit.Assume; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; +import org.junit.jupiter.api.Assumptions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.application.options.SampleOptions; @@ -127,13 +127,13 @@ void population() throws MalformedURLException { } @Test - @Ignore("Class is deprecated") + @Disabled("Class is deprecated") void freight() { Path input = Path.of("..", "..", "..", "..", "shared-svn", "komodnext", "data", "freight", "original_data").toAbsolutePath().normalize(); - Assume.assumeTrue(Files.exists(input)); + Assumptions.assumeTrue(Files.exists(input)); Path output = Path.of(utils.getOutputDirectory()); diff --git a/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java b/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java index da166a7ea88..65299cb0e81 100644 --- a/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/options/CsvOptionsTest.java @@ -5,7 +5,6 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; -import org.junit.rules.TemporaryFolder; import java.io.IOException; import java.nio.file.Path; diff --git a/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java b/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java index 16c043ef0c8..2c9282c4add 100644 --- a/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java +++ b/contribs/application/src/test/java/org/matsim/application/options/ShpOptionsTest.java @@ -1,8 +1,7 @@ package org.matsim.application.options; import org.assertj.core.data.Offset; -import org.junit.Assume; -import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Assumptions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.locationtech.jts.geom.Geometry; @@ -32,7 +31,7 @@ void readZip() { .replace("options", "prepare")) .resolve("andorra-latest-free.shp.zip"); - Assume.assumeTrue(Files.exists(input)); + Assumptions.assumeTrue(Files.exists(input)); ShpOptions shp = new ShpOptions(input, null, null); @@ -52,7 +51,7 @@ void all() { .replace("options", "prepare")) .resolve("andorra-latest-free.shp.zip"); - Assume.assumeTrue(Files.exists(input)); + Assumptions.assumeTrue(Files.exists(input)); ShpOptions shp = new ShpOptions(input, null, null); @@ -74,7 +73,7 @@ void testGetGeometry() { .replace("options", "prepare")) .resolve("andorra-latest-free.shp.zip"); - Assume.assumeTrue(Files.exists(input)); + Assumptions.assumeTrue(Files.exists(input)); ShpOptions shp = new ShpOptions(input, null, null); Geometry geometry = shp.getGeometry() ; diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java index 38747c0fbc7..ca40a8f3057 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/CreateLandUseShpTest.java @@ -1,6 +1,6 @@ package org.matsim.application.prepare; -import org.junit.Assume; +import org.junit.jupiter.api.Assumptions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -20,7 +20,7 @@ void convert() { Path input = Path.of(utils.getClassInputDirectory(), "andorra-latest-free.shp.zip"); - Assume.assumeTrue(Files.exists(input)); + Assumptions.assumeTrue(Files.exists(input)); Path output = Path.of(utils.getOutputDirectory(), "output.shp"); diff --git a/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java b/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java index 0ff988f14cf..74153b6ab75 100644 --- a/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java +++ b/contribs/application/src/test/java/org/matsim/application/prepare/ShapeFileTextLookupTest.java @@ -1,6 +1,6 @@ package org.matsim.application.prepare; -import org.junit.Assume; +import org.junit.jupiter.api.Assumptions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.testcases.MatsimTestUtils; @@ -22,7 +22,7 @@ void main() { Path input = Path.of(utils.getClassInputDirectory(), "verkehrszellen.csv"); Path output = Path.of(utils.getOutputDirectory(), "output.csv"); - Assume.assumeTrue(Files.exists(input)); + Assumptions.assumeTrue(Files.exists(input)); CommandLine cli = new CommandLine(new ShapeFileTextLookup()); int ret = cli.execute( diff --git a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java index 9ab184be6b4..943cebbe4f0 100644 --- a/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java +++ b/contribs/cadytsIntegration/src/test/java/org/matsim/contrib/cadyts/car/CadytsCarWithPtScenarioIT.java @@ -2,7 +2,7 @@ import java.util.concurrent.atomic.AtomicInteger; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import static org.junit.jupiter.api.Assertions.assertTrue; import org.junit.jupiter.api.Test; @@ -23,7 +23,7 @@ public class CadytsCarWithPtScenarioIT { @Test - @Ignore + @Disabled void testCadytsWithPtVehicles() { final Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("siouxfalls-2014"), "config_default.xml")); config.controller().setOverwriteFileSetting(OutputDirectoryHierarchy.OverwriteFileSetting.overwriteExistingFiles); diff --git a/contribs/common/src/test/java/org/matsim/contrib/common/diversitygeneration/planselectors/DiversityGeneratingPlansRemoverTest.java b/contribs/common/src/test/java/org/matsim/contrib/common/diversitygeneration/planselectors/DiversityGeneratingPlansRemoverTest.java index a2b73e1657d..04a8efe7547 100644 --- a/contribs/common/src/test/java/org/matsim/contrib/common/diversitygeneration/planselectors/DiversityGeneratingPlansRemoverTest.java +++ b/contribs/common/src/test/java/org/matsim/contrib/common/diversitygeneration/planselectors/DiversityGeneratingPlansRemoverTest.java @@ -4,7 +4,6 @@ import gnu.trove.map.TMap; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -37,7 +36,7 @@ public class DiversityGeneratingPlansRemoverTest { private static final Logger log = LogManager.getLogger( DiversityGeneratingPlansRemoverTest.class ) ; - + private final Id node0 = Id.createNodeId( "node0" ) ; private final Id node1 = Id.createNodeId( "node1" ) ; private final Id node2 = Id.createNodeId( "node2" ) ; @@ -50,7 +49,7 @@ public class DiversityGeneratingPlansRemoverTest { void calcWeights() { // yy This is not really a strong test. Rather something I wrote for debugging. Would be a good // starting point for a fuller test. kai, jul'18 - + Scenario scenario = ScenarioUtils.createScenario( ConfigUtils.createConfig() ) ; { Network net = scenario.getNetwork(); @@ -130,11 +129,11 @@ void calcWeights() { plans.put("hwh_car_otherMode",plan) ; } pop.addPerson( person ); - + DiversityGeneratingPlansRemover.Builder builder = new DiversityGeneratingPlansRemover.Builder() ; builder.setNetwork( scenario.getNetwork() ) ; final DiversityGeneratingPlansRemover remover = builder.get(); - + for ( Map.Entry entry : plans.entrySet() ) { log.info( "similarity " + entry.getKey() + " to self is " + remover.similarity( entry.getValue(), entry.getValue() ) ); log.info("") ; @@ -145,7 +144,7 @@ void calcWeights() { } log.info("") ; } - + // { // final double similarity = remover.similarity( person.getPlans().get( 0 ), person.getPlans().get( 1 ) ); // log.info( "similarity 0 to 1: " + similarity ); @@ -161,7 +160,7 @@ void calcWeights() { // log.info( "similarity 0 to 2: " + similarity ); // Assert.assertEquals( 12.0, similarity, 10.*Double.MIN_VALUE ); // } - + final Map retVal = remover.calcWeights( person.getPlans() ); log.info("") ; for ( Map.Entry entry : retVal.entrySet() ) { @@ -173,13 +172,13 @@ void calcWeights() { } double[] expecteds = new double[]{1.0,0.0} ; - + // Assert.assertArrayEquals( expecteds, Doubles.toArray( retVal.values() ) , 10.*Double.MIN_VALUE ); } - - + + } - + private Plan createHwhPlan( final PopulationFactory pf ) { Plan plan = pf.createPlan() ; { diff --git a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java index 10b53461d07..a169febcd9e 100644 --- a/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java +++ b/contribs/drt-extensions/src/test/java/org/matsim/contrib/drt/extension/DrtWithExtensionsConfigGroupTest.java @@ -28,7 +28,6 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; -import org.junit.rules.TemporaryFolder; import org.matsim.contrib.drt.extension.DrtWithExtensionsConfigGroup; import org.matsim.contrib.drt.extension.companions.DrtCompanionParams; import org.matsim.contrib.drt.extension.operations.DrtOperationsParams; diff --git a/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingmetrics/SharingFactorTest.java b/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingmetrics/SharingFactorTest.java index e98a066d0ce..b731cedf080 100644 --- a/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingmetrics/SharingFactorTest.java +++ b/contribs/drt/src/test/java/org/matsim/contrib/drt/sharingmetrics/SharingFactorTest.java @@ -1,7 +1,7 @@ package org.matsim.contrib.drt.sharingmetrics; -import org.junit.Assert; -import org.junit.Test; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.population.Person; import org.matsim.contrib.dvrp.fleet.DvrpVehicle; @@ -53,15 +53,15 @@ public boolean isGroupRepresentative(Id personId) { { //single trip, no pooling var requestId = Id.create(0, Request.class); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId)); events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId, personId1, vehicleId)); events.processEvent(new PassengerDroppedOffEvent(300.0, mode, requestId, personId1, vehicleId)); events.flush(); - Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId)); - Assert.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId)); - Assert.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId)); + Assertions.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId)); + Assertions.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId), MatsimTestUtils.EPSILON); } //clean up @@ -71,8 +71,8 @@ public boolean isGroupRepresentative(Id personId) { //two trips exactly after each other, no pooling var requestId1 = Id.create(0, Request.class); var requestId2 = Id.create(1, Request.class); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId1, personId1, vehicleId)); events.processEvent(new PassengerDroppedOffEvent(300.0, mode, requestId1, personId1, vehicleId)); @@ -80,15 +80,15 @@ public boolean isGroupRepresentative(Id personId) { events.processEvent(new PassengerDroppedOffEvent(500.0, mode, requestId2, personId2, vehicleId)); events.flush(); - Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); - Assert.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); + Assertions.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); - Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); - Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); - Assert.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId2)); - Assert.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); + Assertions.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); } //clean up @@ -98,8 +98,8 @@ public boolean isGroupRepresentative(Id personId) { //two trips overlap half of the time var requestId1 = Id.create(0, Request.class); var requestId2 = Id.create(1, Request.class); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId1, personId1, vehicleId)); events.processEvent(new PassengerPickedUpEvent(200.0, mode, requestId2, personId2, vehicleId)); @@ -107,15 +107,15 @@ public boolean isGroupRepresentative(Id personId) { events.processEvent(new PassengerDroppedOffEvent(400.0, mode, requestId2, personId2, vehicleId)); events.flush(); - Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); - Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertEquals((100. + 100.) / (100 + 50), sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); + Assertions.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertEquals((100. + 100.) / (100 + 50), sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); - Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); - Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); - Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId2)); - Assert.assertEquals((100. + 100.) / (50 + 100), sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); + Assertions.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertEquals((100. + 100.) / (50 + 100), sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); } @@ -126,8 +126,8 @@ public boolean isGroupRepresentative(Id personId) { // second trip (sharing factor = 2) happens completely within first trip (sharing factor = 1.2) var requestId1 = Id.create(0, Request.class); var requestId2 = Id.create(1, Request.class); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId1, personId1, vehicleId)); events.processEvent(new PassengerPickedUpEvent(200.0, mode, requestId2, personId2, vehicleId)); @@ -135,15 +135,15 @@ public boolean isGroupRepresentative(Id personId) { events.processEvent(new PassengerDroppedOffEvent(400.0, mode, requestId1, personId1, vehicleId)); events.flush(); - Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); - Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertEquals((100. + 100. + 100.) / (100 + 50 + 100), sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); + Assertions.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertEquals((100. + 100. + 100.) / (100 + 50 + 100), sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); - Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); - Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); - Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId2)); - Assert.assertEquals((100. ) / (50.), sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); + Assertions.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertEquals((100. ) / (50.), sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); } //clean up @@ -154,8 +154,8 @@ public boolean isGroupRepresentative(Id personId) { var requestId1 = Id.create(0, Request.class); var requestId2 = Id.create(1, Request.class); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId1, personId1, vehicleId)); events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId2, personId2, vehicleId)); @@ -163,15 +163,15 @@ public boolean isGroupRepresentative(Id personId) { events.processEvent(new PassengerDroppedOffEvent(200.0, mode, requestId2, personId2, vehicleId)); events.flush(); - Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); - Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertEquals(2., sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); + Assertions.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertEquals(2., sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); - Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); - Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); - Assert.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId2)); - Assert.assertEquals(2., sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId2)); + Assertions.assertTrue(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertEquals(2., sharingFactorTracker.getSharingFactors().get(requestId2), MatsimTestUtils.EPSILON); } @@ -184,8 +184,8 @@ public boolean isGroupRepresentative(Id personId) { var requestId1 = Id.create(0, Request.class); var requestId2 = Id.create(1, Request.class); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId1, personId1, vehicleId)); events.processEvent(new PassengerPickedUpEvent(100.0, mode, requestId2, personId2, vehicleId)); @@ -193,13 +193,13 @@ public boolean isGroupRepresentative(Id personId) { events.processEvent(new PassengerDroppedOffEvent(200.0, mode, requestId2, personId2, vehicleId)); events.flush(); - Assert.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); - Assert.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId1)); - Assert.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); + Assertions.assertNotNull(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertNotNull(sharingFactorTracker.getSharingFactors().get(requestId1)); + Assertions.assertFalse(sharingFactorTracker.getPoolingRates().get(requestId1)); + Assertions.assertEquals(1., sharingFactorTracker.getSharingFactors().get(requestId1), MatsimTestUtils.EPSILON); - Assert.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); - Assert.assertNull(sharingFactorTracker.getSharingFactors().get(requestId2)); + Assertions.assertNull(sharingFactorTracker.getPoolingRates().get(requestId2)); + Assertions.assertNull(sharingFactorTracker.getSharingFactors().get(requestId2)); } } } diff --git a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java index fc8deb6874c..b6661027c45 100644 --- a/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java +++ b/contribs/dvrp/src/test/java/org/matsim/contrib/dvrp/examples/onetaxi/RunOneTaxiWithPrebookingExampleIT.java @@ -32,7 +32,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.assertj.core.data.Offset; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -71,7 +71,7 @@ public class RunOneTaxiWithPrebookingExampleIT { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Ignore + @Disabled @Test void testRun() { // load config diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java index 18bf6881844..d5d32b96239 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/TestColdEmissionAnalysisModule.java @@ -20,7 +20,7 @@ package org.matsim.contrib.emissions; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -70,11 +70,11 @@ public class TestColdEmissionAnalysisModule { private static final Set pollutants = new HashSet<>(Arrays.asList(CO, CO2_TOTAL, FC, HC, NMHC, NOx, NO2,PM, SO2)); private final int numberOfColdEmissions = pollutants.size(); // strings for test cases - + // The material below was confused in the way that strings like "petrol" or "diesel" were given for the // size classes, and "<1,4L" or ">=2L" for the emissions concept. Tried to make it consistent, // but I don't know if it is still testing the original functionality. kai, jul'18 - + // first case: complete data - corresponding entry in average table private static final String petrol_technology = "petrol"; private static final String none_sizeClass = "average"; @@ -95,7 +95,7 @@ public class TestColdEmissionAnalysisModule { private static final Double averagePetrolFactor = .01; private static final double fakeFactor = -1.; - + private boolean excep = false; @@ -116,7 +116,7 @@ void calculateColdEmissionsAndThrowEventTest_Exceptions() { testCasesExceptions.add( Id.create( "", VehicleType.class ) ); //case: null id testCasesExceptions.add( null ); - + for ( Id vehicleTypeId : testCasesExceptions ) { String message = "'" + vehicleTypeId + "'" + " was used to calculate cold emissions and generate an emissions event." + "It should instead throw an exception because it is not a valid vehicle information string."; @@ -139,7 +139,7 @@ void calculateColdEmissionsAndThrowEventTest_minimalVehicleInformation() { ColdEmissionAnalysisModule coldEmissionAnalysisModule = setUp(); excep = false; - + // case: no specifications for technology, size, class, em concept // string has no semicolons as separators - use average values Id vehInfo11 = Id.create("PASSENGER_CAR", VehicleType.class ); @@ -155,16 +155,16 @@ void calculateColdEmissionsAndThrowEventTest_minimalVehicleInformation() { String message = "The expected emissions for an emissions event with vehicle information string '" + vehInfo11 + "' are " + numberOfColdEmissions * averageAverageFactor + " but were " + sumOfEmissions; Assertions.assertEquals( numberOfColdEmissions * averageAverageFactor, sumOfEmissions, MatsimTestUtils.EPSILON, message ); - + } - + private static ColdEmissionAnalysisModule setUp() { Map avgHbefaColdTable = new HashMap<>(); Map detailedHbefaColdTable = new HashMap<>(); - + fillAveragesTable( avgHbefaColdTable ); fillDetailedTable( detailedHbefaColdTable ); - + EventsManager emissionEventManager = new HandlerToTestEmissionAnalysisModules(); EmissionsConfigGroup ecg = new EmissionsConfigGroup(); ecg.setHbefaVehicleDescriptionSource( EmissionsConfigGroup.HbefaVehicleDescriptionSource.usingVehicleTypeId ); @@ -172,7 +172,7 @@ private static ColdEmissionAnalysisModule setUp() { //This represents the previous behavior, which fallbacks to the average table, if values are not found in the detailed table, kmt apr'20 ecg.setDetailedVsAverageLookupBehavior(EmissionsConfigGroup.DetailedVsAverageLookupBehavior.tryDetailedThenTechnologyAverageThenAverageTable); return new ColdEmissionAnalysisModule( avgHbefaColdTable, detailedHbefaColdTable, ecg, pollutants, emissionEventManager ); - + } @@ -196,36 +196,36 @@ private static void fillDetailedTable( Map avgHbefaColdTable ) { // create all needed and one unneeded entry for the average table { // add passenger car entry "average;average;average": HbefaVehicleAttributes vehAtt = ColdEmissionAnalysisModule.createHbefaVehicleAttributes( "average", "average", "average" ) ; - + putIntoHbefaColdTable( avgHbefaColdTable, vehAtt, new HbefaColdEmissionFactor(averageAverageFactor), PASSENGER_CAR ); } { HbefaVehicleAttributes vehAtt = ColdEmissionAnalysisModule.createHbefaVehicleAttributes( petrol_technology, none_sizeClass, none_emConcept ); - + putIntoHbefaColdTable( avgHbefaColdTable, vehAtt, new HbefaColdEmissionFactor( averagePetrolFactor ), PASSENGER_CAR ); } { // duplicate from detailed table, but with different emission factor. // this should not be used but is needed to assure that the detailed table is tried before the average table HbefaVehicleAttributes vehAtt = ColdEmissionAnalysisModule.createHbefaVehicleAttributes( diesel_technology, geq2l_sizeClass, PC_D_Euro_3_emConcept ); - + putIntoHbefaColdTable( avgHbefaColdTable, vehAtt, new HbefaColdEmissionFactor( fakeFactor ), PASSENGER_CAR ); } { // add HGV entry "petrol;none;none". // (pre-existing comment: HEAVY_GOODS_VEHICLE;PC petrol;petrol;none should not be used --???) final HbefaVehicleAttributes vehAtt = ColdEmissionAnalysisModule.createHbefaVehicleAttributes( petrol_technology, none_sizeClass, none_emConcept ); - + putIntoHbefaColdTable( avgHbefaColdTable, vehAtt, new HbefaColdEmissionFactor( fakeFactor ), HEAVY_GOODS_VEHICLE ); } } - + private static void putIntoHbefaColdTable( final Map detailedHbefaColdTable, final HbefaVehicleAttributes vehAtt, final HbefaColdEmissionFactor detColdFactor, final HbefaVehicleCategory hbefaVehicleCategory ) { for ( Pollutant cp : pollutants ) { HbefaColdEmissionFactorKey detColdKey = new HbefaColdEmissionFactorKey(); @@ -237,5 +237,5 @@ private static void putIntoHbefaColdTable( final Map> Maybe a problem in @link{ParallelEventsManagerImpl.class}? + @Disabled //Ignore this test, because the thrown exception during events handling does not always leads to an abort of the Simulation ->> Maybe a problem in @link{ParallelEventsManagerImpl.class}? @Test final void testDetailed_vehTypeV1() { boolean gotAnException = false ; diff --git a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java index 62e8af5a78e..95cbc87199b 100644 --- a/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java +++ b/contribs/emissions/src/test/java/org/matsim/contrib/emissions/example/RunDetailedEmissionToolOnlineExampleIT_vehTypeV2.java @@ -18,7 +18,7 @@ * *********************************************************************** */ package org.matsim.contrib.emissions.example; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -40,7 +40,7 @@ public class RunDetailedEmissionToolOnlineExampleIT_vehTypeV2 { */ // @Test(expected=RuntimeException.class) // Expecting RuntimeException, because requested values are only in average file. Without fallback it has to fail! - @Ignore //Ignore this test, because the thrown exception during events handling does not always leads to an abort of the Simulation ->> Maybe a problem in @link{ParallelEventsManagerImpl.class}? + @Disabled //Ignore this test, because the thrown exception during events handling does not always leads to an abort of the Simulation ->> Maybe a problem in @link{ParallelEventsManagerImpl.class}? @Test final void testDetailed_vehTypeV2() { boolean gotAnException = false ; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java index 760d4942e04..22d23f8eefe 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/CarrierPlanXmlReaderV2WithDtdTest.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers; import org.junit.jupiter.api.BeforeEach; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -55,7 +55,7 @@ public void setUp() throws Exception{ } @Test - @Ignore + @Disabled void test_whenReadingServices_nuOfServicesIsCorrect(){ Assertions.assertEquals(3,testCarrier.getServices().size()); } @@ -77,7 +77,7 @@ void test_whenReadingCarrier_itReadsTypeIdsCorrectly(){ } @Test - @Ignore + @Disabled void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ Map, CarrierVehicle> carrierVehicles = testCarrier.getCarrierCapabilities().getCarrierVehicles(); Assertions.assertEquals(3,carrierVehicles.size()); @@ -86,25 +86,25 @@ void test_whenReadingCarrier_itReadsVehiclesCorrectly(){ } @Test - @Ignore + @Disabled void test_whenReadingCarrier_itReadsFleetSizeCorrectly(){ Assertions.assertEquals(FleetSize.INFINITE, testCarrier.getCarrierCapabilities().getFleetSize()); } @Test - @Ignore + @Disabled void test_whenReadingCarrier_itReadsShipmentsCorrectly(){ Assertions.assertEquals(2, testCarrier.getShipments().size()); } @Test - @Ignore + @Disabled void test_whenReadingCarrier_itReadsPlansCorrectly(){ Assertions.assertEquals(3, testCarrier.getPlans().size()); } @Test - @Ignore + @Disabled void test_whenReadingCarrier_itSelectsPlansCorrectly(){ Assertions.assertNotNull(testCarrier.getSelectedPlan()); } @@ -122,7 +122,7 @@ void test_whenReadingCarrierWithFiniteFleet_itSetsFleetSizeCorrectly(){ } @Test - @Ignore + @Disabled void test_whenReadingPlans_nuOfToursIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); Assertions.assertEquals(1, plans.get(0).getScheduledTours().size()); @@ -131,7 +131,7 @@ void test_whenReadingPlans_nuOfToursIsCorrect(){ } @Test - @Ignore + @Disabled void test_whenReadingToursOfPlan1_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan1 = plans.get(0); @@ -148,7 +148,7 @@ void test_whenReadingToursOfPlan2_nuOfActivitiesIsCorrect(){ } @Test - @Ignore + @Disabled void test_whenReadingToursOfPlan3_nuOfActivitiesIsCorrect(){ List plans = new ArrayList<>(testCarrier.getPlans()); CarrierPlan plan3 = plans.get(2); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java index 310c1942ad4..9514854743f 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/jsprit/MatsimTransformerTest.java @@ -461,7 +461,7 @@ void createVehicleRoutingProblemWithShipments_isMadeCorrectly() { // TODO create } - // @Ignore //Set to ignore due to not implemented functionality of Shipments in MatsimJspritFactory + // @Disabled //Set to ignore due to not implemented functionality of Shipments in MatsimJspritFactory @Test void createVehicleRoutingProblemBuilderWithShipments_isMadeCorrectly() { Carrier carrier = createCarrierWithShipments(); diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/DistanceScoringFunctionFactoryForTests.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/DistanceScoringFunctionFactoryForTests.java index 7dba7a46fdb..121eb0c5616 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/DistanceScoringFunctionFactoryForTests.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/DistanceScoringFunctionFactoryForTests.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers.mobsim; import jakarta.inject.Inject; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -46,7 +46,7 @@ import java.util.HashSet; import java.util.Set; -@Ignore +@Disabled public class DistanceScoringFunctionFactoryForTests implements CarrierScoringFunctionFactory{ static class DriverLegScoring implements BasicScoring, LegScoring{ diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/ScoringFunctionFactoryForTests.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/ScoringFunctionFactoryForTests.java index be93f2ad668..3bf4716a680 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/ScoringFunctionFactoryForTests.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/ScoringFunctionFactoryForTests.java @@ -21,7 +21,7 @@ package org.matsim.freight.carriers.mobsim; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -45,7 +45,7 @@ import java.util.HashSet; import java.util.Set; -@Ignore +@Disabled public class ScoringFunctionFactoryForTests implements CarrierScoringFunctionFactory{ static class DriverLegScoring implements BasicScoring, LegScoring{ diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/StrategyManagerFactoryForTests.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/StrategyManagerFactoryForTests.java index fc693360e04..680ef4e1953 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/StrategyManagerFactoryForTests.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/StrategyManagerFactoryForTests.java @@ -23,7 +23,7 @@ import com.google.inject.Provider; import jakarta.inject.Inject; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -43,7 +43,7 @@ import java.util.Map; -@Ignore +@Disabled public class StrategyManagerFactoryForTests implements Provider{ @Inject Network network; diff --git a/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/TimeScoringFunctionFactoryForTests.java b/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/TimeScoringFunctionFactoryForTests.java index b55a80f9ba1..ee8e1921ed7 100644 --- a/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/TimeScoringFunctionFactoryForTests.java +++ b/contribs/freight/src/test/java/org/matsim/freight/carriers/mobsim/TimeScoringFunctionFactoryForTests.java @@ -22,7 +22,7 @@ package org.matsim.freight.carriers.mobsim; import jakarta.inject.Inject; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -46,7 +46,7 @@ import java.util.HashSet; import java.util.Set; -@Ignore +@Disabled public class TimeScoringFunctionFactoryForTests implements CarrierScoringFunctionFactory{ static class DriverLegScoring implements BasicScoring, LegScoring{ diff --git a/contribs/informed-mode-choice/pom.xml b/contribs/informed-mode-choice/pom.xml index 15bc5fa15b9..ee62e49fbc5 100644 --- a/contribs/informed-mode-choice/pom.xml +++ b/contribs/informed-mode-choice/pom.xml @@ -40,6 +40,11 @@ mockito-core test + + org.mockito + mockito-junit-jupiter + test + diff --git a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java index f307a5b77c3..01efd0381a4 100644 --- a/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java +++ b/contribs/informed-mode-choice/src/test/java/org/matsim/modechoice/search/TopKMinMaxTest.java @@ -7,8 +7,8 @@ import org.assertj.core.data.Offset; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runner.RunWith; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.TransportMode; @@ -31,7 +31,7 @@ import org.matsim.testcases.MatsimTestUtils; import org.mockito.Mock; import org.mockito.invocation.InvocationOnMock; -import org.mockito.junit.MockitoJUnitRunner; +import org.mockito.junit.jupiter.MockitoExtension; import org.mockito.stubbing.Answer; import java.util.Collection; @@ -44,7 +44,7 @@ import static org.mockito.ArgumentMatchers.anyDouble; import static org.mockito.Mockito.when; -@RunWith(MockitoJUnitRunner.class) +@ExtendWith(MockitoExtension.class) public class TopKMinMaxTest { @RegisterExtension diff --git a/contribs/integration/README.txt b/contribs/integration/README.txt index 5f488fea2e3..1820036b350 100644 --- a/contribs/integration/README.txt +++ b/contribs/integration/README.txt @@ -15,7 +15,7 @@ To add an integration test: Sub-packages (e.g. org.matsim.integration.daily.mycode.MyTest.java) are supported. - make sure the class name ends in "Test". - annotate your test methods with "@Test" (import org.junit.Test). -- write your test functionality, including assert statements from JUnit (import org.junit.Assert). +- write your test functionality, including assert statements from JUnit (import org.junit.jupiter.api.assertions). To run the daily/weekly tests locally: diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java index 029bc07e9ed..6553e8c813a 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/MatrixBasedPtRouterIT.java @@ -29,7 +29,6 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; -import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.network.Network; diff --git a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java index 35bb1f4dbd3..2bbde2d9450 100644 --- a/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java +++ b/contribs/matrixbasedptrouter/src/test/java/org/matsim/contrib/matrixbasedptrouter/PtMatrixTest.java @@ -33,7 +33,6 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; -import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Network; diff --git a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java index 2050a1ad87c..85d490e30f1 100644 --- a/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java +++ b/contribs/minibus/src/test/java/org/matsim/contrib/minibus/integration/SubsidyContextTestIT.java @@ -24,7 +24,7 @@ import java.util.LinkedList; import java.util.List; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -56,7 +56,7 @@ public class SubsidyContextTestIT implements TabularFileHandler { private final ArrayList pStatsResults = new ArrayList<>(); private String gridScenarioDirectory ="../../example-scenario/input/"; - @Ignore + @Disabled @Test final void testDefaultPControler() { @@ -115,7 +115,7 @@ final void testDefaultPControler() { Assertions.assertEquals("16", this.pStatsResults.get(31)[8], "Number of +veh (final iteration)"); } - @Ignore + @Disabled @Test final void testSubsidyPControler() { diff --git a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java index 995516bba38..cb24c3d8849 100644 --- a/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java +++ b/contribs/multimodal/src/test/java/org/matsim/contrib/multimodal/MultiModalControlerListenerTest.java @@ -25,7 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -187,21 +187,21 @@ static void runSimpleScenario(int numberOfThreads) { Assertions.assertEquals(8, linkModeChecker.linkLeftCount); } - @Ignore("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm + @Disabled("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm @Test void testBerlinScenario_singleThreaded() { log.info("Run test single threaded..."); runBerlinScenario(1); } - @Ignore("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm + @Disabled("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm @Test void testBerlinScenario_multiThreaded_2() { log.info("Run test multi threaded with 2 threads..."); runBerlinScenario(2); } - @Ignore("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm + @Disabled("Due to bugfixes in slow flowCap accumulation in QueueWithBuffer")//by michalm @Test void testBerlinScenario_multiThreaded_4() { log.info("Run test multi threaded with 4 threads..."); diff --git a/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java b/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java index 6c90bffb6cd..fe89a11d0f4 100644 --- a/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java +++ b/contribs/protobuf/src/test/java/org/matsim/contrib/protobuf/EventWriterPBTest.java @@ -5,7 +5,6 @@ import org.assertj.core.api.Condition; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.events.Event; import org.matsim.api.core.v01.events.GenericEvent; diff --git a/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java b/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java index 12c258a2d6e..bd9e68ada04 100644 --- a/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java +++ b/contribs/pseudosimulation/src/test/java/org/matsim/contrib/pseudosimulation/RunPSimTest.java @@ -3,11 +3,11 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.FixMethodOrder; import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.MethodOrderer; import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.extension.RegisterExtension; -import org.junit.runners.MethodSorters; import org.matsim.analysis.ScoreStatsControlerListener; import org.matsim.api.core.v01.population.Population; import org.matsim.contrib.pseudosimulation.mobsim.transitperformance.NoTransitEmulator; @@ -31,7 +31,7 @@ import java.util.ArrayList; import java.util.List; -@FixMethodOrder(MethodSorters.NAME_ASCENDING) +@TestMethodOrder(MethodOrderer.MethodName.class) public class RunPSimTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); diff --git a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java index 7b5ac7bfb78..26ad9aa3867 100644 --- a/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java +++ b/contribs/simulatedannealing/src/test/java/org/matsim/contrib/simulatedannealing/SimulatedAnnealingConfigGroupTest.java @@ -12,7 +12,6 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; -import org.junit.rules.TemporaryFolder; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; import org.matsim.testcases.MatsimTestUtils; diff --git a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java index 4cbd29d9e7d..a809edfc795 100644 --- a/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java +++ b/contribs/simwrapper/src/test/java/org/matsim/simwrapper/dashboard/EmissionsDashboardTest.java @@ -2,7 +2,7 @@ import com.google.common.collect.Iterables; import org.assertj.core.api.Assertions; -import org.junit.Assume; +import org.junit.jupiter.api.Assumptions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -40,7 +40,7 @@ public class EmissionsDashboardTest { void generate() { // This test can only run if the password is set - Assume.assumeTrue(System.getenv("MATSIM_DECRYPTION_PASSWORD") != null); + Assumptions.assumeTrue(System.getenv("MATSIM_DECRYPTION_PASSWORD") != null); Path out = Path.of(utils.getOutputDirectory(), "analysis", "emissions"); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java index 2bf1b4d1c99..a2612ee9214 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/FullExplorationVsCuttoffTest.java @@ -22,7 +22,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -39,7 +39,7 @@ /** * @author thibautd */ -@Ignore( "expensive") +@Disabled( "expensive") public class FullExplorationVsCuttoffTest { private static final Logger log = LogManager.getLogger(FullExplorationVsCuttoffTest.class); diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java index 518ba077207..1b898a30398 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/framework/replanning/selectors/whoisthebossselector/WhoIsTheBossSelectorTest.java @@ -32,7 +32,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.BeforeEach; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -120,7 +120,7 @@ private Set getGroupIds(final ReplanningGroup group) { } @Test - @Ignore("TODO") + @Disabled("TODO") void testBestPlanIsSelectedIfPossible() throws Exception { throw new UnsupportedOperationException( "TODO" ); } diff --git a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java index 20514741157..2fe372d3158 100644 --- a/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java +++ b/contribs/socnetsim/src/test/java/org/matsim/contrib/socnetsim/sharedvehicles/replanning/OptimizeVehicleAllocationAtTourLevelTest.java @@ -26,7 +26,7 @@ import java.util.Random; import java.util.Set; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -102,7 +102,7 @@ private void fillPlan( } @Test - @Ignore("TODO") + @Disabled("TODO") void testVehiclesAreAllocatedAtTheTourLevel() throws Exception { throw new UnsupportedOperationException( "TODO" ); } @@ -133,7 +133,7 @@ void testCannotFindBetterAllocationRandomly() throws Exception { new AllocateVehicleToPlansInGroupPlanAlgorithm( new Random( j ), vehs, - Collections.singleton( MODE ), + Collections.singleton( MODE ), false, false).run( randomized ); final double randomizedOverlap = algo.calcOverlap( randomized ); diff --git a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java index 1cb5418e60e..7d884443580 100644 --- a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java +++ b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALine2Test.java @@ -9,7 +9,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -746,7 +746,7 @@ public void install() { // this test is failing because raptor treats "walk" in a special way. kai, jul'19 @Test - @Ignore + @Disabled void networkWalkDoesNotWorkWithRaptor() { // test fails with null pointer exception diff --git a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java index 6c315ddf84b..00c908721c0 100644 --- a/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java +++ b/contribs/vsp/src/test/java/org/matsim/integration/drtAndPt/PtAlongALineTest.java @@ -3,7 +3,7 @@ import java.util.HashSet; import java.util.Set; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; @@ -51,7 +51,7 @@ public class PtAlongALineTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Ignore + @Disabled @Test void testPtAlongALine() { @@ -68,7 +68,7 @@ void testPtAlongALine() { * Test of Intermodal Access & Egress to pt using bike.There are three transit stops, and * only the middle stop is accessible by bike. */ - @Ignore + @Disabled @Test void testPtAlongALineWithRaptorAndBike() { @@ -91,7 +91,7 @@ void testPtAlongALineWithRaptorAndBike() { * Test of Drt. 200 drt Vehicles are generated on Link 499-500, and all Agents rely on these * drts to get to their destination */ - @Ignore + @Disabled @Test void testDrtAlongALine() { @@ -202,7 +202,7 @@ void testDrtAlongALine() { * drt, which is set by a StopFilterAttribute */ - @Ignore + @Disabled @Test void testPtAlongALineWithRaptorAndDrtStopFilterAttribute() { Config config = PtAlongALineTest.createConfig(utils.getOutputDirectory()); diff --git a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java index 1b4a71190da..bfa02894495 100644 --- a/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/andreas/bvgAna/level1/StopId2LineId2PulkTest.java @@ -1,6 +1,6 @@ package playground.vsp.andreas.bvgAna.level1; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; @@ -16,7 +16,7 @@ public class StopId2LineId2PulkTest { @Test - @Ignore + @Disabled void testStopId2LineId2Pulk() { // assign Ids to routes, vehicles and agents to be used in Test diff --git a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java index c2f58a3cc25..1d0f93eb272 100644 --- a/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/congestion/MarginalCongestionHandlerFlowSpillbackQueueQsimTest.java @@ -32,7 +32,7 @@ import jakarta.inject.Inject; import jakarta.inject.Provider; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -131,7 +131,7 @@ public class MarginalCongestionHandlerFlowSpillbackQueueQsimTest { * V3 * */ - @Ignore("Temporarily ignoring")//TODO for Amit + @Disabled("Temporarily ignoring")//TODO for Amit @Test final void testFlowAndStorageCongestion_3agents(){ @@ -259,7 +259,7 @@ public void handleEvent(CongestionEvent event) { * V10 * */ - @Ignore("Temporarily ignoring")//TODO for Amit + @Disabled("Temporarily ignoring")//TODO for Amit @Test final void testFlowAndStorageCongestion_3agents_V10() { @@ -309,7 +309,7 @@ public void handleEvent(CongestionEvent event) { // in both iterations the "toll" and the "tollOldValue" should be the same // // 3 iterations are necessary to check the equality of the "toll" and the "tollOldValue" - @Ignore("Temporarily ignoring")//TODO for Amit + @Disabled("Temporarily ignoring")//TODO for Amit @Test final void testRouting(){ @@ -449,7 +449,7 @@ else if(((event.getServices().getConfig().controller().getLastIteration())-(even } // setInsertingWaitingVehiclesBeforeDrivingVehicles = false - @Ignore("Temporarily ignoring")//TODO for Amit + @Disabled("Temporarily ignoring")//TODO for Amit @Test final void testInsertingWaitingVehicles_01(){ @@ -508,7 +508,7 @@ public void handleEvent(LinkLeaveEvent event) { // setInsertingWaitingVehiclesBeforeDrivingVehicles = true // to compare - @Ignore("Temporarily ignoring")//TODO for Amit + @Disabled("Temporarily ignoring")//TODO for Amit @Test final void testInsertingWaitingVehicles_02(){ @@ -569,7 +569,7 @@ public void handleEvent(LinkLeaveEvent event) { // setInsertingWaitingVehiclesBeforeDrivingVehicles = false // agent 2 is already on link 2 when agent 3 ends his activity, // therefore agent 3 has to wait until agent 2 has left the link - @Ignore("Temporarily ignoring")//TODO for Amit + @Disabled("Temporarily ignoring")//TODO for Amit @Test final void testInsertingWaitingVehicles_03(){ @@ -627,7 +627,7 @@ public void handleEvent(LinkLeaveEvent event) { } - @Ignore("Temporarily ignoring")//TODO for Amit + @Disabled("Temporarily ignoring")//TODO for Amit @Test final void testStuckTimePeriod(){ diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java index ce74cd04415..9d9cf8230ec 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java @@ -6,9 +6,10 @@ import java.util.Map; import java.util.stream.Collectors; -import org.junit.BeforeClass; import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.BeforeAll; import org.junit.jupiter.api.Test; +import org.junit.runner.RunWith; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; @@ -60,7 +61,7 @@ public class UrbanEVTests { private static UrbanEVTestHandler handler; private static Map, List> plannedActivitiesPerPerson; - @BeforeEachClass + @BeforeAll public static void run() { Scenario scenario = CreateUrbanEVTestScenario.createTestScenario(); scenario.getConfig().controller().setOutputDirectory("test/output/playground/vsp/ev/UrbanEVTests/"); diff --git a/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java b/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java index 81bd2b2b013..4f1eeb06787 100644 --- a/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/pt/transitRouteTrimmer/TransitRouteTrimmerTest.java @@ -21,7 +21,7 @@ package playground.vsp.pt.transitRouteTrimmer; import javafx.util.Pair; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.locationtech.jts.geom.prep.PreparedGeometry; @@ -53,7 +53,7 @@ * * @author jakobrehmann */ -@Ignore // is ignored :-( +@Disabled // is ignored :-( public class TransitRouteTrimmerTest { final String inZoneShpFile = "https://svn.vsp.tu-berlin.de/repos/public-svn/matsim/scenarios/countries/de/berlin/projects/avoev/shp-files/shp-berlin-hundekopf-areas/berlin_hundekopf.shp"; @@ -96,7 +96,7 @@ public enum routeType { /** * In the allIn scenario, the transitRoute in question should have all stops within zone. */ - @Ignore + @Disabled @Test void test_AllIn() { @@ -126,7 +126,7 @@ void test_AllIn() { * In the halfIn scenario, the transitRoute in question begins outside of the zone and * ends within the zone. */ - @Ignore + @Disabled @Test void test_HalfIn() { @@ -154,7 +154,7 @@ void test_HalfIn() { * In the MiddleIn scenario, the transitRoute in question begins outside of the zone then dips * into the zone, and finally leaves the zone once again */ - @Ignore + @Disabled @Test void test_MiddleIn() { @@ -188,7 +188,7 @@ void test_MiddleIn() { * route scenario: AllIn * The testRoute should be deleted since all stops are within the zone. */ - @Ignore + @Disabled @Test void testDeleteRoutesEntirelyInsideZone_AllIn() { @@ -223,7 +223,7 @@ void testDeleteRoutesEntirelyInsideZone_AllIn() { * The testRoute should be retained and left unmodified, * since some stops are outside the zone. */ - @Ignore + @Disabled @Test void testDeleteRoutesEntirelyInsideZone_HalfIn() { @@ -270,7 +270,7 @@ void testDeleteRoutesEntirelyInsideZone_HalfIn() { * The testRoute should be retained and left unmodified, * since some stops are outside the zone. */ - @Ignore + @Disabled @Test void testDeleteRoutesEntirelyInsideZone_MiddleIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); @@ -316,7 +316,7 @@ void testDeleteRoutesEntirelyInsideZone_MiddleIn() { * route scenario: AllIn * The testRoute should be deleted since all stops are within the zone. */ - @Ignore + @Disabled @Test void testTrimEnds_AllIn() { @@ -350,7 +350,7 @@ void testTrimEnds_AllIn() { * route scenario: HalfIn * The second half of the route is outside the zone and should be trimmed */ - @Ignore + @Disabled @Test void testTrimEnds_HalfIn() { @@ -403,7 +403,7 @@ void testTrimEnds_HalfIn() { * route scenario: MiddleIn * Since the ends are both outside of zone, route should not be modified */ - @Ignore + @Disabled @Test void testTrimEnds_MiddleIn() { @@ -449,7 +449,7 @@ void testTrimEnds_MiddleIn() { * route scenario: AllIn * New route should be empty */ - @Ignore + @Disabled @Test void testSkipStops_AllIn() { @@ -481,7 +481,7 @@ void testSkipStops_AllIn() { * route scenario: HalfIn * Stops outside zone should be skipped */ - @Ignore + @Disabled @Test void testSkipStops_HalfIn() { @@ -531,7 +531,7 @@ void testSkipStops_HalfIn() { * route scenario: MiddleIn * New route should have less stops than old route, but same amount of links */ - @Ignore + @Disabled @Test void testSkipStops_MiddleIn() { @@ -578,7 +578,7 @@ void testSkipStops_MiddleIn() { * route scenario: AllIn * route will be deleted */ - @Ignore + @Disabled @Test void testSplitRoutes_AllIn() { @@ -612,7 +612,7 @@ void testSplitRoutes_AllIn() { * route scenario: HalfIn * New route should have less stops than old route */ - @Ignore + @Disabled @Test void testSplitRoutes_HalfIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); @@ -661,7 +661,7 @@ void testSplitRoutes_HalfIn() { * route scenario: MiddleIn * Two routes should be created, each with only one stop within zone */ - @Ignore + @Disabled @Test void testSplitRoutes_MiddleIn() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); @@ -727,7 +727,7 @@ Hubs allow route to extend into zone to reach a import transit stop (like a majo * tests reach of hubs. Left hub should be included in route 1, while right hub should not be * included in route 2, due to lacking reach */ - @Ignore + @Disabled @Test void testSplitRoutes_MiddleIn_Hub_ValidateReach() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); @@ -797,7 +797,7 @@ void testSplitRoutes_MiddleIn_Hub_ValidateReach() { * tests parameter to include first nearest hub, even if reach is insufficient. * Right hub should be included, even though reach is too low. */ - @Ignore + @Disabled @Test void testSplitRoutes_MiddleIn_Hub_IncludeFirstHubInZone() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); @@ -870,7 +870,7 @@ void testSplitRoutes_MiddleIn_Hub_IncludeFirstHubInZone() { * route scenario: MiddleIn * if multiple hubs are within reach of route, the route should go to further one */ - @Ignore + @Disabled @Test void testSplitRoutes_MiddleIn_Hub_MultipleHubs() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); @@ -939,7 +939,7 @@ void testSplitRoutes_MiddleIn_Hub_MultipleHubs() { * if two new routes overlap (because they both reach to same hub) * then they should be combined into one route */ - @Ignore + @Disabled @Test void testSplitRoutes_MiddleIn_Hub_OverlapRoutes() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); @@ -995,7 +995,7 @@ void testSplitRoutes_MiddleIn_Hub_OverlapRoutes() { * route should not be split, since the parameter allowableStopsWithinZone is equal to the number * of stops within zone */ - @Ignore + @Disabled @Test void testSplitRoutes_MiddleIn_AllowableStopsWithin() { Scenario scenario = provideCopyOfScenario(this.inScheduleFile, this.inNetworkFile, this.inVehiclesFile); @@ -1037,7 +1037,7 @@ void testSplitRoutes_MiddleIn_AllowableStopsWithin() { } - @Ignore + @Disabled @Test void testDeparturesAndOffsetsAndDescription() { diff --git a/matsim/pom.xml b/matsim/pom.xml index dcd4afd69c3..f0c0802c04e 100644 --- a/matsim/pom.xml +++ b/matsim/pom.xml @@ -167,6 +167,10 @@ org.junit.jupiter junit-jupiter + + org.hamcrest + hamcrest + org.matsim matsim-examples diff --git a/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java b/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java index d1145a2e37b..6cc313cbf9f 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java @@ -20,8 +20,8 @@ package org.matsim.api.core.v01; -import org.junit.runner.Description; -import org.junit.runner.notification.RunListener; +import org.junit.jupiter.api.extension.ExtensionContext; +import org.junit.jupiter.api.extension.TestWatcher; /** * Auto-resets Id caches before each test is started. This helps to keep every single unit test independent of others @@ -48,9 +48,19 @@ * * @author Michal Maciejewski (michalm) */ -public class AutoResetIdCaches extends RunListener { +public class AutoResetIdCaches implements TestWatcher { @Override - public void testStarted(Description description) { + public void testSuccessful(ExtensionContext context) { + Id.resetCaches(); + } + + @Override + public void testAborted(ExtensionContext context, Throwable cause) { + Id.resetCaches(); + } + + @Override + public void testFailed(ExtensionContext context, Throwable cause) { Id.resetCaches(); } } diff --git a/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java b/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java index 79e6db37f10..e0b53ca6cd6 100644 --- a/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java +++ b/matsim/src/test/java/org/matsim/core/controler/MatsimServicesImplTest.java @@ -21,7 +21,7 @@ package org.matsim.core.controler; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -36,7 +36,7 @@ public class MatsimServicesImplTest { @RegisterExtension public MatsimTestUtils utils = new MatsimTestUtils(); - @Ignore + @Disabled @Test void testIterationInServicesEqualsIterationInEvent() { diff --git a/matsim/src/test/java/org/matsim/core/mobsim/qsim/AgentNotificationTest.java b/matsim/src/test/java/org/matsim/core/mobsim/qsim/AgentNotificationTest.java index 49a35771959..beb29df2294 100644 --- a/matsim/src/test/java/org/matsim/core/mobsim/qsim/AgentNotificationTest.java +++ b/matsim/src/test/java/org/matsim/core/mobsim/qsim/AgentNotificationTest.java @@ -22,8 +22,7 @@ package org.matsim.core.mobsim.qsim; import static org.hamcrest.CoreMatchers.*; -import static org.junit.Assert.assertThat; -import static org.junit.Assume.assumeThat; +import static org.hamcrest.MatcherAssert.assertThat; import java.util.Map; @@ -31,6 +30,7 @@ import org.hamcrest.FeatureMatcher; import org.hamcrest.Matcher; +import org.junit.jupiter.api.Assumptions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -288,8 +288,7 @@ protected void configureQSim() { .build(scenario, eventsManager) // .run(); - assumeThat(handler.getEvents(), hasItem( - is(both(eventWithTime(25200.0)).and(instanceOf(PersonDepartureEvent.class))))); + Assumptions.assumeTrue(handler.getEvents().stream().anyMatch(e -> e.getTime() == 25200.0 && e instanceof PersonDepartureEvent)); assertThat(handler.getEvents(), hasItem( is(both(eventWithTime(25800.0)).and(instanceOf(MyAgentFactory.MyAgent.HomesicknessEvent.class))))); } diff --git a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java index c1c37f3f96e..d3b5c37d7fe 100644 --- a/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java +++ b/matsim/src/test/java/org/matsim/core/network/DisallowedNextLinksTest.java @@ -11,7 +11,6 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; -import org.junit.rules.TemporaryFolder; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; diff --git a/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java b/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java index 407d57d09c8..1824d8ee25e 100644 --- a/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java +++ b/matsim/src/test/java/org/matsim/core/network/NetworkChangeEventsParserWriterTest.java @@ -37,8 +37,8 @@ import java.util.ArrayList; import java.util.List; +import static org.hamcrest.MatcherAssert.assertThat; import static org.hamcrest.core.IsCollectionContaining.hasItem; -import static org.junit.Assert.assertThat; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertThrows; diff --git a/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java b/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java index 52cdbb2ca36..5d1b6ebe200 100644 --- a/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java +++ b/matsim/src/test/java/org/matsim/core/scoring/ScoringFunctionsForPopulationStressIT.java @@ -20,7 +20,7 @@ package org.matsim.core.scoring; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; @@ -252,7 +252,7 @@ so this tests actually tests some additional (and potentially optional) behavior as it tests some non-required functionality. */ @Test - @Ignore + @Disabled void unlikelyTimingOfScoringFunctionStillWorks() { Config config = ConfigUtils.createConfig(); config.eventsManager().setNumberOfThreads(8); diff --git a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java index 5c20985f8cb..ae05592d528 100644 --- a/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/trafficmonitoring/TravelTimeCalculatorModuleTest.java @@ -23,8 +23,8 @@ import com.google.inject.Key; import com.google.inject.Singleton; -import com.google.inject.name.Names; -import org.junit.jupiter.api.Test; +import com.google.inject.name.Names; +import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Coord; import org.matsim.api.core.v01.Id; @@ -50,14 +50,14 @@ import java.util.LinkedHashSet; import static org.hamcrest.CoreMatchers.is; -import static org.junit.Assert.assertThat; - +import static org.hamcrest.MatcherAssert.assertThat; + public class TravelTimeCalculatorModuleTest { @RegisterExtension - private MatsimTestUtils utils = new MatsimTestUtils(); - - @Test + private MatsimTestUtils utils = new MatsimTestUtils(); + + @Test void testOneTravelTimeCalculatorForAll() { Config config = ConfigUtils.createConfig(); config.travelTimeCalculator().setSeparateModes(false); @@ -90,10 +90,10 @@ public void install() { events.processEvent(new VehicleLeavesTrafficEvent(8.0, Id.createPersonId(1), linkId, Id.createVehicleId(1), "bike", 0.0)); assertThat(testee.getLinkTravelTimes().getLinkTravelTime(link, 0.0,null,null), is(5.0)); - } - - - @Test + } + + + @Test void testOneTravelTimeCalculatorPerMode() { Config config = ConfigUtils.createConfig(); diff --git a/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java index 958f38182ec..0f0a2865a2c 100644 --- a/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/geometry/CoordUtilsTest.java @@ -22,7 +22,7 @@ import static org.junit.jupiter.api.Assertions.*; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -53,11 +53,11 @@ void testPlus() { Coord c2a = CoordUtils.createCoord(1.0, 1.0); Coord c2b = CoordUtils.createCoord(2.0, 2.0); Coord c2c = CoordUtils.createCoord(3.0, 3.0); - + Coord c3a = CoordUtils.createCoord(1.0, 1.0, 1.0); Coord c3b = CoordUtils.createCoord(2.0, 2.0, 2.0); Coord c3c = CoordUtils.createCoord(3.0, 3.0, 3.0); - + // 2D assertEquals(c2c, CoordUtils.plus(c2a, c2b)); // 3D @@ -84,11 +84,11 @@ void testMinus() { Coord c2a = CoordUtils.createCoord(1.0, 1.0); Coord c2b = CoordUtils.createCoord(2.0, 2.0); Coord c2c = CoordUtils.createCoord(3.0, 3.0); - + Coord c3a = CoordUtils.createCoord(1.0, 1.0, 1.0); Coord c3b = CoordUtils.createCoord(2.0, 2.0, 2.0); Coord c3c = CoordUtils.createCoord(3.0, 3.0, 3.0); - + // 2D assertEquals(c2a, CoordUtils.minus(c2c, c2b)); // 3D @@ -116,7 +116,7 @@ void testScalarMult() { Coord c2a = CoordUtils.createCoord(1.0, 1.0); Coord c2b = CoordUtils.createCoord(2.0, 2.0); assertEquals(c2b, CoordUtils.scalarMult(2.0, c2a)); - + // 3D Coord c3a = CoordUtils.createCoord(1.0, 1.0, 1.0); Coord c3b = CoordUtils.createCoord(2.0, 2.0, 2.0); @@ -130,7 +130,7 @@ void testGetCenter() { Coord c2b = CoordUtils.createCoord(2.0, 2.0); Coord c2c = CoordUtils.createCoord(1.0, 1.0); assertEquals(c2c, CoordUtils.getCenter(c2a, c2b)); - + // 3D Coord c3a = CoordUtils.createCoord(0.0, 0.0, 0.0); Coord c3b = CoordUtils.createCoord(2.0, 2.0, 2.0); @@ -170,7 +170,7 @@ void testRotateToRight() { } @Test - @Ignore + @Disabled void testGetCenterWOffset() { fail("Not yet implemented"); } @@ -185,7 +185,7 @@ void testCalcEuclideanDistance() { assertEquals(1.0, CoordUtils.calcEuclideanDistance(c2a, c2b), MatsimTestUtils.EPSILON); assertEquals(1.0, CoordUtils.calcEuclideanDistance(c2a, c2c), MatsimTestUtils.EPSILON); assertEquals(Math.sqrt(2.0), CoordUtils.calcEuclideanDistance(c2a, c2d), MatsimTestUtils.EPSILON); - + // 3D Coord c3a = CoordUtils.createCoord(0.0, 0.0, 0.0); Coord c3b = CoordUtils.createCoord(1.0, 0.0, 0.0); @@ -208,12 +208,12 @@ void testCalcProjectedDistance() { Coord c2a = CoordUtils.createCoord(0.0, 0.0); Coord c2b = CoordUtils.createCoord(1.0, 1.0); assertEquals(Math.sqrt(2.0), CoordUtils.calcProjectedEuclideanDistance(c2a, c2b), MatsimTestUtils.EPSILON); - + // 3D Coord c3a = CoordUtils.createCoord(0.0, 0.0, 0.0); Coord c3b = CoordUtils.createCoord(1.0, 1.0, 1.0); assertEquals(Math.sqrt(2.0), CoordUtils.calcProjectedEuclideanDistance(c3a, c3b), MatsimTestUtils.EPSILON); - + // Mixed 2D and 3D assertEquals(Math.sqrt(2.0), CoordUtils.calcProjectedEuclideanDistance(c2a, c3b), MatsimTestUtils.EPSILON); } @@ -222,9 +222,9 @@ void testCalcProjectedDistance() { @Test void testDistancePointLinesegment() { /* First: 2D */ - + /* * (0,1) c1 - * + * * c2 (1,0) *-------* (2,0) c3 */ Coord c1 = CoordUtils.createCoord(0.0, 1.0); @@ -234,23 +234,23 @@ void testDistancePointLinesegment() { assertEquals(Math.sqrt(2.0), dist, MatsimTestUtils.EPSILON); /* * (3,1) c1 - * + * * c2 (1,0) *-------* (2,0) c3 */ c1 = CoordUtils.createCoord(3.0, 1.0); dist = CoordUtils.distancePointLinesegment(c2, c3, c1); assertEquals(Math.sqrt(2.0), dist, MatsimTestUtils.EPSILON); - + /* * (1.5,1) c1 - * + * * c2 (1,0) *-------* (2,0) c3 */ c1 = CoordUtils.createCoord(1.5, 1.0); dist = CoordUtils.distancePointLinesegment(c2, c3, c1); assertEquals(Math.sqrt(1.0), dist, MatsimTestUtils.EPSILON); - + /* Second: 3D */ - + /* Here the line segment has first/from coordinate (1.0, 1.0, 1.0) and * a second/to coordinate (2.0, 2.0, 2.0) */ c1 = CoordUtils.createCoord(0.0, 0.0, 0.0); @@ -258,11 +258,11 @@ void testDistancePointLinesegment() { c3 = CoordUtils.createCoord(2.0, 2.0, 2.0); dist = CoordUtils.distancePointLinesegment(c2, c3, c1); assertEquals(Math.sqrt(3.0), dist, MatsimTestUtils.EPSILON); - + c1 = CoordUtils.createCoord(1.5, 1.5, 1.5); dist = CoordUtils.distancePointLinesegment(c2, c3, c1); assertEquals(0.0, dist, MatsimTestUtils.EPSILON); - + c1 = CoordUtils.createCoord(3.0, 2.0, 3.0); dist = CoordUtils.distancePointLinesegment(c2, c3, c1); assertEquals(CoordUtils.calcEuclideanDistance(c3, c1), dist, MatsimTestUtils.EPSILON); @@ -274,21 +274,21 @@ void testOrthogonalProjectionOnLineSegment(){ Coord point = CoordUtils.createCoord(2.0, 0.0); Coord lineFrom = CoordUtils.createCoord(0.0, 0.0); Coord lineTo = CoordUtils.createCoord(2.0, 2.0); - + Coord projection = CoordUtils.createCoord(1.0, 1.0); assertEquals(projection, CoordUtils.orthogonalProjectionOnLineSegment(lineFrom, lineTo, point)); - + /* Second: 3D */ lineFrom = CoordUtils.createCoord(0.0, 0.0, 0.0); lineTo = CoordUtils.createCoord(2.0, 2.0, 2.0); point = CoordUtils.createCoord(2.0, 0.0, 1.0); - + projection = CoordUtils.createCoord(1.0, 1.0, 1.0); assertEquals(projection, CoordUtils.orthogonalProjectionOnLineSegment(lineFrom, lineTo, point)); - + point = CoordUtils.createCoord(3.0, 3.0, 3.0); assertEquals(point, CoordUtils.orthogonalProjectionOnLineSegment(lineFrom, lineTo, point)); } - + } diff --git a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java index d4d3f715283..4c300c39c09 100644 --- a/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/io/MatsimXmlParserTest.java @@ -23,7 +23,6 @@ import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.junit.jupiter.api.io.TempDir; -import org.junit.rules.TemporaryFolder; import org.xml.sax.Attributes; import org.xml.sax.SAXParseException; diff --git a/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java b/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java index 73c7bde965d..c2bf6888369 100644 --- a/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java +++ b/matsim/src/test/java/org/matsim/core/utils/misc/ConfigUtilsTest.java @@ -24,7 +24,6 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; -import org.junit.Assert; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; @@ -75,8 +74,7 @@ void testModifyPaths_missingSeparator() throws IOException { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); Assertions.assertEquals("network.xml", config.network().getInputFile()); ConfigUtils.modifyFilePaths(config, "/home/username/matsim"); - Assert.assertThat(config.network().getInputFile(), anyOf(is("/home/username/matsim/network.xml"),is("/home/username/matsim\\network.xml"))); - + Assertions.assertTrue(config.network().getInputFile().equals("/home/username/matsim/network.xml") || config.network().getInputFile().equals("/home/username/matsim\\network.xml")); } @Test @@ -84,7 +82,7 @@ void testModifyPaths_withSeparator() throws IOException { Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); Assertions.assertEquals("network.xml", config.network().getInputFile()); ConfigUtils.modifyFilePaths(config, "/home/username/matsim/"); - Assert.assertThat(config.network().getInputFile(), anyOf(is("/home/username/matsim/network.xml"),is("/home/username/matsim\\network.xml"))); + Assertions.assertTrue(config.network().getInputFile().equals("/home/username/matsim/network.xml") || config.network().getInputFile().equals("/home/username/matsim\\network.xml")); } @Test diff --git a/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java b/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java index a7dfc337995..8b523e2ba36 100644 --- a/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java +++ b/matsim/src/test/java/org/matsim/other/DownloadAndReadXmlTest.java @@ -19,8 +19,9 @@ package org.matsim.other; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Scenario; @@ -41,7 +42,7 @@ public class DownloadAndReadXmlTest { @RegisterExtension private MatsimTestUtils utils = new MatsimTestUtils(); - @Ignore + @Disabled @Test /** * Http downloads from the SVN server will be forbidden soon, according to jwilk. */ diff --git a/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java b/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java index 883bef1aa26..c5bfec0e2b7 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/PersonPrepareForSimTest.java @@ -22,7 +22,7 @@ import java.util.HashSet; import java.util.Set; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; import org.matsim.api.core.v01.Coord; @@ -94,7 +94,7 @@ void testRun_MultimodalScenario() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createAndAddNetwork(sc); Id link1id = Id.createLinkId("1"); - + Population pop = sc.getPopulation(); Person person; Activity a1; @@ -114,9 +114,9 @@ void testRun_MultimodalScenario() { person.addPlan(p); pop.addPerson(person); } - + new PersonPrepareForSim(new DummyRouter(), sc).run(person); - + Assertions.assertEquals(link1id, a1.getLinkId()); Assertions.assertEquals(link1id, a2.getLinkId()); // must also be linked to l1, as l2 has no car mode } @@ -149,7 +149,7 @@ void testSingleLegTripRoutingMode() { TripStructureUtils.getRoutingMode(leg), "wrong routing mode!"); } - + // test routing mode set { PopulationFactory pf = pop.getFactory(); @@ -177,8 +177,8 @@ void testSingleLegTripRoutingMode() { /** * Fallback modes are outdated with the introduction of routingMode. So, we want the simulation to crash if we encounter * them after {@link PrepareForSimImpl} was run (and adapted outdated plans). However, for the time being we do not - * explicitly check for outdated modes and hope that an exception will be thrown during routing of that single leg trip, - * because no router should be registered for those modes (and wasn't registered before introducing routingMode, besides + * explicitly check for outdated modes and hope that an exception will be thrown during routing of that single leg trip, + * because no router should be registered for those modes (and wasn't registered before introducing routingMode, besides * "transit_walk" which was also used for access/egress to pt and transfer between pt and therefore is * checked explicitly). */ @@ -209,7 +209,7 @@ void testSingleFallbackModeLegTrip() { Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} } - + // test outdated fallback mode single leg trip (arbitrary drt mode) { PopulationFactory pf = pop.getFactory(); @@ -240,7 +240,7 @@ void testCorrectTripsRemainUnchanged() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createAndAddNetwork(sc); Population pop = sc.getPopulation(); - + // test car trip with access/egress walk legs { PopulationFactory pf = pop.getFactory(); @@ -267,20 +267,20 @@ void testCorrectTripsRemainUnchanged() { plan.addActivity(activity4); person.addPlan(plan); pop.addPerson(person); - + new PersonPrepareForSim(new DummyRouter(), sc).run(person); - + // Check leg modes remain unchanged Assertions.assertEquals(TransportMode.walk, leg1.getMode(), "wrong routing mode!"); Assertions.assertEquals(TransportMode.car, leg2.getMode(), "wrong routing mode!"); Assertions.assertEquals(TransportMode.walk, leg3.getMode(), "wrong routing mode!"); - + // Check routing mode: Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg1), "wrong routing mode!"); Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg2), "wrong routing mode!"); Assertions.assertEquals(TransportMode.car, TripStructureUtils.getRoutingMode(leg3), "wrong routing mode!"); } - + // test complicated intermodal trip with consistent routing modes passes unchanged { PopulationFactory pf = pop.getFactory(); @@ -345,9 +345,9 @@ void testCorrectTripsRemainUnchanged() { plan.addActivity(activity12); person.addPlan(plan); pop.addPerson(person); - + new PersonPrepareForSim(new DummyRouter(), sc).run(person); - + Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg1), "wrong routing mode set"); Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg2), "wrong routing mode set"); Assertions.assertEquals(TransportMode.pt, TripStructureUtils.getRoutingMode(leg3), "wrong routing mode set"); @@ -367,7 +367,7 @@ void testRoutingModeConsistency() { Scenario sc = ScenarioUtils.createScenario(ConfigUtils.createConfig()); createAndAddNetwork(sc); Population pop = sc.getPopulation(); - + // test trip with inconsistent routing modes causes exception { PopulationFactory pf = pop.getFactory(); @@ -392,13 +392,13 @@ void testRoutingModeConsistency() { plan.addActivity(activity4); person.addPlan(plan); pop.addPerson(person); - + try { new PersonPrepareForSim(new DummyRouter(), sc).run(person); Assertions.fail("expected Exception, got none."); } catch (RuntimeException expected) {} } - + // test trip with legs with and others without routing modes causes exception { PopulationFactory pf = pop.getFactory(); @@ -423,7 +423,7 @@ void testRoutingModeConsistency() { plan.addActivity(activity4); person.addPlan(plan); pop.addPerson(person); - + try { new PersonPrepareForSim(new DummyRouter(), sc).run(person); Assertions.fail("expected Exception, got none."); @@ -484,7 +484,7 @@ private static class DummyRouter implements PlanAlgorithm { public void run(final Plan plan) { } } - + private Link createAndAddNetwork(Scenario sc) { Network net = sc.getNetwork(); Link link1; diff --git a/matsim/src/test/java/org/matsim/population/algorithms/TestsUtil.java b/matsim/src/test/java/org/matsim/population/algorithms/TestsUtil.java index d113d5a99cc..2c18cc6e194 100644 --- a/matsim/src/test/java/org/matsim/population/algorithms/TestsUtil.java +++ b/matsim/src/test/java/org/matsim/population/algorithms/TestsUtil.java @@ -21,7 +21,7 @@ import java.util.List; -import org.junit.Ignore; +import org.junit.jupiter.api.Disabled; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.network.Link; import org.matsim.api.core.v01.network.Network; @@ -34,7 +34,7 @@ import org.matsim.facilities.ActivityFacilitiesImpl; import org.matsim.facilities.ActivityFacility; -@Ignore +@Disabled public class TestsUtil { static Plan createPlanFromFacilities(ActivityFacilitiesImpl layer, Person person, String mode, String facString) { diff --git a/pom.xml b/pom.xml index 2b03c25e29d..a820708afc1 100644 --- a/pom.xml +++ b/pom.xml @@ -314,6 +314,18 @@ 5.8.0 test + + org.mockito + mockito-junit-jupiter + 5.8.0 + test + + + org.hamcrest + hamcrest + 2.2 + test + tech.tablesaw @@ -378,10 +390,9 @@ maven-surefire-plugin - - listener - org.matsim.api.core.v01.AutoResetIdCaches - + + true + @@ -390,10 +401,9 @@ maven-failsafe-plugin - - listener - org.matsim.api.core.v01.AutoResetIdCaches - + + true + From ae32b5956e402497a2640b90c2bb37be0d47245d Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Tue, 12 Dec 2023 16:59:41 +0100 Subject: [PATCH 35/43] fixed matsim test utils usage --- ...coringParametersFromPersonAttributesNoSubpopulationTest.java | 2 +- .../PersonScoringParametersFromPersonAttributesTest.java | 2 +- contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java | 1 - ...tilityOfMoneyPersonScoringParametersNoSubpopulationTest.java | 2 +- ...ncomeDependentUtilityOfMoneyPersonScoringParametersTest.java | 2 +- 5 files changed, 4 insertions(+), 5 deletions(-) diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java index 3e089eaf6c9..395990c6a8c 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesNoSubpopulationTest.java @@ -51,7 +51,7 @@ public class PersonScoringParametersFromPersonAttributesNoSubpopulationTest { @RegisterExtension - private MatsimTestUtils utils; + private MatsimTestUtils utils = new MatsimTestUtils(); private PersonScoringParametersFromPersonAttributes personScoringParams; private Population population; diff --git a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java index 6202e3c83b5..72f00ce92ef 100644 --- a/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java +++ b/contribs/vsp/src/test/java/org/matsim/core/scoring/functions/PersonScoringParametersFromPersonAttributesTest.java @@ -51,7 +51,7 @@ public class PersonScoringParametersFromPersonAttributesTest { @RegisterExtension - private MatsimTestUtils utils; + private MatsimTestUtils utils = new MatsimTestUtils(); private PersonScoringParametersFromPersonAttributes personScoringParams; private Population population; diff --git a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java index 9d9cf8230ec..a71bfc6ce8a 100644 --- a/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java +++ b/contribs/vsp/src/test/java/playground/vsp/ev/UrbanEVTests.java @@ -9,7 +9,6 @@ import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.BeforeAll; import org.junit.jupiter.api.Test; -import org.junit.runner.RunWith; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; import org.matsim.api.core.v01.TransportMode; diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java index e5c151a010e..0a0d109b4cb 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest.java @@ -29,7 +29,7 @@ public class IncomeDependentUtilityOfMoneyPersonScoringParametersNoSubpopulationTest { @RegisterExtension - private MatsimTestUtils utils; + private MatsimTestUtils utils = new MatsimTestUtils(); private IncomeDependentUtilityOfMoneyPersonScoringParameters personScoringParams; private Population population; diff --git a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java index 215d1c5816e..9332cbf6bdb 100644 --- a/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java +++ b/contribs/vsp/src/test/java/playground/vsp/scoring/IncomeDependentUtilityOfMoneyPersonScoringParametersTest.java @@ -29,7 +29,7 @@ public class IncomeDependentUtilityOfMoneyPersonScoringParametersTest { @RegisterExtension - private MatsimTestUtils utils; + private MatsimTestUtils utils = new MatsimTestUtils(); private IncomeDependentUtilityOfMoneyPersonScoringParameters personScoringParams; private Population population; From 395f4b1c9a3d2d58722aafd22ff50c7be7f66a80 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 13 Dec 2023 14:51:52 +0000 Subject: [PATCH 36/43] build(deps): bump org.apache.maven.plugins:maven-surefire-report-plugin Bumps [org.apache.maven.plugins:maven-surefire-report-plugin](https://github.com/apache/maven-surefire) from 3.2.2 to 3.2.3. - [Release notes](https://github.com/apache/maven-surefire/releases) - [Commits](https://github.com/apache/maven-surefire/compare/surefire-3.2.2...surefire-3.2.3) --- updated-dependencies: - dependency-name: org.apache.maven.plugins:maven-surefire-report-plugin dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] --- matsim/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/matsim/pom.xml b/matsim/pom.xml index 6bf9a851f4d..7a1f20aa905 100644 --- a/matsim/pom.xml +++ b/matsim/pom.xml @@ -117,7 +117,7 @@ org.apache.maven.plugins maven-surefire-report-plugin - 3.2.2 + 3.2.3 From 76f5cc15d6fa5aff71a0bafd3c01ab937bfadf24 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Wed, 13 Dec 2023 16:13:12 +0100 Subject: [PATCH 37/43] delete auto id reset --- .../api/core/v01/AutoResetIdCaches.java | 66 ------------------- pom.xml | 14 ---- 2 files changed, 80 deletions(-) delete mode 100644 matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java diff --git a/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java b/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java deleted file mode 100644 index 6cc313cbf9f..00000000000 --- a/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java +++ /dev/null @@ -1,66 +0,0 @@ -/* - * *********************************************************************** * - * project: org.matsim.* - * *********************************************************************** * - * * - * copyright : (C) 2021 by the members listed in the COPYING, * - * LICENSE and WARRANTY file. * - * email : info at matsim dot org * - * * - * *********************************************************************** * - * * - * This program is free software; you can redistribute it and/or modify * - * it under the terms of the GNU General Public License as published by * - * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * - * See also COPYING, LICENSE and WARRANTY file * - * * - * *********************************************************************** * - */ - -package org.matsim.api.core.v01; - -import org.junit.jupiter.api.extension.ExtensionContext; -import org.junit.jupiter.api.extension.TestWatcher; - -/** - * Auto-resets Id caches before each test is started. This helps to keep every single unit test independent of others - * (so things like execution order etc. will not impact them). - *

    - * It is enabled in tests (run by maven) by registering them as listeners in the surefire and failsafe plugin configs: - *

    - * {@code
    - * 
    - * listener
    - * org.matsim.api.core.v01.IdCacheCleaner
    - * 
    - * }
    - * 
    - *

    - * IntelliJ does not support junit listeners out of the box. To enable them in IntelliJ, you can install a plugin - * https://plugins.jetbrains.com/plugin/15718-junit-4-surefire-listener - *

    - * Not sure about Eclipse, but it seems that an additional plugin would be required (see: - * https://bugs.eclipse.org/bugs/show_bug.cgi?id=538885) - *

    - * Since IDEs have a limited support for registering jUnit RunListeners via pom.xml, there may be cases where we need - * to explicitly reset the Id caches while setting up a test (to make them green in IDEs). - * - * @author Michal Maciejewski (michalm) - */ -public class AutoResetIdCaches implements TestWatcher { - @Override - public void testSuccessful(ExtensionContext context) { - Id.resetCaches(); - } - - @Override - public void testAborted(ExtensionContext context, Throwable cause) { - Id.resetCaches(); - } - - @Override - public void testFailed(ExtensionContext context, Throwable cause) { - Id.resetCaches(); - } -} diff --git a/pom.xml b/pom.xml index a820708afc1..1d47117e4ed 100644 --- a/pom.xml +++ b/pom.xml @@ -388,24 +388,10 @@ org.apache.maven.plugins maven-surefire-plugin - - - - true - - - org.apache.maven.plugins maven-failsafe-plugin - - - - true - - - From 7719a5fc263a523978f7456f9ac56f1aa2189e65 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 13 Dec 2023 16:15:05 +0000 Subject: [PATCH 38/43] build(deps): bump org.apache.maven.plugins:maven-failsafe-plugin Bumps [org.apache.maven.plugins:maven-failsafe-plugin](https://github.com/apache/maven-surefire) from 3.2.2 to 3.2.3. - [Release notes](https://github.com/apache/maven-surefire/releases) - [Commits](https://github.com/apache/maven-surefire/compare/surefire-3.2.2...surefire-3.2.3) --- updated-dependencies: - dependency-name: org.apache.maven.plugins:maven-failsafe-plugin dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index a6649d3bc2e..8aae5adde2d 100644 --- a/pom.xml +++ b/pom.xml @@ -402,7 +402,7 @@ org.apache.maven.plugins maven-failsafe-plugin - 3.2.2 + 3.2.3 org.apache.maven.plugins From 697c0e8b560206bdde9e970b72a542be8a27467c Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 13 Dec 2023 16:44:46 +0000 Subject: [PATCH 39/43] build(deps): bump org.apache.maven.plugins:maven-surefire-plugin Bumps [org.apache.maven.plugins:maven-surefire-plugin](https://github.com/apache/maven-surefire) from 3.2.2 to 3.2.3. - [Release notes](https://github.com/apache/maven-surefire/releases) - [Commits](https://github.com/apache/maven-surefire/compare/surefire-3.2.2...surefire-3.2.3) --- updated-dependencies: - dependency-name: org.apache.maven.plugins:maven-surefire-plugin dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index 8aae5adde2d..595f6bbbc62 100644 --- a/pom.xml +++ b/pom.xml @@ -397,7 +397,7 @@ org.apache.maven.plugins maven-surefire-plugin - 3.2.2 + 3.2.3 org.apache.maven.plugins From 2d046b0f84a1c9e3d97a1ab71df86d6ac4cedc3c Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Thu, 14 Dec 2023 10:51:16 +0100 Subject: [PATCH 40/43] add auto reset id caches --- .../api/core/v01/AutoResetIdCaches.java | 50 +++++++++++++++++++ .../org.junit.jupiter.api.extension.Extension | 1 + .../test/resources/junit-platform.properties | 1 + pom.xml | 10 ++++ .../org.junit.jupiter.api.extension.Extension | 1 + src/test/resources/junit-platform.properties | 1 + 6 files changed, 64 insertions(+) create mode 100644 matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java create mode 100644 matsim/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension create mode 100644 matsim/src/test/resources/junit-platform.properties create mode 100644 src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension create mode 100644 src/test/resources/junit-platform.properties diff --git a/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java b/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java new file mode 100644 index 00000000000..ec4ef401864 --- /dev/null +++ b/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java @@ -0,0 +1,50 @@ +/* + * *********************************************************************** * + * project: org.matsim.* + * *********************************************************************** * + * * + * copyright : (C) 2021 by the members listed in the COPYING, * + * LICENSE and WARRANTY file. * + * email : info at matsim dot org * + * * + * *********************************************************************** * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * See also COPYING, LICENSE and WARRANTY file * + * * + * *********************************************************************** * + */ + +package org.matsim.api.core.v01; + +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; +import org.junit.jupiter.api.extension.ExtensionContext; +import org.junit.jupiter.api.extension.TestInstancePostProcessor; + +/** + * Auto-resets Id caches before each test is started. This helps to keep every single unit test independent of others + * (so things like execution order etc. will not impact them). + *

    + * It is configured in the junit-platform.properties file and in META-INF/services/org.junit.jupiter.api.extension.Extension file. + * (Also see https://www.baeldung.com/junit-5-extensions) + * Both files are located in the root of the matsim project in order to inherit the auto extension in all submodules. + *

    + * IntelliJ does also recognize this configuration and will automatically enable the extension. + *

    + * For some reason, the configuration files need to be placed in the matsim module (where this class is placed). Otherwise, it won't work. + * + * @author Michal Maciejewski (michalm) + */ +public class AutoResetIdCaches implements TestInstancePostProcessor { + private static final Logger log = LogManager.getLogger(AutoResetIdCaches.class); + + @Override + public void postProcessTestInstance(Object o, ExtensionContext extensionContext) throws Exception { + log.info("Resetting Id caches."); + Id.resetCaches(); + } +} diff --git a/matsim/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension b/matsim/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension new file mode 100644 index 00000000000..b4e0250699e --- /dev/null +++ b/matsim/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension @@ -0,0 +1 @@ +org.matsim.api.core.v01.AutoResetIdCaches \ No newline at end of file diff --git a/matsim/src/test/resources/junit-platform.properties b/matsim/src/test/resources/junit-platform.properties new file mode 100644 index 00000000000..b059a65dc46 --- /dev/null +++ b/matsim/src/test/resources/junit-platform.properties @@ -0,0 +1 @@ +junit.jupiter.extensions.autodetection.enabled=true \ No newline at end of file diff --git a/pom.xml b/pom.xml index 1d47117e4ed..b25040479a6 100644 --- a/pom.xml +++ b/pom.xml @@ -453,6 +453,16 @@ + + + src/test/resources + true + + **/*.pdf + **/*.gz + + + diff --git a/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension b/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension new file mode 100644 index 00000000000..b4e0250699e --- /dev/null +++ b/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension @@ -0,0 +1 @@ +org.matsim.api.core.v01.AutoResetIdCaches \ No newline at end of file diff --git a/src/test/resources/junit-platform.properties b/src/test/resources/junit-platform.properties new file mode 100644 index 00000000000..b059a65dc46 --- /dev/null +++ b/src/test/resources/junit-platform.properties @@ -0,0 +1 @@ +junit.jupiter.extensions.autodetection.enabled=true \ No newline at end of file From 62ca2fcc7e9a33d22edf38965742deb2aa874803 Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Thu, 14 Dec 2023 12:45:16 +0100 Subject: [PATCH 41/43] implemented test watcher instead of post instance processor --- .../api/core/v01/AutoResetIdCaches.java | 26 +++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java b/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java index ec4ef401864..8d992aaa110 100644 --- a/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java +++ b/matsim/src/test/java/org/matsim/api/core/v01/AutoResetIdCaches.java @@ -24,6 +24,9 @@ import org.apache.logging.log4j.Logger; import org.junit.jupiter.api.extension.ExtensionContext; import org.junit.jupiter.api.extension.TestInstancePostProcessor; +import org.junit.jupiter.api.extension.TestWatcher; + +import java.util.Optional; /** * Auto-resets Id caches before each test is started. This helps to keep every single unit test independent of others @@ -39,11 +42,30 @@ * * @author Michal Maciejewski (michalm) */ -public class AutoResetIdCaches implements TestInstancePostProcessor { +public class AutoResetIdCaches implements TestWatcher { private static final Logger log = LogManager.getLogger(AutoResetIdCaches.class); @Override - public void postProcessTestInstance(Object o, ExtensionContext extensionContext) throws Exception { + public void testDisabled(ExtensionContext context, Optional reason) { + resetIdCaches(); + } + + @Override + public void testSuccessful(ExtensionContext context) { + resetIdCaches(); + } + + @Override + public void testAborted(ExtensionContext context, Throwable cause) { + resetIdCaches(); + } + + @Override + public void testFailed(ExtensionContext context, Throwable cause) { + resetIdCaches(); + } + + private void resetIdCaches() { log.info("Resetting Id caches."); Id.resetCaches(); } From ad3990cc029ad2c19309da1af28308090a3cac3a Mon Sep 17 00:00:00 2001 From: Paul Heinrich Date: Thu, 14 Dec 2023 13:49:38 +0100 Subject: [PATCH 42/43] removed unnecessary resources in pom --- pom.xml | 10 ---------- .../services/org.junit.jupiter.api.extension.Extension | 1 - src/test/resources/junit-platform.properties | 1 - 3 files changed, 12 deletions(-) delete mode 100644 src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension delete mode 100644 src/test/resources/junit-platform.properties diff --git a/pom.xml b/pom.xml index b25040479a6..1d47117e4ed 100644 --- a/pom.xml +++ b/pom.xml @@ -453,16 +453,6 @@ - - - src/test/resources - true - - **/*.pdf - **/*.gz - - - diff --git a/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension b/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension deleted file mode 100644 index b4e0250699e..00000000000 --- a/src/test/resources/META-INF/services/org.junit.jupiter.api.extension.Extension +++ /dev/null @@ -1 +0,0 @@ -org.matsim.api.core.v01.AutoResetIdCaches \ No newline at end of file diff --git a/src/test/resources/junit-platform.properties b/src/test/resources/junit-platform.properties deleted file mode 100644 index b059a65dc46..00000000000 --- a/src/test/resources/junit-platform.properties +++ /dev/null @@ -1 +0,0 @@ -junit.jupiter.extensions.autodetection.enabled=true \ No newline at end of file From a1dc392193ed95d3baa0162622ad9d9a55693437 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Thu, 14 Dec 2023 15:03:32 +0000 Subject: [PATCH 43/43] build(deps): bump the github-actions group with 1 update Bumps the github-actions group with 1 update: [github/codeql-action](https://github.com/github/codeql-action). - [Release notes](https://github.com/github/codeql-action/releases) - [Changelog](https://github.com/github/codeql-action/blob/main/CHANGELOG.md) - [Commits](https://github.com/github/codeql-action/compare/v2...v3) --- updated-dependencies: - dependency-name: github/codeql-action dependency-type: direct:production update-type: version-update:semver-major dependency-group: github-actions ... Signed-off-by: dependabot[bot] --- .github/workflows/codeql.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/codeql.yml b/.github/workflows/codeql.yml index 0f30527d41b..7804cbe9423 100644 --- a/.github/workflows/codeql.yml +++ b/.github/workflows/codeql.yml @@ -27,7 +27,7 @@ jobs: # Initializes the CodeQL tools for scanning. - name: Initialize CodeQL - uses: github/codeql-action/init@v2 + uses: github/codeql-action/init@v3 with: languages: 'java' # If you wish to specify custom queries, you can do so here or in a config file. @@ -41,9 +41,9 @@ jobs: # Autobuild attempts to build any compiled languages (C/C++, C#, Go, Java, or Swift). # If this step fails, then you should remove it and run the build manually (see below) - name: Autobuild - uses: github/codeql-action/autobuild@v2 + uses: github/codeql-action/autobuild@v3 - name: Perform CodeQL Analysis - uses: github/codeql-action/analyze@v2 + uses: github/codeql-action/analyze@v3 with: category: "/language:java"

    %Q5 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%0A`BP>XTid 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%0Dau{TcOK( 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